Passed
Push — master ( e8e8db...e29aba )
by Brian
04:14
created
includes/admin/meta-boxes/class-getpaid-meta-box-item-details.php 1 patch
Indentation   +27 added lines, -27 removed lines patch added patch discarded remove patch
@@ -8,7 +8,7 @@  discard block
 block discarded – undo
8 8
  */
9 9
 
10 10
 if ( ! defined( 'ABSPATH' ) ) {
11
-	exit; // Exit if accessed directly
11
+    exit; // Exit if accessed directly
12 12
 }
13 13
 
14 14
 /**
@@ -17,10 +17,10 @@  discard block
 block discarded – undo
17 17
 class GetPaid_Meta_Box_Item_Details {
18 18
 
19 19
     /**
20
-	 * Output the metabox.
21
-	 *
22
-	 * @param WP_Post $post
23
-	 */
20
+     * Output the metabox.
21
+     *
22
+     * @param WP_Post $post
23
+     */
24 24
     public static function output( $post ) {
25 25
 
26 26
         // Prepare the item.
@@ -270,35 +270,35 @@  discard block
 block discarded – undo
270 270
     }
271 271
 
272 272
     /**
273
-	 * Save meta box data.
274
-	 *
275
-	 * @param int $post_id
276
-	 */
277
-	public static function save( $post_id ) {
273
+     * Save meta box data.
274
+     *
275
+     * @param int $post_id
276
+     */
277
+    public static function save( $post_id ) {
278 278
 
279 279
         // Prepare the item.
280 280
         $item = new WPInv_Item( $post_id );
281 281
 
282 282
         // Load new data.
283 283
         $item->set_props(
284
-			array(
285
-				'price'                => isset( $_POST['wpinv_item_price'] ) ? (float) $_POST['wpinv_item_price'] : null,
286
-				'vat_rule'             => isset( $_POST['wpinv_vat_rules'] ) ? wpinv_clean( $_POST['wpinv_vat_rules'] ) : null,
287
-				'vat_class'            => isset( $_POST['wpinv_vat_class'] ) ? wpinv_clean( $_POST['wpinv_vat_class'] ) : null,
288
-				'type'                 => isset( $_POST['wpinv_item_type'] ) ? wpinv_clean( $_POST['wpinv_item_type'] ) : null,
289
-				'is_dynamic_pricing'   => isset( $_POST['wpinv_name_your_price'] ),
284
+            array(
285
+                'price'                => isset( $_POST['wpinv_item_price'] ) ? (float) $_POST['wpinv_item_price'] : null,
286
+                'vat_rule'             => isset( $_POST['wpinv_vat_rules'] ) ? wpinv_clean( $_POST['wpinv_vat_rules'] ) : null,
287
+                'vat_class'            => isset( $_POST['wpinv_vat_class'] ) ? wpinv_clean( $_POST['wpinv_vat_class'] ) : null,
288
+                'type'                 => isset( $_POST['wpinv_item_type'] ) ? wpinv_clean( $_POST['wpinv_item_type'] ) : null,
289
+                'is_dynamic_pricing'   => isset( $_POST['wpinv_name_your_price'] ),
290 290
                 'minimum_price'        => isset( $_POST['wpinv_minimum_price'] ) ? (float) $_POST['wpinv_minimum_price'] : null,
291
-				'is_recurring'         => isset( $_POST['wpinv_is_recurring'] ),
292
-				'recurring_period'     => isset( $_POST['wpinv_recurring_period'] ) ? wpinv_clean( $_POST['wpinv_recurring_period'] ) : null,
293
-				'recurring_interval'   => isset( $_POST['wpinv_recurring_interval'] ) ? (int) $_POST['wpinv_recurring_interval'] : 1,
294
-				'recurring_limit'      => isset( $_POST['wpinv_recurring_limit'] ) ? (int) $_POST['wpinv_recurring_limit'] : null,
295
-				'is_free_trial'        => isset( $_POST['wpinv_trial_interval'] ) ? ( 0 != (int) $_POST['wpinv_trial_interval'] ) : null,
296
-				'trial_period'         => isset( $_POST['wpinv_trial_period'] ) ? wpinv_clean( $_POST['wpinv_trial_period'] ) : null,
297
-				'trial_interval'       => isset( $_POST['wpinv_trial_interval'] ) ? (int) $_POST['wpinv_trial_interval'] : null,
298
-			)
291
+                'is_recurring'         => isset( $_POST['wpinv_is_recurring'] ),
292
+                'recurring_period'     => isset( $_POST['wpinv_recurring_period'] ) ? wpinv_clean( $_POST['wpinv_recurring_period'] ) : null,
293
+                'recurring_interval'   => isset( $_POST['wpinv_recurring_interval'] ) ? (int) $_POST['wpinv_recurring_interval'] : 1,
294
+                'recurring_limit'      => isset( $_POST['wpinv_recurring_limit'] ) ? (int) $_POST['wpinv_recurring_limit'] : null,
295
+                'is_free_trial'        => isset( $_POST['wpinv_trial_interval'] ) ? ( 0 != (int) $_POST['wpinv_trial_interval'] ) : null,
296
+                'trial_period'         => isset( $_POST['wpinv_trial_period'] ) ? wpinv_clean( $_POST['wpinv_trial_period'] ) : null,
297
+                'trial_interval'       => isset( $_POST['wpinv_trial_interval'] ) ? (int) $_POST['wpinv_trial_interval'] : null,
298
+            )
299 299
         );
300 300
 
301
-		$item->save();
302
-		do_action( 'getpaid_item_metabox_save', $post_id, $item );
303
-	}
301
+        $item->save();
302
+        do_action( 'getpaid_item_metabox_save', $post_id, $item );
303
+    }
304 304
 }
Please login to merge, or discard this patch.
includes/admin/class-getpaid-post-types-admin.php 1 patch
Indentation   +653 added lines, -653 removed lines patch added patch discarded remove patch
@@ -13,648 +13,648 @@  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
-
34
-		// Items table columns.
35
-		add_filter( 'manage_wpi_item_posts_columns', array( __CLASS__, 'item_columns' ), 100 );
36
-		add_filter( 'manage_edit-wpi_item_sortable_columns', array( __CLASS__, 'sortable_item_columns' ), 20 );
37
-		add_action( 'manage_wpi_item_posts_custom_column', array( __CLASS__, 'display_item_columns' ), 10, 2 );
38
-		add_action( 'restrict_manage_posts', array( __CLASS__, 'add_item_filters' ), 100 );
39
-		add_action( 'parse_query', array( __CLASS__, 'filter_item_query' ), 100 );
40
-		add_action( 'request', array( __CLASS__, 'reorder_items' ), 100 );
41
-
42
-		// Payment forms columns.
43
-		add_filter( 'manage_wpi_payment_form_posts_columns', array( __CLASS__, 'payment_form_columns' ), 100 );
44
-		add_action( 'manage_wpi_payment_form_posts_custom_column', array( __CLASS__, 'display_payment_form_columns' ), 10, 2 );
45
-		add_filter( 'display_post_states', array( __CLASS__, 'filter_payment_form_state' ), 10, 2 );
46
-
47
-		// Discount table columns.
48
-		add_filter( 'manage_wpi_discount_posts_columns', array( __CLASS__, 'discount_columns' ), 100 );
49
-		add_filter( 'bulk_actions-edit-wpi_discount', '__return_empty_array', 100 );
50
-
51
-		// Deleting posts.
52
-		add_action( 'delete_post', array( __CLASS__, 'delete_post' ) );
53
-		add_filter( 'display_post_states', array( __CLASS__, 'filter_discount_state' ), 10, 2 );
54
-
55
-		add_filter( 'display_post_states', array( __CLASS__, 'add_display_post_states' ), 10, 2 );
56
-	}
57
-
58
-	/**
59
-	 * Post updated messages.
60
-	 */
61
-	public static function post_updated_messages( $messages ) {
62
-		global $post;
63
-
64
-		$messages['wpi_discount'] = array(
65
-			0   => '',
66
-			1   => __( 'Discount updated.', 'invoicing' ),
67
-			2   => __( 'Custom field updated.', 'invoicing' ),
68
-			3   => __( 'Custom field deleted.', 'invoicing' ),
69
-			4   => __( 'Discount updated.', 'invoicing' ),
70
-			5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Discount restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
71
-			6   => __( 'Discount updated.', 'invoicing' ),
72
-			7   => __( 'Discount saved.', 'invoicing' ),
73
-			8   => __( 'Discount submitted.', 'invoicing' ),
74
-			9   => wp_sprintf( __( 'Discount scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
75
-			10  => __( 'Discount draft updated.', 'invoicing' ),
76
-		);
77
-
78
-		$messages['wpi_payment_form'] = array(
79
-			0   => '',
80
-			1   => __( 'Payment Form updated.', 'invoicing' ),
81
-			2   => __( 'Custom field updated.', 'invoicing' ),
82
-			3   => __( 'Custom field deleted.', 'invoicing' ),
83
-			4   => __( 'Payment Form updated.', 'invoicing' ),
84
-			5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Payment Form restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
85
-			6   => __( 'Payment Form updated.', 'invoicing' ),
86
-			7   => __( 'Payment Form saved.', 'invoicing' ),
87
-			8   => __( 'Payment Form submitted.', 'invoicing' ),
88
-			9   => wp_sprintf( __( 'Payment Form scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
89
-			10  => __( 'Payment Form draft updated.', 'invoicing' ),
90
-		);
91
-
92
-		return $messages;
93
-
94
-	}
95
-
96
-	/**
97
-	 * Post row actions.
98
-	 */
99
-	public static function post_row_actions( $actions, $post ) {
100
-
101
-		$post = get_post( $post );
102
-
103
-		// We do not want to edit the default payment form.
104
-		if ( 'wpi_payment_form' == $post->post_type && $post->ID == wpinv_get_default_payment_form() ) {
105
-			unset( $actions['trash'] );
106
-			unset( $actions['inline hide-if-no-js'] );
107
-		}
108
-
109
-		return $actions;
110
-	}
111
-
112
-	/**
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
+
34
+        // Items table columns.
35
+        add_filter( 'manage_wpi_item_posts_columns', array( __CLASS__, 'item_columns' ), 100 );
36
+        add_filter( 'manage_edit-wpi_item_sortable_columns', array( __CLASS__, 'sortable_item_columns' ), 20 );
37
+        add_action( 'manage_wpi_item_posts_custom_column', array( __CLASS__, 'display_item_columns' ), 10, 2 );
38
+        add_action( 'restrict_manage_posts', array( __CLASS__, 'add_item_filters' ), 100 );
39
+        add_action( 'parse_query', array( __CLASS__, 'filter_item_query' ), 100 );
40
+        add_action( 'request', array( __CLASS__, 'reorder_items' ), 100 );
41
+
42
+        // Payment forms columns.
43
+        add_filter( 'manage_wpi_payment_form_posts_columns', array( __CLASS__, 'payment_form_columns' ), 100 );
44
+        add_action( 'manage_wpi_payment_form_posts_custom_column', array( __CLASS__, 'display_payment_form_columns' ), 10, 2 );
45
+        add_filter( 'display_post_states', array( __CLASS__, 'filter_payment_form_state' ), 10, 2 );
46
+
47
+        // Discount table columns.
48
+        add_filter( 'manage_wpi_discount_posts_columns', array( __CLASS__, 'discount_columns' ), 100 );
49
+        add_filter( 'bulk_actions-edit-wpi_discount', '__return_empty_array', 100 );
50
+
51
+        // Deleting posts.
52
+        add_action( 'delete_post', array( __CLASS__, 'delete_post' ) );
53
+        add_filter( 'display_post_states', array( __CLASS__, 'filter_discount_state' ), 10, 2 );
54
+
55
+        add_filter( 'display_post_states', array( __CLASS__, 'add_display_post_states' ), 10, 2 );
56
+    }
57
+
58
+    /**
59
+     * Post updated messages.
60
+     */
61
+    public static function post_updated_messages( $messages ) {
62
+        global $post;
63
+
64
+        $messages['wpi_discount'] = array(
65
+            0   => '',
66
+            1   => __( 'Discount updated.', 'invoicing' ),
67
+            2   => __( 'Custom field updated.', 'invoicing' ),
68
+            3   => __( 'Custom field deleted.', 'invoicing' ),
69
+            4   => __( 'Discount updated.', 'invoicing' ),
70
+            5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Discount restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
71
+            6   => __( 'Discount updated.', 'invoicing' ),
72
+            7   => __( 'Discount saved.', 'invoicing' ),
73
+            8   => __( 'Discount submitted.', 'invoicing' ),
74
+            9   => wp_sprintf( __( 'Discount scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
75
+            10  => __( 'Discount draft updated.', 'invoicing' ),
76
+        );
77
+
78
+        $messages['wpi_payment_form'] = array(
79
+            0   => '',
80
+            1   => __( 'Payment Form updated.', 'invoicing' ),
81
+            2   => __( 'Custom field updated.', 'invoicing' ),
82
+            3   => __( 'Custom field deleted.', 'invoicing' ),
83
+            4   => __( 'Payment Form updated.', 'invoicing' ),
84
+            5   => isset( $_GET['revision'] ) ? wp_sprintf( __( 'Payment Form restored to revision from %s', 'invoicing' ), wp_post_revision_title( (int) $_GET['revision'], false ) ) : false,
85
+            6   => __( 'Payment Form updated.', 'invoicing' ),
86
+            7   => __( 'Payment Form saved.', 'invoicing' ),
87
+            8   => __( 'Payment Form submitted.', 'invoicing' ),
88
+            9   => wp_sprintf( __( 'Payment Form scheduled for: <strong>%1$s</strong>.', 'invoicing' ), date_i18n( __( 'M j, Y @ G:i', 'invoicing' ), strtotime( $post->post_date ) ) ),
89
+            10  => __( 'Payment Form draft updated.', 'invoicing' ),
90
+        );
91
+
92
+        return $messages;
93
+
94
+    }
95
+
96
+    /**
97
+     * Post row actions.
98
+     */
99
+    public static function post_row_actions( $actions, $post ) {
100
+
101
+        $post = get_post( $post );
102
+
103
+        // We do not want to edit the default payment form.
104
+        if ( 'wpi_payment_form' == $post->post_type && $post->ID == wpinv_get_default_payment_form() ) {
105
+            unset( $actions['trash'] );
106
+            unset( $actions['inline hide-if-no-js'] );
107
+        }
108
+
109
+        return $actions;
110
+    }
111
+
112
+    /**
113 113
      * Remove bulk edit option from admin side quote listing
114 114
      *
115 115
      * @since    1.0.0
116 116
      * @param array $actions post actions
117
-	 * @param WP_Post $post
117
+     * @param WP_Post $post
118 118
      * @return array $actions actions without edit option
119 119
      */
120 120
     public static function filter_invoice_row_actions( $actions, $post ) {
121 121
 
122 122
         if ( getpaid_is_invoice_post_type( $post->post_type ) ) {
123 123
 
124
-			$actions = array();
125
-			$invoice = new WPInv_Invoice( $post );
126
-
127
-			$actions['edit'] =  sprintf(
128
-				'<a href="%1$s">%2$s</a>',
129
-				esc_url( get_edit_post_link( $invoice->get_id() ) ),
130
-				esc_html( __( 'Edit', 'invoicing' ) )
131
-			);
132
-
133
-			if ( ! $invoice->is_draft() ) {
134
-
135
-				$actions['view'] =  sprintf(
136
-					'<a href="%1$s">%2$s</a>',
137
-					esc_url( $invoice->get_view_url() ),
138
-					sprintf(
139
-						esc_html( __( 'View %s', 'invoicing' ) ),
140
-						getpaid_get_post_type_label( $invoice->get_post_type(), false )
141
-					)
142
-				);
143
-
144
-				$actions['send'] =  sprintf(
145
-					'<a href="%1$s">%2$s</a>',
146
-					esc_url(
147
-						wp_nonce_url(
148
-							add_query_arg(
149
-								array(
150
-									'getpaid-admin-action' => 'send_invoice',
151
-									'invoice_id'           => $invoice->get_id()
152
-								)
153
-							),
154
-							'getpaid-nonce',
155
-							'getpaid-nonce'
156
-						)
157
-					),
158
-					esc_html( __( 'Send to Customer', 'invoicing' ) )
159
-				);
160
-
161
-			}
124
+            $actions = array();
125
+            $invoice = new WPInv_Invoice( $post );
126
+
127
+            $actions['edit'] =  sprintf(
128
+                '<a href="%1$s">%2$s</a>',
129
+                esc_url( get_edit_post_link( $invoice->get_id() ) ),
130
+                esc_html( __( 'Edit', 'invoicing' ) )
131
+            );
132
+
133
+            if ( ! $invoice->is_draft() ) {
134
+
135
+                $actions['view'] =  sprintf(
136
+                    '<a href="%1$s">%2$s</a>',
137
+                    esc_url( $invoice->get_view_url() ),
138
+                    sprintf(
139
+                        esc_html( __( 'View %s', 'invoicing' ) ),
140
+                        getpaid_get_post_type_label( $invoice->get_post_type(), false )
141
+                    )
142
+                );
143
+
144
+                $actions['send'] =  sprintf(
145
+                    '<a href="%1$s">%2$s</a>',
146
+                    esc_url(
147
+                        wp_nonce_url(
148
+                            add_query_arg(
149
+                                array(
150
+                                    'getpaid-admin-action' => 'send_invoice',
151
+                                    'invoice_id'           => $invoice->get_id()
152
+                                )
153
+                            ),
154
+                            'getpaid-nonce',
155
+                            'getpaid-nonce'
156
+                        )
157
+                    ),
158
+                    esc_html( __( 'Send to Customer', 'invoicing' ) )
159
+                );
160
+
161
+            }
162 162
 
163 163
         }
164 164
 
165 165
         return $actions;
166
-	}
167
-
168
-	/**
169
-	 * Returns an array of invoice table columns.
170
-	 */
171
-	public static function invoice_columns( $columns ) {
172
-
173
-		$columns = array(
174
-			'cb'                => $columns['cb'],
175
-			'number'            => __( 'Invoice', 'invoicing' ),
176
-			'customer'          => __( 'Customer', 'invoicing' ),
177
-			'invoice_date'      => __( 'Created', 'invoicing' ),
178
-			'payment_date'      => __( 'Completed', 'invoicing' ),
179
-			'amount'            => __( 'Amount', 'invoicing' ),
180
-			'recurring'         => __( 'Recurring', 'invoicing' ),
181
-			'status'            => __( 'Status', 'invoicing' ),
182
-		);
183
-
184
-		return apply_filters( 'wpi_invoice_table_columns', $columns );
185
-	}
186
-
187
-	/**
188
-	 * Displays invoice table columns.
189
-	 */
190
-	public static function display_invoice_columns( $column_name, $post_id ) {
191
-
192
-		$invoice = new WPInv_Invoice( $post_id );
193
-
194
-		switch ( $column_name ) {
195
-
196
-			case 'invoice_date' :
197
-				$date_time = esc_attr( $invoice->get_created_date() );
198
-				$date      = getpaid_format_date_value( $date_time, "&mdash;", true );
199
-				echo "<span title='$date_time'>$date</span>";
200
-				break;
201
-
202
-			case 'payment_date' :
203
-
204
-				if ( $invoice->is_paid() ) {
205
-					$date_time = esc_attr( $invoice->get_completed_date() );
206
-					$date      = getpaid_format_date_value( $date_time, "&mdash;", true );
207
-					echo "<span title='$date_time'>$date</span>";
208
-				} else {
209
-					echo "&mdash;";
210
-				}
166
+    }
167
+
168
+    /**
169
+     * Returns an array of invoice table columns.
170
+     */
171
+    public static function invoice_columns( $columns ) {
172
+
173
+        $columns = array(
174
+            'cb'                => $columns['cb'],
175
+            'number'            => __( 'Invoice', 'invoicing' ),
176
+            'customer'          => __( 'Customer', 'invoicing' ),
177
+            'invoice_date'      => __( 'Created', 'invoicing' ),
178
+            'payment_date'      => __( 'Completed', 'invoicing' ),
179
+            'amount'            => __( 'Amount', 'invoicing' ),
180
+            'recurring'         => __( 'Recurring', 'invoicing' ),
181
+            'status'            => __( 'Status', 'invoicing' ),
182
+        );
183
+
184
+        return apply_filters( 'wpi_invoice_table_columns', $columns );
185
+    }
186
+
187
+    /**
188
+     * Displays invoice table columns.
189
+     */
190
+    public static function display_invoice_columns( $column_name, $post_id ) {
191
+
192
+        $invoice = new WPInv_Invoice( $post_id );
193
+
194
+        switch ( $column_name ) {
195
+
196
+            case 'invoice_date' :
197
+                $date_time = esc_attr( $invoice->get_created_date() );
198
+                $date      = getpaid_format_date_value( $date_time, "&mdash;", true );
199
+                echo "<span title='$date_time'>$date</span>";
200
+                break;
201
+
202
+            case 'payment_date' :
203
+
204
+                if ( $invoice->is_paid() ) {
205
+                    $date_time = esc_attr( $invoice->get_completed_date() );
206
+                    $date      = getpaid_format_date_value( $date_time, "&mdash;", true );
207
+                    echo "<span title='$date_time'>$date</span>";
208
+                } else {
209
+                    echo "&mdash;";
210
+                }
211 211
 				
212
-				break;
212
+                break;
213 213
 
214
-			case 'amount' :
214
+            case 'amount' :
215 215
 
216
-				$amount = $invoice->get_total();
217
-				$formated_amount = wpinv_price( $amount, $invoice->get_currency() );
216
+                $amount = $invoice->get_total();
217
+                $formated_amount = wpinv_price( $amount, $invoice->get_currency() );
218 218
 
219
-				if ( $invoice->is_refunded() ) {
220
-					$refunded_amount = wpinv_price( 0, $invoice->get_currency() );
221
-					echo "<del>$formated_amount</del>&nbsp;<ins>$refunded_amount</ins>";
222
-				} else {
219
+                if ( $invoice->is_refunded() ) {
220
+                    $refunded_amount = wpinv_price( 0, $invoice->get_currency() );
221
+                    echo "<del>$formated_amount</del>&nbsp;<ins>$refunded_amount</ins>";
222
+                } else {
223 223
 
224
-					$discount = $invoice->get_total_discount();
224
+                    $discount = $invoice->get_total_discount();
225 225
 
226
-					if ( ! empty( $discount ) ) {
227
-						$new_amount = wpinv_price( $amount + $discount, $invoice->get_currency() );
228
-						echo "<del>$new_amount</del>&nbsp;<ins>$formated_amount</ins>";
229
-					} else {
230
-						echo $formated_amount;
231
-					}
226
+                    if ( ! empty( $discount ) ) {
227
+                        $new_amount = wpinv_price( $amount + $discount, $invoice->get_currency() );
228
+                        echo "<del>$new_amount</del>&nbsp;<ins>$formated_amount</ins>";
229
+                    } else {
230
+                        echo $formated_amount;
231
+                    }
232 232
 
233
-				}
233
+                }
234 234
 
235
-				break;
235
+                break;
236 236
 
237
-			case 'status' :
238
-				$status       = sanitize_text_field( $invoice->get_status() );
239
-				$status_label = sanitize_text_field( $invoice->get_status_nicename() );
237
+            case 'status' :
238
+                $status       = sanitize_text_field( $invoice->get_status() );
239
+                $status_label = sanitize_text_field( $invoice->get_status_nicename() );
240 240
 
241
-				// If it is paid, show the gateway title.
242
-				if ( $invoice->is_paid() ) {
243
-					$gateway = sanitize_text_field( $invoice->get_gateway_title() );
244
-					$gateway = wp_sprintf( esc_attr__( 'Paid via %s', 'invoicing' ), $gateway );
241
+                // If it is paid, show the gateway title.
242
+                if ( $invoice->is_paid() ) {
243
+                    $gateway = sanitize_text_field( $invoice->get_gateway_title() );
244
+                    $gateway = wp_sprintf( esc_attr__( 'Paid via %s', 'invoicing' ), $gateway );
245 245
 
246
-					echo "<mark class='wpi-help-tip getpaid-invoice-status $status' title='$gateway'><span>$status_label</span></mark>";
247
-				} else {
248
-					echo "<mark class='getpaid-invoice-status $status'><span>$status_label</span></mark>";
249
-				}
246
+                    echo "<mark class='wpi-help-tip getpaid-invoice-status $status' title='$gateway'><span>$status_label</span></mark>";
247
+                } else {
248
+                    echo "<mark class='getpaid-invoice-status $status'><span>$status_label</span></mark>";
249
+                }
250 250
 
251
-				// If it is not paid, display the overdue and view status.
252
-				if ( ! $invoice->is_paid() && ! $invoice->is_refunded() ) {
251
+                // If it is not paid, display the overdue and view status.
252
+                if ( ! $invoice->is_paid() && ! $invoice->is_refunded() ) {
253 253
 
254
-					// Invoice view status.
255
-					if ( wpinv_is_invoice_viewed( $invoice->get_id() ) ) {
256
-						echo '&nbsp;&nbsp;<i class="fa fa-eye wpi-help-tip" title="'. esc_attr__( 'Viewed by Customer', 'invoicing' ).'"></i>';
257
-					} else {
258
-						echo '&nbsp;&nbsp;<i class="fa fa-eye-slash wpi-help-tip" title="'. esc_attr__( 'Not Viewed by Customer', 'invoicing' ).'"></i>';
259
-					}
254
+                    // Invoice view status.
255
+                    if ( wpinv_is_invoice_viewed( $invoice->get_id() ) ) {
256
+                        echo '&nbsp;&nbsp;<i class="fa fa-eye wpi-help-tip" title="'. esc_attr__( 'Viewed by Customer', 'invoicing' ).'"></i>';
257
+                    } else {
258
+                        echo '&nbsp;&nbsp;<i class="fa fa-eye-slash wpi-help-tip" title="'. esc_attr__( 'Not Viewed by Customer', 'invoicing' ).'"></i>';
259
+                    }
260 260
 
261
-					// Display the overview status.
262
-					if ( wpinv_get_option( 'overdue_active' ) ) {
263
-						$due_date = $invoice->get_due_date();
264
-						$fomatted = getpaid_format_date( $due_date );
261
+                    // Display the overview status.
262
+                    if ( wpinv_get_option( 'overdue_active' ) ) {
263
+                        $due_date = $invoice->get_due_date();
264
+                        $fomatted = getpaid_format_date( $due_date );
265 265
 
266
-						if ( ! empty( $fomatted ) ) {
267
-							$date = wp_sprintf( __( 'Due %s', 'invoicing' ), $fomatted );
268
-							echo "<p class='description' style='color: #888;' title='$due_date'>$fomatted</p>";
269
-						}
270
-					}
266
+                        if ( ! empty( $fomatted ) ) {
267
+                            $date = wp_sprintf( __( 'Due %s', 'invoicing' ), $fomatted );
268
+                            echo "<p class='description' style='color: #888;' title='$due_date'>$fomatted</p>";
269
+                        }
270
+                    }
271 271
 
272
-				}
272
+                }
273 273
 
274
-				break;
274
+                break;
275 275
 
276
-			case 'recurring':
276
+            case 'recurring':
277 277
 
278
-				if ( $invoice->is_recurring() ) {
279
-					echo '<i class="fa fa-check" style="color:#43850a;"></i>';
280
-				} else {
281
-					echo '<i class="fa fa-times" style="color:#616161;"></i>';
282
-				}
283
-				break;
278
+                if ( $invoice->is_recurring() ) {
279
+                    echo '<i class="fa fa-check" style="color:#43850a;"></i>';
280
+                } else {
281
+                    echo '<i class="fa fa-times" style="color:#616161;"></i>';
282
+                }
283
+                break;
284 284
 
285
-			case 'number' :
285
+            case 'number' :
286 286
 
287
-				$edit_link       = esc_url( get_edit_post_link( $invoice->get_id() ) );
288
-				$invoice_number  = sanitize_text_field( $invoice->get_number() );
289
-				$invoice_details = esc_attr__( 'View Invoice Details', 'invoicing' );
287
+                $edit_link       = esc_url( get_edit_post_link( $invoice->get_id() ) );
288
+                $invoice_number  = sanitize_text_field( $invoice->get_number() );
289
+                $invoice_details = esc_attr__( 'View Invoice Details', 'invoicing' );
290 290
 
291
-				echo "<a href='$edit_link' title='$invoice_details'><strong>$invoice_number</strong></a>";
291
+                echo "<a href='$edit_link' title='$invoice_details'><strong>$invoice_number</strong></a>";
292 292
 
293
-				break;
293
+                break;
294 294
 
295
-			case 'customer' :
295
+            case 'customer' :
296 296
 	
297
-				$customer_name = $invoice->get_user_full_name();
297
+                $customer_name = $invoice->get_user_full_name();
298 298
 	
299
-				if ( empty( $customer_name ) ) {
300
-					$customer_name = $invoice->get_email();
301
-				}
299
+                if ( empty( $customer_name ) ) {
300
+                    $customer_name = $invoice->get_email();
301
+                }
302 302
 	
303
-				if ( ! empty( $customer_name ) ) {
304
-					$customer_details = esc_attr__( 'View Customer Details', 'invoicing' );
305
-					$view_link        = esc_url( add_query_arg( 'user_id', $invoice->get_user_id(), admin_url( 'user-edit.php' ) ) );
306
-					echo "<a href='$view_link' title='$customer_details'><span>$customer_name</span></a>";
307
-				} else {
308
-					echo '<div>&mdash;</div>';
309
-				}
303
+                if ( ! empty( $customer_name ) ) {
304
+                    $customer_details = esc_attr__( 'View Customer Details', 'invoicing' );
305
+                    $view_link        = esc_url( add_query_arg( 'user_id', $invoice->get_user_id(), admin_url( 'user-edit.php' ) ) );
306
+                    echo "<a href='$view_link' title='$customer_details'><span>$customer_name</span></a>";
307
+                } else {
308
+                    echo '<div>&mdash;</div>';
309
+                }
310 310
 
311
-				break;
311
+                break;
312 312
 
313
-		}
313
+        }
314 314
 
315
-	}
315
+    }
316 316
 
317
-	/**
318
-	 * Returns an array of payment forms table columns.
319
-	 */
320
-	public static function payment_form_columns( $columns ) {
317
+    /**
318
+     * Returns an array of payment forms table columns.
319
+     */
320
+    public static function payment_form_columns( $columns ) {
321 321
 
322
-		$columns = array(
323
-			'cb'                => $columns['cb'],
324
-			'title'             => __( 'Name', 'invoicing' ),
325
-			'shortcode'         => __( 'Shortcode', 'invoicing' ),
326
-			'earnings'          => __( 'Revenue', 'invoicing' ),
327
-			'refunds'           => __( 'Refunded', 'invoicing' ),
328
-			'items'             => __( 'Items', 'invoicing' ),
329
-			'date'              => __( 'Date', 'invoicing' ),
330
-		);
322
+        $columns = array(
323
+            'cb'                => $columns['cb'],
324
+            'title'             => __( 'Name', 'invoicing' ),
325
+            'shortcode'         => __( 'Shortcode', 'invoicing' ),
326
+            'earnings'          => __( 'Revenue', 'invoicing' ),
327
+            'refunds'           => __( 'Refunded', 'invoicing' ),
328
+            'items'             => __( 'Items', 'invoicing' ),
329
+            'date'              => __( 'Date', 'invoicing' ),
330
+        );
331 331
 
332
-		return apply_filters( 'wpi_payment_form_table_columns', $columns );
332
+        return apply_filters( 'wpi_payment_form_table_columns', $columns );
333 333
 
334
-	}
334
+    }
335 335
 
336
-	/**
337
-	 * Displays payment form table columns.
338
-	 */
339
-	public static function display_payment_form_columns( $column_name, $post_id ) {
336
+    /**
337
+     * Displays payment form table columns.
338
+     */
339
+    public static function display_payment_form_columns( $column_name, $post_id ) {
340 340
 
341
-		// Retrieve the payment form.
342
-		$form = new GetPaid_Payment_Form( $post_id );
341
+        // Retrieve the payment form.
342
+        $form = new GetPaid_Payment_Form( $post_id );
343 343
 
344
-		switch ( $column_name ) {
344
+        switch ( $column_name ) {
345 345
 
346
-			case 'earnings' :
347
-				echo wpinv_price( $form->get_earned() );
348
-				break;
346
+            case 'earnings' :
347
+                echo wpinv_price( $form->get_earned() );
348
+                break;
349 349
 
350
-			case 'refunds' :
351
-				echo wpinv_price( $form->get_refunded() );
352
-				break;
350
+            case 'refunds' :
351
+                echo wpinv_price( $form->get_refunded() );
352
+                break;
353 353
 
354
-			case 'refunds' :
355
-				echo wpinv_price( $form->get_refunded() );
356
-				break;
354
+            case 'refunds' :
355
+                echo wpinv_price( $form->get_refunded() );
356
+                break;
357 357
 
358
-			case 'shortcode' :
358
+            case 'shortcode' :
359 359
 
360
-				if ( $form->is_default() ) {
361
-					echo '&mdash;';
362
-				} else {
363
-					echo '<input onClick="this.select()" type="text" value="[getpaid form=' . esc_attr( $form->get_id() ) . ']" style="width: 100%;" readonly/>';
364
-				}
360
+                if ( $form->is_default() ) {
361
+                    echo '&mdash;';
362
+                } else {
363
+                    echo '<input onClick="this.select()" type="text" value="[getpaid form=' . esc_attr( $form->get_id() ) . ']" style="width: 100%;" readonly/>';
364
+                }
365 365
 
366
-				break;
366
+                break;
367 367
 
368
-			case 'items' :
368
+            case 'items' :
369 369
 
370
-				$items = $form->get_items();
370
+                $items = $form->get_items();
371 371
 
372
-				if ( $form->is_default() || empty( $items ) ) {
373
-					echo '&mdash;';
374
-					return;
375
-				}
372
+                if ( $form->is_default() || empty( $items ) ) {
373
+                    echo '&mdash;';
374
+                    return;
375
+                }
376 376
 
377
-				$_items = array();
377
+                $_items = array();
378 378
 
379
-				foreach ( $items as $item ) {
380
-					$url = $item->get_edit_url();
379
+                foreach ( $items as $item ) {
380
+                    $url = $item->get_edit_url();
381 381
 
382
-					if ( empty( $url ) ) {
383
-						$_items[] = sanitize_text_field( $item->get_name() );
384
-					} else {
385
-						$_items[] = sprintf(
386
-							'<a href="%s">%s</a>',
387
-							esc_url( $url ),
388
-							sanitize_text_field( $item->get_name() )
389
-						);
390
-					}
382
+                    if ( empty( $url ) ) {
383
+                        $_items[] = sanitize_text_field( $item->get_name() );
384
+                    } else {
385
+                        $_items[] = sprintf(
386
+                            '<a href="%s">%s</a>',
387
+                            esc_url( $url ),
388
+                            sanitize_text_field( $item->get_name() )
389
+                        );
390
+                    }
391 391
 
392
-				}
392
+                }
393 393
 
394
-				echo implode( '<br>', $_items );
394
+                echo implode( '<br>', $_items );
395 395
 
396
-				break;
396
+                break;
397 397
 
398
-		}
398
+        }
399 399
 
400
-	}
400
+    }
401 401
 
402
-	/**
403
-	 * Filters post states.
404
-	 */
405
-	public static function filter_payment_form_state( $post_states, $post ) {
402
+    /**
403
+     * Filters post states.
404
+     */
405
+    public static function filter_payment_form_state( $post_states, $post ) {
406 406
 
407
-		if ( 'wpi_payment_form' == $post->post_type && wpinv_get_default_payment_form() == $post->ID ) {
408
-			$post_states[ 'default_form' ] = __( 'Default Payment Form', 'invoicing' );
409
-		}
407
+        if ( 'wpi_payment_form' == $post->post_type && wpinv_get_default_payment_form() == $post->ID ) {
408
+            $post_states[ 'default_form' ] = __( 'Default Payment Form', 'invoicing' );
409
+        }
410 410
 	
411
-		return $post_states;
412
-
413
-	}
414
-
415
-	/**
416
-	 * Returns an array of coupon table columns.
417
-	 */
418
-	public static function discount_columns( $columns ) {
419
-
420
-		$columns = array(
421
-			'cb'                => $columns['cb'],
422
-			'title'             => __( 'Name', 'invoicing' ),
423
-			'code'              => __( 'Code', 'invoicing' ),
424
-			'amount'            => __( 'Amount', 'invoicing' ),
425
-			'usage'             => __( 'Usage / Limit', 'invoicing' ),
426
-			'start_date'        => __( 'Start Date', 'invoicing' ),
427
-			'expiry_date'       => __( 'Expiry Date', 'invoicing' ),
428
-		);
429
-
430
-		return apply_filters( 'wpi_discount_table_columns', $columns );
431
-	}
432
-
433
-	/**
434
-	 * Filters post states.
435
-	 */
436
-	public static function filter_discount_state( $post_states, $post ) {
437
-
438
-		if ( 'wpi_discount' == $post->post_type ) {
439
-
440
-			$discount = new WPInv_Discount( $post );
441
-
442
-			$status = $discount->is_expired() ? 'expired' : $discount->get_status();
443
-
444
-			if ( $status != 'publish' ) {
445
-				return array(
446
-					'discount_status' => wpinv_discount_status( $status ),
447
-				);
448
-			}
449
-
450
-			return array();
451
-
452
-		}
453
-
454
-		return $post_states;
455
-
456
-	}
457
-
458
-	/**
459
-	 * Returns an array of items table columns.
460
-	 */
461
-	public static function item_columns( $columns ) {
462
-
463
-		$columns = array(
464
-			'cb'                => $columns['cb'],
465
-			'title'             => __( 'Name', 'invoicing' ),
466
-			'price'             => __( 'Price', 'invoicing' ),
467
-			'vat_rule'          => __( 'VAT rule', 'invoicing' ),
468
-			'vat_class'         => __( 'VAT class', 'invoicing' ),
469
-			'type'              => __( 'Type', 'invoicing' ),
470
-			'shortcode'         => __( 'Shortcode', 'invoicing' ),
471
-		);
472
-
473
-		if ( ! wpinv_use_taxes() ) {
474
-			unset( $columns['vat_rule'] );
475
-			unset( $columns['vat_class'] );
476
-		}
477
-
478
-		return apply_filters( 'wpi_item_table_columns', $columns );
479
-	}
480
-
481
-	/**
482
-	 * Returns an array of sortable items table columns.
483
-	 */
484
-	public static function sortable_item_columns( $columns ) {
485
-
486
-		return array_merge(
487
-			$columns,
488
-			array(
489
-				'price'     => 'price',
490
-				'vat_rule'  => 'vat_rule',
491
-				'vat_class' => 'vat_class',
492
-				'type'      => 'type',
493
-			)
494
-		);
495
-
496
-	}
497
-
498
-	/**
499
-	 * Displays items table columns.
500
-	 */
501
-	public static function display_item_columns( $column_name, $post_id ) {
411
+        return $post_states;
412
+
413
+    }
414
+
415
+    /**
416
+     * Returns an array of coupon table columns.
417
+     */
418
+    public static function discount_columns( $columns ) {
419
+
420
+        $columns = array(
421
+            'cb'                => $columns['cb'],
422
+            'title'             => __( 'Name', 'invoicing' ),
423
+            'code'              => __( 'Code', 'invoicing' ),
424
+            'amount'            => __( 'Amount', 'invoicing' ),
425
+            'usage'             => __( 'Usage / Limit', 'invoicing' ),
426
+            'start_date'        => __( 'Start Date', 'invoicing' ),
427
+            'expiry_date'       => __( 'Expiry Date', 'invoicing' ),
428
+        );
429
+
430
+        return apply_filters( 'wpi_discount_table_columns', $columns );
431
+    }
432
+
433
+    /**
434
+     * Filters post states.
435
+     */
436
+    public static function filter_discount_state( $post_states, $post ) {
437
+
438
+        if ( 'wpi_discount' == $post->post_type ) {
439
+
440
+            $discount = new WPInv_Discount( $post );
441
+
442
+            $status = $discount->is_expired() ? 'expired' : $discount->get_status();
443
+
444
+            if ( $status != 'publish' ) {
445
+                return array(
446
+                    'discount_status' => wpinv_discount_status( $status ),
447
+                );
448
+            }
449
+
450
+            return array();
451
+
452
+        }
453
+
454
+        return $post_states;
455
+
456
+    }
457
+
458
+    /**
459
+     * Returns an array of items table columns.
460
+     */
461
+    public static function item_columns( $columns ) {
462
+
463
+        $columns = array(
464
+            'cb'                => $columns['cb'],
465
+            'title'             => __( 'Name', 'invoicing' ),
466
+            'price'             => __( 'Price', 'invoicing' ),
467
+            'vat_rule'          => __( 'VAT rule', 'invoicing' ),
468
+            'vat_class'         => __( 'VAT class', 'invoicing' ),
469
+            'type'              => __( 'Type', 'invoicing' ),
470
+            'shortcode'         => __( 'Shortcode', 'invoicing' ),
471
+        );
472
+
473
+        if ( ! wpinv_use_taxes() ) {
474
+            unset( $columns['vat_rule'] );
475
+            unset( $columns['vat_class'] );
476
+        }
477
+
478
+        return apply_filters( 'wpi_item_table_columns', $columns );
479
+    }
480
+
481
+    /**
482
+     * Returns an array of sortable items table columns.
483
+     */
484
+    public static function sortable_item_columns( $columns ) {
485
+
486
+        return array_merge(
487
+            $columns,
488
+            array(
489
+                'price'     => 'price',
490
+                'vat_rule'  => 'vat_rule',
491
+                'vat_class' => 'vat_class',
492
+                'type'      => 'type',
493
+            )
494
+        );
495
+
496
+    }
497
+
498
+    /**
499
+     * Displays items table columns.
500
+     */
501
+    public static function display_item_columns( $column_name, $post_id ) {
502 502
  
503
-		$item = new WPInv_Item( $post_id );
503
+        $item = new WPInv_Item( $post_id );
504 504
 
505
-		switch ( $column_name ) {
505
+        switch ( $column_name ) {
506 506
 
507
-			case 'price' :
507
+            case 'price' :
508 508
 
509
-				if ( ! $item->is_recurring() ) {
510
-					echo $item->get_the_price();
511
-					break;
512
-				}
509
+                if ( ! $item->is_recurring() ) {
510
+                    echo $item->get_the_price();
511
+                    break;
512
+                }
513 513
 
514
-				$price = wp_sprintf(
515
-					__( '%s / %s', 'invoicing' ),
516
-					$item->get_the_price(),
517
-					getpaid_get_subscription_period_label( $item->get_recurring_period(), $item->get_recurring_interval(), '' )
518
-				);
514
+                $price = wp_sprintf(
515
+                    __( '%s / %s', 'invoicing' ),
516
+                    $item->get_the_price(),
517
+                    getpaid_get_subscription_period_label( $item->get_recurring_period(), $item->get_recurring_interval(), '' )
518
+                );
519 519
 
520
-				if ( $item->get_the_price() == $item->get_the_initial_price() ) {
521
-					echo $price;
522
-					break;
523
-				}
520
+                if ( $item->get_the_price() == $item->get_the_initial_price() ) {
521
+                    echo $price;
522
+                    break;
523
+                }
524 524
 
525
-				echo $item->get_the_initial_price();
525
+                echo $item->get_the_initial_price();
526 526
 
527
-				echo '<span class="meta">' . wp_sprintf( __( 'then %s', 'invoicing' ), $price )  .'</span>';
528
-				break;
527
+                echo '<span class="meta">' . wp_sprintf( __( 'then %s', 'invoicing' ), $price )  .'</span>';
528
+                break;
529 529
 
530
-			case 'vat_rule' :
531
-				echo getpaid_get_tax_rule_label( $item->get_vat_rule() );
532
-				break;
530
+            case 'vat_rule' :
531
+                echo getpaid_get_tax_rule_label( $item->get_vat_rule() );
532
+                break;
533 533
 
534
-			case 'vat_class' :
535
-				echo getpaid_get_tax_class_label( $item->get_vat_class() );
536
-				break;
534
+            case 'vat_class' :
535
+                echo getpaid_get_tax_class_label( $item->get_vat_class() );
536
+                break;
537 537
 
538
-			case 'shortcode' :
539
-				echo '<input onClick="this.select()" type="text" value="[getpaid item=' . esc_attr( $item->get_id() ) . ' button=\'Buy Now\']" style="width: 100%;" readonly/>';
540
-				break;
538
+            case 'shortcode' :
539
+                echo '<input onClick="this.select()" type="text" value="[getpaid item=' . esc_attr( $item->get_id() ) . ' button=\'Buy Now\']" style="width: 100%;" readonly/>';
540
+                break;
541 541
 
542
-			case 'type' :
543
-				echo wpinv_item_type( $item->get_id() ) . '<span class="meta">' . $item->get_custom_singular_name() . '</span>';
544
-				break;
542
+            case 'type' :
543
+                echo wpinv_item_type( $item->get_id() ) . '<span class="meta">' . $item->get_custom_singular_name() . '</span>';
544
+                break;
545 545
 
546
-		}
546
+        }
547 547
 
548
-	}
548
+    }
549 549
 
550
-	/**
551
-	 * Lets users filter items using taxes.
552
-	 */
553
-	public static function add_item_filters( $post_type ) {
550
+    /**
551
+     * Lets users filter items using taxes.
552
+     */
553
+    public static function add_item_filters( $post_type ) {
554 554
 
555
-		// Abort if we're not dealing with items.
556
-		if ( $post_type != 'wpi_item' ) {
557
-			return;
558
-		}
555
+        // Abort if we're not dealing with items.
556
+        if ( $post_type != 'wpi_item' ) {
557
+            return;
558
+        }
559 559
 
560
-		// Filter by vat rules.
561
-		if ( wpinv_use_taxes() ) {
560
+        // Filter by vat rules.
561
+        if ( wpinv_use_taxes() ) {
562 562
 	
563
-			// Sanitize selected vat rule.
564
-			$vat_rule   = '';
565
-			$vat_rules  = getpaid_get_tax_rules();
566
-			if ( isset( $_GET['vat_rule'] ) ) {
567
-				$vat_rule   =  $_GET['vat_rule'];
568
-			}
569
-
570
-			// Filter by VAT rule.
571
-			echo wpinv_html_select(
572
-				array(
573
-					'options'          => array_merge(
574
-						array(
575
-							'' => __( 'All VAT rules', 'invoicing' )
576
-						),
577
-						$vat_rules
578
-					),
579
-					'name'             => 'vat_rule',
580
-					'id'               => 'vat_rule',
581
-					'selected'         => in_array( $vat_rule, array_keys( $vat_rules ) ) ? $vat_rule : '',
582
-					'show_option_all'  => false,
583
-					'show_option_none' => false,
584
-				)
585
-			);
586
-
587
-			// Filter by VAT class.
563
+            // Sanitize selected vat rule.
564
+            $vat_rule   = '';
565
+            $vat_rules  = getpaid_get_tax_rules();
566
+            if ( isset( $_GET['vat_rule'] ) ) {
567
+                $vat_rule   =  $_GET['vat_rule'];
568
+            }
569
+
570
+            // Filter by VAT rule.
571
+            echo wpinv_html_select(
572
+                array(
573
+                    'options'          => array_merge(
574
+                        array(
575
+                            '' => __( 'All VAT rules', 'invoicing' )
576
+                        ),
577
+                        $vat_rules
578
+                    ),
579
+                    'name'             => 'vat_rule',
580
+                    'id'               => 'vat_rule',
581
+                    'selected'         => in_array( $vat_rule, array_keys( $vat_rules ) ) ? $vat_rule : '',
582
+                    'show_option_all'  => false,
583
+                    'show_option_none' => false,
584
+                )
585
+            );
586
+
587
+            // Filter by VAT class.
588 588
 	
589
-			// Sanitize selected vat rule.
590
-			$vat_class   = '';
591
-			$vat_classes = getpaid_get_tax_classes();
592
-			if ( isset( $_GET['vat_class'] ) ) {
593
-				$vat_class   =  $_GET['vat_class'];
594
-			}
595
-
596
-			echo wpinv_html_select(
597
-				array(
598
-					'options'          => array_merge(
599
-						array(
600
-							'' => __( 'All VAT classes', 'invoicing' )
601
-						),
602
-						$vat_classes
603
-					),
604
-					'name'             => 'vat_class',
605
-					'id'               => 'vat_class',
606
-					'selected'         => in_array( $vat_class, array_keys( $vat_classes ) ) ? $vat_class : '',
607
-					'show_option_all'  => false,
608
-					'show_option_none' => false,
609
-				)
610
-			);
611
-
612
-		}
613
-
614
-		// Filter by item type.
615
-		$type   = '';
616
-		if ( isset( $_GET['type'] ) ) {
617
-			$type   =  $_GET['type'];
618
-		}
619
-
620
-		echo wpinv_html_select(
621
-			array(
622
-				'options'          => array_merge(
623
-					array(
624
-						'' => __( 'All item types', 'invoicing' )
625
-					),
626
-					wpinv_get_item_types()
627
-				),
628
-				'name'             => 'type',
629
-				'id'               => 'type',
630
-				'selected'         => in_array( $type, wpinv_item_types() ) ? $type : '',
631
-				'show_option_all'  => false,
632
-				'show_option_none' => false,
633
-			)
634
-		);
635
-
636
-	}
637
-
638
-	/**
639
-	 * Filters the item query.
640
-	 */
641
-	public static function filter_item_query( $query ) {
642
-
643
-		// modify the query only if it admin and main query.
644
-		if ( ! ( is_admin() && $query->is_main_query() ) ){ 
645
-			return $query;
646
-		}
647
-
648
-		// we want to modify the query for our items.
649
-		if ( empty( $query->query['post_type'] ) || 'wpi_item' != $query->query['post_type'] ){
650
-			return $query;
651
-		}
652
-
653
-		if ( empty( $query->query_vars['meta_query'] ) ) {
654
-			$query->query_vars['meta_query'] = array();
655
-		}
656
-
657
-		// Filter vat rule type
589
+            // Sanitize selected vat rule.
590
+            $vat_class   = '';
591
+            $vat_classes = getpaid_get_tax_classes();
592
+            if ( isset( $_GET['vat_class'] ) ) {
593
+                $vat_class   =  $_GET['vat_class'];
594
+            }
595
+
596
+            echo wpinv_html_select(
597
+                array(
598
+                    'options'          => array_merge(
599
+                        array(
600
+                            '' => __( 'All VAT classes', 'invoicing' )
601
+                        ),
602
+                        $vat_classes
603
+                    ),
604
+                    'name'             => 'vat_class',
605
+                    'id'               => 'vat_class',
606
+                    'selected'         => in_array( $vat_class, array_keys( $vat_classes ) ) ? $vat_class : '',
607
+                    'show_option_all'  => false,
608
+                    'show_option_none' => false,
609
+                )
610
+            );
611
+
612
+        }
613
+
614
+        // Filter by item type.
615
+        $type   = '';
616
+        if ( isset( $_GET['type'] ) ) {
617
+            $type   =  $_GET['type'];
618
+        }
619
+
620
+        echo wpinv_html_select(
621
+            array(
622
+                'options'          => array_merge(
623
+                    array(
624
+                        '' => __( 'All item types', 'invoicing' )
625
+                    ),
626
+                    wpinv_get_item_types()
627
+                ),
628
+                'name'             => 'type',
629
+                'id'               => 'type',
630
+                'selected'         => in_array( $type, wpinv_item_types() ) ? $type : '',
631
+                'show_option_all'  => false,
632
+                'show_option_none' => false,
633
+            )
634
+        );
635
+
636
+    }
637
+
638
+    /**
639
+     * Filters the item query.
640
+     */
641
+    public static function filter_item_query( $query ) {
642
+
643
+        // modify the query only if it admin and main query.
644
+        if ( ! ( is_admin() && $query->is_main_query() ) ){ 
645
+            return $query;
646
+        }
647
+
648
+        // we want to modify the query for our items.
649
+        if ( empty( $query->query['post_type'] ) || 'wpi_item' != $query->query['post_type'] ){
650
+            return $query;
651
+        }
652
+
653
+        if ( empty( $query->query_vars['meta_query'] ) ) {
654
+            $query->query_vars['meta_query'] = array();
655
+        }
656
+
657
+        // Filter vat rule type
658 658
         if ( ! empty( $_GET['vat_rule'] ) ) {
659 659
             $query->query_vars['meta_query'][] = array(
660 660
                 'key'     => '_wpinv_vat_rule',
@@ -679,97 +679,97 @@  discard block
 block discarded – undo
679 679
                 'value'   => sanitize_text_field( $_GET['type'] ),
680 680
                 'compare' => '='
681 681
             );
682
-		}
683
-
684
-	}
685
-
686
-	/**
687
-	 * Reorders items.
688
-	 */
689
-	public static function reorder_items( $vars ) {
690
-		global $typenow;
691
-
692
-		if ( 'wpi_item' !== $typenow || empty( $vars['orderby'] ) ) {
693
-			return $vars;
694
-		}
695
-
696
-		// By item type.
697
-		if ( 'type' == $vars['orderby'] ) {
698
-			return array_merge(
699
-				$vars,
700
-				array(
701
-					'meta_key' => '_wpinv_type',
702
-					'orderby'  => 'meta_value'
703
-				)
704
-			);
705
-		}
706
-
707
-		// By vat class.
708
-		if ( 'vat_class' == $vars['orderby'] ) {
709
-			return array_merge(
710
-				$vars,
711
-				array(
712
-					'meta_key' => '_wpinv_vat_class',
713
-					'orderby'  => 'meta_value'
714
-				)
715
-			);
716
-		}
717
-
718
-		// By vat rule.
719
-		if ( 'vat_rule' == $vars['orderby'] ) {
720
-			return array_merge(
721
-				$vars,
722
-				array(
723
-					'meta_key' => '_wpinv_vat_rule',
724
-					'orderby'  => 'meta_value'
725
-				)
726
-			);
727
-		}
728
-
729
-		// By price.
730
-		if ( 'price' == $vars['orderby'] ) {
731
-			return array_merge(
732
-				$vars,
733
-				array(
734
-					'meta_key' => '_wpinv_price',
735
-					'orderby'  => 'meta_value_num'
736
-				)
737
-			);
738
-		}
739
-
740
-		return $vars;
741
-
742
-	}
743
-
744
-	/**
745
-	 * Fired when deleting a post.
746
-	 */
747
-	public static function delete_post( $post_id ) {
748
-
749
-		switch ( get_post_type( $post_id ) ) {
750
-
751
-			case 'wpi_item' :
752
-				do_action( "getpaid_before_delete_item", new WPInv_Item( $post_id ) );
753
-				break;
754
-
755
-			case 'wpi_payment_form' :
756
-				do_action( "getpaid_before_delete_payment_form", new GetPaid_Payment_Form( $post_id ) );
757
-				break;
758
-
759
-			case 'wpi_discount' :
760
-				do_action( "getpaid_before_delete_discount", new WPInv_Discount( $post_id ) );
761
-				break;
762
-
763
-			case 'wpi_invoice' :
764
-				$invoice = new WPInv_Invoice( $post_id );
765
-				do_action( "getpaid_before_delete_invoice", $invoice );
766
-				$invoice->get_data_store()->delete_items( $invoice );
767
-				$invoice->get_data_store()->delete_special_fields( $invoice );
768
-				break;
769
-		}
770
-	}
771
-
772
-	/**
682
+        }
683
+
684
+    }
685
+
686
+    /**
687
+     * Reorders items.
688
+     */
689
+    public static function reorder_items( $vars ) {
690
+        global $typenow;
691
+
692
+        if ( 'wpi_item' !== $typenow || empty( $vars['orderby'] ) ) {
693
+            return $vars;
694
+        }
695
+
696
+        // By item type.
697
+        if ( 'type' == $vars['orderby'] ) {
698
+            return array_merge(
699
+                $vars,
700
+                array(
701
+                    'meta_key' => '_wpinv_type',
702
+                    'orderby'  => 'meta_value'
703
+                )
704
+            );
705
+        }
706
+
707
+        // By vat class.
708
+        if ( 'vat_class' == $vars['orderby'] ) {
709
+            return array_merge(
710
+                $vars,
711
+                array(
712
+                    'meta_key' => '_wpinv_vat_class',
713
+                    'orderby'  => 'meta_value'
714
+                )
715
+            );
716
+        }
717
+
718
+        // By vat rule.
719
+        if ( 'vat_rule' == $vars['orderby'] ) {
720
+            return array_merge(
721
+                $vars,
722
+                array(
723
+                    'meta_key' => '_wpinv_vat_rule',
724
+                    'orderby'  => 'meta_value'
725
+                )
726
+            );
727
+        }
728
+
729
+        // By price.
730
+        if ( 'price' == $vars['orderby'] ) {
731
+            return array_merge(
732
+                $vars,
733
+                array(
734
+                    'meta_key' => '_wpinv_price',
735
+                    'orderby'  => 'meta_value_num'
736
+                )
737
+            );
738
+        }
739
+
740
+        return $vars;
741
+
742
+    }
743
+
744
+    /**
745
+     * Fired when deleting a post.
746
+     */
747
+    public static function delete_post( $post_id ) {
748
+
749
+        switch ( get_post_type( $post_id ) ) {
750
+
751
+            case 'wpi_item' :
752
+                do_action( "getpaid_before_delete_item", new WPInv_Item( $post_id ) );
753
+                break;
754
+
755
+            case 'wpi_payment_form' :
756
+                do_action( "getpaid_before_delete_payment_form", new GetPaid_Payment_Form( $post_id ) );
757
+                break;
758
+
759
+            case 'wpi_discount' :
760
+                do_action( "getpaid_before_delete_discount", new WPInv_Discount( $post_id ) );
761
+                break;
762
+
763
+            case 'wpi_invoice' :
764
+                $invoice = new WPInv_Invoice( $post_id );
765
+                do_action( "getpaid_before_delete_invoice", $invoice );
766
+                $invoice->get_data_store()->delete_items( $invoice );
767
+                $invoice->get_data_store()->delete_special_fields( $invoice );
768
+                break;
769
+        }
770
+    }
771
+
772
+    /**
773 773
      * Add a post display state for special GetPaid pages in the page list table.
774 774
      *
775 775
      * @param array   $post_states An array of post display states.
@@ -783,22 +783,22 @@  discard block
 block discarded – undo
783 783
             $post_states['getpaid_success_page'] = __( 'GetPaid Receipt Page', 'invoicing' );
784 784
         }
785 785
 
786
-		foreach ( getpaid_get_invoice_post_types() as $post_type => $label ) {
786
+        foreach ( getpaid_get_invoice_post_types() as $post_type => $label ) {
787 787
 
788
-			if ( wpinv_get_option( "{$post_type}_history_page", 0 ) == $post->ID ) {
789
-				$post_states["getpaid_{$post_type}_history_page"] = sprintf(
790
-					__( 'GetPaid %s History Page', 'invoicing' ),
791
-					$label
792
-				);
793
-			}
788
+            if ( wpinv_get_option( "{$post_type}_history_page", 0 ) == $post->ID ) {
789
+                $post_states["getpaid_{$post_type}_history_page"] = sprintf(
790
+                    __( 'GetPaid %s History Page', 'invoicing' ),
791
+                    $label
792
+                );
793
+            }
794 794
 
795
-		}
795
+        }
796 796
 		
797
-		if ( wpinv_get_option( 'invoice_subscription_page', 0 ) == $post->ID ) {
797
+        if ( wpinv_get_option( 'invoice_subscription_page', 0 ) == $post->ID ) {
798 798
             $post_states['getpaid_invoice_subscription_page'] = __( 'GetPaid Subscription Page', 'invoicing' );
799 799
         }
800 800
 
801
-		if ( wpinv_get_option( 'checkout_page', 0 ) == $post->ID ) {
801
+        if ( wpinv_get_option( 'checkout_page', 0 ) == $post->ID ) {
802 802
             $post_states['getpaid_checkout_page'] = __( 'GetPaid Checkout Page', 'invoicing' );
803 803
         }
804 804
 
Please login to merge, or discard this patch.
includes/payments/class-getpaid-payment-form-submission-refresh-prices.php 1 patch
Indentation   +261 added lines, -261 removed lines patch added patch discarded remove patch
@@ -12,288 +12,288 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Payment_Form_Submission_Refresh_Prices {
14 14
 
15
-	/**
16
-	 * Contains the response for refreshing prices.
17
-	 * @var array
18
-	 */
19
-	public $response = array();
15
+    /**
16
+     * Contains the response for refreshing prices.
17
+     * @var array
18
+     */
19
+    public $response = array();
20 20
 
21 21
     /**
22
-	 * Class constructor
23
-	 *
24
-	 * @param GetPaid_Payment_Form_Submission $submission
25
-	 */
26
-	public function __construct( $submission ) {
27
-
28
-		$this->response = array(
29
-			'submission_id'                    => $submission->id,
22
+     * Class constructor
23
+     *
24
+     * @param GetPaid_Payment_Form_Submission $submission
25
+     */
26
+    public function __construct( $submission ) {
27
+
28
+        $this->response = array(
29
+            'submission_id'                    => $submission->id,
30 30
             'has_recurring'                    => $submission->has_recurring,
31
-			'has_subscription_group'           => $submission->has_subscription_group(),
32
-			'has_multiple_subscription_groups' => $submission->has_multiple_subscription_groups(),
31
+            'has_subscription_group'           => $submission->has_subscription_group(),
32
+            'has_multiple_subscription_groups' => $submission->has_multiple_subscription_groups(),
33 33
             'is_free'                          => ! $submission->should_collect_payment_details(),
34
-		);
35
-
36
-		$this->add_totals( $submission );
37
-		$this->add_texts( $submission );
38
-		$this->add_items( $submission );
39
-		$this->add_fees( $submission );
40
-		$this->add_discounts( $submission );
41
-		$this->add_taxes( $submission );
42
-		$this->add_gateways( $submission );
43
-		$this->add_data( $submission );
44
-
45
-	}
46
-
47
-	/**
48
-	 * Adds totals to a response for submission refresh prices.
49
-	 *
50
-	 * @param GetPaid_Payment_Form_Submission $submission
51
-	 */
52
-	public function add_totals( $submission ) {
53
-
54
-		$this->response = array_merge(
55
-			$this->response,
56
-			array(
57
-
58
-				'totals'        => array(
59
-					'subtotal'  => $submission->format_amount( $submission->get_subtotal() ),
60
-					'discount'  => $submission->format_amount( $submission->get_discount() ),
61
-					'fees'      => $submission->format_amount( $submission->get_fee() ),
62
-					'tax'       => $submission->format_amount( $submission->get_tax() ),
63
-					'total'     => $submission->format_amount( $submission->get_total() ),
64
-					'raw_total' => html_entity_decode( sanitize_text_field( $submission->format_amount( $submission->get_total() ) ), ENT_QUOTES ),
65
-				),
66
-
67
-				'recurring'     => array(
68
-					'subtotal'  => $submission->format_amount( $submission->get_recurring_subtotal() ),
69
-					'discount'  => $submission->format_amount( $submission->get_recurring_discount() ),
70
-					'fees'      => $submission->format_amount( $submission->get_recurring_fee() ),
71
-					'tax'       => $submission->format_amount( $submission->get_recurring_tax() ),
72
-					'total'     => $submission->format_amount( $submission->get_recurring_total() ),
73
-				),
74
-
75
-				'initial_amt'   => wpinv_round_amount( $submission->get_total(), null, true ),
76
-				'currency'      => $submission->get_currency(),
77
-
78
-			)
79
-		);
80
-
81
-	}
82
-
83
-	/**
84
-	 * Adds texts to a response for submission refresh prices.
85
-	 *
86
-	 * @param GetPaid_Payment_Form_Submission $submission
87
-	 */
88
-	public function add_texts( $submission ) {
89
-
90
-		$payable = $submission->format_amount( $submission->get_total() );
91
-		$groups  = getpaid_get_subscription_groups( $submission );
92
-
93
-		if ( $submission->has_recurring && 2 > count( $groups ) ) {
94
-
95
-			$recurring = new WPInv_Item( $submission->has_recurring );
96
-			$period    = getpaid_get_subscription_period_label( $recurring->get_recurring_period( true ), $recurring->get_recurring_interval(), '' );
97
-			$main_item = reset( $groups );
98
-
99
-			if ( $submission->get_total() == $submission->get_recurring_total() ) {
100
-				$payable = "$payable / $period";
101
-			} else if ( $main_item ) {
102
-
103
-				$main_item = reset( $main_item );
104
-
105
-				// Calculate the next renewal date.
106
-				$_period      = $main_item->get_recurring_period( true );
107
-				$_interval    = $main_item->get_recurring_interval();
108
-
109
-				// If the subscription item has a trial period...
110
-				if ( $main_item->has_free_trial() ) {
111
-					$_period   = $main_item->get_trial_period( true );
112
-					$_interval = $main_item->get_trial_interval();
113
-				}
114
-
115
-				$payable = sprintf(
116
-					__( '%1$s (renews at %2$s / %3$s)', 'invoicing' ),
117
-					$submission->format_amount( $submission->get_total() ),
118
-					$submission->format_amount( $submission->get_recurring_total() ),
119
-					$period
120
-				);
121
-
122
-				$payable .= sprintf(
123
-					'<small class="text-muted form-text">%s</small>',
124
-					sprintf(
125
-						__( 'First renewal on %s', 'invoicing' ),
126
-						getpaid_format_date( date( 'Y-m-d H:i:s', strtotime( "+$_interval $_period", current_time( 'timestamp' ) ) ) )
127
-					)
128
-				);
129
-
130
-			} else {
131
-				$payable = sprintf(
132
-					__( '%1$s (renews at %2$s / %3$s)', 'invoicing' ),
133
-					$submission->format_amount( $submission->get_total() ),
134
-					$submission->format_amount( $submission->get_recurring_total() ),
135
-					$period
136
-				);
137
-			}
138
-
139
-		}
140
-
141
-		$texts = array(
142
-			'.getpaid-checkout-total-payable' => $payable,
143
-		);
144
-
145
-		foreach ( $submission->get_items() as $item ) {
146
-			$item_id                                               = $item->get_id();
147
-			$initial_price                                         = $submission->format_amount( $item->get_sub_total() - $item->item_discount );
148
-			$recurring_price                                       = $submission->format_amount( $item->get_recurring_sub_total() - $item->recurring_item_discount );
149
-			$texts[".item-$item_id .getpaid-form-item-price-desc"] = getpaid_item_recurring_price_help_text( $item, $submission->get_currency(), $initial_price, $recurring_price );
150
-		}
151
-
152
-		$this->response = array_merge( $this->response, array( 'texts' => $texts ) );
153
-
154
-	}
155
-
156
-	/**
157
-	 * Adds items to a response for submission refresh prices.
158
-	 *
159
-	 * @param GetPaid_Payment_Form_Submission $submission
160
-	 */
161
-	public function add_items( $submission ) {
162
-
163
-		// Add items.
164
-		$items = array();
34
+        );
35
+
36
+        $this->add_totals( $submission );
37
+        $this->add_texts( $submission );
38
+        $this->add_items( $submission );
39
+        $this->add_fees( $submission );
40
+        $this->add_discounts( $submission );
41
+        $this->add_taxes( $submission );
42
+        $this->add_gateways( $submission );
43
+        $this->add_data( $submission );
44
+
45
+    }
46
+
47
+    /**
48
+     * Adds totals to a response for submission refresh prices.
49
+     *
50
+     * @param GetPaid_Payment_Form_Submission $submission
51
+     */
52
+    public function add_totals( $submission ) {
53
+
54
+        $this->response = array_merge(
55
+            $this->response,
56
+            array(
57
+
58
+                'totals'        => array(
59
+                    'subtotal'  => $submission->format_amount( $submission->get_subtotal() ),
60
+                    'discount'  => $submission->format_amount( $submission->get_discount() ),
61
+                    'fees'      => $submission->format_amount( $submission->get_fee() ),
62
+                    'tax'       => $submission->format_amount( $submission->get_tax() ),
63
+                    'total'     => $submission->format_amount( $submission->get_total() ),
64
+                    'raw_total' => html_entity_decode( sanitize_text_field( $submission->format_amount( $submission->get_total() ) ), ENT_QUOTES ),
65
+                ),
66
+
67
+                'recurring'     => array(
68
+                    'subtotal'  => $submission->format_amount( $submission->get_recurring_subtotal() ),
69
+                    'discount'  => $submission->format_amount( $submission->get_recurring_discount() ),
70
+                    'fees'      => $submission->format_amount( $submission->get_recurring_fee() ),
71
+                    'tax'       => $submission->format_amount( $submission->get_recurring_tax() ),
72
+                    'total'     => $submission->format_amount( $submission->get_recurring_total() ),
73
+                ),
74
+
75
+                'initial_amt'   => wpinv_round_amount( $submission->get_total(), null, true ),
76
+                'currency'      => $submission->get_currency(),
77
+
78
+            )
79
+        );
80
+
81
+    }
82
+
83
+    /**
84
+     * Adds texts to a response for submission refresh prices.
85
+     *
86
+     * @param GetPaid_Payment_Form_Submission $submission
87
+     */
88
+    public function add_texts( $submission ) {
89
+
90
+        $payable = $submission->format_amount( $submission->get_total() );
91
+        $groups  = getpaid_get_subscription_groups( $submission );
92
+
93
+        if ( $submission->has_recurring && 2 > count( $groups ) ) {
94
+
95
+            $recurring = new WPInv_Item( $submission->has_recurring );
96
+            $period    = getpaid_get_subscription_period_label( $recurring->get_recurring_period( true ), $recurring->get_recurring_interval(), '' );
97
+            $main_item = reset( $groups );
98
+
99
+            if ( $submission->get_total() == $submission->get_recurring_total() ) {
100
+                $payable = "$payable / $period";
101
+            } else if ( $main_item ) {
102
+
103
+                $main_item = reset( $main_item );
104
+
105
+                // Calculate the next renewal date.
106
+                $_period      = $main_item->get_recurring_period( true );
107
+                $_interval    = $main_item->get_recurring_interval();
108
+
109
+                // If the subscription item has a trial period...
110
+                if ( $main_item->has_free_trial() ) {
111
+                    $_period   = $main_item->get_trial_period( true );
112
+                    $_interval = $main_item->get_trial_interval();
113
+                }
114
+
115
+                $payable = sprintf(
116
+                    __( '%1$s (renews at %2$s / %3$s)', 'invoicing' ),
117
+                    $submission->format_amount( $submission->get_total() ),
118
+                    $submission->format_amount( $submission->get_recurring_total() ),
119
+                    $period
120
+                );
121
+
122
+                $payable .= sprintf(
123
+                    '<small class="text-muted form-text">%s</small>',
124
+                    sprintf(
125
+                        __( 'First renewal on %s', 'invoicing' ),
126
+                        getpaid_format_date( date( 'Y-m-d H:i:s', strtotime( "+$_interval $_period", current_time( 'timestamp' ) ) ) )
127
+                    )
128
+                );
129
+
130
+            } else {
131
+                $payable = sprintf(
132
+                    __( '%1$s (renews at %2$s / %3$s)', 'invoicing' ),
133
+                    $submission->format_amount( $submission->get_total() ),
134
+                    $submission->format_amount( $submission->get_recurring_total() ),
135
+                    $period
136
+                );
137
+            }
138
+
139
+        }
140
+
141
+        $texts = array(
142
+            '.getpaid-checkout-total-payable' => $payable,
143
+        );
165 144
 
166 145
         foreach ( $submission->get_items() as $item ) {
167
-			$item_id           = $item->get_id();
168
-			$items["$item_id"] = $submission->format_amount( $item->get_sub_total() );
169
-		}
146
+            $item_id                                               = $item->get_id();
147
+            $initial_price                                         = $submission->format_amount( $item->get_sub_total() - $item->item_discount );
148
+            $recurring_price                                       = $submission->format_amount( $item->get_recurring_sub_total() - $item->recurring_item_discount );
149
+            $texts[".item-$item_id .getpaid-form-item-price-desc"] = getpaid_item_recurring_price_help_text( $item, $submission->get_currency(), $initial_price, $recurring_price );
150
+        }
170 151
 
171
-		$this->response = array_merge(
172
-			$this->response,
173
-			array( 'items' => $items )
174
-		);
152
+        $this->response = array_merge( $this->response, array( 'texts' => $texts ) );
175 153
 
176
-	}
154
+    }
177 155
 
178
-	/**
179
-	 * Adds fees to a response for submission refresh prices.
180
-	 *
181
-	 * @param GetPaid_Payment_Form_Submission $submission
182
-	 */
183
-	public function add_fees( $submission ) {
156
+    /**
157
+     * Adds items to a response for submission refresh prices.
158
+     *
159
+     * @param GetPaid_Payment_Form_Submission $submission
160
+     */
161
+    public function add_items( $submission ) {
184 162
 
185
-		$fees = array();
163
+        // Add items.
164
+        $items = array();
165
+
166
+        foreach ( $submission->get_items() as $item ) {
167
+            $item_id           = $item->get_id();
168
+            $items["$item_id"] = $submission->format_amount( $item->get_sub_total() );
169
+        }
170
+
171
+        $this->response = array_merge(
172
+            $this->response,
173
+            array( 'items' => $items )
174
+        );
175
+
176
+    }
177
+
178
+    /**
179
+     * Adds fees to a response for submission refresh prices.
180
+     *
181
+     * @param GetPaid_Payment_Form_Submission $submission
182
+     */
183
+    public function add_fees( $submission ) {
184
+
185
+        $fees = array();
186 186
 
187 187
         foreach ( $submission->get_fees() as $name => $data ) {
188
-			$fees[$name] = $submission->format_amount( $data['initial_fee'] );
189
-		}
188
+            $fees[$name] = $submission->format_amount( $data['initial_fee'] );
189
+        }
190 190
 
191
-		$this->response = array_merge(
192
-			$this->response,
193
-			array( 'fees' => $fees )
194
-		);
191
+        $this->response = array_merge(
192
+            $this->response,
193
+            array( 'fees' => $fees )
194
+        );
195 195
 
196
-	}
196
+    }
197 197
 
198
-	/**
199
-	 * Adds discounts to a response for submission refresh prices.
200
-	 *
201
-	 * @param GetPaid_Payment_Form_Submission $submission
202
-	 */
203
-	public function add_discounts( $submission ) {
198
+    /**
199
+     * Adds discounts to a response for submission refresh prices.
200
+     *
201
+     * @param GetPaid_Payment_Form_Submission $submission
202
+     */
203
+    public function add_discounts( $submission ) {
204 204
 
205
-		$discounts = array();
205
+        $discounts = array();
206 206
 
207 207
         foreach ( $submission->get_discounts() as $name => $data ) {
208
-			$discounts[$name] = $submission->format_amount( $data['initial_discount'] );
209
-		}
210
-
211
-		$this->response = array_merge(
212
-			$this->response,
213
-			array( 'discounts' => $discounts )
214
-		);
208
+            $discounts[$name] = $submission->format_amount( $data['initial_discount'] );
209
+        }
215 210
 
216
-	}
211
+        $this->response = array_merge(
212
+            $this->response,
213
+            array( 'discounts' => $discounts )
214
+        );
217 215
 
218
-	/**
219
-	 * Adds taxes to a response for submission refresh prices.
220
-	 *
221
-	 * @param GetPaid_Payment_Form_Submission $submission
222
-	 */
223
-	public function add_taxes( $submission ) {
216
+    }
224 217
 
225
-		$taxes  = array();
226
-		$markup = '';
218
+    /**
219
+     * Adds taxes to a response for submission refresh prices.
220
+     *
221
+     * @param GetPaid_Payment_Form_Submission $submission
222
+     */
223
+    public function add_taxes( $submission ) {
224
+
225
+        $taxes  = array();
226
+        $markup = '';
227 227
         foreach ( $submission->get_taxes() as $name => $data ) {
228
-			$name          = sanitize_text_field( $name );
229
-			$amount        = $submission->format_amount( $data['initial_tax'] );
230
-			$taxes[$name]  = $amount;
231
-			$markup       .= "<small class='form-text'>$name : $amount</small>";
232
-		}
233
-
234
-		if ( wpinv_display_individual_tax_rates() && ! empty( $taxes ) ) {
235
-			$this->response['texts']['.getpaid-form-cart-totals-total-tax'] = $markup;
236
-		}
237
-
238
-		$this->response = array_merge(
239
-			$this->response,
240
-			array( 'taxes' => $taxes )
241
-		);
242
-
243
-	}
244
-
245
-	/**
246
-	 * Adds gateways to a response for submission refresh prices.
247
-	 *
248
-	 * @param GetPaid_Payment_Form_Submission $submission
249
-	 */
250
-	public function add_gateways( $submission ) {
251
-
252
-		$gateways = array_keys( wpinv_get_enabled_payment_gateways() );
253
-
254
-		if ( $this->response['has_recurring'] ) {
255
-
256
-			foreach ( $gateways as $i => $gateway ) {
257
-
258
-				if (
259
-					! getpaid_payment_gateway_supports( $gateway, 'subscription' )
260
-					|| ( $this->response['has_subscription_group'] && ! getpaid_payment_gateway_supports( $gateway, 'single_subscription_group' ) )
261
-					|| ( $this->response['has_multiple_subscription_groups'] && ! getpaid_payment_gateway_supports( $gateway, 'multiple_subscription_groups' ) ) ) {
262
-					unset( $gateways[ $i ] );
263
-				}
264
-
265
-			}
266
-
267
-		}
268
-
269
-		$gateways = apply_filters( 'getpaid_submission_gateways', $gateways, $submission );
270
-		$this->response = array_merge(
271
-			$this->response,
272
-			array( 'gateways' => $gateways )
273
-		);
274
-
275
-	}
276
-
277
-	/**
278
-	 * Adds data to a response for submission refresh prices.
279
-	 *
280
-	 * @param GetPaid_Payment_Form_Submission $submission
281
-	 */
282
-	public function add_data( $submission ) {
283
-
284
-		$this->response = array_merge(
285
-			$this->response,
286
-			array(
287
-				'js_data' => apply_filters(
288
-					'getpaid_submission_js_data',
289
-					array(
290
-						'is_recurring' => $this->response['has_recurring'],
291
-					),
292
-					$submission
293
-				)
294
-			)
295
-		);
296
-
297
-	}
228
+            $name          = sanitize_text_field( $name );
229
+            $amount        = $submission->format_amount( $data['initial_tax'] );
230
+            $taxes[$name]  = $amount;
231
+            $markup       .= "<small class='form-text'>$name : $amount</small>";
232
+        }
233
+
234
+        if ( wpinv_display_individual_tax_rates() && ! empty( $taxes ) ) {
235
+            $this->response['texts']['.getpaid-form-cart-totals-total-tax'] = $markup;
236
+        }
237
+
238
+        $this->response = array_merge(
239
+            $this->response,
240
+            array( 'taxes' => $taxes )
241
+        );
242
+
243
+    }
244
+
245
+    /**
246
+     * Adds gateways to a response for submission refresh prices.
247
+     *
248
+     * @param GetPaid_Payment_Form_Submission $submission
249
+     */
250
+    public function add_gateways( $submission ) {
251
+
252
+        $gateways = array_keys( wpinv_get_enabled_payment_gateways() );
253
+
254
+        if ( $this->response['has_recurring'] ) {
255
+
256
+            foreach ( $gateways as $i => $gateway ) {
257
+
258
+                if (
259
+                    ! getpaid_payment_gateway_supports( $gateway, 'subscription' )
260
+                    || ( $this->response['has_subscription_group'] && ! getpaid_payment_gateway_supports( $gateway, 'single_subscription_group' ) )
261
+                    || ( $this->response['has_multiple_subscription_groups'] && ! getpaid_payment_gateway_supports( $gateway, 'multiple_subscription_groups' ) ) ) {
262
+                    unset( $gateways[ $i ] );
263
+                }
264
+
265
+            }
266
+
267
+        }
268
+
269
+        $gateways = apply_filters( 'getpaid_submission_gateways', $gateways, $submission );
270
+        $this->response = array_merge(
271
+            $this->response,
272
+            array( 'gateways' => $gateways )
273
+        );
274
+
275
+    }
276
+
277
+    /**
278
+     * Adds data to a response for submission refresh prices.
279
+     *
280
+     * @param GetPaid_Payment_Form_Submission $submission
281
+     */
282
+    public function add_data( $submission ) {
283
+
284
+        $this->response = array_merge(
285
+            $this->response,
286
+            array(
287
+                'js_data' => apply_filters(
288
+                    'getpaid_submission_js_data',
289
+                    array(
290
+                        'is_recurring' => $this->response['has_recurring'],
291
+                    ),
292
+                    $submission
293
+                )
294
+            )
295
+        );
296
+
297
+    }
298 298
 
299 299
 }
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Indentation   +1933 added lines, -1933 removed lines patch added patch discarded remove patch
@@ -1,262 +1,262 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
3
+    exit;
4 4
 }
5 5
 
6 6
 if ( ! class_exists( 'WP_Super_Duper' ) ) {
7 7
 
8 8
 
9
-	/**
10
-	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
11
-	 *
12
-	 * Should not be called direct but extended instead.
13
-	 *
14
-	 * Class WP_Super_Duper
15
-	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
16
-	 * @ver 1.0.19
17
-	 */
18
-	class WP_Super_Duper extends WP_Widget {
19
-
20
-		public $version = "1.0.26";
21
-		public $font_awesome_icon_version = "5.11.2";
22
-		public $block_code;
23
-		public $options;
24
-		public $base_id;
25
-		public $settings_hash;
26
-		public $arguments = array();
27
-		public $instance = array();
28
-		private $class_name;
29
-
30
-		/**
31
-		 * The relative url to the current folder.
32
-		 *
33
-		 * @var string
34
-		 */
35
-		public $url = '';
36
-
37
-		/**
38
-		 * Take the array options and use them to build.
39
-		 */
40
-		public function __construct( $options ) {
41
-			global $sd_widgets;
42
-
43
-			$sd_widgets[ $options['base_id'] ] = array(
44
-				'name'       => $options['name'],
45
-				'class_name' => $options['class_name']
46
-			);
47
-			$this->base_id                     = $options['base_id'];
48
-			// lets filter the options before we do anything
49
-			$options       = apply_filters( "wp_super_duper_options", $options );
50
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
51
-			$options       = $this->add_name_from_key( $options );
52
-			$this->options = $options;
53
-
54
-			$this->base_id   = $options['base_id'];
55
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
56
-
57
-			// init parent
58
-			parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
59
-
60
-			if ( isset( $options['class_name'] ) ) {
61
-				// register widget
62
-				$this->class_name = $options['class_name'];
63
-
64
-				// register shortcode
65
-				$this->register_shortcode();
66
-
67
-				// Fusion Builder (avada) support
68
-				if ( function_exists( 'fusion_builder_map' ) ) {
69
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
70
-				}
71
-
72
-				// register block
73
-				add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
74
-			}
75
-
76
-			// add the CSS and JS we need ONCE
77
-			global $sd_widget_scripts;
78
-
79
-			if ( ! $sd_widget_scripts ) {
80
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
81
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
82
-				wp_add_inline_style( 'widgets', $this->widget_css() );
83
-
84
-				// maybe add elementor editor styles
85
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
86
-
87
-				$sd_widget_scripts = true;
88
-
89
-				// add shortcode insert button once
90
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
91
-				// generatepress theme sections compatibility
92
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
93
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
94
-				}
95
-				if ( $this->is_preview() ) {
96
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
97
-					// this makes the insert button work for elementor
98
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
99
-						$this,
100
-						'shortcode_insert_button_script'
101
-					) ); // for elementor
102
-				}
103
-				// this makes the insert button work for cornerstone
104
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
105
-
106
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
107
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
108
-
109
-				// add generator text to admin head
110
-				add_action( 'admin_head', array( $this, 'generator' ) );
111
-			}
112
-
113
-			do_action( 'wp_super_duper_widget_init', $options, $this );
114
-		}
115
-
116
-		/**
117
-		 * Add our widget CSS to elementor editor.
118
-		 */
119
-		public function elementor_editor_styles() {
120
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
121
-		}
122
-
123
-		public function register_fusion_element() {
124
-
125
-			$options = $this->options;
126
-
127
-			if ( $this->base_id ) {
128
-
129
-				$params = $this->get_fusion_params();
130
-
131
-				$args = array(
132
-					'name'            => $options['name'],
133
-					'shortcode'       => $this->base_id,
134
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
135
-					'allow_generator' => true,
136
-				);
137
-
138
-				if ( ! empty( $params ) ) {
139
-					$args['params'] = $params;
140
-				}
141
-
142
-				fusion_builder_map( $args );
143
-			}
144
-
145
-		}
146
-
147
-		public function get_fusion_params() {
148
-			$params    = array();
149
-			$arguments = $this->get_arguments();
150
-
151
-			if ( ! empty( $arguments ) ) {
152
-				foreach ( $arguments as $key => $val ) {
153
-					$param = array();
154
-					// type
155
-					$param['type'] = str_replace(
156
-						array(
157
-							"text",
158
-							"number",
159
-							"email",
160
-							"color",
161
-							"checkbox"
162
-						),
163
-						array(
164
-							"textfield",
165
-							"textfield",
166
-							"textfield",
167
-							"colorpicker",
168
-							"select",
169
-
170
-						),
171
-						$val['type'] );
172
-
173
-					// multiselect
174
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
175
-						$param['type']     = 'multiple_select';
176
-						$param['multiple'] = true;
177
-					}
178
-
179
-					// heading
180
-					$param['heading'] = $val['title'];
181
-
182
-					// description
183
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
184
-
185
-					// param_name
186
-					$param['param_name'] = $key;
187
-
188
-					// Default
189
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
190
-
191
-					// Group
192
-					if ( isset( $val['group'] ) ) {
193
-						$param['group'] = $val['group'];
194
-					}
195
-
196
-					// value
197
-					if ( $val['type'] == 'checkbox' ) {
198
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
199
-							unset( $param['default'] );
200
-						}
201
-						$param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
202
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
203
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
204
-					} else {
205
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
206
-					}
207
-
208
-					// setup the param
209
-					$params[] = $param;
210
-
211
-				}
212
-			}
213
-
214
-
215
-			return $params;
216
-		}
217
-
218
-		/**
219
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
220
-		 */
221
-		public static function maybe_cornerstone_builder() {
222
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
223
-				self::shortcode_insert_button_script();
224
-			}
225
-		}
226
-
227
-		/**
228
-		 * A function to ge the shortcode builder picker html.
229
-		 *
230
-		 * @param string $editor_id
231
-		 *
232
-		 * @return string
233
-		 */
234
-		public static function get_picker( $editor_id = '' ) {
235
-
236
-			ob_start();
237
-			if ( isset( $_POST['editor_id'] ) ) {
238
-				$editor_id = esc_attr( $_POST['editor_id'] );
239
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
240
-				$editor_id = 'main_content_content_vb_tiny_mce';
241
-			}
242
-
243
-			global $sd_widgets;
244
-			?>
9
+    /**
10
+     * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
11
+     *
12
+     * Should not be called direct but extended instead.
13
+     *
14
+     * Class WP_Super_Duper
15
+     * @since 1.0.16 change log moved to file change-log.txt - CHANGED
16
+     * @ver 1.0.19
17
+     */
18
+    class WP_Super_Duper extends WP_Widget {
19
+
20
+        public $version = "1.0.26";
21
+        public $font_awesome_icon_version = "5.11.2";
22
+        public $block_code;
23
+        public $options;
24
+        public $base_id;
25
+        public $settings_hash;
26
+        public $arguments = array();
27
+        public $instance = array();
28
+        private $class_name;
29
+
30
+        /**
31
+         * The relative url to the current folder.
32
+         *
33
+         * @var string
34
+         */
35
+        public $url = '';
36
+
37
+        /**
38
+         * Take the array options and use them to build.
39
+         */
40
+        public function __construct( $options ) {
41
+            global $sd_widgets;
42
+
43
+            $sd_widgets[ $options['base_id'] ] = array(
44
+                'name'       => $options['name'],
45
+                'class_name' => $options['class_name']
46
+            );
47
+            $this->base_id                     = $options['base_id'];
48
+            // lets filter the options before we do anything
49
+            $options       = apply_filters( "wp_super_duper_options", $options );
50
+            $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
51
+            $options       = $this->add_name_from_key( $options );
52
+            $this->options = $options;
53
+
54
+            $this->base_id   = $options['base_id'];
55
+            $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
56
+
57
+            // init parent
58
+            parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
59
+
60
+            if ( isset( $options['class_name'] ) ) {
61
+                // register widget
62
+                $this->class_name = $options['class_name'];
63
+
64
+                // register shortcode
65
+                $this->register_shortcode();
66
+
67
+                // Fusion Builder (avada) support
68
+                if ( function_exists( 'fusion_builder_map' ) ) {
69
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
70
+                }
71
+
72
+                // register block
73
+                add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
74
+            }
75
+
76
+            // add the CSS and JS we need ONCE
77
+            global $sd_widget_scripts;
78
+
79
+            if ( ! $sd_widget_scripts ) {
80
+                wp_add_inline_script( 'admin-widgets', $this->widget_js() );
81
+                wp_add_inline_script( 'customize-controls', $this->widget_js() );
82
+                wp_add_inline_style( 'widgets', $this->widget_css() );
83
+
84
+                // maybe add elementor editor styles
85
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
86
+
87
+                $sd_widget_scripts = true;
88
+
89
+                // add shortcode insert button once
90
+                add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
91
+                // generatepress theme sections compatibility
92
+                if ( function_exists( 'generate_sections_sections_metabox' ) ) {
93
+                    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
94
+                }
95
+                if ( $this->is_preview() ) {
96
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
97
+                    // this makes the insert button work for elementor
98
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
99
+                        $this,
100
+                        'shortcode_insert_button_script'
101
+                    ) ); // for elementor
102
+                }
103
+                // this makes the insert button work for cornerstone
104
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
105
+
106
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
107
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
108
+
109
+                // add generator text to admin head
110
+                add_action( 'admin_head', array( $this, 'generator' ) );
111
+            }
112
+
113
+            do_action( 'wp_super_duper_widget_init', $options, $this );
114
+        }
115
+
116
+        /**
117
+         * Add our widget CSS to elementor editor.
118
+         */
119
+        public function elementor_editor_styles() {
120
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
121
+        }
122
+
123
+        public function register_fusion_element() {
124
+
125
+            $options = $this->options;
126
+
127
+            if ( $this->base_id ) {
128
+
129
+                $params = $this->get_fusion_params();
130
+
131
+                $args = array(
132
+                    'name'            => $options['name'],
133
+                    'shortcode'       => $this->base_id,
134
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
135
+                    'allow_generator' => true,
136
+                );
137
+
138
+                if ( ! empty( $params ) ) {
139
+                    $args['params'] = $params;
140
+                }
141
+
142
+                fusion_builder_map( $args );
143
+            }
144
+
145
+        }
146
+
147
+        public function get_fusion_params() {
148
+            $params    = array();
149
+            $arguments = $this->get_arguments();
150
+
151
+            if ( ! empty( $arguments ) ) {
152
+                foreach ( $arguments as $key => $val ) {
153
+                    $param = array();
154
+                    // type
155
+                    $param['type'] = str_replace(
156
+                        array(
157
+                            "text",
158
+                            "number",
159
+                            "email",
160
+                            "color",
161
+                            "checkbox"
162
+                        ),
163
+                        array(
164
+                            "textfield",
165
+                            "textfield",
166
+                            "textfield",
167
+                            "colorpicker",
168
+                            "select",
169
+
170
+                        ),
171
+                        $val['type'] );
172
+
173
+                    // multiselect
174
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
175
+                        $param['type']     = 'multiple_select';
176
+                        $param['multiple'] = true;
177
+                    }
178
+
179
+                    // heading
180
+                    $param['heading'] = $val['title'];
181
+
182
+                    // description
183
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
184
+
185
+                    // param_name
186
+                    $param['param_name'] = $key;
187
+
188
+                    // Default
189
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
190
+
191
+                    // Group
192
+                    if ( isset( $val['group'] ) ) {
193
+                        $param['group'] = $val['group'];
194
+                    }
195
+
196
+                    // value
197
+                    if ( $val['type'] == 'checkbox' ) {
198
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
199
+                            unset( $param['default'] );
200
+                        }
201
+                        $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
202
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
203
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
204
+                    } else {
205
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
206
+                    }
207
+
208
+                    // setup the param
209
+                    $params[] = $param;
210
+
211
+                }
212
+            }
213
+
214
+
215
+            return $params;
216
+        }
217
+
218
+        /**
219
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
220
+         */
221
+        public static function maybe_cornerstone_builder() {
222
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
223
+                self::shortcode_insert_button_script();
224
+            }
225
+        }
226
+
227
+        /**
228
+         * A function to ge the shortcode builder picker html.
229
+         *
230
+         * @param string $editor_id
231
+         *
232
+         * @return string
233
+         */
234
+        public static function get_picker( $editor_id = '' ) {
235
+
236
+            ob_start();
237
+            if ( isset( $_POST['editor_id'] ) ) {
238
+                $editor_id = esc_attr( $_POST['editor_id'] );
239
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
240
+                $editor_id = 'main_content_content_vb_tiny_mce';
241
+            }
242
+
243
+            global $sd_widgets;
244
+            ?>
245 245
 
246 246
 			<div class="sd-shortcode-left-wrap">
247 247
 				<?php
248
-				ksort( $sd_widgets );
249
-				//				print_r($sd_widgets);exit;
250
-				if ( ! empty( $sd_widgets ) ) {
251
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
252
-					echo "<option>" . __( 'Select shortcode' ) . "</option>";
253
-					foreach ( $sd_widgets as $shortcode => $class ) {
254
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
255
-					}
256
-					echo "</select>";
257
-
258
-				}
259
-				?>
248
+                ksort( $sd_widgets );
249
+                //				print_r($sd_widgets);exit;
250
+                if ( ! empty( $sd_widgets ) ) {
251
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
252
+                    echo "<option>" . __( 'Select shortcode' ) . "</option>";
253
+                    foreach ( $sd_widgets as $shortcode => $class ) {
254
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
255
+                    }
256
+                    echo "</select>";
257
+
258
+                }
259
+                ?>
260 260
 				<div class="sd-shortcode-settings"></div>
261 261
 
262 262
 			</div>
@@ -267,8 +267,8 @@  discard block
 block discarded – undo
267 267
 					<?php if ( $editor_id != '' ) { ?>
268 268
 						<button class="button sd-insert-shortcode-button"
269 269
 						        onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
270
-							        echo "'" . $editor_id . "'";
271
-						        } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
270
+                                    echo "'" . $editor_id . "'";
271
+                                } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
272 272
 					<?php } ?>
273 273
 					<button class="button"
274 274
 					        onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -276,134 +276,134 @@  discard block
 block discarded – undo
276 276
 			</div>
277 277
 			<?php
278 278
 
279
-			$html = ob_get_clean();
280
-
281
-			if ( wp_doing_ajax() ) {
282
-				echo $html;
283
-				$should_die = true;
284
-
285
-				// some builder get the editor via ajax so we should not die on those ocasions
286
-				$dont_die = array(
287
-					'parent_tag',// WP Bakery
288
-					'avia_request' // enfold
289
-				);
290
-
291
-				foreach ( $dont_die as $request ) {
292
-					if ( isset( $_REQUEST[ $request ] ) ) {
293
-						$should_die = false;
294
-					}
295
-				}
296
-
297
-				if ( $should_die ) {
298
-					wp_die();
299
-				}
300
-
301
-			} else {
302
-				return $html;
303
-			}
304
-
305
-			return '';
306
-
307
-		}
308
-
309
-		/**
310
-		 * Output the version in the admin header.
311
-		 */
312
-		public function generator() {
313
-			echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
314
-		}
315
-
316
-		/**
317
-		 * Get widget settings.
318
-		 *
319
-		 * @since 1.0.0
320
-		 */
321
-		public static function get_widget_settings() {
322
-			global $sd_widgets;
323
-
324
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
325
-			if ( ! $shortcode ) {
326
-				wp_die();
327
-			}
328
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
329
-			if ( ! $widget_args ) {
330
-				wp_die();
331
-			}
332
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
333
-			if ( ! $class_name ) {
334
-				wp_die();
335
-			}
336
-
337
-			// invoke an instance method
338
-			$widget = new $class_name;
339
-
340
-			ob_start();
341
-			$widget->form( array() );
342
-			$form = ob_get_clean();
343
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
344
-			echo "<style>" . $widget->widget_css() . "</style>";
345
-			echo "<script>" . $widget->widget_js() . "</script>";
346
-			?>
279
+            $html = ob_get_clean();
280
+
281
+            if ( wp_doing_ajax() ) {
282
+                echo $html;
283
+                $should_die = true;
284
+
285
+                // some builder get the editor via ajax so we should not die on those ocasions
286
+                $dont_die = array(
287
+                    'parent_tag',// WP Bakery
288
+                    'avia_request' // enfold
289
+                );
290
+
291
+                foreach ( $dont_die as $request ) {
292
+                    if ( isset( $_REQUEST[ $request ] ) ) {
293
+                        $should_die = false;
294
+                    }
295
+                }
296
+
297
+                if ( $should_die ) {
298
+                    wp_die();
299
+                }
300
+
301
+            } else {
302
+                return $html;
303
+            }
304
+
305
+            return '';
306
+
307
+        }
308
+
309
+        /**
310
+         * Output the version in the admin header.
311
+         */
312
+        public function generator() {
313
+            echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
314
+        }
315
+
316
+        /**
317
+         * Get widget settings.
318
+         *
319
+         * @since 1.0.0
320
+         */
321
+        public static function get_widget_settings() {
322
+            global $sd_widgets;
323
+
324
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
325
+            if ( ! $shortcode ) {
326
+                wp_die();
327
+            }
328
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
329
+            if ( ! $widget_args ) {
330
+                wp_die();
331
+            }
332
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
333
+            if ( ! $class_name ) {
334
+                wp_die();
335
+            }
336
+
337
+            // invoke an instance method
338
+            $widget = new $class_name;
339
+
340
+            ob_start();
341
+            $widget->form( array() );
342
+            $form = ob_get_clean();
343
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
344
+            echo "<style>" . $widget->widget_css() . "</style>";
345
+            echo "<script>" . $widget->widget_js() . "</script>";
346
+            ?>
347 347
 			<?php
348
-			wp_die();
349
-		}
350
-
351
-		/**
352
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
353
-		 *
354
-		 * @since 1.0.0
355
-		 *
356
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
357
-		 * @param string $insert_shortcode_function Optional. Insert shotcode function. Default null.
358
-		 */
359
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
360
-			global $sd_widgets, $shortcode_insert_button_once;
361
-			if ( $shortcode_insert_button_once ) {
362
-				return;
363
-			}
364
-			add_thickbox();
365
-
366
-
367
-			/**
368
-			 * Cornerstone makes us play dirty tricks :/
369
-			 * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
370
-			 */
371
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
372
-				echo '<span id="insert-media-button">';
373
-			}
374
-
375
-			echo self::shortcode_button( 'this', 'true' );
376
-
377
-			// see opening note
378
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
379
-				echo '</span>'; // end #insert-media-button
380
-			}
381
-
382
-			// Add separate script for generatepress theme sections
383
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
384
-			} else {
385
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
386
-			}
387
-
388
-			$shortcode_insert_button_once = true;
389
-		}
390
-
391
-		/**
392
-		 * Gets the shortcode insert button html.
393
-		 *
394
-		 * @param string $id
395
-		 * @param string $search_for_id
396
-		 *
397
-		 * @return mixed
398
-		 */
399
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
400
-			ob_start();
401
-			?>
348
+            wp_die();
349
+        }
350
+
351
+        /**
352
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
353
+         *
354
+         * @since 1.0.0
355
+         *
356
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
357
+         * @param string $insert_shortcode_function Optional. Insert shotcode function. Default null.
358
+         */
359
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
360
+            global $sd_widgets, $shortcode_insert_button_once;
361
+            if ( $shortcode_insert_button_once ) {
362
+                return;
363
+            }
364
+            add_thickbox();
365
+
366
+
367
+            /**
368
+             * Cornerstone makes us play dirty tricks :/
369
+             * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
370
+             */
371
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
372
+                echo '<span id="insert-media-button">';
373
+            }
374
+
375
+            echo self::shortcode_button( 'this', 'true' );
376
+
377
+            // see opening note
378
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
379
+                echo '</span>'; // end #insert-media-button
380
+            }
381
+
382
+            // Add separate script for generatepress theme sections
383
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
384
+            } else {
385
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
386
+            }
387
+
388
+            $shortcode_insert_button_once = true;
389
+        }
390
+
391
+        /**
392
+         * Gets the shortcode insert button html.
393
+         *
394
+         * @param string $id
395
+         * @param string $search_for_id
396
+         *
397
+         * @return mixed
398
+         */
399
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
400
+            ob_start();
401
+            ?>
402 402
 			<span class="sd-lable-shortcode-inserter">
403 403
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
404
-				if ( $search_for_id ) {
405
-					echo "," . $search_for_id;
406
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
404
+                if ( $search_for_id ) {
405
+                    echo "," . $search_for_id;
406
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
407 407
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
408 408
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
409 409
 					      class="dashicons dashicons-screenoptions"></span>
@@ -414,21 +414,21 @@  discard block
 block discarded – undo
414 414
 			</span>
415 415
 
416 416
 			<?php
417
-			$html = ob_get_clean();
418
-
419
-			// remove line breaks so we can use it in js
420
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
421
-		}
422
-
423
-		/**
424
-		 * Makes SD work with the siteOrigin page builder.
425
-		 *
426
-		 * @since 1.0.6
427
-		 * @return mixed
428
-		 */
429
-		public static function siteorigin_js() {
430
-			ob_start();
431
-			?>
417
+            $html = ob_get_clean();
418
+
419
+            // remove line breaks so we can use it in js
420
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
421
+        }
422
+
423
+        /**
424
+         * Makes SD work with the siteOrigin page builder.
425
+         *
426
+         * @since 1.0.6
427
+         * @return mixed
428
+         */
429
+        public static function siteorigin_js() {
430
+            ob_start();
431
+            ?>
432 432
 			<script>
433 433
 				/**
434 434
 				 * Check a form to see what items shoudl be shown or hidden.
@@ -506,28 +506,28 @@  discard block
 block discarded – undo
506 506
 				});
507 507
 			</script>
508 508
 			<?php
509
-			$output = ob_get_clean();
509
+            $output = ob_get_clean();
510 510
 
511
-			/*
511
+            /*
512 512
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
513 513
 			 */
514 514
 
515
-			return str_replace( array(
516
-				'<script>',
517
-				'</script>'
518
-			), '', $output );
519
-		}
520
-
521
-		/**
522
-		 * Output the JS and CSS for the shortcode insert button.
523
-		 *
524
-		 * @since 1.0.6
525
-		 *
526
-		 * @param string $editor_id
527
-		 * @param string $insert_shortcode_function
528
-		 */
529
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
530
-			?>
515
+            return str_replace( array(
516
+                '<script>',
517
+                '</script>'
518
+            ), '', $output );
519
+        }
520
+
521
+        /**
522
+         * Output the JS and CSS for the shortcode insert button.
523
+         *
524
+         * @since 1.0.6
525
+         *
526
+         * @param string $editor_id
527
+         * @param string $insert_shortcode_function
528
+         */
529
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
530
+            ?>
531 531
 			<style>
532 532
 				.sd-shortcode-left-wrap {
533 533
 					float: left;
@@ -653,35 +653,35 @@  discard block
 block discarded – undo
653 653
 				<?php } ?>
654 654
 			</style>
655 655
 			<?php
656
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
657
-				echo "<script>" . self::siteorigin_js() . "</script>";
658
-			}
659
-			?>
656
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
657
+                echo "<script>" . self::siteorigin_js() . "</script>";
658
+            }
659
+            ?>
660 660
 			<script>
661 661
 				<?php
662
-				if(! empty( $insert_shortcode_function )){
663
-					echo $insert_shortcode_function;
664
-				}else{
665
-
666
-				/**
667
-				 * Function for super duper insert shortcode.
668
-				 *
669
-				 * @since 1.0.0
670
-				 */
671
-				?>
662
+                if(! empty( $insert_shortcode_function )){
663
+                    echo $insert_shortcode_function;
664
+                }else{
665
+
666
+                /**
667
+                 * Function for super duper insert shortcode.
668
+                 *
669
+                 * @since 1.0.0
670
+                 */
671
+                ?>
672 672
 				function sd_insert_shortcode($editor_id) {
673 673
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
674 674
 					if ($shortcode) {
675 675
 						if (!$editor_id) {
676 676
 							<?php
677
-							if ( isset( $_REQUEST['et_fb'] ) ) {
678
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
679
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
680
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
681
-							} else {
682
-								echo '$editor_id = "#wp-content-editor-container textarea";';
683
-							}
684
-							?>
677
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
678
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
679
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
680
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
681
+                            } else {
682
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
683
+                            }
684
+                            ?>
685 685
 						} else {
686 686
 							$editor_id = '#' + $editor_id;
687 687
 						}
@@ -1007,18 +1007,18 @@  discard block
 block discarded – undo
1007 1007
 
1008 1008
 			</script>
1009 1009
 			<?php
1010
-		}
1011
-
1012
-		/**
1013
-		 * Gets some CSS for the widgets screen.
1014
-		 *
1015
-		 * @param bool $advanced If we should include advanced CSS.
1016
-		 *
1017
-		 * @return mixed
1018
-		 */
1019
-		public function widget_css( $advanced = true ) {
1020
-			ob_start();
1021
-			?>
1010
+        }
1011
+
1012
+        /**
1013
+         * Gets some CSS for the widgets screen.
1014
+         *
1015
+         * @param bool $advanced If we should include advanced CSS.
1016
+         *
1017
+         * @return mixed
1018
+         */
1019
+        public function widget_css( $advanced = true ) {
1020
+            ob_start();
1021
+            ?>
1022 1022
 			<style>
1023 1023
 				<?php if( $advanced ){ ?>
1024 1024
 				.sd-advanced-setting {
@@ -1056,26 +1056,26 @@  discard block
 block discarded – undo
1056 1056
 				}
1057 1057
 			</style>
1058 1058
 			<?php
1059
-			$output = ob_get_clean();
1059
+            $output = ob_get_clean();
1060 1060
 
1061
-			/*
1061
+            /*
1062 1062
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1063 1063
 			 */
1064 1064
 
1065
-			return str_replace( array(
1066
-				'<style>',
1067
-				'</style>'
1068
-			), '', $output );
1069
-		}
1070
-
1071
-		/**
1072
-		 * Gets some JS for the widgets screen.
1073
-		 *
1074
-		 * @return mixed
1075
-		 */
1076
-		public function widget_js() {
1077
-			ob_start();
1078
-			?>
1065
+            return str_replace( array(
1066
+                '<style>',
1067
+                '</style>'
1068
+            ), '', $output );
1069
+        }
1070
+
1071
+        /**
1072
+         * Gets some JS for the widgets screen.
1073
+         *
1074
+         * @return mixed
1075
+         */
1076
+        public function widget_js() {
1077
+            ob_start();
1078
+            ?>
1079 1079
 			<script>
1080 1080
 
1081 1081
 				/**
@@ -1233,405 +1233,405 @@  discard block
 block discarded – undo
1233 1233
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1234 1234
 			</script>
1235 1235
 			<?php
1236
-			$output = ob_get_clean();
1236
+            $output = ob_get_clean();
1237 1237
 
1238
-			/*
1238
+            /*
1239 1239
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1240 1240
 			 */
1241 1241
 
1242
-			return str_replace( array(
1243
-				'<script>',
1244
-				'</script>'
1245
-			), '', $output );
1246
-		}
1247
-
1248
-
1249
-		/**
1250
-		 * Set the name from the argument key.
1251
-		 *
1252
-		 * @param $options
1253
-		 *
1254
-		 * @return mixed
1255
-		 */
1256
-		private function add_name_from_key( $options, $arguments = false ) {
1257
-			if ( ! empty( $options['arguments'] ) ) {
1258
-				foreach ( $options['arguments'] as $key => $val ) {
1259
-					$options['arguments'][ $key ]['name'] = $key;
1260
-				}
1261
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1262
-				foreach ( $options as $key => $val ) {
1263
-					$options[ $key ]['name'] = $key;
1264
-				}
1265
-			}
1266
-
1267
-			return $options;
1268
-		}
1269
-
1270
-		/**
1271
-		 * Register the parent shortcode.
1272
-		 *
1273
-		 * @since 1.0.0
1274
-		 */
1275
-		public function register_shortcode() {
1276
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1277
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) );
1278
-		}
1279
-
1280
-		/**
1281
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1282
-		 *
1283
-		 * @since 1.0.0
1284
-		 */
1285
-		public static function render_shortcode() {
1286
-
1287
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1288
-			if ( ! current_user_can( 'manage_options' ) ) {
1289
-				wp_die();
1290
-			}
1291
-
1292
-			// we might need the $post value here so lets set it.
1293
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1294
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1295
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1296
-					global $post;
1297
-					$post = $post_obj;
1298
-				}
1299
-			}
1300
-
1301
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1302
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1303
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1304
-				$attributes       = '';
1305
-				if ( ! empty( $attributes_array ) ) {
1306
-					foreach ( $attributes_array as $key => $value ) {
1307
-						if ( is_array( $value ) ) {
1308
-							$value = implode( ",", $value );
1309
-						}
1310
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' ";
1311
-					}
1312
-				}
1313
-
1314
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1315
-
1316
-				echo do_shortcode( $shortcode );
1317
-
1318
-			}
1319
-			wp_die();
1320
-		}
1321
-
1322
-		/**
1323
-		 * Output the shortcode.
1324
-		 *
1325
-		 * @param array $args
1326
-		 * @param string $content
1327
-		 *
1328
-		 * @return string
1329
-		 */
1330
-		public function shortcode_output( $args = array(), $content = '' ) {
1331
-			$args = $this->argument_values( $args );
1332
-
1333
-			// add extra argument so we know its a output to gutenberg
1334
-			//$args
1335
-			$args = $this->string_to_bool( $args );
1336
-
1337
-			// if we have a enclosed shortcode we add it to the special `html` argument
1338
-			if ( ! empty( $content ) ) {
1339
-				$args['html'] = $content;
1340
-			}
1341
-
1342
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1343
-			$class .= " sdel-".$this->get_instance_hash();
1344
-
1345
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1346
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1347
-
1348
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1349
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran?
1350
-
1351
-			$shortcode_args = array();
1352
-			$output         = '';
1353
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1354
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1355
-				$no_wrap = true;
1356
-			}
1357
-			$main_content = $this->output( $args, $shortcode_args, $content );
1358
-			if ( $main_content && ! $no_wrap ) {
1359
-				// wrap the shortcode in a div with the same class as the widget
1360
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1361
-				if ( ! empty( $args['title'] ) ) {
1362
-					// if its a shortcode and there is a title try to grab the title wrappers
1363
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1364
-					if ( empty( $instance ) ) {
1365
-						global $wp_registered_sidebars;
1366
-						if ( ! empty( $wp_registered_sidebars ) ) {
1367
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1368
-								if ( ! empty( $sidebar['before_title'] ) ) {
1369
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1370
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1371
-									break;
1372
-								}
1373
-							}
1374
-						}
1375
-					}
1376
-					$output .= $this->output_title( $shortcode_args, $args );
1377
-				}
1378
-				$output .= $main_content;
1379
-				$output .= '</div>';
1380
-			} elseif ( $main_content && $no_wrap ) {
1381
-				$output .= $main_content;
1382
-			}
1383
-
1384
-			// if preview show a placeholder if empty
1385
-			if ( $this->is_preview() && $output == '' ) {
1386
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1387
-			}
1388
-
1389
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1390
-		}
1391
-
1392
-		/**
1393
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1394
-		 *
1395
-		 * @param string $name
1396
-		 *
1397
-		 * @return string
1398
-		 */
1399
-		public function preview_placeholder_text( $name = '' ) {
1400
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1401
-		}
1402
-
1403
-		/**
1404
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1405
-		 *
1406
-		 * @param $options
1407
-		 *
1408
-		 * @return mixed
1409
-		 */
1410
-		public function string_to_bool( $options ) {
1411
-			// convert bool strings to booleans
1412
-			foreach ( $options as $key => $val ) {
1413
-				if ( $val == 'false' ) {
1414
-					$options[ $key ] = false;
1415
-				} elseif ( $val == 'true' ) {
1416
-					$options[ $key ] = true;
1417
-				}
1418
-			}
1419
-
1420
-			return $options;
1421
-		}
1422
-
1423
-		/**
1424
-		 * Get the argument values that are also filterable.
1425
-		 *
1426
-		 * @param $instance
1427
-		 *
1428
-		 * @since 1.0.12 Don't set checkbox default value if the value is empty.
1429
-		 *
1430
-		 * @return array
1431
-		 */
1432
-		public function argument_values( $instance ) {
1433
-			$argument_values = array();
1434
-
1435
-			// set widget instance
1436
-			$this->instance = $instance;
1437
-
1438
-			if ( empty( $this->arguments ) ) {
1439
-				$this->arguments = $this->get_arguments();
1440
-			}
1441
-
1442
-			if ( ! empty( $this->arguments ) ) {
1443
-				foreach ( $this->arguments as $key => $args ) {
1444
-					// set the input name from the key
1445
-					$args['name'] = $key;
1446
-					//
1447
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1448
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1449
-						// don't set default for an empty checkbox
1450
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1451
-						$argument_values[ $key ] = $args['default'];
1452
-					}
1453
-				}
1454
-			}
1455
-
1456
-			return $argument_values;
1457
-		}
1458
-
1459
-		/**
1460
-		 * Set arguments in super duper.
1461
-		 *
1462
-		 * @since 1.0.0
1463
-		 *
1464
-		 * @return array Set arguments.
1465
-		 */
1466
-		public function set_arguments() {
1467
-			return $this->arguments;
1468
-		}
1469
-
1470
-		/**
1471
-		 * Get arguments in super duper.
1472
-		 *
1473
-		 * @since 1.0.0
1474
-		 *
1475
-		 * @return array Get arguments.
1476
-		 */
1477
-		public function get_arguments() {
1478
-			if ( empty( $this->arguments ) ) {
1479
-				$this->arguments = $this->set_arguments();
1480
-			}
1481
-
1482
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1483
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1484
-
1485
-			return $this->arguments;
1486
-		}
1487
-
1488
-		/**
1489
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1490
-		 *
1491
-		 * @param array $args
1492
-		 * @param array $widget_args
1493
-		 * @param string $content
1494
-		 */
1495
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1496
-
1497
-		}
1498
-
1499
-		/**
1500
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1501
-		 */
1502
-		public function register_block() {
1503
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1504
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1505
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1506
-			}
1507
-		}
1508
-
1509
-		/**
1510
-		 * Check if we need to show advanced options.
1511
-		 *
1512
-		 * @return bool
1513
-		 */
1514
-		public function block_show_advanced() {
1515
-
1516
-			$show      = false;
1517
-			$arguments = $this->arguments;
1518
-
1519
-			if ( empty( $arguments ) ) {
1520
-				$arguments = $this->get_arguments();
1521
-			}
1522
-
1523
-			if ( ! empty( $arguments ) ) {
1524
-				foreach ( $arguments as $argument ) {
1525
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1526
-						$show = true;
1527
-						break; // no need to continue if we know we have it
1528
-					}
1529
-				}
1530
-			}
1531
-
1532
-			return $show;
1533
-		}
1534
-
1535
-		/**
1536
-		 * Get the url path to the current folder.
1537
-		 *
1538
-		 * @return string
1539
-		 */
1540
-		public function get_url() {
1541
-
1542
-			$url = $this->url;
1543
-
1544
-			if ( ! $url ) {
1545
-				// check if we are inside a plugin
1546
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1547
-
1548
-				$dir_parts = explode( "/wp-content/", $file_dir );
1549
-				$url_parts = explode( "/wp-content/", plugins_url() );
1550
-
1551
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1552
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1553
-					$this->url = $url;
1554
-				}
1555
-			}
1556
-
1557
-
1558
-			return $url;
1559
-		}
1560
-
1561
-		/**
1562
-		 * Generate the block icon.
1563
-		 *
1564
-		 * Enables the use of Font Awesome icons.
1565
-		 *
1566
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1567
-		 *
1568
-		 * @param $icon
1569
-		 *
1570
-		 * @since 1.1.0
1571
-		 * @return string
1572
-		 */
1573
-		public function get_block_icon( $icon ) {
1574
-
1575
-			// check if we have a Font Awesome icon
1576
-			$fa_type = '';
1577
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1578
-				$fa_type = 'solid';
1579
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1580
-				$fa_type = 'regular';
1581
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1582
-				$fa_type = 'brands';
1583
-			} else {
1584
-				$icon = "'" . $icon . "'";
1585
-			}
1586
-
1587
-			// set the icon if we found one
1588
-			if ( $fa_type ) {
1589
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1590
-				$icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1591
-			}
1592
-
1593
-			return $icon;
1594
-		}
1595
-
1596
-		public function group_arguments( $arguments ) {
1242
+            return str_replace( array(
1243
+                '<script>',
1244
+                '</script>'
1245
+            ), '', $output );
1246
+        }
1247
+
1248
+
1249
+        /**
1250
+         * Set the name from the argument key.
1251
+         *
1252
+         * @param $options
1253
+         *
1254
+         * @return mixed
1255
+         */
1256
+        private function add_name_from_key( $options, $arguments = false ) {
1257
+            if ( ! empty( $options['arguments'] ) ) {
1258
+                foreach ( $options['arguments'] as $key => $val ) {
1259
+                    $options['arguments'][ $key ]['name'] = $key;
1260
+                }
1261
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1262
+                foreach ( $options as $key => $val ) {
1263
+                    $options[ $key ]['name'] = $key;
1264
+                }
1265
+            }
1266
+
1267
+            return $options;
1268
+        }
1269
+
1270
+        /**
1271
+         * Register the parent shortcode.
1272
+         *
1273
+         * @since 1.0.0
1274
+         */
1275
+        public function register_shortcode() {
1276
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1277
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) );
1278
+        }
1279
+
1280
+        /**
1281
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1282
+         *
1283
+         * @since 1.0.0
1284
+         */
1285
+        public static function render_shortcode() {
1286
+
1287
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1288
+            if ( ! current_user_can( 'manage_options' ) ) {
1289
+                wp_die();
1290
+            }
1291
+
1292
+            // we might need the $post value here so lets set it.
1293
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1294
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1295
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1296
+                    global $post;
1297
+                    $post = $post_obj;
1298
+                }
1299
+            }
1300
+
1301
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1302
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1303
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1304
+                $attributes       = '';
1305
+                if ( ! empty( $attributes_array ) ) {
1306
+                    foreach ( $attributes_array as $key => $value ) {
1307
+                        if ( is_array( $value ) ) {
1308
+                            $value = implode( ",", $value );
1309
+                        }
1310
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' ";
1311
+                    }
1312
+                }
1313
+
1314
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1315
+
1316
+                echo do_shortcode( $shortcode );
1317
+
1318
+            }
1319
+            wp_die();
1320
+        }
1321
+
1322
+        /**
1323
+         * Output the shortcode.
1324
+         *
1325
+         * @param array $args
1326
+         * @param string $content
1327
+         *
1328
+         * @return string
1329
+         */
1330
+        public function shortcode_output( $args = array(), $content = '' ) {
1331
+            $args = $this->argument_values( $args );
1332
+
1333
+            // add extra argument so we know its a output to gutenberg
1334
+            //$args
1335
+            $args = $this->string_to_bool( $args );
1336
+
1337
+            // if we have a enclosed shortcode we add it to the special `html` argument
1338
+            if ( ! empty( $content ) ) {
1339
+                $args['html'] = $content;
1340
+            }
1341
+
1342
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1343
+            $class .= " sdel-".$this->get_instance_hash();
1344
+
1345
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1346
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1347
+
1348
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1349
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran?
1350
+
1351
+            $shortcode_args = array();
1352
+            $output         = '';
1353
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1354
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1355
+                $no_wrap = true;
1356
+            }
1357
+            $main_content = $this->output( $args, $shortcode_args, $content );
1358
+            if ( $main_content && ! $no_wrap ) {
1359
+                // wrap the shortcode in a div with the same class as the widget
1360
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1361
+                if ( ! empty( $args['title'] ) ) {
1362
+                    // if its a shortcode and there is a title try to grab the title wrappers
1363
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1364
+                    if ( empty( $instance ) ) {
1365
+                        global $wp_registered_sidebars;
1366
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1367
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1368
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1369
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1370
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1371
+                                    break;
1372
+                                }
1373
+                            }
1374
+                        }
1375
+                    }
1376
+                    $output .= $this->output_title( $shortcode_args, $args );
1377
+                }
1378
+                $output .= $main_content;
1379
+                $output .= '</div>';
1380
+            } elseif ( $main_content && $no_wrap ) {
1381
+                $output .= $main_content;
1382
+            }
1383
+
1384
+            // if preview show a placeholder if empty
1385
+            if ( $this->is_preview() && $output == '' ) {
1386
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1387
+            }
1388
+
1389
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1390
+        }
1391
+
1392
+        /**
1393
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1394
+         *
1395
+         * @param string $name
1396
+         *
1397
+         * @return string
1398
+         */
1399
+        public function preview_placeholder_text( $name = '' ) {
1400
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1401
+        }
1402
+
1403
+        /**
1404
+         * Sometimes booleans values can be turned to strings, so we fix that.
1405
+         *
1406
+         * @param $options
1407
+         *
1408
+         * @return mixed
1409
+         */
1410
+        public function string_to_bool( $options ) {
1411
+            // convert bool strings to booleans
1412
+            foreach ( $options as $key => $val ) {
1413
+                if ( $val == 'false' ) {
1414
+                    $options[ $key ] = false;
1415
+                } elseif ( $val == 'true' ) {
1416
+                    $options[ $key ] = true;
1417
+                }
1418
+            }
1419
+
1420
+            return $options;
1421
+        }
1422
+
1423
+        /**
1424
+         * Get the argument values that are also filterable.
1425
+         *
1426
+         * @param $instance
1427
+         *
1428
+         * @since 1.0.12 Don't set checkbox default value if the value is empty.
1429
+         *
1430
+         * @return array
1431
+         */
1432
+        public function argument_values( $instance ) {
1433
+            $argument_values = array();
1434
+
1435
+            // set widget instance
1436
+            $this->instance = $instance;
1437
+
1438
+            if ( empty( $this->arguments ) ) {
1439
+                $this->arguments = $this->get_arguments();
1440
+            }
1441
+
1442
+            if ( ! empty( $this->arguments ) ) {
1443
+                foreach ( $this->arguments as $key => $args ) {
1444
+                    // set the input name from the key
1445
+                    $args['name'] = $key;
1446
+                    //
1447
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1448
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1449
+                        // don't set default for an empty checkbox
1450
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1451
+                        $argument_values[ $key ] = $args['default'];
1452
+                    }
1453
+                }
1454
+            }
1455
+
1456
+            return $argument_values;
1457
+        }
1458
+
1459
+        /**
1460
+         * Set arguments in super duper.
1461
+         *
1462
+         * @since 1.0.0
1463
+         *
1464
+         * @return array Set arguments.
1465
+         */
1466
+        public function set_arguments() {
1467
+            return $this->arguments;
1468
+        }
1469
+
1470
+        /**
1471
+         * Get arguments in super duper.
1472
+         *
1473
+         * @since 1.0.0
1474
+         *
1475
+         * @return array Get arguments.
1476
+         */
1477
+        public function get_arguments() {
1478
+            if ( empty( $this->arguments ) ) {
1479
+                $this->arguments = $this->set_arguments();
1480
+            }
1481
+
1482
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1483
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1484
+
1485
+            return $this->arguments;
1486
+        }
1487
+
1488
+        /**
1489
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1490
+         *
1491
+         * @param array $args
1492
+         * @param array $widget_args
1493
+         * @param string $content
1494
+         */
1495
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1496
+
1497
+        }
1498
+
1499
+        /**
1500
+         * Add the dynamic block code inline when the wp-block in enqueued.
1501
+         */
1502
+        public function register_block() {
1503
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1504
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1505
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1506
+            }
1507
+        }
1508
+
1509
+        /**
1510
+         * Check if we need to show advanced options.
1511
+         *
1512
+         * @return bool
1513
+         */
1514
+        public function block_show_advanced() {
1515
+
1516
+            $show      = false;
1517
+            $arguments = $this->arguments;
1518
+
1519
+            if ( empty( $arguments ) ) {
1520
+                $arguments = $this->get_arguments();
1521
+            }
1522
+
1523
+            if ( ! empty( $arguments ) ) {
1524
+                foreach ( $arguments as $argument ) {
1525
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1526
+                        $show = true;
1527
+                        break; // no need to continue if we know we have it
1528
+                    }
1529
+                }
1530
+            }
1531
+
1532
+            return $show;
1533
+        }
1534
+
1535
+        /**
1536
+         * Get the url path to the current folder.
1537
+         *
1538
+         * @return string
1539
+         */
1540
+        public function get_url() {
1541
+
1542
+            $url = $this->url;
1543
+
1544
+            if ( ! $url ) {
1545
+                // check if we are inside a plugin
1546
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1547
+
1548
+                $dir_parts = explode( "/wp-content/", $file_dir );
1549
+                $url_parts = explode( "/wp-content/", plugins_url() );
1550
+
1551
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1552
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1553
+                    $this->url = $url;
1554
+                }
1555
+            }
1556
+
1557
+
1558
+            return $url;
1559
+        }
1560
+
1561
+        /**
1562
+         * Generate the block icon.
1563
+         *
1564
+         * Enables the use of Font Awesome icons.
1565
+         *
1566
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1567
+         *
1568
+         * @param $icon
1569
+         *
1570
+         * @since 1.1.0
1571
+         * @return string
1572
+         */
1573
+        public function get_block_icon( $icon ) {
1574
+
1575
+            // check if we have a Font Awesome icon
1576
+            $fa_type = '';
1577
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1578
+                $fa_type = 'solid';
1579
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1580
+                $fa_type = 'regular';
1581
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1582
+                $fa_type = 'brands';
1583
+            } else {
1584
+                $icon = "'" . $icon . "'";
1585
+            }
1586
+
1587
+            // set the icon if we found one
1588
+            if ( $fa_type ) {
1589
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1590
+                $icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1591
+            }
1592
+
1593
+            return $icon;
1594
+        }
1595
+
1596
+        public function group_arguments( $arguments ) {
1597 1597
 //			echo '###';print_r($arguments);
1598
-			if ( ! empty( $arguments ) ) {
1599
-				$temp_arguments = array();
1600
-				$general        = __( "General" );
1601
-				$add_sections   = false;
1602
-				foreach ( $arguments as $key => $args ) {
1603
-					if ( isset( $args['group'] ) ) {
1604
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1605
-						$add_sections                             = true;
1606
-					} else {
1607
-						$temp_arguments[ $general ][ $key ] = $args;
1608
-					}
1609
-				}
1610
-
1611
-				// only add sections if more than one
1612
-				if ( $add_sections ) {
1613
-					$arguments = $temp_arguments;
1614
-				}
1615
-			}
1598
+            if ( ! empty( $arguments ) ) {
1599
+                $temp_arguments = array();
1600
+                $general        = __( "General" );
1601
+                $add_sections   = false;
1602
+                foreach ( $arguments as $key => $args ) {
1603
+                    if ( isset( $args['group'] ) ) {
1604
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1605
+                        $add_sections                             = true;
1606
+                    } else {
1607
+                        $temp_arguments[ $general ][ $key ] = $args;
1608
+                    }
1609
+                }
1610
+
1611
+                // only add sections if more than one
1612
+                if ( $add_sections ) {
1613
+                    $arguments = $temp_arguments;
1614
+                }
1615
+            }
1616 1616
 
1617 1617
 //			echo '###';print_r($arguments);
1618
-			return $arguments;
1619
-		}
1620
-
1621
-
1622
-		/**
1623
-		 * Output the JS for building the dynamic Guntenberg block.
1624
-		 *
1625
-		 * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap.
1626
-		 * @since 1.0.9 Save numbers as numbers and not strings.
1627
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1628
-		 * @return mixed
1629
-		 */
1630
-		public function block() {
1631
-			ob_start();
1632
-
1633
-			$show_advanced = $this->block_show_advanced();
1634
-			?>
1618
+            return $arguments;
1619
+        }
1620
+
1621
+
1622
+        /**
1623
+         * Output the JS for building the dynamic Guntenberg block.
1624
+         *
1625
+         * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap.
1626
+         * @since 1.0.9 Save numbers as numbers and not strings.
1627
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1628
+         * @return mixed
1629
+         */
1630
+        public function block() {
1631
+            ob_start();
1632
+
1633
+            $show_advanced = $this->block_show_advanced();
1634
+            ?>
1635 1635
 			<script>
1636 1636
 				/**
1637 1637
 				 * BLOCK: Basic
@@ -1675,97 +1675,97 @@  discard block
 block discarded – undo
1675 1675
 						icon: <?php echo $this->get_block_icon( $this->options['block-icon'] );?>,//'<?php echo isset( $this->options['block-icon'] ) ? esc_attr( $this->options['block-icon'] ) : 'shield-alt';?>', // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/.
1676 1676
 						supports: {
1677 1677
 							<?php
1678
-							if ( isset( $this->options['block-supports'] ) ) {
1679
-								echo $this->array_to_attributes( $this->options['block-supports'] );
1680
-							}
1681
-							?>
1678
+                            if ( isset( $this->options['block-supports'] ) ) {
1679
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
1680
+                            }
1681
+                            ?>
1682 1682
 						},
1683 1683
 						category: '<?php echo isset( $this->options['block-category'] ) ? esc_attr( $this->options['block-category'] ) : 'common';?>', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed.
1684 1684
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
1685
-						echo "keywords : " . $this->options['block-keywords'] . ",";
1686
-					}?>
1685
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
1686
+                    }?>
1687 1687
 
1688 1688
 						<?php
1689 1689
 
1690
-						// maybe set no_wrap
1691
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1692
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1693
-							$no_wrap = true;
1694
-						}
1695
-						if ( $no_wrap ) {
1696
-							$this->options['block-wrap'] = '';
1697
-						}
1690
+                        // maybe set no_wrap
1691
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1692
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1693
+                            $no_wrap = true;
1694
+                        }
1695
+                        if ( $no_wrap ) {
1696
+                            $this->options['block-wrap'] = '';
1697
+                        }
1698 1698
 
1699 1699
 
1700 1700
 
1701
-						$show_alignment = false;
1702
-						// align feature
1703
-						/*echo "supports: {";
1701
+                        $show_alignment = false;
1702
+                        // align feature
1703
+                        /*echo "supports: {";
1704 1704
 						echo "	align: true,";
1705 1705
 						echo "  html: false";
1706 1706
 						echo "},";*/
1707 1707
 
1708
-						if ( ! empty( $this->arguments ) ) {
1709
-							echo "attributes : {";
1710
-
1711
-							if ( $show_advanced ) {
1712
-								echo "show_advanced: {";
1713
-								echo "	type: 'boolean',";
1714
-								echo "  default: false,";
1715
-								echo "},";
1716
-							}
1717
-
1718
-							// block wrap element
1719
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1720
-								echo "block_wrap: {";
1721
-								echo "	type: 'string',";
1722
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1723
-								echo "},";
1724
-							}
1725
-
1726
-							foreach ( $this->arguments as $key => $args ) {
1727
-
1728
-								// set if we should show alignment
1729
-								if ( $key == 'alignment' ) {
1730
-									$show_alignment = true;
1731
-								}
1732
-
1733
-								$extra = '';
1734
-
1735
-								if ( $args['type'] == 'checkbox' ) {
1736
-									$type    = 'boolean';
1737
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1738
-								} elseif ( $args['type'] == 'number' ) {
1739
-									$type    = 'number';
1740
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1741
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1742
-									$type = 'array';
1743
-									if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
1744
-										$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1745
-									} else {
1746
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1747
-									}
1748
-								} elseif ( $args['type'] == 'multiselect' ) {
1749
-									$type    = 'array';
1750
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1751
-								} else {
1752
-									$type    = 'string';
1753
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1754
-								}
1755
-								echo $key . " : {";
1756
-								echo "type : '$type',";
1757
-								echo "default : $default,";
1758
-								echo "},";
1759
-							}
1760
-
1761
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1762
-							echo "className: { type: 'string', default: '' },";
1763
-
1764
-							echo "},";
1765
-
1766
-						}
1767
-
1768
-						?>
1708
+                        if ( ! empty( $this->arguments ) ) {
1709
+                            echo "attributes : {";
1710
+
1711
+                            if ( $show_advanced ) {
1712
+                                echo "show_advanced: {";
1713
+                                echo "	type: 'boolean',";
1714
+                                echo "  default: false,";
1715
+                                echo "},";
1716
+                            }
1717
+
1718
+                            // block wrap element
1719
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1720
+                                echo "block_wrap: {";
1721
+                                echo "	type: 'string',";
1722
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1723
+                                echo "},";
1724
+                            }
1725
+
1726
+                            foreach ( $this->arguments as $key => $args ) {
1727
+
1728
+                                // set if we should show alignment
1729
+                                if ( $key == 'alignment' ) {
1730
+                                    $show_alignment = true;
1731
+                                }
1732
+
1733
+                                $extra = '';
1734
+
1735
+                                if ( $args['type'] == 'checkbox' ) {
1736
+                                    $type    = 'boolean';
1737
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1738
+                                } elseif ( $args['type'] == 'number' ) {
1739
+                                    $type    = 'number';
1740
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1741
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1742
+                                    $type = 'array';
1743
+                                    if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
1744
+                                        $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1745
+                                    } else {
1746
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1747
+                                    }
1748
+                                } elseif ( $args['type'] == 'multiselect' ) {
1749
+                                    $type    = 'array';
1750
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1751
+                                } else {
1752
+                                    $type    = 'string';
1753
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1754
+                                }
1755
+                                echo $key . " : {";
1756
+                                echo "type : '$type',";
1757
+                                echo "default : $default,";
1758
+                                echo "},";
1759
+                            }
1760
+
1761
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1762
+                            echo "className: { type: 'string', default: '' },";
1763
+
1764
+                            echo "},";
1765
+
1766
+                        }
1767
+
1768
+                        ?>
1769 1769
 
1770 1770
 						// The "edit" property must be a valid function.
1771 1771
 						edit: function (props) {
@@ -1773,9 +1773,9 @@  discard block
 block discarded – undo
1773 1773
 
1774 1774
 							var $value = '';
1775 1775
 							<?php
1776
-							// if we have a post_type and a category then link them
1777
-							if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1778
-							?>
1776
+                            // if we have a post_type and a category then link them
1777
+                            if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1778
+                            ?>
1779 1779
 							if(typeof(prev_attributes[props.id]) != 'undefined' ){
1780 1780
 								$pt = props.attributes.post_type;
1781 1781
 								if(post_type_rest_slugs.length){
@@ -1859,8 +1859,8 @@  discard block
 block discarded – undo
1859 1859
 										'shortcode': '<?php echo $this->options['base_id'];?>',
1860 1860
 										'attributes': props.attributes,
1861 1861
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
1862
-										echo $post->ID;
1863
-									}else{echo '0';}?>,
1862
+                                        echo $post->ID;
1863
+                                    }else{echo '0';}?>,
1864 1864
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
1865 1865
 									};
1866 1866
 
@@ -1912,10 +1912,10 @@  discard block
 block discarded – undo
1912 1912
 
1913 1913
 									<?php
1914 1914
 
1915
-									if(! empty( $this->arguments )){
1915
+                                    if(! empty( $this->arguments )){
1916 1916
 
1917
-									if ( $show_advanced ) {
1918
-									?>
1917
+                                    if ( $show_advanced ) {
1918
+                                    ?>
1919 1919
 									el('div', {
1920 1920
 											style: {'padding-left': '16px','padding-right': '16px'}
1921 1921
 										},
@@ -1933,79 +1933,79 @@  discard block
 block discarded – undo
1933 1933
 									,
1934 1934
 									<?php
1935 1935
 
1936
-									}
1936
+                                    }
1937 1937
 
1938
-									$arguments = $this->group_arguments( $this->arguments );
1938
+                                    $arguments = $this->group_arguments( $this->arguments );
1939 1939
 
1940
-									// Do we have sections?
1941
-									$has_sections = $arguments == $this->arguments ? false : true;
1940
+                                    // Do we have sections?
1941
+                                    $has_sections = $arguments == $this->arguments ? false : true;
1942 1942
 
1943 1943
 
1944
-									if($has_sections){
1945
-									$panel_count = 0;
1946
-									foreach($arguments as $key => $args){
1947
-									?>
1944
+                                    if($has_sections){
1945
+                                    $panel_count = 0;
1946
+                                    foreach($arguments as $key => $args){
1947
+                                    ?>
1948 1948
 									el(wp.components.PanelBody, {
1949 1949
 											title: '<?php esc_attr_e( $key ); ?>',
1950 1950
 											initialOpen: <?php if ( $panel_count ) {
1951
-											echo "false";
1952
-										} else {
1953
-											echo "true";
1954
-										}?>
1951
+                                            echo "false";
1952
+                                        } else {
1953
+                                            echo "true";
1954
+                                        }?>
1955 1955
 										},
1956 1956
 										<?php
1957 1957
 
1958 1958
 
1959 1959
 
1960
-										foreach ( $args as $k => $a ) {
1960
+                                        foreach ( $args as $k => $a ) {
1961 1961
 
1962
-											$this->block_row_start( $k, $a );
1963
-											$this->build_block_arguments( $k, $a );
1964
-											$this->block_row_end( $k, $a );
1965
-										}
1966
-										?>
1962
+                                            $this->block_row_start( $k, $a );
1963
+                                            $this->build_block_arguments( $k, $a );
1964
+                                            $this->block_row_end( $k, $a );
1965
+                                        }
1966
+                                        ?>
1967 1967
 									),
1968 1968
 									<?php
1969
-									$panel_count ++;
1969
+                                    $panel_count ++;
1970 1970
 
1971
-									}
1972
-									}else {
1973
-									?>
1971
+                                    }
1972
+                                    }else {
1973
+                                    ?>
1974 1974
 									el(wp.components.PanelBody, {
1975 1975
 											title: '<?php esc_attr_e( "Settings" ); ?>',
1976 1976
 											initialOpen: true
1977 1977
 										},
1978 1978
 										<?php
1979
-										foreach ( $this->arguments as $key => $args ) {
1980
-											$this->block_row_start( $key, $args );
1981
-											$this->build_block_arguments( $key, $args );
1982
-											$this->block_row_end( $key, $args );
1983
-										}
1984
-										?>
1979
+                                        foreach ( $this->arguments as $key => $args ) {
1980
+                                            $this->block_row_start( $key, $args );
1981
+                                            $this->build_block_arguments( $key, $args );
1982
+                                            $this->block_row_end( $key, $args );
1983
+                                        }
1984
+                                        ?>
1985 1985
 									),
1986 1986
 									<?php
1987
-									}
1987
+                                    }
1988 1988
 
1989
-									}
1990
-									?>
1989
+                                    }
1990
+                                    ?>
1991 1991
 
1992 1992
 								),
1993 1993
 
1994 1994
 								<?php
1995
-								// If the user sets block-output array then build it
1996
-								if ( ! empty( $this->options['block-output'] ) ) {
1997
-								$this->block_element( $this->options['block-output'] );
1998
-							}else{
1999
-								// if no block-output is set then we try and get the shortcode html output via ajax.
2000
-								?>
1995
+                                // If the user sets block-output array then build it
1996
+                                if ( ! empty( $this->options['block-output'] ) ) {
1997
+                                $this->block_element( $this->options['block-output'] );
1998
+                            }else{
1999
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
2000
+                                ?>
2001 2001
 								el('div', {
2002 2002
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
2003 2003
 									className: props.className,
2004 2004
 									style: {'minHeight': '30px'}
2005 2005
 								})
2006 2006
 								<?php
2007
-								}
2008
-								?>
2007
+                                }
2008
+                                ?>
2009 2009
 							]; // end return
2010 2010
 						},
2011 2011
 
@@ -2023,10 +2023,10 @@  discard block
 block discarded – undo
2023 2023
 							$html = '';
2024 2024
 							<?php
2025 2025
 
2026
-							if(! empty( $this->arguments )){
2026
+                            if(! empty( $this->arguments )){
2027 2027
 
2028
-							foreach($this->arguments as $key => $args){
2029
-							?>
2028
+                            foreach($this->arguments as $key => $args){
2029
+                            ?>
2030 2030
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2031 2031
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
2032 2032
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -2035,10 +2035,10 @@  discard block
 block discarded – undo
2035 2035
 								}
2036 2036
 							}
2037 2037
 							<?php
2038
-							}
2039
-							}
2038
+                            }
2039
+                            }
2040 2040
 
2041
-							?>
2041
+                            ?>
2042 2042
 							content += "]";
2043 2043
 
2044 2044
 							// if has html element
@@ -2061,20 +2061,20 @@  discard block
 block discarded – undo
2061 2061
 							}
2062 2062
 
2063 2063
 							<?php
2064
-							if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2065
-							?>
2064
+                            if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2065
+                            ?>
2066 2066
 							return content;
2067 2067
 							<?php
2068
-							}else{
2069
-							?>
2068
+                            }else{
2069
+                            ?>
2070 2070
 							var block_wrap = 'div';
2071 2071
 							if (attr.hasOwnProperty("block_wrap")) {
2072 2072
 								block_wrap = attr.block_wrap;
2073 2073
 							}
2074 2074
 							return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align});
2075 2075
 							<?php
2076
-							}
2077
-							?>
2076
+                            }
2077
+                            ?>
2078 2078
 
2079 2079
 
2080 2080
 						}
@@ -2082,30 +2082,30 @@  discard block
 block discarded – undo
2082 2082
 				})();
2083 2083
 			</script>
2084 2084
 			<?php
2085
-			$output = ob_get_clean();
2085
+            $output = ob_get_clean();
2086 2086
 
2087
-			/*
2087
+            /*
2088 2088
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
2089 2089
 			 */
2090 2090
 
2091
-			return str_replace( array(
2092
-				'<script>',
2093
-				'</script>'
2094
-			), '', $output );
2095
-		}
2091
+            return str_replace( array(
2092
+                '<script>',
2093
+                '</script>'
2094
+            ), '', $output );
2095
+        }
2096 2096
 
2097
-		public function block_row_start($key, $args){
2097
+        public function block_row_start($key, $args){
2098 2098
 
2099
-			// check for row
2100
-			if(!empty($args['row'])){
2099
+            // check for row
2100
+            if(!empty($args['row'])){
2101 2101
 
2102
-				if(!empty($args['row']['open'])){
2102
+                if(!empty($args['row']['open'])){
2103 2103
 
2104
-				// element require
2105
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2106
-				echo $element_require;
2104
+                // element require
2105
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2106
+                echo $element_require;
2107 2107
 
2108
-					if(false){?><script><?php }?>
2108
+                    if(false){?><script><?php }?>
2109 2109
 						el('div', {
2110 2110
 								className: 'bsui components-base-control',
2111 2111
 							},
@@ -2135,87 +2135,87 @@  discard block
 block discarded – undo
2135 2135
 									},
2136 2136
 
2137 2137
 					<?php
2138
-					if(false){?></script><?php }
2139
-				}elseif(!empty($args['row']['close'])){
2140
-					if(false){?><script><?php }?>
2138
+                    if(false){?></script><?php }
2139
+                }elseif(!empty($args['row']['close'])){
2140
+                    if(false){?><script><?php }?>
2141 2141
 						el(
2142 2142
 							'div',
2143 2143
 							{
2144 2144
 								className: 'col pl-0',
2145 2145
 							},
2146 2146
 					<?php
2147
-					if(false){?></script><?php }
2148
-				}else{
2149
-					if(false){?><script><?php }?>
2147
+                    if(false){?></script><?php }
2148
+                }else{
2149
+                    if(false){?><script><?php }?>
2150 2150
 						el(
2151 2151
 							'div',
2152 2152
 							{
2153 2153
 								className: 'col pl-0 pr-2',
2154 2154
 							},
2155 2155
 					<?php
2156
-					if(false){?></script><?php }
2157
-				}
2158
-
2159
-			}
2160
-
2161
-		}
2162
-
2163
-		public function block_row_end($key, $args){
2164
-
2165
-			if(!empty($args['row'])){
2166
-				// maybe close
2167
-				if(!empty($args['row']['close'])){
2168
-					echo "))";
2169
-				}
2170
-
2171
-				echo "),";
2172
-			}
2173
-		}
2174
-
2175
-		public function build_block_arguments( $key, $args ) {
2176
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2177
-			$options           = '';
2178
-			$extra             = '';
2179
-			$require           = '';
2180
-
2181
-			// `content` is a protected and special argument
2182
-			if ( $key == 'content' ) {
2183
-				return;
2184
-			}
2185
-
2186
-
2187
-			// icon
2188
-			$icon = '';
2189
-			if( !empty( $args['icon'] ) ){
2190
-				$icon .= "el('div', {";
2191
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2192
-									$icon .= "className: 'text-center',";
2193
-									$icon .= "title: '".addslashes( $args['title'] )."',";
2194
-								$icon .= "}),";
2195
-
2196
-				// blank title as its added to the icon.
2197
-				$args['title'] = '';
2198
-			}
2199
-
2200
-			// require advanced
2201
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2202
-
2203
-			// element require
2204
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2205
-
2206
-
2207
-			$onchange  = "props.setAttributes({ $key: $key } )";
2208
-			$onchangecomplete  = "";
2209
-			$value     = "props.attributes.$key";
2210
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2211
-			if ( in_array( $args['type'], $text_type ) ) {
2212
-				$type = 'TextControl';
2213
-				// Save numbers as numbers and not strings
2214
-				if ( $args['type'] == 'number' ) {
2215
-					$onchange = "props.setAttributes({ $key: Number($key) } )";
2216
-				}
2217
-			}
2218
-			/*
2156
+                    if(false){?></script><?php }
2157
+                }
2158
+
2159
+            }
2160
+
2161
+        }
2162
+
2163
+        public function block_row_end($key, $args){
2164
+
2165
+            if(!empty($args['row'])){
2166
+                // maybe close
2167
+                if(!empty($args['row']['close'])){
2168
+                    echo "))";
2169
+                }
2170
+
2171
+                echo "),";
2172
+            }
2173
+        }
2174
+
2175
+        public function build_block_arguments( $key, $args ) {
2176
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2177
+            $options           = '';
2178
+            $extra             = '';
2179
+            $require           = '';
2180
+
2181
+            // `content` is a protected and special argument
2182
+            if ( $key == 'content' ) {
2183
+                return;
2184
+            }
2185
+
2186
+
2187
+            // icon
2188
+            $icon = '';
2189
+            if( !empty( $args['icon'] ) ){
2190
+                $icon .= "el('div', {";
2191
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2192
+                                    $icon .= "className: 'text-center',";
2193
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
2194
+                                $icon .= "}),";
2195
+
2196
+                // blank title as its added to the icon.
2197
+                $args['title'] = '';
2198
+            }
2199
+
2200
+            // require advanced
2201
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2202
+
2203
+            // element require
2204
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2205
+
2206
+
2207
+            $onchange  = "props.setAttributes({ $key: $key } )";
2208
+            $onchangecomplete  = "";
2209
+            $value     = "props.attributes.$key";
2210
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2211
+            if ( in_array( $args['type'], $text_type ) ) {
2212
+                $type = 'TextControl';
2213
+                // Save numbers as numbers and not strings
2214
+                if ( $args['type'] == 'number' ) {
2215
+                    $onchange = "props.setAttributes({ $key: Number($key) } )";
2216
+                }
2217
+            }
2218
+            /*
2219 2219
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
2220 2220
 						elseif($args['type']=='tabs'){
2221 2221
 							?>
@@ -2249,85 +2249,85 @@  discard block
 block discarded – undo
2249 2249
 							return;
2250 2250
 						}
2251 2251
 			*/
2252
-			elseif ( $args['type'] == 'color' ) {
2253
-				$type = 'ColorPicker';
2254
-				$onchange = "";
2255
-				$extra = "color: $value,";
2256
-				if(!empty($args['disable_alpha'])){
2257
-					$extra .= "disableAlpha: true,";
2258
-				}
2259
-				$onchangecomplete = "onChangeComplete: function($key) {
2252
+            elseif ( $args['type'] == 'color' ) {
2253
+                $type = 'ColorPicker';
2254
+                $onchange = "";
2255
+                $extra = "color: $value,";
2256
+                if(!empty($args['disable_alpha'])){
2257
+                    $extra .= "disableAlpha: true,";
2258
+                }
2259
+                $onchangecomplete = "onChangeComplete: function($key) {
2260 2260
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
2261 2261
                         props.setAttributes({
2262 2262
                             $key: value
2263 2263
                         });
2264 2264
                     },";
2265
-			}
2266
-			elseif ( $args['type'] == 'checkbox' ) {
2267
-				$type = 'CheckboxControl';
2268
-				$extra .= "checked: props.attributes.$key,";
2269
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2270
-			} elseif ( $args['type'] == 'textarea' ) {
2271
-				$type = 'TextareaControl';
2272
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2273
-				$type = 'SelectControl';
2274
-
2275
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2276
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2277
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2278
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2279
-				}else {
2280
-
2281
-					if ( ! empty( $args['options'] ) ) {
2282
-						$options .= "options: [";
2283
-						foreach ( $args['options'] as $option_val => $option_label ) {
2284
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2285
-						}
2286
-						$options .= "],";
2287
-					}
2288
-				}
2289
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2290
-					$extra .= ' multiple: true, ';
2291
-				}
2292
-			} elseif ( $args['type'] == 'alignment' ) {
2293
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2294
-			}elseif ( $args['type'] == 'margins' ) {
2295
-
2296
-			} else {
2297
-				return;// if we have not implemented the control then don't break the JS.
2298
-			}
2299
-
2300
-
2301
-
2302
-			// color input does not show the labels so we add them
2303
-			if($args['type']=='color'){
2304
-				// add show only if advanced
2305
-				echo $require_advanced;
2306
-				// add setting require if defined
2307
-				echo $element_require;
2308
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2309
-			}
2310
-
2311
-			// add show only if advanced
2312
-			echo $require_advanced;
2313
-			// add setting require if defined
2314
-			echo $element_require;
2315
-
2316
-			// icon
2317
-			echo $icon;
2318
-			?>
2265
+            }
2266
+            elseif ( $args['type'] == 'checkbox' ) {
2267
+                $type = 'CheckboxControl';
2268
+                $extra .= "checked: props.attributes.$key,";
2269
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2270
+            } elseif ( $args['type'] == 'textarea' ) {
2271
+                $type = 'TextareaControl';
2272
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2273
+                $type = 'SelectControl';
2274
+
2275
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2276
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2277
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2278
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2279
+                }else {
2280
+
2281
+                    if ( ! empty( $args['options'] ) ) {
2282
+                        $options .= "options: [";
2283
+                        foreach ( $args['options'] as $option_val => $option_label ) {
2284
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2285
+                        }
2286
+                        $options .= "],";
2287
+                    }
2288
+                }
2289
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2290
+                    $extra .= ' multiple: true, ';
2291
+                }
2292
+            } elseif ( $args['type'] == 'alignment' ) {
2293
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2294
+            }elseif ( $args['type'] == 'margins' ) {
2295
+
2296
+            } else {
2297
+                return;// if we have not implemented the control then don't break the JS.
2298
+            }
2299
+
2300
+
2301
+
2302
+            // color input does not show the labels so we add them
2303
+            if($args['type']=='color'){
2304
+                // add show only if advanced
2305
+                echo $require_advanced;
2306
+                // add setting require if defined
2307
+                echo $element_require;
2308
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2309
+            }
2310
+
2311
+            // add show only if advanced
2312
+            echo $require_advanced;
2313
+            // add setting require if defined
2314
+            echo $element_require;
2315
+
2316
+            // icon
2317
+            echo $icon;
2318
+            ?>
2319 2319
 			el( wp.components.<?php echo $type; ?>, {
2320 2320
 			label: '<?php echo addslashes( $args['title'] ); ?>',
2321 2321
 			help: '<?php if ( isset( $args['desc'] ) ) {
2322
-				echo addslashes( $args['desc'] );
2323
-			} ?>',
2322
+                echo addslashes( $args['desc'] );
2323
+            } ?>',
2324 2324
 			value: <?php echo $value; ?>,
2325 2325
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
2326
-				echo "type: '" . addslashes( $args['type'] ) . "',";
2327
-			} ?>
2326
+                echo "type: '" . addslashes( $args['type'] ) . "',";
2327
+            } ?>
2328 2328
 			<?php if ( ! empty( $args['placeholder'] ) ) {
2329
-				echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2330
-			} ?>
2329
+                echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2330
+            } ?>
2331 2331
 			<?php echo $options; ?>
2332 2332
 			<?php echo $extra; ?>
2333 2333
 			<?php echo $custom_attributes; ?>
@@ -2339,601 +2339,601 @@  discard block
 block discarded – undo
2339 2339
 			<?php
2340 2340
 
2341 2341
 
2342
-		}
2343
-
2344
-		/**
2345
-		 * Convert an array of attributes to block string.
2346
-		 *
2347
-		 * @todo there is prob a faster way to do this, also we could add some validation here.
2348
-		 *
2349
-		 * @param $custom_attributes
2350
-		 *
2351
-		 * @return string
2352
-		 */
2353
-		public function array_to_attributes( $custom_attributes, $html = false ) {
2354
-			$attributes = '';
2355
-			if ( ! empty( $custom_attributes ) ) {
2356
-
2357
-				if ( $html ) {
2358
-					foreach ( $custom_attributes as $key => $val ) {
2359
-						$attributes .= " $key='$val' ";
2360
-					}
2361
-				} else {
2362
-					foreach ( $custom_attributes as $key => $val ) {
2363
-						$attributes .= "'$key': '$val',";
2364
-					}
2365
-				}
2366
-			}
2367
-
2368
-			return $attributes;
2369
-		}
2370
-
2371
-		/**
2372
-		 * A self looping function to create the output for JS block elements.
2373
-		 *
2374
-		 * This is what is output in the WP Editor visual view.
2375
-		 *
2376
-		 * @param $args
2377
-		 */
2378
-		public function block_element( $args ) {
2379
-
2380
-
2381
-			if ( ! empty( $args ) ) {
2382
-				foreach ( $args as $element => $new_args ) {
2383
-
2384
-					if ( is_array( $new_args ) ) { // its an element
2385
-
2386
-
2387
-						if ( isset( $new_args['element'] ) ) {
2388
-
2389
-							if ( isset( $new_args['element_require'] ) ) {
2390
-								echo str_replace( array(
2391
-										"'+",
2392
-										"+'"
2393
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2394
-								unset( $new_args['element_require'] );
2395
-							}
2396
-
2397
-							echo "\n el( '" . $new_args['element'] . "', {";
2398
-
2399
-							// get the attributes
2400
-							foreach ( $new_args as $new_key => $new_value ) {
2401
-
2402
-
2403
-								if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2404
-									// do nothing
2405
-								} else {
2406
-									echo $this->block_element( array( $new_key => $new_value ) );
2407
-								}
2408
-							}
2409
-
2410
-							echo "},";// end attributes
2411
-
2412
-							// get the content
2413
-							$first_item = 0;
2414
-							foreach ( $new_args as $new_key => $new_value ) {
2415
-								if ( $new_key === 'content' || is_array( $new_value ) ) {
2416
-
2417
-									if ( $new_key === 'content' ) {
2418
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2419
-									}
2420
-
2421
-									if ( is_array( $new_value ) ) {
2422
-
2423
-										if ( isset( $new_value['element_require'] ) ) {
2424
-											echo str_replace( array(
2425
-													"'+",
2426
-													"+'"
2427
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2428
-											unset( $new_value['element_require'] );
2429
-										}
2430
-
2431
-										if ( isset( $new_value['element_repeat'] ) ) {
2432
-											$x = 1;
2433
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
2434
-												$this->block_element( array( '' => $new_value ) );
2435
-												$x ++;
2436
-											}
2437
-										} else {
2438
-											$this->block_element( array( '' => $new_value ) );
2439
-										}
2440
-									}
2441
-									$first_item ++;
2442
-								}
2443
-							}
2444
-
2445
-							echo ")";// end content
2446
-
2447
-							echo ", \n";
2448
-
2449
-						}
2450
-					} else {
2451
-
2452
-						if ( substr( $element, 0, 3 ) === "if_" ) {
2453
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2454
-						} elseif ( $element == 'style' ) {
2455
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2456
-						} else {
2457
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2458
-						}
2459
-
2460
-					}
2461
-				}
2462
-			}
2463
-		}
2464
-
2465
-		/**
2466
-		 * Replace block attributes placeholders with the proper naming.
2467
-		 *
2468
-		 * @param $string
2469
-		 *
2470
-		 * @return mixed
2471
-		 */
2472
-		public function block_props_replace( $string, $no_wrap = false ) {
2473
-
2474
-			if ( $no_wrap ) {
2475
-				$string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2476
-			} else {
2477
-				$string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2478
-			}
2479
-
2480
-			return $string;
2481
-		}
2482
-
2483
-		/**
2484
-		 * Outputs the content of the widget
2485
-		 *
2486
-		 * @param array $args
2487
-		 * @param array $instance
2488
-		 */
2489
-		public function widget( $args, $instance ) {
2490
-
2491
-			// get the filtered values
2492
-			$argument_values = $this->argument_values( $instance );
2493
-			$argument_values = $this->string_to_bool( $argument_values );
2494
-			$output          = $this->output( $argument_values, $args );
2495
-
2496
-			$no_wrap = false;
2497
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2498
-				$no_wrap = true;
2499
-			}
2500
-
2501
-			ob_start();
2502
-			if ( $output && ! $no_wrap ) {
2503
-
2504
-				$class_original = $this->options['widget_ops']['classname'];
2505
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2506
-
2507
-				// Before widget
2508
-				$before_widget = $args['before_widget'];
2509
-				$before_widget = str_replace($class_original,$class,$before_widget);
2510
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2511
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2512
-
2513
-				// After widget
2514
-				$after_widget = $args['after_widget'];
2515
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2516
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2517
-
2518
-				echo $before_widget;
2519
-				// elementor strips the widget wrapping div so we check for and add it back if needed
2520
-				if ( $this->is_elementor_widget_output() ) {
2521
-					echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class  ) . "'>" : '';
2522
-				}
2523
-				echo $this->output_title( $args, $instance );
2524
-				echo $output;
2525
-				if ( $this->is_elementor_widget_output() ) {
2526
-					echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : '';
2527
-				}
2528
-				echo $after_widget;
2529
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2530
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2531
-				echo $output;
2532
-			} elseif ( $output && $no_wrap ) {
2533
-				echo $output;
2534
-			}
2535
-			$output = ob_get_clean();
2536
-
2537
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2538
-
2539
-			echo $output;
2540
-		}
2541
-
2542
-		/**
2543
-		 * Tests if the current output is inside a elementor container.
2544
-		 *
2545
-		 * @since 1.0.4
2546
-		 * @return bool
2547
-		 */
2548
-		public function is_elementor_widget_output() {
2549
-			$result = false;
2550
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2551
-				$result = true;
2552
-			}
2553
-
2554
-			return $result;
2555
-		}
2556
-
2557
-		/**
2558
-		 * Tests if the current output is inside a elementor preview.
2559
-		 *
2560
-		 * @since 1.0.4
2561
-		 * @return bool
2562
-		 */
2563
-		public function is_elementor_preview() {
2564
-			$result = false;
2565
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2566
-				$result = true;
2567
-			}
2568
-
2569
-			return $result;
2570
-		}
2571
-
2572
-		/**
2573
-		 * Tests if the current output is inside a Divi preview.
2574
-		 *
2575
-		 * @since 1.0.6
2576
-		 * @return bool
2577
-		 */
2578
-		public function is_divi_preview() {
2579
-			$result = false;
2580
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2581
-				$result = true;
2582
-			}
2583
-
2584
-			return $result;
2585
-		}
2586
-
2587
-		/**
2588
-		 * Tests if the current output is inside a Beaver builder preview.
2589
-		 *
2590
-		 * @since 1.0.6
2591
-		 * @return bool
2592
-		 */
2593
-		public function is_beaver_preview() {
2594
-			$result = false;
2595
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
2596
-				$result = true;
2597
-			}
2598
-
2599
-			return $result;
2600
-		}
2601
-
2602
-		/**
2603
-		 * Tests if the current output is inside a siteorigin builder preview.
2604
-		 *
2605
-		 * @since 1.0.6
2606
-		 * @return bool
2607
-		 */
2608
-		public function is_siteorigin_preview() {
2609
-			$result = false;
2610
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2611
-				$result = true;
2612
-			}
2613
-
2614
-			return $result;
2615
-		}
2616
-
2617
-		/**
2618
-		 * Tests if the current output is inside a cornerstone builder preview.
2619
-		 *
2620
-		 * @since 1.0.8
2621
-		 * @return bool
2622
-		 */
2623
-		public function is_cornerstone_preview() {
2624
-			$result = false;
2625
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2626
-				$result = true;
2627
-			}
2628
-
2629
-			return $result;
2630
-		}
2631
-
2632
-		/**
2633
-		 * Tests if the current output is inside a fusion builder preview.
2634
-		 *
2635
-		 * @since 1.1.0
2636
-		 * @return bool
2637
-		 */
2638
-		public function is_fusion_preview() {
2639
-			$result = false;
2640
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2641
-				$result = true;
2642
-			}
2643
-
2644
-			return $result;
2645
-		}
2646
-
2647
-		/**
2648
-		 * Tests if the current output is inside a Oxygen builder preview.
2649
-		 *
2650
-		 * @since 1.0.18
2651
-		 * @return bool
2652
-		 */
2653
-		public function is_oxygen_preview() {
2654
-			$result = false;
2655
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2656
-				$result = true;
2657
-			}
2658
-
2659
-			return $result;
2660
-		}
2661
-
2662
-		/**
2663
-		 * General function to check if we are in a preview situation.
2664
-		 *
2665
-		 * @since 1.0.6
2666
-		 * @return bool
2667
-		 */
2668
-		public function is_preview() {
2669
-			$preview = false;
2670
-			if ( $this->is_divi_preview() ) {
2671
-				$preview = true;
2672
-			} elseif ( $this->is_elementor_preview() ) {
2673
-				$preview = true;
2674
-			} elseif ( $this->is_beaver_preview() ) {
2675
-				$preview = true;
2676
-			} elseif ( $this->is_siteorigin_preview() ) {
2677
-				$preview = true;
2678
-			} elseif ( $this->is_cornerstone_preview() ) {
2679
-				$preview = true;
2680
-			} elseif ( $this->is_fusion_preview() ) {
2681
-				$preview = true;
2682
-			} elseif ( $this->is_oxygen_preview() ) {
2683
-				$preview = true;
2684
-			} elseif( $this->is_block_content_call() ) {
2685
-				$preview = true;
2686
-			}
2687
-
2688
-			return $preview;
2689
-		}
2690
-
2691
-		/**
2692
-		 * Output the super title.
2693
-		 *
2694
-		 * @param $args
2695
-		 * @param array $instance
2696
-		 *
2697
-		 * @return string
2698
-		 */
2699
-		public function output_title( $args, $instance = array() ) {
2700
-			$output = '';
2701
-			if ( ! empty( $instance['title'] ) ) {
2702
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2703
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2704
-
2705
-				if(empty($instance['widget_title_tag'])){
2706
-					$output = $args['before_title'] . $title . $args['after_title'];
2707
-				}else{
2708
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
2709
-
2710
-					// classes
2711
-					$title_classes = array();
2712
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2713
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2714
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2715
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2716
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2717
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2718
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2719
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2720
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2721
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2722
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2723
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2724
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2725
-
2726
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2727
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
2728
-				}
2729
-
2730
-			}
2731
-
2732
-			return $output;
2733
-		}
2734
-
2735
-		/**
2736
-		 * Outputs the options form inputs for the widget.
2737
-		 *
2738
-		 * @param array $instance The widget options.
2739
-		 */
2740
-		public function form( $instance ) {
2741
-
2742
-			// set widget instance
2743
-			$this->instance = $instance;
2744
-
2745
-			// set it as a SD widget
2746
-			echo $this->widget_advanced_toggle();
2747
-
2748
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2749
-			$arguments_raw = $this->get_arguments();
2750
-
2751
-			if ( is_array( $arguments_raw ) ) {
2752
-
2753
-				$arguments = $this->group_arguments( $arguments_raw );
2754
-
2755
-				// Do we have sections?
2756
-				$has_sections = $arguments == $arguments_raw ? false : true;
2757
-
2758
-
2759
-				if ( $has_sections ) {
2760
-					$panel_count = 0;
2761
-					foreach ( $arguments as $key => $args ) {
2762
-
2763
-						?>
2342
+        }
2343
+
2344
+        /**
2345
+         * Convert an array of attributes to block string.
2346
+         *
2347
+         * @todo there is prob a faster way to do this, also we could add some validation here.
2348
+         *
2349
+         * @param $custom_attributes
2350
+         *
2351
+         * @return string
2352
+         */
2353
+        public function array_to_attributes( $custom_attributes, $html = false ) {
2354
+            $attributes = '';
2355
+            if ( ! empty( $custom_attributes ) ) {
2356
+
2357
+                if ( $html ) {
2358
+                    foreach ( $custom_attributes as $key => $val ) {
2359
+                        $attributes .= " $key='$val' ";
2360
+                    }
2361
+                } else {
2362
+                    foreach ( $custom_attributes as $key => $val ) {
2363
+                        $attributes .= "'$key': '$val',";
2364
+                    }
2365
+                }
2366
+            }
2367
+
2368
+            return $attributes;
2369
+        }
2370
+
2371
+        /**
2372
+         * A self looping function to create the output for JS block elements.
2373
+         *
2374
+         * This is what is output in the WP Editor visual view.
2375
+         *
2376
+         * @param $args
2377
+         */
2378
+        public function block_element( $args ) {
2379
+
2380
+
2381
+            if ( ! empty( $args ) ) {
2382
+                foreach ( $args as $element => $new_args ) {
2383
+
2384
+                    if ( is_array( $new_args ) ) { // its an element
2385
+
2386
+
2387
+                        if ( isset( $new_args['element'] ) ) {
2388
+
2389
+                            if ( isset( $new_args['element_require'] ) ) {
2390
+                                echo str_replace( array(
2391
+                                        "'+",
2392
+                                        "+'"
2393
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2394
+                                unset( $new_args['element_require'] );
2395
+                            }
2396
+
2397
+                            echo "\n el( '" . $new_args['element'] . "', {";
2398
+
2399
+                            // get the attributes
2400
+                            foreach ( $new_args as $new_key => $new_value ) {
2401
+
2402
+
2403
+                                if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2404
+                                    // do nothing
2405
+                                } else {
2406
+                                    echo $this->block_element( array( $new_key => $new_value ) );
2407
+                                }
2408
+                            }
2409
+
2410
+                            echo "},";// end attributes
2411
+
2412
+                            // get the content
2413
+                            $first_item = 0;
2414
+                            foreach ( $new_args as $new_key => $new_value ) {
2415
+                                if ( $new_key === 'content' || is_array( $new_value ) ) {
2416
+
2417
+                                    if ( $new_key === 'content' ) {
2418
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2419
+                                    }
2420
+
2421
+                                    if ( is_array( $new_value ) ) {
2422
+
2423
+                                        if ( isset( $new_value['element_require'] ) ) {
2424
+                                            echo str_replace( array(
2425
+                                                    "'+",
2426
+                                                    "+'"
2427
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2428
+                                            unset( $new_value['element_require'] );
2429
+                                        }
2430
+
2431
+                                        if ( isset( $new_value['element_repeat'] ) ) {
2432
+                                            $x = 1;
2433
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
2434
+                                                $this->block_element( array( '' => $new_value ) );
2435
+                                                $x ++;
2436
+                                            }
2437
+                                        } else {
2438
+                                            $this->block_element( array( '' => $new_value ) );
2439
+                                        }
2440
+                                    }
2441
+                                    $first_item ++;
2442
+                                }
2443
+                            }
2444
+
2445
+                            echo ")";// end content
2446
+
2447
+                            echo ", \n";
2448
+
2449
+                        }
2450
+                    } else {
2451
+
2452
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
2453
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2454
+                        } elseif ( $element == 'style' ) {
2455
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2456
+                        } else {
2457
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2458
+                        }
2459
+
2460
+                    }
2461
+                }
2462
+            }
2463
+        }
2464
+
2465
+        /**
2466
+         * Replace block attributes placeholders with the proper naming.
2467
+         *
2468
+         * @param $string
2469
+         *
2470
+         * @return mixed
2471
+         */
2472
+        public function block_props_replace( $string, $no_wrap = false ) {
2473
+
2474
+            if ( $no_wrap ) {
2475
+                $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2476
+            } else {
2477
+                $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2478
+            }
2479
+
2480
+            return $string;
2481
+        }
2482
+
2483
+        /**
2484
+         * Outputs the content of the widget
2485
+         *
2486
+         * @param array $args
2487
+         * @param array $instance
2488
+         */
2489
+        public function widget( $args, $instance ) {
2490
+
2491
+            // get the filtered values
2492
+            $argument_values = $this->argument_values( $instance );
2493
+            $argument_values = $this->string_to_bool( $argument_values );
2494
+            $output          = $this->output( $argument_values, $args );
2495
+
2496
+            $no_wrap = false;
2497
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2498
+                $no_wrap = true;
2499
+            }
2500
+
2501
+            ob_start();
2502
+            if ( $output && ! $no_wrap ) {
2503
+
2504
+                $class_original = $this->options['widget_ops']['classname'];
2505
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2506
+
2507
+                // Before widget
2508
+                $before_widget = $args['before_widget'];
2509
+                $before_widget = str_replace($class_original,$class,$before_widget);
2510
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2511
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2512
+
2513
+                // After widget
2514
+                $after_widget = $args['after_widget'];
2515
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2516
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2517
+
2518
+                echo $before_widget;
2519
+                // elementor strips the widget wrapping div so we check for and add it back if needed
2520
+                if ( $this->is_elementor_widget_output() ) {
2521
+                    echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class  ) . "'>" : '';
2522
+                }
2523
+                echo $this->output_title( $args, $instance );
2524
+                echo $output;
2525
+                if ( $this->is_elementor_widget_output() ) {
2526
+                    echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : '';
2527
+                }
2528
+                echo $after_widget;
2529
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2530
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2531
+                echo $output;
2532
+            } elseif ( $output && $no_wrap ) {
2533
+                echo $output;
2534
+            }
2535
+            $output = ob_get_clean();
2536
+
2537
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2538
+
2539
+            echo $output;
2540
+        }
2541
+
2542
+        /**
2543
+         * Tests if the current output is inside a elementor container.
2544
+         *
2545
+         * @since 1.0.4
2546
+         * @return bool
2547
+         */
2548
+        public function is_elementor_widget_output() {
2549
+            $result = false;
2550
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2551
+                $result = true;
2552
+            }
2553
+
2554
+            return $result;
2555
+        }
2556
+
2557
+        /**
2558
+         * Tests if the current output is inside a elementor preview.
2559
+         *
2560
+         * @since 1.0.4
2561
+         * @return bool
2562
+         */
2563
+        public function is_elementor_preview() {
2564
+            $result = false;
2565
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2566
+                $result = true;
2567
+            }
2568
+
2569
+            return $result;
2570
+        }
2571
+
2572
+        /**
2573
+         * Tests if the current output is inside a Divi preview.
2574
+         *
2575
+         * @since 1.0.6
2576
+         * @return bool
2577
+         */
2578
+        public function is_divi_preview() {
2579
+            $result = false;
2580
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2581
+                $result = true;
2582
+            }
2583
+
2584
+            return $result;
2585
+        }
2586
+
2587
+        /**
2588
+         * Tests if the current output is inside a Beaver builder preview.
2589
+         *
2590
+         * @since 1.0.6
2591
+         * @return bool
2592
+         */
2593
+        public function is_beaver_preview() {
2594
+            $result = false;
2595
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
2596
+                $result = true;
2597
+            }
2598
+
2599
+            return $result;
2600
+        }
2601
+
2602
+        /**
2603
+         * Tests if the current output is inside a siteorigin builder preview.
2604
+         *
2605
+         * @since 1.0.6
2606
+         * @return bool
2607
+         */
2608
+        public function is_siteorigin_preview() {
2609
+            $result = false;
2610
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2611
+                $result = true;
2612
+            }
2613
+
2614
+            return $result;
2615
+        }
2616
+
2617
+        /**
2618
+         * Tests if the current output is inside a cornerstone builder preview.
2619
+         *
2620
+         * @since 1.0.8
2621
+         * @return bool
2622
+         */
2623
+        public function is_cornerstone_preview() {
2624
+            $result = false;
2625
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2626
+                $result = true;
2627
+            }
2628
+
2629
+            return $result;
2630
+        }
2631
+
2632
+        /**
2633
+         * Tests if the current output is inside a fusion builder preview.
2634
+         *
2635
+         * @since 1.1.0
2636
+         * @return bool
2637
+         */
2638
+        public function is_fusion_preview() {
2639
+            $result = false;
2640
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2641
+                $result = true;
2642
+            }
2643
+
2644
+            return $result;
2645
+        }
2646
+
2647
+        /**
2648
+         * Tests if the current output is inside a Oxygen builder preview.
2649
+         *
2650
+         * @since 1.0.18
2651
+         * @return bool
2652
+         */
2653
+        public function is_oxygen_preview() {
2654
+            $result = false;
2655
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2656
+                $result = true;
2657
+            }
2658
+
2659
+            return $result;
2660
+        }
2661
+
2662
+        /**
2663
+         * General function to check if we are in a preview situation.
2664
+         *
2665
+         * @since 1.0.6
2666
+         * @return bool
2667
+         */
2668
+        public function is_preview() {
2669
+            $preview = false;
2670
+            if ( $this->is_divi_preview() ) {
2671
+                $preview = true;
2672
+            } elseif ( $this->is_elementor_preview() ) {
2673
+                $preview = true;
2674
+            } elseif ( $this->is_beaver_preview() ) {
2675
+                $preview = true;
2676
+            } elseif ( $this->is_siteorigin_preview() ) {
2677
+                $preview = true;
2678
+            } elseif ( $this->is_cornerstone_preview() ) {
2679
+                $preview = true;
2680
+            } elseif ( $this->is_fusion_preview() ) {
2681
+                $preview = true;
2682
+            } elseif ( $this->is_oxygen_preview() ) {
2683
+                $preview = true;
2684
+            } elseif( $this->is_block_content_call() ) {
2685
+                $preview = true;
2686
+            }
2687
+
2688
+            return $preview;
2689
+        }
2690
+
2691
+        /**
2692
+         * Output the super title.
2693
+         *
2694
+         * @param $args
2695
+         * @param array $instance
2696
+         *
2697
+         * @return string
2698
+         */
2699
+        public function output_title( $args, $instance = array() ) {
2700
+            $output = '';
2701
+            if ( ! empty( $instance['title'] ) ) {
2702
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2703
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2704
+
2705
+                if(empty($instance['widget_title_tag'])){
2706
+                    $output = $args['before_title'] . $title . $args['after_title'];
2707
+                }else{
2708
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
2709
+
2710
+                    // classes
2711
+                    $title_classes = array();
2712
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2713
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2714
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2715
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2716
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2717
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2718
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2719
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2720
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2721
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2722
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2723
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2724
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2725
+
2726
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2727
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
2728
+                }
2729
+
2730
+            }
2731
+
2732
+            return $output;
2733
+        }
2734
+
2735
+        /**
2736
+         * Outputs the options form inputs for the widget.
2737
+         *
2738
+         * @param array $instance The widget options.
2739
+         */
2740
+        public function form( $instance ) {
2741
+
2742
+            // set widget instance
2743
+            $this->instance = $instance;
2744
+
2745
+            // set it as a SD widget
2746
+            echo $this->widget_advanced_toggle();
2747
+
2748
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2749
+            $arguments_raw = $this->get_arguments();
2750
+
2751
+            if ( is_array( $arguments_raw ) ) {
2752
+
2753
+                $arguments = $this->group_arguments( $arguments_raw );
2754
+
2755
+                // Do we have sections?
2756
+                $has_sections = $arguments == $arguments_raw ? false : true;
2757
+
2758
+
2759
+                if ( $has_sections ) {
2760
+                    $panel_count = 0;
2761
+                    foreach ( $arguments as $key => $args ) {
2762
+
2763
+                        ?>
2764 2764
 						<script>
2765 2765
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
2766 2766
 						</script>
2767 2767
 						<?php
2768 2768
 
2769
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
2770
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2771
-						echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
2772
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2769
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
2770
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2771
+                        echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
2772
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2773 2773
 
2774
-						foreach ( $args as $k => $a ) {
2774
+                        foreach ( $args as $k => $a ) {
2775 2775
 
2776
-							$this->widget_inputs_row_start($k, $a);
2777
-							$this->widget_inputs( $a, $instance );
2778
-							$this->widget_inputs_row_end($k, $a);
2776
+                            $this->widget_inputs_row_start($k, $a);
2777
+                            $this->widget_inputs( $a, $instance );
2778
+                            $this->widget_inputs_row_end($k, $a);
2779 2779
 
2780
-						}
2780
+                        }
2781 2781
 
2782
-						echo "</div>";
2782
+                        echo "</div>";
2783 2783
 
2784
-						$panel_count ++;
2784
+                        $panel_count ++;
2785 2785
 
2786
-					}
2787
-				} else {
2788
-					foreach ( $arguments as $key => $args ) {
2789
-						$this->widget_inputs_row_start($key, $args);
2790
-						$this->widget_inputs( $args, $instance );
2791
-						$this->widget_inputs_row_end($key, $args);
2792
-					}
2793
-				}
2786
+                    }
2787
+                } else {
2788
+                    foreach ( $arguments as $key => $args ) {
2789
+                        $this->widget_inputs_row_start($key, $args);
2790
+                        $this->widget_inputs( $args, $instance );
2791
+                        $this->widget_inputs_row_end($key, $args);
2792
+                    }
2793
+                }
2794 2794
 
2795
-			}
2796
-		}
2795
+            }
2796
+        }
2797 2797
 
2798
-		public function widget_inputs_row_start($key, $args){
2799
-			if(!empty($args['row'])){
2800
-				// maybe open
2801
-				if(!empty($args['row']['open'])){
2802
-					?>
2798
+        public function widget_inputs_row_start($key, $args){
2799
+            if(!empty($args['row'])){
2800
+                // maybe open
2801
+                if(!empty($args['row']['open'])){
2802
+                    ?>
2803 2803
 					<div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) {
2804
-						echo $this->convert_element_require( $args['row']['element_require'] );
2805
-					} ?>'>
2804
+                        echo $this->convert_element_require( $args['row']['element_require'] );
2805
+                    } ?>'>
2806 2806
 					<?php if(!empty($args['row']['title'])){ ?>
2807 2807
 					<label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
2808 2808
 					<?php }?>
2809 2809
 					<div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'>
2810 2810
 					<div class='col pr-2'>
2811 2811
 					<?php
2812
-				}elseif(!empty($args['row']['close'])){
2813
-					echo "<div class='col pl-0'>";
2814
-				}else{
2815
-					echo "<div class='col pl-0 pr-2'>";
2816
-				}
2817
-			}
2818
-		}
2819
-
2820
-		public function widget_inputs_row_end($key, $args){
2821
-
2822
-			if(!empty($args['row'])){
2823
-				// maybe close
2824
-				if(!empty($args['row']['close'])){
2825
-					echo "</div></div>";
2826
-				}
2827
-
2828
-				echo "</div>";
2829
-			}
2830
-		}
2831
-
2832
-		/**
2833
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
2834
-		 *
2835
-		 * @return string
2836
-		 */
2837
-		public function widget_advanced_toggle() {
2838
-
2839
-			$output = '';
2840
-			if ( $this->block_show_advanced() ) {
2841
-				$val = 1;
2842
-			} else {
2843
-				$val = 0;
2844
-			}
2845
-
2846
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2847
-
2848
-			return $output;
2849
-		}
2850
-
2851
-		/**
2852
-		 * Convert require element.
2853
-		 *
2854
-		 * @since 1.0.0
2855
-		 *
2856
-		 * @param string $input Input element.
2857
-		 *
2858
-		 * @return string $output
2859
-		 */
2860
-		public function convert_element_require( $input ) {
2861
-
2862
-			$input = str_replace( "'", '"', $input );// we only want double quotes
2863
-
2864
-			$output = esc_attr( str_replace( array( "[%", "%]" ), array(
2865
-				"jQuery(form).find('[data-argument=\"",
2866
-				"\"]').find('input,select,textarea').val()"
2867
-			), $input ) );
2868
-
2869
-			return $output;
2870
-		}
2871
-
2872
-		/**
2873
-		 * Builds the inputs for the widget options.
2874
-		 *
2875
-		 * @param $args
2876
-		 * @param $instance
2877
-		 */
2878
-		public function widget_inputs( $args, $instance ) {
2879
-
2880
-			$class             = "";
2881
-			$element_require   = "";
2882
-			$custom_attributes = "";
2883
-
2884
-			// get value
2885
-			if ( isset( $instance[ $args['name'] ] ) ) {
2886
-				$value = $instance[ $args['name'] ];
2887
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2888
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2889
-			} else {
2890
-				$value = '';
2891
-			}
2892
-
2893
-			// get placeholder
2894
-			if ( ! empty( $args['placeholder'] ) ) {
2895
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2896
-			} else {
2897
-				$placeholder = '';
2898
-			}
2899
-
2900
-			// get if advanced
2901
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2902
-				$class .= " sd-advanced-setting ";
2903
-			}
2904
-
2905
-			// element_require
2906
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2907
-				$element_require = $args['element_require'];
2908
-			}
2909
-
2910
-			// custom_attributes
2911
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2912
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2913
-			}
2914
-
2915
-
2916
-			// before wrapper
2917
-			?>
2812
+                }elseif(!empty($args['row']['close'])){
2813
+                    echo "<div class='col pl-0'>";
2814
+                }else{
2815
+                    echo "<div class='col pl-0 pr-2'>";
2816
+                }
2817
+            }
2818
+        }
2819
+
2820
+        public function widget_inputs_row_end($key, $args){
2821
+
2822
+            if(!empty($args['row'])){
2823
+                // maybe close
2824
+                if(!empty($args['row']['close'])){
2825
+                    echo "</div></div>";
2826
+                }
2827
+
2828
+                echo "</div>";
2829
+            }
2830
+        }
2831
+
2832
+        /**
2833
+         * Get the hidden input that when added makes the advanced button show on widget settings.
2834
+         *
2835
+         * @return string
2836
+         */
2837
+        public function widget_advanced_toggle() {
2838
+
2839
+            $output = '';
2840
+            if ( $this->block_show_advanced() ) {
2841
+                $val = 1;
2842
+            } else {
2843
+                $val = 0;
2844
+            }
2845
+
2846
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2847
+
2848
+            return $output;
2849
+        }
2850
+
2851
+        /**
2852
+         * Convert require element.
2853
+         *
2854
+         * @since 1.0.0
2855
+         *
2856
+         * @param string $input Input element.
2857
+         *
2858
+         * @return string $output
2859
+         */
2860
+        public function convert_element_require( $input ) {
2861
+
2862
+            $input = str_replace( "'", '"', $input );// we only want double quotes
2863
+
2864
+            $output = esc_attr( str_replace( array( "[%", "%]" ), array(
2865
+                "jQuery(form).find('[data-argument=\"",
2866
+                "\"]').find('input,select,textarea').val()"
2867
+            ), $input ) );
2868
+
2869
+            return $output;
2870
+        }
2871
+
2872
+        /**
2873
+         * Builds the inputs for the widget options.
2874
+         *
2875
+         * @param $args
2876
+         * @param $instance
2877
+         */
2878
+        public function widget_inputs( $args, $instance ) {
2879
+
2880
+            $class             = "";
2881
+            $element_require   = "";
2882
+            $custom_attributes = "";
2883
+
2884
+            // get value
2885
+            if ( isset( $instance[ $args['name'] ] ) ) {
2886
+                $value = $instance[ $args['name'] ];
2887
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2888
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2889
+            } else {
2890
+                $value = '';
2891
+            }
2892
+
2893
+            // get placeholder
2894
+            if ( ! empty( $args['placeholder'] ) ) {
2895
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2896
+            } else {
2897
+                $placeholder = '';
2898
+            }
2899
+
2900
+            // get if advanced
2901
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2902
+                $class .= " sd-advanced-setting ";
2903
+            }
2904
+
2905
+            // element_require
2906
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2907
+                $element_require = $args['element_require'];
2908
+            }
2909
+
2910
+            // custom_attributes
2911
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2912
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2913
+            }
2914
+
2915
+
2916
+            // before wrapper
2917
+            ?>
2918 2918
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>"
2919 2919
 			data-argument='<?php echo esc_attr( $args['name'] ); ?>'
2920 2920
 			data-element_require='<?php if ( $element_require ) {
2921
-				echo $this->convert_element_require( $element_require );
2922
-			} ?>'
2921
+                echo $this->convert_element_require( $element_require );
2922
+            } ?>'
2923 2923
 			>
2924 2924
 			<?php
2925 2925
 
2926 2926
 
2927
-			switch ( $args['type'] ) {
2928
-				//array('text','password','number','email','tel','url','color')
2929
-				case "text":
2930
-				case "password":
2931
-				case "number":
2932
-				case "email":
2933
-				case "tel":
2934
-				case "url":
2935
-				case "color":
2936
-					?>
2927
+            switch ( $args['type'] ) {
2928
+                //array('text','password','number','email','tel','url','color')
2929
+                case "text":
2930
+                case "password":
2931
+                case "number":
2932
+                case "email":
2933
+                case "tel":
2934
+                case "url":
2935
+                case "color":
2936
+                    ?>
2937 2937
 					<label
2938 2938
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
2939 2939
 					<input <?php echo $placeholder; ?> class="widefat"
@@ -2944,47 +2944,47 @@  discard block
 block discarded – undo
2944 2944
 						                               value="<?php echo esc_attr( $value ); ?>">
2945 2945
 					<?php
2946 2946
 
2947
-					break;
2948
-				case "select":
2949
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2950
-					if ( $multiple ) {
2951
-						if ( empty( $value ) ) {
2952
-							$value = array();
2953
-						}
2954
-					}
2955
-					?>
2947
+                    break;
2948
+                case "select":
2949
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2950
+                    if ( $multiple ) {
2951
+                        if ( empty( $value ) ) {
2952
+                            $value = array();
2953
+                        }
2954
+                    }
2955
+                    ?>
2956 2956
 					<label
2957 2957
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
2958 2958
 					<select <?php echo $placeholder; ?> class="widefat"
2959 2959
 						<?php echo $custom_attributes; ?>
2960 2960
 						                                id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
2961 2961
 						                                name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) );
2962
-						                                if ( $multiple ) {
2963
-							                                echo "[]";
2964
-						                                } ?>"
2962
+                                                        if ( $multiple ) {
2963
+                                                            echo "[]";
2964
+                                                        } ?>"
2965 2965
 						<?php if ( $multiple ) {
2966
-							echo "multiple";
2967
-						} //@todo not implemented yet due to gutenberg not supporting it
2968
-						?>
2966
+                            echo "multiple";
2967
+                        } //@todo not implemented yet due to gutenberg not supporting it
2968
+                        ?>
2969 2969
 					>
2970 2970
 						<?php
2971 2971
 
2972
-						if ( ! empty( $args['options'] ) ) {
2973
-							foreach ( $args['options'] as $val => $label ) {
2974
-								if ( $multiple ) {
2975
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
2976
-								} else {
2977
-									$selected = selected( $value, $val, false );
2978
-								}
2979
-								echo "<option value='$val' " . $selected . ">$label</option>";
2980
-							}
2981
-						}
2982
-						?>
2972
+                        if ( ! empty( $args['options'] ) ) {
2973
+                            foreach ( $args['options'] as $val => $label ) {
2974
+                                if ( $multiple ) {
2975
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
2976
+                                } else {
2977
+                                    $selected = selected( $value, $val, false );
2978
+                                }
2979
+                                echo "<option value='$val' " . $selected . ">$label</option>";
2980
+                            }
2981
+                        }
2982
+                        ?>
2983 2983
 					</select>
2984 2984
 					<?php
2985
-					break;
2986
-				case "checkbox":
2987
-					?>
2985
+                    break;
2986
+                case "checkbox":
2987
+                    ?>
2988 2988
 					<input <?php echo $placeholder; ?>
2989 2989
 						<?php checked( 1, $value, true ) ?>
2990 2990
 						<?php echo $custom_attributes; ?>
@@ -2994,9 +2994,9 @@  discard block
 block discarded – undo
2994 2994
 					<label
2995 2995
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
2996 2996
 					<?php
2997
-					break;
2998
-				case "textarea":
2999
-					?>
2997
+                    break;
2998
+                case "textarea":
2999
+                    ?>
3000 3000
 					<label
3001 3001
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
3002 3002
 					<textarea <?php echo $placeholder; ?> class="widefat"
@@ -3006,207 +3006,207 @@  discard block
 block discarded – undo
3006 3006
 					><?php echo esc_attr( $value ); ?></textarea>
3007 3007
 					<?php
3008 3008
 
3009
-					break;
3010
-				case "hidden":
3011
-					?>
3009
+                    break;
3010
+                case "hidden":
3011
+                    ?>
3012 3012
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3013 3013
 					       name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden"
3014 3014
 					       value="<?php echo esc_attr( $value ); ?>">
3015 3015
 					<?php
3016
-					break;
3017
-				default:
3018
-					echo "No input type found!"; // @todo we need to add more input types.
3019
-			}
3016
+                    break;
3017
+                default:
3018
+                    echo "No input type found!"; // @todo we need to add more input types.
3019
+            }
3020 3020
 
3021
-			// after wrapper
3022
-			?>
3021
+            // after wrapper
3022
+            ?>
3023 3023
 			</p>
3024 3024
 			<?php
3025 3025
 
3026 3026
 
3027
-		}
3028
-
3029
-		public function get_widget_icon($icon = 'box-top', $title = ''){
3030
-			if($icon=='box-top'){
3031
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
3032
-			}elseif($icon=='box-right'){
3033
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
3034
-			}elseif($icon=='box-bottom'){
3035
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
3036
-			}elseif($icon=='box-left'){
3037
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
3038
-			}
3039
-		}
3040
-
3041
-		/**
3042
-		 * Get the widget input description html.
3043
-		 *
3044
-		 * @param $args
3045
-		 *
3046
-		 * @return string
3047
-		 * @todo, need to make its own tooltip script
3048
-		 */
3049
-		public function widget_field_desc( $args ) {
3050
-
3051
-			$description = '';
3052
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
3053
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3054
-					$description = $this->desc_tip( $args['desc'] );
3055
-				} else {
3056
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3057
-				}
3058
-			}
3059
-
3060
-			return $description;
3061
-		}
3062
-
3063
-		/**
3064
-		 * Get the widget input title html.
3065
-		 *
3066
-		 * @param $args
3067
-		 *
3068
-		 * @return string
3069
-		 */
3070
-		public function widget_field_title( $args ) {
3071
-
3072
-			$title = '';
3073
-			if ( isset( $args['title'] ) && $args['title'] ) {
3074
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
3075
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
3076
-				} else {
3077
-					$title = esc_attr($args['title']);
3078
-				}
3079
-			}
3080
-
3081
-			return $title;
3082
-		}
3083
-
3084
-		/**
3085
-		 * Get the tool tip html.
3086
-		 *
3087
-		 * @param $tip
3088
-		 * @param bool $allow_html
3089
-		 *
3090
-		 * @return string
3091
-		 */
3092
-		function desc_tip( $tip, $allow_html = false ) {
3093
-			if ( $allow_html ) {
3094
-				$tip = $this->sanitize_tooltip( $tip );
3095
-			} else {
3096
-				$tip = esc_attr( $tip );
3097
-			}
3098
-
3099
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3100
-		}
3101
-
3102
-		/**
3103
-		 * Sanitize a string destined to be a tooltip.
3104
-		 *
3105
-		 * @param string $var
3106
-		 *
3107
-		 * @return string
3108
-		 */
3109
-		public function sanitize_tooltip( $var ) {
3110
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3111
-				'br'     => array(),
3112
-				'em'     => array(),
3113
-				'strong' => array(),
3114
-				'small'  => array(),
3115
-				'span'   => array(),
3116
-				'ul'     => array(),
3117
-				'li'     => array(),
3118
-				'ol'     => array(),
3119
-				'p'      => array(),
3120
-			) ) );
3121
-		}
3122
-
3123
-		/**
3124
-		 * Processing widget options on save
3125
-		 *
3126
-		 * @param array $new_instance The new options
3127
-		 * @param array $old_instance The previous options
3128
-		 *
3129
-		 * @return array
3130
-		 * @todo we should add some sanitation here.
3131
-		 */
3132
-		public function update( $new_instance, $old_instance ) {
3133
-
3134
-			//save the widget
3135
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
3136
-
3137
-			// set widget instance
3138
-			$this->instance = $instance;
3139
-
3140
-			if ( empty( $this->arguments ) ) {
3141
-				$this->get_arguments();
3142
-			}
3143
-
3144
-			// check for checkboxes
3145
-			if ( ! empty( $this->arguments ) ) {
3146
-				foreach ( $this->arguments as $argument ) {
3147
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3148
-						$instance[ $argument['name'] ] = '0';
3149
-					}
3150
-				}
3151
-			}
3152
-
3153
-			return $instance;
3154
-		}
3155
-
3156
-		/**
3157
-		 * Checks if the current call is a ajax call to get the block content.
3158
-		 *
3159
-		 * This can be used in your widget to return different content as the block content.
3160
-		 *
3161
-		 * @since 1.0.3
3162
-		 * @return bool
3163
-		 */
3164
-		public function is_block_content_call() {
3165
-			$result = false;
3166
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3167
-				$result = true;
3168
-			}
3169
-
3170
-			return $result;
3171
-		}
3172
-
3173
-		/**
3174
-		 * Get an instance hash that will be unique to the type and settings.
3175
-		 *
3176
-		 * @since 1.0.20
3177
-		 * @return string
3178
-		 */
3179
-		public function get_instance_hash(){
3180
-			$instance_string = $this->base_id.serialize($this->instance);
3181
-			return hash('crc32b',$instance_string);
3182
-		}
3183
-
3184
-		/**
3185
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3186
-		 *
3187
-		 * @param array $rules
3188
-		 *
3189
-		 * @since 1.0.20
3190
-		 * @return string
3191
-		 */
3192
-		public function get_instance_style($rules = array()){
3193
-			$css = '';
3194
-
3195
-			if(!empty($rules)){
3196
-				$rules = array_unique($rules);
3197
-				$instance_hash = $this->get_instance_hash();
3198
-				$css .= "<style>";
3199
-				foreach($rules as $rule){
3200
-					$css .= ".sdel-$instance_hash $rule";
3201
-				}
3202
-				$css .= "</style>";
3203
-			}
3204
-
3205
-
3206
-			return $css;
3207
-
3208
-		}
3209
-
3210
-	}
3027
+        }
3028
+
3029
+        public function get_widget_icon($icon = 'box-top', $title = ''){
3030
+            if($icon=='box-top'){
3031
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
3032
+            }elseif($icon=='box-right'){
3033
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
3034
+            }elseif($icon=='box-bottom'){
3035
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
3036
+            }elseif($icon=='box-left'){
3037
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
3038
+            }
3039
+        }
3040
+
3041
+        /**
3042
+         * Get the widget input description html.
3043
+         *
3044
+         * @param $args
3045
+         *
3046
+         * @return string
3047
+         * @todo, need to make its own tooltip script
3048
+         */
3049
+        public function widget_field_desc( $args ) {
3050
+
3051
+            $description = '';
3052
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
3053
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3054
+                    $description = $this->desc_tip( $args['desc'] );
3055
+                } else {
3056
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3057
+                }
3058
+            }
3059
+
3060
+            return $description;
3061
+        }
3062
+
3063
+        /**
3064
+         * Get the widget input title html.
3065
+         *
3066
+         * @param $args
3067
+         *
3068
+         * @return string
3069
+         */
3070
+        public function widget_field_title( $args ) {
3071
+
3072
+            $title = '';
3073
+            if ( isset( $args['title'] ) && $args['title'] ) {
3074
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
3075
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
3076
+                } else {
3077
+                    $title = esc_attr($args['title']);
3078
+                }
3079
+            }
3080
+
3081
+            return $title;
3082
+        }
3083
+
3084
+        /**
3085
+         * Get the tool tip html.
3086
+         *
3087
+         * @param $tip
3088
+         * @param bool $allow_html
3089
+         *
3090
+         * @return string
3091
+         */
3092
+        function desc_tip( $tip, $allow_html = false ) {
3093
+            if ( $allow_html ) {
3094
+                $tip = $this->sanitize_tooltip( $tip );
3095
+            } else {
3096
+                $tip = esc_attr( $tip );
3097
+            }
3098
+
3099
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3100
+        }
3101
+
3102
+        /**
3103
+         * Sanitize a string destined to be a tooltip.
3104
+         *
3105
+         * @param string $var
3106
+         *
3107
+         * @return string
3108
+         */
3109
+        public function sanitize_tooltip( $var ) {
3110
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3111
+                'br'     => array(),
3112
+                'em'     => array(),
3113
+                'strong' => array(),
3114
+                'small'  => array(),
3115
+                'span'   => array(),
3116
+                'ul'     => array(),
3117
+                'li'     => array(),
3118
+                'ol'     => array(),
3119
+                'p'      => array(),
3120
+            ) ) );
3121
+        }
3122
+
3123
+        /**
3124
+         * Processing widget options on save
3125
+         *
3126
+         * @param array $new_instance The new options
3127
+         * @param array $old_instance The previous options
3128
+         *
3129
+         * @return array
3130
+         * @todo we should add some sanitation here.
3131
+         */
3132
+        public function update( $new_instance, $old_instance ) {
3133
+
3134
+            //save the widget
3135
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
3136
+
3137
+            // set widget instance
3138
+            $this->instance = $instance;
3139
+
3140
+            if ( empty( $this->arguments ) ) {
3141
+                $this->get_arguments();
3142
+            }
3143
+
3144
+            // check for checkboxes
3145
+            if ( ! empty( $this->arguments ) ) {
3146
+                foreach ( $this->arguments as $argument ) {
3147
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3148
+                        $instance[ $argument['name'] ] = '0';
3149
+                    }
3150
+                }
3151
+            }
3152
+
3153
+            return $instance;
3154
+        }
3155
+
3156
+        /**
3157
+         * Checks if the current call is a ajax call to get the block content.
3158
+         *
3159
+         * This can be used in your widget to return different content as the block content.
3160
+         *
3161
+         * @since 1.0.3
3162
+         * @return bool
3163
+         */
3164
+        public function is_block_content_call() {
3165
+            $result = false;
3166
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3167
+                $result = true;
3168
+            }
3169
+
3170
+            return $result;
3171
+        }
3172
+
3173
+        /**
3174
+         * Get an instance hash that will be unique to the type and settings.
3175
+         *
3176
+         * @since 1.0.20
3177
+         * @return string
3178
+         */
3179
+        public function get_instance_hash(){
3180
+            $instance_string = $this->base_id.serialize($this->instance);
3181
+            return hash('crc32b',$instance_string);
3182
+        }
3183
+
3184
+        /**
3185
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3186
+         *
3187
+         * @param array $rules
3188
+         *
3189
+         * @since 1.0.20
3190
+         * @return string
3191
+         */
3192
+        public function get_instance_style($rules = array()){
3193
+            $css = '';
3194
+
3195
+            if(!empty($rules)){
3196
+                $rules = array_unique($rules);
3197
+                $instance_hash = $this->get_instance_hash();
3198
+                $css .= "<style>";
3199
+                foreach($rules as $rule){
3200
+                    $css .= ".sdel-$instance_hash $rule";
3201
+                }
3202
+                $css .= "</style>";
3203
+            }
3204
+
3205
+
3206
+            return $css;
3207
+
3208
+        }
3209
+
3210
+    }
3211 3211
 
3212 3212
 }
Please login to merge, or discard this patch.
includes/admin/class-getpaid-installer.php 1 patch
Indentation   +369 added lines, -369 removed lines patch added patch discarded remove patch
@@ -20,222 +20,222 @@  discard block
 block discarded – undo
20 20
  */
21 21
 class GetPaid_Installer {
22 22
 
23
-	/**
24
-	 * Upgrades the install.
25
-	 *
26
-	 * @param string $upgrade_from The current invoicing version.
27
-	 */
28
-	public function upgrade_db( $upgrade_from ) {
29
-
30
-		// Save the current invoicing version.
31
-		update_option( 'wpinv_version', WPINV_VERSION );
32
-
33
-		// Setup the invoice Custom Post Type.
34
-		GetPaid_Post_Types::register_post_types();
35
-
36
-		// Clear the permalinks
37
-		flush_rewrite_rules();
38
-
39
-		// Maybe create new/missing pages.
40
-		$this->create_pages();
41
-
42
-		// Maybe re(add) admin capabilities.
43
-		$this->add_capabilities();
44
-
45
-		// Maybe create the default payment form.
46
-		wpinv_get_default_payment_form();
47
-
48
-		// Create any missing database tables.
49
-		$method = "upgrade_from_$upgrade_from";
50
-
51
-		if ( method_exists( $this, $method ) ) {
52
-			$this->$method();
53
-		}
54
-
55
-	}
56
-
57
-	/**
58
-	 * Do a fresh install.
59
-	 *
60
-	 */
61
-	public function upgrade_from_0() {
62
-		$this->create_subscriptions_table();
63
-		$this->create_invoices_table();
64
-		$this->create_invoice_items_table();
65
-
66
-		// Save default tax rates.
67
-		update_option( 'wpinv_tax_rates', wpinv_get_data( 'tax-rates' ) );
68
-	}
69
-
70
-	/**
71
-	 * Upgrade to 0.0.5
72
-	 *
73
-	 */
74
-	public function upgrade_from_004() {
75
-		global $wpdb;
76
-
77
-		// Invoices.
78
-		$results = $wpdb->get_results( "SELECT ID FROM {$wpdb->posts} WHERE post_type = 'wpi_invoice' AND post_status IN( 'pending', 'processing', 'onhold', 'refunded', 'cancelled', 'failed', 'renewal' )" );
79
-		if ( ! empty( $results ) ) {
80
-			$wpdb->query( "UPDATE {$wpdb->posts} SET post_status = CONCAT( 'wpi-', post_status ) WHERE post_type = 'wpi_invoice' AND post_status IN( 'pending', 'processing', 'onhold', 'refunded', 'cancelled', 'failed', 'renewal' )" );
81
-
82
-			// Clean post cache
83
-			foreach ( $results as $row ) {
84
-				clean_post_cache( $row->ID );
85
-			}
86
-
87
-		}
88
-
89
-		// Item meta key changes
90
-		$query = "SELECT DISTINCT post_id FROM " . $wpdb->postmeta . " WHERE meta_key IN( '_wpinv_item_id', '_wpinv_package_id', '_wpinv_post_id', '_wpinv_cpt_name', '_wpinv_cpt_singular_name' )";
91
-		$results = $wpdb->get_results( $query );
92
-
93
-		if ( ! empty( $results ) ) {
94
-			$wpdb->query( "UPDATE " . $wpdb->postmeta . " SET meta_key = '_wpinv_custom_id' WHERE meta_key IN( '_wpinv_item_id', '_wpinv_package_id', '_wpinv_post_id' )" );
95
-			$wpdb->query( "UPDATE " . $wpdb->postmeta . " SET meta_key = '_wpinv_custom_name' WHERE meta_key = '_wpinv_cpt_name'" );
96
-			$wpdb->query( "UPDATE " . $wpdb->postmeta . " SET meta_key = '_wpinv_custom_singular_name' WHERE meta_key = '_wpinv_cpt_singular_name'" );
97
-
98
-			foreach ( $results as $row ) {
99
-				clean_post_cache( $row->post_id );
100
-			}
101
-
102
-		}
103
-
104
-		$this->upgrade_from_102();
105
-	}
106
-
107
-	/**
108
-	 * Upgrade to 1.0.3
109
-	 *
110
-	 */
111
-	public function upgrade_from_102() {
112
-		$this->create_subscriptions_table();
113
-		$this->upgrade_from_118();
114
-	}
115
-
116
-	/**
117
-	 * Upgrade to version 2.0.0.
118
-	 *
119
-	 */
120
-	public function upgrade_from_118() {
121
-		$this->create_invoices_table();
122
-		$this->create_invoice_items_table();
123
-		$this->migrate_old_invoices();
124
-	}
125
-
126
-	/**
127
-	 * Upgrade to version 2.0.8.
128
-	 *
129
-	 */
130
-	public function upgrade_from_207() {
131
-		global $wpdb;
132
-		$wpdb->query( "ALTER TABLE {$wpdb->prefix}getpaid_invoice_items MODIFY COLUMN quantity FLOAT(20);" );
133
-	}
134
-
135
-	/**
136
-	 * Give administrators the capability to manage GetPaid.
137
-	 *
138
-	 */
139
-	public function add_capabilities() {
140
-		$GLOBALS['wp_roles']->add_cap( 'administrator', 'manage_invoicing' );
141
-	}
142
-
143
-	/**
144
-	 * Retreives GetPaid pages.
145
-	 *
146
-	 */
147
-	public static function get_pages() {
148
-
149
-		return apply_filters(
150
-			'wpinv_create_pages',
151
-			array(
152
-
153
-				// Checkout page.
154
-				'checkout_page' => array(
155
-					'name'      => _x( 'gp-checkout', 'Page slug', 'invoicing' ),
156
-					'title'     => _x( 'Checkout', 'Page title', 'invoicing' ),
157
-					'content'   => '
23
+    /**
24
+     * Upgrades the install.
25
+     *
26
+     * @param string $upgrade_from The current invoicing version.
27
+     */
28
+    public function upgrade_db( $upgrade_from ) {
29
+
30
+        // Save the current invoicing version.
31
+        update_option( 'wpinv_version', WPINV_VERSION );
32
+
33
+        // Setup the invoice Custom Post Type.
34
+        GetPaid_Post_Types::register_post_types();
35
+
36
+        // Clear the permalinks
37
+        flush_rewrite_rules();
38
+
39
+        // Maybe create new/missing pages.
40
+        $this->create_pages();
41
+
42
+        // Maybe re(add) admin capabilities.
43
+        $this->add_capabilities();
44
+
45
+        // Maybe create the default payment form.
46
+        wpinv_get_default_payment_form();
47
+
48
+        // Create any missing database tables.
49
+        $method = "upgrade_from_$upgrade_from";
50
+
51
+        if ( method_exists( $this, $method ) ) {
52
+            $this->$method();
53
+        }
54
+
55
+    }
56
+
57
+    /**
58
+     * Do a fresh install.
59
+     *
60
+     */
61
+    public function upgrade_from_0() {
62
+        $this->create_subscriptions_table();
63
+        $this->create_invoices_table();
64
+        $this->create_invoice_items_table();
65
+
66
+        // Save default tax rates.
67
+        update_option( 'wpinv_tax_rates', wpinv_get_data( 'tax-rates' ) );
68
+    }
69
+
70
+    /**
71
+     * Upgrade to 0.0.5
72
+     *
73
+     */
74
+    public function upgrade_from_004() {
75
+        global $wpdb;
76
+
77
+        // Invoices.
78
+        $results = $wpdb->get_results( "SELECT ID FROM {$wpdb->posts} WHERE post_type = 'wpi_invoice' AND post_status IN( 'pending', 'processing', 'onhold', 'refunded', 'cancelled', 'failed', 'renewal' )" );
79
+        if ( ! empty( $results ) ) {
80
+            $wpdb->query( "UPDATE {$wpdb->posts} SET post_status = CONCAT( 'wpi-', post_status ) WHERE post_type = 'wpi_invoice' AND post_status IN( 'pending', 'processing', 'onhold', 'refunded', 'cancelled', 'failed', 'renewal' )" );
81
+
82
+            // Clean post cache
83
+            foreach ( $results as $row ) {
84
+                clean_post_cache( $row->ID );
85
+            }
86
+
87
+        }
88
+
89
+        // Item meta key changes
90
+        $query = "SELECT DISTINCT post_id FROM " . $wpdb->postmeta . " WHERE meta_key IN( '_wpinv_item_id', '_wpinv_package_id', '_wpinv_post_id', '_wpinv_cpt_name', '_wpinv_cpt_singular_name' )";
91
+        $results = $wpdb->get_results( $query );
92
+
93
+        if ( ! empty( $results ) ) {
94
+            $wpdb->query( "UPDATE " . $wpdb->postmeta . " SET meta_key = '_wpinv_custom_id' WHERE meta_key IN( '_wpinv_item_id', '_wpinv_package_id', '_wpinv_post_id' )" );
95
+            $wpdb->query( "UPDATE " . $wpdb->postmeta . " SET meta_key = '_wpinv_custom_name' WHERE meta_key = '_wpinv_cpt_name'" );
96
+            $wpdb->query( "UPDATE " . $wpdb->postmeta . " SET meta_key = '_wpinv_custom_singular_name' WHERE meta_key = '_wpinv_cpt_singular_name'" );
97
+
98
+            foreach ( $results as $row ) {
99
+                clean_post_cache( $row->post_id );
100
+            }
101
+
102
+        }
103
+
104
+        $this->upgrade_from_102();
105
+    }
106
+
107
+    /**
108
+     * Upgrade to 1.0.3
109
+     *
110
+     */
111
+    public function upgrade_from_102() {
112
+        $this->create_subscriptions_table();
113
+        $this->upgrade_from_118();
114
+    }
115
+
116
+    /**
117
+     * Upgrade to version 2.0.0.
118
+     *
119
+     */
120
+    public function upgrade_from_118() {
121
+        $this->create_invoices_table();
122
+        $this->create_invoice_items_table();
123
+        $this->migrate_old_invoices();
124
+    }
125
+
126
+    /**
127
+     * Upgrade to version 2.0.8.
128
+     *
129
+     */
130
+    public function upgrade_from_207() {
131
+        global $wpdb;
132
+        $wpdb->query( "ALTER TABLE {$wpdb->prefix}getpaid_invoice_items MODIFY COLUMN quantity FLOAT(20);" );
133
+    }
134
+
135
+    /**
136
+     * Give administrators the capability to manage GetPaid.
137
+     *
138
+     */
139
+    public function add_capabilities() {
140
+        $GLOBALS['wp_roles']->add_cap( 'administrator', 'manage_invoicing' );
141
+    }
142
+
143
+    /**
144
+     * Retreives GetPaid pages.
145
+     *
146
+     */
147
+    public static function get_pages() {
148
+
149
+        return apply_filters(
150
+            'wpinv_create_pages',
151
+            array(
152
+
153
+                // Checkout page.
154
+                'checkout_page' => array(
155
+                    'name'      => _x( 'gp-checkout', 'Page slug', 'invoicing' ),
156
+                    'title'     => _x( 'Checkout', 'Page title', 'invoicing' ),
157
+                    'content'   => '
158 158
 						<!-- wp:shortcode -->
159 159
 						[wpinv_checkout]
160 160
 						<!-- /wp:shortcode -->
161 161
 					',
162
-					'parent'    => '',
163
-				),
164
-
165
-				// Invoice history page.
166
-				'invoice_history_page' => array(
167
-					'name'    => _x( 'gp-invoices', 'Page slug', 'invoicing' ),
168
-					'title'   => _x( 'My Invoices', 'Page title', 'invoicing' ),
169
-					'content' => '
162
+                    'parent'    => '',
163
+                ),
164
+
165
+                // Invoice history page.
166
+                'invoice_history_page' => array(
167
+                    'name'    => _x( 'gp-invoices', 'Page slug', 'invoicing' ),
168
+                    'title'   => _x( 'My Invoices', 'Page title', 'invoicing' ),
169
+                    'content' => '
170 170
 					<!-- wp:shortcode -->
171 171
 					[wpinv_history]
172 172
 					<!-- /wp:shortcode -->
173 173
 				',
174
-					'parent'  => '',
175
-				),
176
-
177
-				// Success page content.
178
-				'success_page' => array(
179
-					'name'     => _x( 'gp-receipt', 'Page slug', 'invoicing' ),
180
-					'title'    => _x( 'Payment Confirmation', 'Page title', 'invoicing' ),
181
-					'content'  => '
174
+                    'parent'  => '',
175
+                ),
176
+
177
+                // Success page content.
178
+                'success_page' => array(
179
+                    'name'     => _x( 'gp-receipt', 'Page slug', 'invoicing' ),
180
+                    'title'    => _x( 'Payment Confirmation', 'Page title', 'invoicing' ),
181
+                    'content'  => '
182 182
 					<!-- wp:shortcode -->
183 183
 					[wpinv_receipt]
184 184
 					<!-- /wp:shortcode -->
185 185
 				',
186
-					'parent'   => 'gp-checkout',
187
-				),
188
-
189
-				// Failure page content.
190
-				'failure_page' => array(
191
-					'name'    => _x( 'gp-transaction-failed', 'Page slug', 'invoicing' ),
192
-					'title'   => _x( 'Transaction Failed', 'Page title', 'invoicing' ),
193
-					'content' => __( 'Your transaction failed, please try again or contact site support.', 'invoicing' ),
194
-					'parent'  => 'gp-checkout',
195
-				),
196
-
197
-				// Subscriptions history page.
198
-				'invoice_subscription_page' => array(
199
-					'name'    => _x( 'gp-subscriptions', 'Page slug', 'invoicing' ),
200
-					'title'   => _x( 'My Subscriptions', 'Page title', 'invoicing' ),
201
-					'content' => '
186
+                    'parent'   => 'gp-checkout',
187
+                ),
188
+
189
+                // Failure page content.
190
+                'failure_page' => array(
191
+                    'name'    => _x( 'gp-transaction-failed', 'Page slug', 'invoicing' ),
192
+                    'title'   => _x( 'Transaction Failed', 'Page title', 'invoicing' ),
193
+                    'content' => __( 'Your transaction failed, please try again or contact site support.', 'invoicing' ),
194
+                    'parent'  => 'gp-checkout',
195
+                ),
196
+
197
+                // Subscriptions history page.
198
+                'invoice_subscription_page' => array(
199
+                    'name'    => _x( 'gp-subscriptions', 'Page slug', 'invoicing' ),
200
+                    'title'   => _x( 'My Subscriptions', 'Page title', 'invoicing' ),
201
+                    'content' => '
202 202
 					<!-- wp:shortcode -->
203 203
 					[wpinv_subscriptions]
204 204
 					<!-- /wp:shortcode -->
205 205
 				',
206
-					'parent' => '',
207
-				),
206
+                    'parent' => '',
207
+                ),
208 208
 
209
-			)
210
-		);
209
+            )
210
+        );
211 211
 
212
-	}
212
+    }
213 213
 
214
-	/**
215
-	 * Re-create GetPaid pages.
216
-	 *
217
-	 */
218
-	public function create_pages() {
214
+    /**
215
+     * Re-create GetPaid pages.
216
+     *
217
+     */
218
+    public function create_pages() {
219 219
 
220
-		foreach ( self::get_pages() as $key => $page ) {
221
-			wpinv_create_page( esc_sql( $page['name'] ), $key, $page['title'], $page['content'], $page['parent'] );
222
-		}
220
+        foreach ( self::get_pages() as $key => $page ) {
221
+            wpinv_create_page( esc_sql( $page['name'] ), $key, $page['title'], $page['content'], $page['parent'] );
222
+        }
223 223
 
224
-	}
224
+    }
225 225
 
226
-	/**
227
-	 * Create subscriptions table.
228
-	 *
229
-	 */
230
-	public function create_subscriptions_table() {
226
+    /**
227
+     * Create subscriptions table.
228
+     *
229
+     */
230
+    public function create_subscriptions_table() {
231 231
 
232
-		global $wpdb;
232
+        global $wpdb;
233 233
 
234
-		require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
234
+        require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
235 235
 
236
-		// Create tables.
237
-		$charset_collate = $wpdb->get_charset_collate();
238
-		$sql             = "CREATE TABLE IF NOT EXISTS {$wpdb->prefix}wpinv_subscriptions (
236
+        // Create tables.
237
+        $charset_collate = $wpdb->get_charset_collate();
238
+        $sql             = "CREATE TABLE IF NOT EXISTS {$wpdb->prefix}wpinv_subscriptions (
239 239
 			id bigint(20) unsigned NOT NULL auto_increment,
240 240
 			customer_id bigint(20) NOT NULL,
241 241
 			frequency int(11) NOT NULL DEFAULT '1',
@@ -258,22 +258,22 @@  discard block
 block discarded – undo
258 258
 			KEY customer_and_status (customer_id, status)
259 259
 		  ) $charset_collate;";
260 260
 
261
-		dbDelta( $sql );
261
+        dbDelta( $sql );
262 262
 
263
-	}
263
+    }
264 264
 
265
-	/**
266
-	 * Create invoices table.
267
-	 *
268
-	 */
269
-	public function create_invoices_table() {
270
-		global $wpdb;
265
+    /**
266
+     * Create invoices table.
267
+     *
268
+     */
269
+    public function create_invoices_table() {
270
+        global $wpdb;
271 271
 
272
-		require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
272
+        require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
273 273
 
274
-		// Create tables.
275
-		$charset_collate = $wpdb->get_charset_collate();
276
-		$sql             = "CREATE TABLE IF NOT EXISTS {$wpdb->prefix}getpaid_invoices (
274
+        // Create tables.
275
+        $charset_collate = $wpdb->get_charset_collate();
276
+        $sql             = "CREATE TABLE IF NOT EXISTS {$wpdb->prefix}getpaid_invoices (
277 277
 			post_id BIGINT(20) NOT NULL,
278 278
             `number` VARCHAR(100),
279 279
             `key` VARCHAR(100),
@@ -309,22 +309,22 @@  discard block
 block discarded – undo
309 309
 			KEY `key` (`key`)
310 310
 		  ) $charset_collate;";
311 311
 
312
-		dbDelta( $sql );
312
+        dbDelta( $sql );
313 313
 
314
-	}
314
+    }
315 315
 
316
-	/**
317
-	 * Create invoice items table.
318
-	 *
319
-	 */
320
-	public function create_invoice_items_table() {
321
-		global $wpdb;
316
+    /**
317
+     * Create invoice items table.
318
+     *
319
+     */
320
+    public function create_invoice_items_table() {
321
+        global $wpdb;
322 322
 
323
-		require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
323
+        require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
324 324
 
325
-		// Create tables.
326
-		$charset_collate = $wpdb->get_charset_collate();
327
-		$sql             = "CREATE TABLE IF NOT EXISTS {$wpdb->prefix}getpaid_invoice_items (
325
+        // Create tables.
326
+        $charset_collate = $wpdb->get_charset_collate();
327
+        $sql             = "CREATE TABLE IF NOT EXISTS {$wpdb->prefix}getpaid_invoice_items (
328 328
 			ID BIGINT(20) NOT NULL AUTO_INCREMENT,
329 329
             post_id BIGINT(20) NOT NULL,
330 330
             item_id BIGINT(20) NOT NULL,
@@ -346,159 +346,159 @@  discard block
 block discarded – undo
346 346
 			KEY post_id (post_id)
347 347
 		  ) $charset_collate;";
348 348
 
349
-		dbDelta( $sql );
350
-
351
-	}
352
-
353
-	/**
354
-	 * Migrates old invoices to new invoices.
355
-	 *
356
-	 */
357
-	public function migrate_old_invoices() {
358
-		global $wpdb;
359
-
360
-		$invoices_table      = $wpdb->prefix . 'getpaid_invoices';
361
-		$invoice_items_table = $wpdb->prefix . 'getpaid_invoice_items';
362
-		$migrated            = $wpdb->get_col( "SELECT post_id FROM $invoices_table" );
363
-		$invoices            = array_unique(
364
-			get_posts(
365
-				array(
366
-					'post_type'      => array( 'wpi_invoice', 'wpi_quote' ),
367
-					'posts_per_page' => -1,
368
-					'fields'         => 'ids',
369
-					'post_status'    => array_keys( get_post_stati() ),
370
-					'exclude'        => (array) $migrated,
371
-				)
372
-			)
373
-		);
374
-
375
-		// Abort if we do not have any invoices.
376
-		if ( empty( $invoices ) ) {
377
-			return;
378
-		}
379
-
380
-		require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-legacy-invoice.php' );
381
-
382
-		$invoice_rows = array();
383
-		foreach ( $invoices as $invoice ) {
384
-
385
-			$invoice = new WPInv_Legacy_Invoice( $invoice );
386
-
387
-			if ( empty( $invoice->ID ) ) {
388
-				return;
389
-			}
390
-
391
-			$fields = array (
392
-				'post_id'        => $invoice->ID,
393
-				'number'         => $invoice->get_number(),
394
-				'key'            => $invoice->get_key(),
395
-				'type'           => str_replace( 'wpi_', '', $invoice->post_type ),
396
-				'mode'           => $invoice->mode,
397
-				'user_ip'        => $invoice->get_ip(),
398
-				'first_name'     => $invoice->get_first_name(),
399
-				'last_name'      => $invoice->get_last_name(),
400
-				'address'        => $invoice->get_address(),
401
-				'city'           => $invoice->city,
402
-				'state'          => $invoice->state,
403
-				'country'        => $invoice->country,
404
-				'zip'            => $invoice->zip,
405
-				'adddress_confirmed' => (int) $invoice->adddress_confirmed,
406
-				'gateway'        => $invoice->get_gateway(),
407
-				'transaction_id' => $invoice->get_transaction_id(),
408
-				'currency'       => $invoice->get_currency(),
409
-				'subtotal'       => $invoice->get_subtotal(),
410
-				'tax'            => $invoice->get_tax(),
411
-				'fees_total'     => $invoice->get_fees_total(),
412
-				'total'          => $invoice->get_total(),
413
-				'discount'       => $invoice->get_discount(),
414
-				'discount_code'  => $invoice->get_discount_code(),
415
-				'disable_taxes'  => $invoice->disable_taxes,
416
-				'due_date'       => $invoice->get_due_date(),
417
-				'completed_date' => $invoice->get_completed_date(),
418
-				'company'        => $invoice->company,
419
-				'vat_number'     => $invoice->vat_number,
420
-				'vat_rate'       => $invoice->vat_rate,
421
-				'custom_meta'    => $invoice->payment_meta
422
-			);
423
-
424
-			foreach ( $fields as $key => $val ) {
425
-				if ( is_null( $val ) ) {
426
-					$val = '';
427
-				}
428
-				$val = maybe_serialize( $val );
429
-				$fields[ $key ] = $wpdb->prepare( '%s', $val );
430
-			}
431
-
432
-			$fields = implode( ', ', $fields );
433
-			$invoice_rows[] = "($fields)";
434
-
435
-			$item_rows    = array();
436
-			$item_columns = array();
437
-			foreach ( $invoice->get_cart_details() as $details ) {
438
-				$fields = array(
439
-					'post_id'          => $invoice->ID,
440
-					'item_id'          => $details['id'],
441
-					'item_name'        => $details['name'],
442
-					'item_description' => empty( $details['meta']['description'] ) ? '' : $details['meta']['description'],
443
-					'vat_rate'         => $details['vat_rate'],
444
-					'vat_class'        => empty( $details['vat_class'] ) ? '_standard' : $details['vat_class'],
445
-					'tax'              => $details['tax'],
446
-					'item_price'       => $details['item_price'],
447
-					'custom_price'     => $details['custom_price'],
448
-					'quantity'         => $details['quantity'],
449
-					'discount'         => $details['discount'],
450
-					'subtotal'         => $details['subtotal'],
451
-					'price'            => $details['price'],
452
-					'meta'             => $details['meta'],
453
-					'fees'             => $details['fees'],
454
-				);
455
-
456
-				$item_columns = array_keys ( $fields );
457
-
458
-				foreach ( $fields as $key => $val ) {
459
-					if ( is_null( $val ) ) {
460
-						$val = '';
461
-					}
462
-					$val = maybe_serialize( $val );
463
-					$fields[ $key ] = $wpdb->prepare( '%s', $val );
464
-				}
465
-
466
-				$fields = implode( ', ', $fields );
467
-				$item_rows[] = "($fields)";
468
-			}
469
-
470
-			$item_rows    = implode( ', ', $item_rows );
471
-			$item_columns = implode( ', ', $item_columns );
472
-			$wpdb->query( "INSERT INTO $invoice_items_table ($item_columns) VALUES $item_rows" );
473
-		}
474
-
475
-		if ( empty( $invoice_rows ) ) {
476
-			return;
477
-		}
478
-
479
-		$invoice_rows = implode( ', ', $invoice_rows );
480
-		$wpdb->query( "INSERT INTO $invoices_table VALUES $invoice_rows" );
481
-
482
-	}
483
-
484
-	/**
485
-	 * Migrates old invoices to new invoices.
486
-	 *
487
-	 */
488
-	public static function rename_gateways_label() {
489
-		global $wpdb;
490
-
491
-		foreach ( array_keys( wpinv_get_payment_gateways() ) as $gateway ) {
492
-
493
-			$wpdb->update(
494
-				$wpdb->prefix . 'getpaid_invoices',
495
-				array( 'gateway' => $gateway ),
496
-				array( 'gateway' => wpinv_get_gateway_admin_label( $gateway ) ),
497
-				'%s',
498
-				'%s'
499
-			);
500
-
501
-		}
502
-	}
349
+        dbDelta( $sql );
350
+
351
+    }
352
+
353
+    /**
354
+     * Migrates old invoices to new invoices.
355
+     *
356
+     */
357
+    public function migrate_old_invoices() {
358
+        global $wpdb;
359
+
360
+        $invoices_table      = $wpdb->prefix . 'getpaid_invoices';
361
+        $invoice_items_table = $wpdb->prefix . 'getpaid_invoice_items';
362
+        $migrated            = $wpdb->get_col( "SELECT post_id FROM $invoices_table" );
363
+        $invoices            = array_unique(
364
+            get_posts(
365
+                array(
366
+                    'post_type'      => array( 'wpi_invoice', 'wpi_quote' ),
367
+                    'posts_per_page' => -1,
368
+                    'fields'         => 'ids',
369
+                    'post_status'    => array_keys( get_post_stati() ),
370
+                    'exclude'        => (array) $migrated,
371
+                )
372
+            )
373
+        );
374
+
375
+        // Abort if we do not have any invoices.
376
+        if ( empty( $invoices ) ) {
377
+            return;
378
+        }
379
+
380
+        require_once( WPINV_PLUGIN_DIR . 'includes/class-wpinv-legacy-invoice.php' );
381
+
382
+        $invoice_rows = array();
383
+        foreach ( $invoices as $invoice ) {
384
+
385
+            $invoice = new WPInv_Legacy_Invoice( $invoice );
386
+
387
+            if ( empty( $invoice->ID ) ) {
388
+                return;
389
+            }
390
+
391
+            $fields = array (
392
+                'post_id'        => $invoice->ID,
393
+                'number'         => $invoice->get_number(),
394
+                'key'            => $invoice->get_key(),
395
+                'type'           => str_replace( 'wpi_', '', $invoice->post_type ),
396
+                'mode'           => $invoice->mode,
397
+                'user_ip'        => $invoice->get_ip(),
398
+                'first_name'     => $invoice->get_first_name(),
399
+                'last_name'      => $invoice->get_last_name(),
400
+                'address'        => $invoice->get_address(),
401
+                'city'           => $invoice->city,
402
+                'state'          => $invoice->state,
403
+                'country'        => $invoice->country,
404
+                'zip'            => $invoice->zip,
405
+                'adddress_confirmed' => (int) $invoice->adddress_confirmed,
406
+                'gateway'        => $invoice->get_gateway(),
407
+                'transaction_id' => $invoice->get_transaction_id(),
408
+                'currency'       => $invoice->get_currency(),
409
+                'subtotal'       => $invoice->get_subtotal(),
410
+                'tax'            => $invoice->get_tax(),
411
+                'fees_total'     => $invoice->get_fees_total(),
412
+                'total'          => $invoice->get_total(),
413
+                'discount'       => $invoice->get_discount(),
414
+                'discount_code'  => $invoice->get_discount_code(),
415
+                'disable_taxes'  => $invoice->disable_taxes,
416
+                'due_date'       => $invoice->get_due_date(),
417
+                'completed_date' => $invoice->get_completed_date(),
418
+                'company'        => $invoice->company,
419
+                'vat_number'     => $invoice->vat_number,
420
+                'vat_rate'       => $invoice->vat_rate,
421
+                'custom_meta'    => $invoice->payment_meta
422
+            );
423
+
424
+            foreach ( $fields as $key => $val ) {
425
+                if ( is_null( $val ) ) {
426
+                    $val = '';
427
+                }
428
+                $val = maybe_serialize( $val );
429
+                $fields[ $key ] = $wpdb->prepare( '%s', $val );
430
+            }
431
+
432
+            $fields = implode( ', ', $fields );
433
+            $invoice_rows[] = "($fields)";
434
+
435
+            $item_rows    = array();
436
+            $item_columns = array();
437
+            foreach ( $invoice->get_cart_details() as $details ) {
438
+                $fields = array(
439
+                    'post_id'          => $invoice->ID,
440
+                    'item_id'          => $details['id'],
441
+                    'item_name'        => $details['name'],
442
+                    'item_description' => empty( $details['meta']['description'] ) ? '' : $details['meta']['description'],
443
+                    'vat_rate'         => $details['vat_rate'],
444
+                    'vat_class'        => empty( $details['vat_class'] ) ? '_standard' : $details['vat_class'],
445
+                    'tax'              => $details['tax'],
446
+                    'item_price'       => $details['item_price'],
447
+                    'custom_price'     => $details['custom_price'],
448
+                    'quantity'         => $details['quantity'],
449
+                    'discount'         => $details['discount'],
450
+                    'subtotal'         => $details['subtotal'],
451
+                    'price'            => $details['price'],
452
+                    'meta'             => $details['meta'],
453
+                    'fees'             => $details['fees'],
454
+                );
455
+
456
+                $item_columns = array_keys ( $fields );
457
+
458
+                foreach ( $fields as $key => $val ) {
459
+                    if ( is_null( $val ) ) {
460
+                        $val = '';
461
+                    }
462
+                    $val = maybe_serialize( $val );
463
+                    $fields[ $key ] = $wpdb->prepare( '%s', $val );
464
+                }
465
+
466
+                $fields = implode( ', ', $fields );
467
+                $item_rows[] = "($fields)";
468
+            }
469
+
470
+            $item_rows    = implode( ', ', $item_rows );
471
+            $item_columns = implode( ', ', $item_columns );
472
+            $wpdb->query( "INSERT INTO $invoice_items_table ($item_columns) VALUES $item_rows" );
473
+        }
474
+
475
+        if ( empty( $invoice_rows ) ) {
476
+            return;
477
+        }
478
+
479
+        $invoice_rows = implode( ', ', $invoice_rows );
480
+        $wpdb->query( "INSERT INTO $invoices_table VALUES $invoice_rows" );
481
+
482
+    }
483
+
484
+    /**
485
+     * Migrates old invoices to new invoices.
486
+     *
487
+     */
488
+    public static function rename_gateways_label() {
489
+        global $wpdb;
490
+
491
+        foreach ( array_keys( wpinv_get_payment_gateways() ) as $gateway ) {
492
+
493
+            $wpdb->update(
494
+                $wpdb->prefix . 'getpaid_invoices',
495
+                array( 'gateway' => $gateway ),
496
+                array( 'gateway' => wpinv_get_gateway_admin_label( $gateway ) ),
497
+                '%s',
498
+                '%s'
499
+            );
500
+
501
+        }
502
+    }
503 503
 
504 504
 }
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-input.php 1 patch
Indentation   +1021 added lines, -1021 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,1031 +11,1031 @@  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
-		);
51
-
52
-		/**
53
-		 * Parse incoming $args into an array and merge it with $defaults
54
-		 */
55
-		$args   = wp_parse_args( $args, $defaults );
56
-		$output = '';
57
-		if ( ! empty( $args['type'] ) ) {
58
-			// hidden label option needs to be empty
59
-			$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
60
-
61
-			$type = sanitize_html_class( $args['type'] );
62
-
63
-			$help_text = '';
64
-			$label = '';
65
-			$label_after = $args['label_after'];
66
-			$label_args = array(
67
-				'title'=> $args['label'],
68
-				'for'=> $args['id'],
69
-				'class' => $args['label_class']." ",
70
-				'label_type' => $args['label_type']
71
-			);
72
-
73
-			// floating labels need label after
74
-			if( $args['label_type'] == 'floating' && $type != 'checkbox' ){
75
-				$label_after = true;
76
-				$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
77
-			}
78
-
79
-			// Some special sauce for files
80
-			if($type=='file' ){
81
-				$label_after = true; // if type file we need the label after
82
-				$args['class'] .= ' custom-file-input ';
83
-			}elseif($type=='checkbox'){
84
-				$label_after = true; // if type file we need the label after
85
-				$args['class'] .= ' custom-control-input ';
86
-			}elseif($type=='datepicker' || $type=='timepicker'){
87
-				$type = 'text';
88
-				//$args['class'] .= ' aui-flatpickr bg-initial ';
89
-				$args['class'] .= ' bg-initial ';
90
-
91
-				$args['extra_attributes']['data-aui-init'] = 'flatpickr';
92
-				// enqueue the script
93
-				$aui_settings = AyeCode_UI_Settings::instance();
94
-				$aui_settings->enqueue_flatpickr();
95
-			}
96
-
97
-
98
-			// open/type
99
-			$output .= '<input type="' . $type . '" ';
100
-
101
-			// name
102
-			if(!empty($args['name'])){
103
-				$output .= ' name="'.esc_attr($args['name']).'" ';
104
-			}
105
-
106
-			// id
107
-			if(!empty($args['id'])){
108
-				$output .= ' id="'.sanitize_html_class($args['id']).'" ';
109
-			}
110
-
111
-			// placeholder
112
-			if(isset($args['placeholder']) && '' != $args['placeholder'] ){
113
-				$output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
114
-			}
115
-
116
-			// title
117
-			if(!empty($args['title'])){
118
-				$output .= ' title="'.esc_attr($args['title']).'" ';
119
-			}
120
-
121
-			// value
122
-			if(!empty($args['value'])){
123
-				$output .= ' value="'.sanitize_text_field($args['value']).'" ';
124
-			}
125
-
126
-			// checked, for radio and checkboxes
127
-			if( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ){
128
-				$output .= ' checked ';
129
-			}
130
-
131
-			// validation text
132
-			if(!empty($args['validation_text'])){
133
-				$output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
134
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
135
-			}
136
-
137
-			// validation_pattern
138
-			if(!empty($args['validation_pattern'])){
139
-				$output .= ' pattern="'.$args['validation_pattern'].'" ';
140
-			}
141
-
142
-			// step (for numbers)
143
-			if(!empty($args['step'])){
144
-				$output .= ' step="'.$args['step'].'" ';
145
-			}
146
-
147
-			// required
148
-			if(!empty($args['required'])){
149
-				$output .= ' required ';
150
-			}
151
-
152
-			// class
153
-			$class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
154
-			$output .= ' class="form-control '.$class.'" ';
155
-
156
-			// data-attributes
157
-			$output .= AUI_Component_Helper::data_attributes($args);
158
-
159
-			// extra attributes
160
-			if(!empty($args['extra_attributes'])){
161
-				$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
162
-			}
163
-
164
-			// close
165
-			$output .= ' >';
166
-
167
-
168
-			// label
169
-			if(!empty($args['label'])){
170
-				if($type == 'file'){$label_args['class'] .= 'custom-file-label';}
171
-				elseif($type == 'checkbox'){$label_args['class'] .= 'custom-control-label';}
172
-				$label = self::label( $label_args, $type );
173
-			}
174
-
175
-			// help text
176
-			if(!empty($args['help_text'])){
177
-				$help_text = AUI_Component_Helper::help_text($args['help_text']);
178
-			}
179
-
180
-
181
-			// set help text in the correct possition
182
-			if($label_after){
183
-				$output .= $label . $help_text;
184
-			}
185
-
186
-			// some input types need a separate wrap
187
-			if($type == 'file') {
188
-				$output = self::wrap( array(
189
-					'content' => $output,
190
-					'class'   => 'form-group custom-file'
191
-				) );
192
-			}elseif($type == 'checkbox'){
193
-				$wrap_class = $args['switch'] ? 'custom-switch' : 'custom-checkbox';
194
-				$output = self::wrap( array(
195
-					'content' => $output,
196
-					'class'   => 'custom-control '.$wrap_class
197
-				) );
198
-
199
-				if($args['label_type']=='horizontal'){
200
-					$output = '<div class="col-sm-2 col-form-label"></div><div class="col-sm-10">' . $output . '</div>';
201
-				}
202
-			}elseif($type == 'password' && $args['password_toggle'] && !$args['input_group_right']){
203
-
204
-
205
-				// allow password field to toggle view
206
-				$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
+        );
51
+
52
+        /**
53
+         * Parse incoming $args into an array and merge it with $defaults
54
+         */
55
+        $args   = wp_parse_args( $args, $defaults );
56
+        $output = '';
57
+        if ( ! empty( $args['type'] ) ) {
58
+            // hidden label option needs to be empty
59
+            $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
60
+
61
+            $type = sanitize_html_class( $args['type'] );
62
+
63
+            $help_text = '';
64
+            $label = '';
65
+            $label_after = $args['label_after'];
66
+            $label_args = array(
67
+                'title'=> $args['label'],
68
+                'for'=> $args['id'],
69
+                'class' => $args['label_class']." ",
70
+                'label_type' => $args['label_type']
71
+            );
72
+
73
+            // floating labels need label after
74
+            if( $args['label_type'] == 'floating' && $type != 'checkbox' ){
75
+                $label_after = true;
76
+                $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
77
+            }
78
+
79
+            // Some special sauce for files
80
+            if($type=='file' ){
81
+                $label_after = true; // if type file we need the label after
82
+                $args['class'] .= ' custom-file-input ';
83
+            }elseif($type=='checkbox'){
84
+                $label_after = true; // if type file we need the label after
85
+                $args['class'] .= ' custom-control-input ';
86
+            }elseif($type=='datepicker' || $type=='timepicker'){
87
+                $type = 'text';
88
+                //$args['class'] .= ' aui-flatpickr bg-initial ';
89
+                $args['class'] .= ' bg-initial ';
90
+
91
+                $args['extra_attributes']['data-aui-init'] = 'flatpickr';
92
+                // enqueue the script
93
+                $aui_settings = AyeCode_UI_Settings::instance();
94
+                $aui_settings->enqueue_flatpickr();
95
+            }
96
+
97
+
98
+            // open/type
99
+            $output .= '<input type="' . $type . '" ';
100
+
101
+            // name
102
+            if(!empty($args['name'])){
103
+                $output .= ' name="'.esc_attr($args['name']).'" ';
104
+            }
105
+
106
+            // id
107
+            if(!empty($args['id'])){
108
+                $output .= ' id="'.sanitize_html_class($args['id']).'" ';
109
+            }
110
+
111
+            // placeholder
112
+            if(isset($args['placeholder']) && '' != $args['placeholder'] ){
113
+                $output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
114
+            }
115
+
116
+            // title
117
+            if(!empty($args['title'])){
118
+                $output .= ' title="'.esc_attr($args['title']).'" ';
119
+            }
120
+
121
+            // value
122
+            if(!empty($args['value'])){
123
+                $output .= ' value="'.sanitize_text_field($args['value']).'" ';
124
+            }
125
+
126
+            // checked, for radio and checkboxes
127
+            if( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ){
128
+                $output .= ' checked ';
129
+            }
130
+
131
+            // validation text
132
+            if(!empty($args['validation_text'])){
133
+                $output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
134
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
135
+            }
136
+
137
+            // validation_pattern
138
+            if(!empty($args['validation_pattern'])){
139
+                $output .= ' pattern="'.$args['validation_pattern'].'" ';
140
+            }
141
+
142
+            // step (for numbers)
143
+            if(!empty($args['step'])){
144
+                $output .= ' step="'.$args['step'].'" ';
145
+            }
146
+
147
+            // required
148
+            if(!empty($args['required'])){
149
+                $output .= ' required ';
150
+            }
151
+
152
+            // class
153
+            $class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
154
+            $output .= ' class="form-control '.$class.'" ';
155
+
156
+            // data-attributes
157
+            $output .= AUI_Component_Helper::data_attributes($args);
158
+
159
+            // extra attributes
160
+            if(!empty($args['extra_attributes'])){
161
+                $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
162
+            }
163
+
164
+            // close
165
+            $output .= ' >';
166
+
167
+
168
+            // label
169
+            if(!empty($args['label'])){
170
+                if($type == 'file'){$label_args['class'] .= 'custom-file-label';}
171
+                elseif($type == 'checkbox'){$label_args['class'] .= 'custom-control-label';}
172
+                $label = self::label( $label_args, $type );
173
+            }
174
+
175
+            // help text
176
+            if(!empty($args['help_text'])){
177
+                $help_text = AUI_Component_Helper::help_text($args['help_text']);
178
+            }
179
+
180
+
181
+            // set help text in the correct possition
182
+            if($label_after){
183
+                $output .= $label . $help_text;
184
+            }
185
+
186
+            // some input types need a separate wrap
187
+            if($type == 'file') {
188
+                $output = self::wrap( array(
189
+                    'content' => $output,
190
+                    'class'   => 'form-group custom-file'
191
+                ) );
192
+            }elseif($type == 'checkbox'){
193
+                $wrap_class = $args['switch'] ? 'custom-switch' : 'custom-checkbox';
194
+                $output = self::wrap( array(
195
+                    'content' => $output,
196
+                    'class'   => 'custom-control '.$wrap_class
197
+                ) );
198
+
199
+                if($args['label_type']=='horizontal'){
200
+                    $output = '<div class="col-sm-2 col-form-label"></div><div class="col-sm-10">' . $output . '</div>';
201
+                }
202
+            }elseif($type == 'password' && $args['password_toggle'] && !$args['input_group_right']){
203
+
204
+
205
+                // allow password field to toggle view
206
+                $args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
207 207
 onclick="var $el = jQuery(this).find(\'i\');$el.toggleClass(\'fa-eye fa-eye-slash\');
208 208
 var $eli = jQuery(this).parent().parent().find(\'input\');
209 209
 if($el.hasClass(\'fa-eye\'))
210 210
 {$eli.attr(\'type\',\'text\');}
211 211
 else{$eli.attr(\'type\',\'password\');}"
212 212
 ><i class="far fa-fw fa-eye-slash"></i></span>';
213
-			}
214
-
215
-			// input group wraps
216
-			if($args['input_group_left'] || $args['input_group_right']){
217
-				$w100 = strpos($args['class'], 'w-100') !== false ? ' w-100' : '';
218
-				if($args['input_group_left']){
219
-					$output = self::wrap( array(
220
-						'content' => $output,
221
-						'class'   => $args['input_group_left_inside'] ? 'input-group-inside position-relative'.$w100  : 'input-group',
222
-						'input_group_left' => $args['input_group_left'],
223
-						'input_group_left_inside'    => $args['input_group_left_inside']
224
-					) );
225
-				}
226
-				if($args['input_group_right']){
227
-					$output = self::wrap( array(
228
-						'content' => $output,
229
-						'class'   => $args['input_group_right_inside'] ? 'input-group-inside position-relative'.$w100 : 'input-group',
230
-						'input_group_right' => $args['input_group_right'],
231
-						'input_group_right_inside'    => $args['input_group_right_inside']
232
-					) );
233
-				}
234
-
235
-			}
236
-
237
-			if(!$label_after){
238
-				$output .= $help_text;
239
-			}
240
-
241
-
242
-			if($args['label_type']=='horizontal' && $type != 'checkbox'){
243
-				$output = self::wrap( array(
244
-					'content' => $output,
245
-					'class'   => 'col-sm-10',
246
-				) );
247
-			}
248
-
249
-			if(!$label_after){
250
-				$output = $label . $output;
251
-			}
252
-
253
-			// wrap
254
-			if(!$args['no_wrap']){
255
-
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
-				));
265
-			}
266
-
267
-
268
-
269
-		}
270
-
271
-		return $output;
272
-	}
273
-
274
-	/**
275
-	 * Build the component.
276
-	 *
277
-	 * @param array $args
278
-	 *
279
-	 * @return string The rendered component.
280
-	 */
281
-	public static function textarea($args = array()){
282
-		$defaults = array(
283
-			'name'       => '',
284
-			'class'      => '',
285
-			'wrap_class' => '',
286
-			'id'         => '',
287
-			'placeholder'=> '',
288
-			'title'      => '',
289
-			'value'      => '',
290
-			'required'   => false,
291
-			'label'      => '',
292
-			'label_after'=> false,
293
-			'label_class'      => '',
294
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
295
-			'help_text'  => '',
296
-			'validation_text'   => '',
297
-			'validation_pattern' => '',
298
-			'no_wrap'    => false,
299
-			'rows'      => '',
300
-			'wysiwyg'   => false,
301
-			'allow_tags' => false, // Allow HTML tags
302
-			'element_require'   => '', // [%element_id%] == "1"
303
-			'extra_attributes'  => array(), // an array of extra attributes
304
-		);
305
-
306
-		/**
307
-		 * Parse incoming $args into an array and merge it with $defaults
308
-		 */
309
-		$args   = wp_parse_args( $args, $defaults );
310
-		$output = '';
311
-
312
-		// hidden label option needs to be empty
313
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
314
-
315
-		// floating labels don't work with wysiwyg so set it as top
316
-		if($args['label_type'] == 'floating' && !empty($args['wysiwyg'])){
317
-			$args['label_type'] = 'top';
318
-		}
319
-
320
-		$label_after = $args['label_after'];
321
-
322
-		// floating labels need label after
323
-		if( $args['label_type'] == 'floating' && empty($args['wysiwyg']) ){
324
-			$label_after = true;
325
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
326
-		}
327
-
328
-		// label
329
-		if(!empty($args['label']) && is_array($args['label'])){
330
-		}elseif(!empty($args['label']) && !$label_after){
331
-			$label_args = array(
332
-				'title'=> $args['label'],
333
-				'for'=> $args['id'],
334
-				'class' => $args['label_class']." ",
335
-				'label_type' => $args['label_type']
336
-			);
337
-			$output .= self::label( $label_args );
338
-		}
339
-
340
-		// maybe horizontal label
341
-		if($args['label_type']=='horizontal'){
342
-			$output .= '<div class="col-sm-10">';
343
-		}
344
-
345
-		if(!empty($args['wysiwyg'])){
346
-			ob_start();
347
-			$content = $args['value'];
348
-			$editor_id = !empty($args['id']) ? sanitize_html_class($args['id']) : 'wp_editor';
349
-			$settings = array(
350
-				'textarea_rows' => !empty(absint($args['rows'])) ? absint($args['rows']) : 4,
351
-				'quicktags'     => false,
352
-				'media_buttons' => false,
353
-				'editor_class'  => 'form-control',
354
-				'textarea_name' => !empty($args['name']) ? sanitize_html_class($args['name']) : sanitize_html_class($args['id']),
355
-				'teeny'         => true,
356
-			);
357
-
358
-			// maybe set settings if array
359
-			if(is_array($args['wysiwyg'])){
360
-				$settings  = wp_parse_args( $args['wysiwyg'], $settings );
361
-			}
362
-
363
-			wp_editor( $content, $editor_id, $settings );
364
-			$output .= ob_get_clean();
365
-		}else{
366
-
367
-			// open
368
-			$output .= '<textarea ';
369
-
370
-			// name
371
-			if(!empty($args['name'])){
372
-				$output .= ' name="'.sanitize_html_class($args['name']).'" ';
373
-			}
374
-
375
-			// id
376
-			if(!empty($args['id'])){
377
-				$output .= ' id="'.sanitize_html_class($args['id']).'" ';
378
-			}
379
-
380
-			// placeholder
381
-			if(isset($args['placeholder']) && '' != $args['placeholder']){
382
-				$output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
383
-			}
384
-
385
-			// title
386
-			if(!empty($args['title'])){
387
-				$output .= ' title="'.esc_attr($args['title']).'" ';
388
-			}
389
-
390
-			// validation text
391
-			if(!empty($args['validation_text'])){
392
-				$output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
393
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
394
-			}
395
-
396
-			// validation_pattern
397
-			if(!empty($args['validation_pattern'])){
398
-				$output .= ' pattern="'.$args['validation_pattern'].'" ';
399
-			}
400
-
401
-			// required
402
-			if(!empty($args['required'])){
403
-				$output .= ' required ';
404
-			}
405
-
406
-			// rows
407
-			if(!empty($args['rows'])){
408
-				$output .= ' rows="'.absint($args['rows']).'" ';
409
-			}
410
-
411
-
412
-			// class
413
-			$class = !empty($args['class']) ? $args['class'] : '';
414
-			$output .= ' class="form-control '.$class.'" ';
415
-
416
-			// extra attributes
417
-			if(!empty($args['extra_attributes'])){
418
-				$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
419
-			}
420
-
421
-			// close tag
422
-			$output .= ' >';
423
-
424
-			// value
425
-			if ( ! empty( $args['value'] ) ) {
426
-				if ( ! empty( $args['allow_tags'] ) ) {
427
-					$output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
428
-				} else {
429
-					$output .= sanitize_textarea_field( $args['value'] );
430
-				}
431
-			}
432
-
433
-			// closing tag
434
-			$output .= '</textarea>';
435
-
436
-		}
437
-
438
-		if(!empty($args['label']) && $label_after){
439
-			$label_args = array(
440
-				'title'=> $args['label'],
441
-				'for'=> $args['id'],
442
-				'class' => $args['label_class']." ",
443
-				'label_type' => $args['label_type']
444
-			);
445
-			$output .= self::label( $label_args );
446
-		}
447
-
448
-		// help text
449
-		if(!empty($args['help_text'])){
450
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
451
-		}
452
-
453
-		// maybe horizontal label
454
-		if($args['label_type']=='horizontal'){
455
-			$output .= '</div>';
456
-		}
457
-
458
-
459
-		// wrap
460
-		if(!$args['no_wrap']){
461
-			$form_group_class = $args['label_type']=='floating' ? 'form-label-group' : 'form-group';
462
-			$wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
463
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
464
-			$output = self::wrap(array(
465
-				'content' => $output,
466
-				'class'   => $wrap_class,
467
-				'element_require'   => $args['element_require'],
468
-				'argument_id'  => $args['id']
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="'.sanitize_text_field($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
-		);
555
-
556
-		/**
557
-		 * Parse incoming $args into an array and merge it with $defaults
558
-		 */
559
-		$args   = wp_parse_args( $args, $defaults );
560
-		$output = '';
561
-		if($args['type']){
562
-
563
-			// open
564
-			$output .= '<'.sanitize_html_class($args['type']);
565
-
566
-			// element require
567
-			if(!empty($args['element_require'])){
568
-				$output .= AUI_Component_Helper::element_require($args['element_require']);
569
-				$args['class'] .= " aui-conditional-field";
570
-			}
571
-
572
-			// argument_id
573
-			if( !empty($args['argument_id']) ){
574
-				$output .= ' data-argument="'.esc_attr($args['argument_id']).'"';
575
-			}
576
-
577
-			// class
578
-			$class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
579
-			$output .= ' class="'.$class.'" ';
580
-
581
-			// close wrap
582
-			$output .= ' >';
583
-
584
-
585
-			// Input group left
586
-			if(!empty($args['input_group_left'])){
587
-				$position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
588
-				$input_group_left = strpos($args['input_group_left'], '<') !== false ? $args['input_group_left'] : '<span class="input-group-text">'.$args['input_group_left'].'</span>';
589
-				$output .= '<div class="input-group-prepend '.$position_class.'">'.$input_group_left.'</div>';
590
-			}
591
-
592
-			// content
593
-			$output .= $args['content'];
594
-
595
-			// Input group right
596
-			if(!empty($args['input_group_right'])){
597
-				$position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
598
-				$input_group_right = strpos($args['input_group_right'], '<') !== false ? $args['input_group_right'] : '<span class="input-group-text">'.$args['input_group_right'].'</span>';
599
-				$output .= '<div class="input-group-append '.$position_class.'">'.$input_group_right.'</div>';
600
-			}
601
-
602
-
603
-			// close wrap
604
-			$output .= '</'.sanitize_html_class($args['type']).'>';
605
-
606
-
607
-		}else{
608
-			$output = $args['content'];
609
-		}
610
-
611
-		return $output;
612
-	}
613
-
614
-	/**
615
-	 * Build the component.
616
-	 *
617
-	 * @param array $args
618
-	 *
619
-	 * @return string The rendered component.
620
-	 */
621
-	public static function select($args = array()){
622
-		$defaults = array(
623
-			'class'      => '',
624
-			'wrap_class' => '',
625
-			'id'         => '',
626
-			'title'      => '',
627
-			'value'      => '', // can be an array or a string
628
-			'required'   => false,
629
-			'label'      => '',
630
-			'label_after'=> false,
631
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
632
-			'label_class'      => '',
633
-			'help_text'  => '',
634
-			'placeholder'=> '',
635
-			'options'    => array(), // array or string
636
-			'icon'       => '',
637
-			'multiple'   => false,
638
-			'select2'    => false,
639
-			'no_wrap'    => false,
640
-			'element_require'   => '', // [%element_id%] == "1"
641
-			'extra_attributes'  => array(), // an array of extra attributes
642
-		);
643
-
644
-		/**
645
-		 * Parse incoming $args into an array and merge it with $defaults
646
-		 */
647
-		$args   = wp_parse_args( $args, $defaults );
648
-		$output = '';
649
-
650
-		// for now lets hide floating labels
651
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'hidden';}
652
-
653
-		// hidden label option needs to be empty
654
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
655
-
656
-
657
-		$label_after = $args['label_after'];
658
-
659
-		// floating labels need label after
660
-		if( $args['label_type'] == 'floating' ){
661
-			$label_after = true;
662
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
663
-		}
664
-
665
-		// Maybe setup select2
666
-		$is_select2 = false;
667
-		if(!empty($args['select2'])){
668
-			$args['class'] .= ' aui-select2';
669
-			$is_select2 = true;
670
-		}elseif( strpos($args['class'], 'aui-select2') !== false){
671
-			$is_select2 = true;
672
-		}
673
-
674
-		// select2 tags
675
-		if( !empty($args['select2']) && $args['select2'] === 'tags'){ // triple equals needed here for some reason
676
-			$args['data-tags'] = 'true';
677
-			$args['data-token-separators'] = "[',']";
678
-			$args['multiple'] = true;
679
-		}
680
-
681
-		// select2 placeholder
682
-		if($is_select2 && isset($args['placeholder']) && '' != $args['placeholder'] && empty($args['data-placeholder'])){
683
-			$args['data-placeholder'] = esc_attr($args['placeholder']);
684
-			$args['data-allow-clear'] = isset($args['data-allow-clear']) ? (bool) $args['data-allow-clear'] : true;
685
-		}
686
-
687
-		// label
688
-		if(!empty($args['label']) && is_array($args['label'])){
689
-		}elseif(!empty($args['label']) && !$label_after){
690
-			$label_args = array(
691
-				'title'=> $args['label'],
692
-				'for'=> $args['id'],
693
-				'class' => $args['label_class']." ",
694
-				'label_type' => $args['label_type']
695
-			);
696
-			$output .= self::label($label_args);
697
-		}
698
-
699
-		// maybe horizontal label
700
-		if($args['label_type']=='horizontal'){
701
-			$output .= '<div class="col-sm-10">';
702
-		}
703
-
704
-		// Set hidden input to save empty value for multiselect.
705
-		if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
706
-			$output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
707
-		}
708
-
709
-		// open/type
710
-		$output .= '<select ';
711
-
712
-		// style
713
-		if($is_select2){
714
-			$output .= " style='width:100%;' ";
715
-		}
716
-
717
-		// element require
718
-		if(!empty($args['element_require'])){
719
-			$output .= AUI_Component_Helper::element_require($args['element_require']);
720
-			$args['class'] .= " aui-conditional-field";
721
-		}
722
-
723
-		// class
724
-		$class = !empty($args['class']) ? $args['class'] : '';
725
-		$output .= AUI_Component_Helper::class_attr('custom-select '.$class);
726
-
727
-		// name
728
-		if(!empty($args['name'])){
729
-			$output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
730
-		}
731
-
732
-		// id
733
-		if(!empty($args['id'])){
734
-			$output .= AUI_Component_Helper::id($args['id']);
735
-		}
736
-
737
-		// title
738
-		if(!empty($args['title'])){
739
-			$output .= AUI_Component_Helper::title($args['title']);
740
-		}
741
-
742
-		// data-attributes
743
-		$output .= AUI_Component_Helper::data_attributes($args);
744
-
745
-		// aria-attributes
746
-		$output .= AUI_Component_Helper::aria_attributes($args);
747
-
748
-		// extra attributes
749
-		if(!empty($args['extra_attributes'])){
750
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
751
-		}
752
-
753
-		// required
754
-		if(!empty($args['required'])){
755
-			$output .= ' required ';
756
-		}
757
-
758
-		// multiple
759
-		if(!empty($args['multiple'])){
760
-			$output .= ' multiple ';
761
-		}
762
-
763
-		// close opening tag
764
-		$output .= ' >';
765
-
766
-		// placeholder
767
-		if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
768
-			$output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
769
-		}elseif($is_select2 && !empty($args['placeholder'])){
770
-			$output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
771
-		}
772
-
773
-		// Options
774
-		if(!empty($args['options'])){
775
-
776
-			if(!is_array($args['options'])){
777
-				$output .= $args['options']; // not the preferred way but an option
778
-			}else{
779
-				foreach($args['options'] as $val => $name){
780
-					$selected = '';
781
-					if(is_array($name)){
782
-						if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
783
-							$option_label = isset($name['label']) ? $name['label'] : '';
784
-
785
-							$output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
786
-						} else {
787
-							$option_label = isset($name['label']) ? $name['label'] : '';
788
-							$option_value = isset($name['value']) ? $name['value'] : '';
789
-							if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
790
-								$selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
791
-							} elseif(!empty($args['value'])) {
792
-								$selected = selected($option_value,stripslashes_deep($args['value']), false);
793
-							}
794
-
795
-							$output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
796
-						}
797
-					}else{
798
-						if(!empty($args['value'])){
799
-							if(is_array($args['value'])){
800
-								$selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
801
-							} elseif(!empty($args['value'])) {
802
-								$selected = selected( $args['value'], $val, false);
803
-							}
804
-						}
805
-						$output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
806
-					}
807
-				}
808
-			}
809
-
810
-		}
811
-
812
-		// closing tag
813
-		$output .= '</select>';
814
-
815
-		if(!empty($args['label']) && $label_after){
816
-			$label_args = array(
817
-				'title'=> $args['label'],
818
-				'for'=> $args['id'],
819
-				'class' => $args['label_class']." ",
820
-				'label_type' => $args['label_type']
821
-			);
822
-			$output .= self::label($label_args);
823
-		}
824
-
825
-		// help text
826
-		if(!empty($args['help_text'])){
827
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
828
-		}
829
-
830
-		// maybe horizontal label
831
-		if($args['label_type']=='horizontal'){
832
-			$output .= '</div>';
833
-		}
834
-
835
-
836
-		// wrap
837
-		if(!$args['no_wrap']){
838
-			$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
839
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
840
-			$output = self::wrap(array(
841
-				'content' => $output,
842
-				'class'   => $wrap_class,
843
-				'element_require'   => $args['element_require'],
844
-				'argument_id'  => $args['id']
845
-			));
846
-		}
847
-
848
-
849
-		return $output;
850
-	}
851
-
852
-	/**
853
-	 * Build the component.
854
-	 *
855
-	 * @param array $args
856
-	 *
857
-	 * @return string The rendered component.
858
-	 */
859
-	public static function radio($args = array()){
860
-		$defaults = array(
861
-			'class'      => '',
862
-			'wrap_class' => '',
863
-			'id'         => '',
864
-			'title'      => '',
865
-			'horizontal' => false, // sets the lable horizontal
866
-			'value'      => '',
867
-			'label'      => '',
868
-			'label_class'=> '',
869
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
870
-			'help_text'  => '',
871
-			'inline'     => true,
872
-			'required'   => false,
873
-			'options'    => array(),
874
-			'icon'       => '',
875
-			'no_wrap'    => false,
876
-			'element_require'   => '', // [%element_id%] == "1"
877
-			'extra_attributes'  => array() // an array of extra attributes
878
-		);
879
-
880
-		/**
881
-		 * Parse incoming $args into an array and merge it with $defaults
882
-		 */
883
-		$args   = wp_parse_args( $args, $defaults );
884
-
885
-		// for now lets use horizontal for floating
886
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
887
-
888
-		$label_args = array(
889
-			'title'=> $args['label'],
890
-			'class' => $args['label_class']." pt-0 ",
891
-			'label_type' => $args['label_type']
892
-		);
893
-
894
-		$output = '';
895
-
896
-
897
-
898
-		// label before
899
-		if(!empty($args['label'])){
900
-			$output .= self::label( $label_args, 'radio' );
901
-		}
902
-
903
-		// maybe horizontal label
904
-		if($args['label_type']=='horizontal'){
905
-			$output .= '<div class="col-sm-10">';
906
-		}
907
-
908
-		if(!empty($args['options'])){
909
-			$count = 0;
910
-			foreach($args['options'] as $value => $label){
911
-				$option_args = $args;
912
-				$option_args['value'] = $value;
913
-				$option_args['label'] = $label;
914
-				$option_args['checked'] = $value == $args['value'] ? true : false;
915
-				$output .= self::radio_option($option_args,$count);
916
-				$count++;
917
-			}
918
-		}
919
-
920
-		// help text
921
-		$help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
922
-		$output .= $help_text;
923
-
924
-		// maybe horizontal label
925
-		if($args['label_type']=='horizontal'){
926
-			$output .= '</div>';
927
-		}
928
-
929
-		// wrap
930
-		$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
931
-		$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
932
-		$output = self::wrap(array(
933
-			'content' => $output,
934
-			'class'   => $wrap_class,
935
-			'element_require'   => $args['element_require'],
936
-			'argument_id'  => $args['id']
937
-		));
938
-
939
-
940
-		return $output;
941
-	}
942
-
943
-	/**
944
-	 * Build the component.
945
-	 *
946
-	 * @param array $args
947
-	 *
948
-	 * @return string The rendered component.
949
-	 */
950
-	public static function radio_option($args = array(),$count = ''){
951
-		$defaults = array(
952
-			'class'      => '',
953
-			'id'         => '',
954
-			'title'      => '',
955
-			'value'      => '',
956
-			'required'   => false,
957
-			'inline'     => true,
958
-			'label'      => '',
959
-			'options'    => array(),
960
-			'icon'       => '',
961
-			'no_wrap'    => false,
962
-			'extra_attributes'  => array() // an array of extra attributes
963
-		);
964
-
965
-		/**
966
-		 * Parse incoming $args into an array and merge it with $defaults
967
-		 */
968
-		$args   = wp_parse_args( $args, $defaults );
969
-
970
-		$output = '';
971
-
972
-		// open/type
973
-		$output .= '<input type="radio"';
974
-
975
-		// class
976
-		$output .= ' class="form-check-input" ';
977
-
978
-		// name
979
-		if(!empty($args['name'])){
980
-			$output .= AUI_Component_Helper::name($args['name']);
981
-		}
982
-
983
-		// id
984
-		if(!empty($args['id'])){
985
-			$output .= AUI_Component_Helper::id($args['id'].$count);
986
-		}
987
-
988
-		// title
989
-		if(!empty($args['title'])){
990
-			$output .= AUI_Component_Helper::title($args['title']);
991
-		}
992
-
993
-		// value
994
-		if(isset($args['value'])){
995
-			$output .= ' value="'.sanitize_text_field($args['value']).'" ';
996
-		}
997
-
998
-		// checked, for radio and checkboxes
999
-		if( $args['checked'] ){
1000
-			$output .= ' checked ';
1001
-		}
1002
-
1003
-		// data-attributes
1004
-		$output .= AUI_Component_Helper::data_attributes($args);
1005
-
1006
-		// aria-attributes
1007
-		$output .= AUI_Component_Helper::aria_attributes($args);
1008
-
1009
-		// extra attributes
1010
-		if(!empty($args['extra_attributes'])){
1011
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1012
-		}
1013
-
1014
-		// required
1015
-		if(!empty($args['required'])){
1016
-			$output .= ' required ';
1017
-		}
1018
-
1019
-		// close opening tag
1020
-		$output .= ' >';
1021
-
1022
-		// label
1023
-		if(!empty($args['label']) && is_array($args['label'])){
1024
-		}elseif(!empty($args['label'])){
1025
-			$output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1026
-		}
1027
-
1028
-		// wrap
1029
-		if(!$args['no_wrap']){
1030
-			$wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1031
-			$output = self::wrap(array(
1032
-				'content' => $output,
1033
-				'class' => $wrap_class
1034
-			));
1035
-		}
1036
-
1037
-
1038
-		return $output;
1039
-	}
213
+            }
214
+
215
+            // input group wraps
216
+            if($args['input_group_left'] || $args['input_group_right']){
217
+                $w100 = strpos($args['class'], 'w-100') !== false ? ' w-100' : '';
218
+                if($args['input_group_left']){
219
+                    $output = self::wrap( array(
220
+                        'content' => $output,
221
+                        'class'   => $args['input_group_left_inside'] ? 'input-group-inside position-relative'.$w100  : 'input-group',
222
+                        'input_group_left' => $args['input_group_left'],
223
+                        'input_group_left_inside'    => $args['input_group_left_inside']
224
+                    ) );
225
+                }
226
+                if($args['input_group_right']){
227
+                    $output = self::wrap( array(
228
+                        'content' => $output,
229
+                        'class'   => $args['input_group_right_inside'] ? 'input-group-inside position-relative'.$w100 : 'input-group',
230
+                        'input_group_right' => $args['input_group_right'],
231
+                        'input_group_right_inside'    => $args['input_group_right_inside']
232
+                    ) );
233
+                }
234
+
235
+            }
236
+
237
+            if(!$label_after){
238
+                $output .= $help_text;
239
+            }
240
+
241
+
242
+            if($args['label_type']=='horizontal' && $type != 'checkbox'){
243
+                $output = self::wrap( array(
244
+                    'content' => $output,
245
+                    'class'   => 'col-sm-10',
246
+                ) );
247
+            }
248
+
249
+            if(!$label_after){
250
+                $output = $label . $output;
251
+            }
252
+
253
+            // wrap
254
+            if(!$args['no_wrap']){
255
+
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
+                ));
265
+            }
266
+
267
+
268
+
269
+        }
270
+
271
+        return $output;
272
+    }
273
+
274
+    /**
275
+     * Build the component.
276
+     *
277
+     * @param array $args
278
+     *
279
+     * @return string The rendered component.
280
+     */
281
+    public static function textarea($args = array()){
282
+        $defaults = array(
283
+            'name'       => '',
284
+            'class'      => '',
285
+            'wrap_class' => '',
286
+            'id'         => '',
287
+            'placeholder'=> '',
288
+            'title'      => '',
289
+            'value'      => '',
290
+            'required'   => false,
291
+            'label'      => '',
292
+            'label_after'=> false,
293
+            'label_class'      => '',
294
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
295
+            'help_text'  => '',
296
+            'validation_text'   => '',
297
+            'validation_pattern' => '',
298
+            'no_wrap'    => false,
299
+            'rows'      => '',
300
+            'wysiwyg'   => false,
301
+            'allow_tags' => false, // Allow HTML tags
302
+            'element_require'   => '', // [%element_id%] == "1"
303
+            'extra_attributes'  => array(), // an array of extra attributes
304
+        );
305
+
306
+        /**
307
+         * Parse incoming $args into an array and merge it with $defaults
308
+         */
309
+        $args   = wp_parse_args( $args, $defaults );
310
+        $output = '';
311
+
312
+        // hidden label option needs to be empty
313
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
314
+
315
+        // floating labels don't work with wysiwyg so set it as top
316
+        if($args['label_type'] == 'floating' && !empty($args['wysiwyg'])){
317
+            $args['label_type'] = 'top';
318
+        }
319
+
320
+        $label_after = $args['label_after'];
321
+
322
+        // floating labels need label after
323
+        if( $args['label_type'] == 'floating' && empty($args['wysiwyg']) ){
324
+            $label_after = true;
325
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
326
+        }
327
+
328
+        // label
329
+        if(!empty($args['label']) && is_array($args['label'])){
330
+        }elseif(!empty($args['label']) && !$label_after){
331
+            $label_args = array(
332
+                'title'=> $args['label'],
333
+                'for'=> $args['id'],
334
+                'class' => $args['label_class']." ",
335
+                'label_type' => $args['label_type']
336
+            );
337
+            $output .= self::label( $label_args );
338
+        }
339
+
340
+        // maybe horizontal label
341
+        if($args['label_type']=='horizontal'){
342
+            $output .= '<div class="col-sm-10">';
343
+        }
344
+
345
+        if(!empty($args['wysiwyg'])){
346
+            ob_start();
347
+            $content = $args['value'];
348
+            $editor_id = !empty($args['id']) ? sanitize_html_class($args['id']) : 'wp_editor';
349
+            $settings = array(
350
+                'textarea_rows' => !empty(absint($args['rows'])) ? absint($args['rows']) : 4,
351
+                'quicktags'     => false,
352
+                'media_buttons' => false,
353
+                'editor_class'  => 'form-control',
354
+                'textarea_name' => !empty($args['name']) ? sanitize_html_class($args['name']) : sanitize_html_class($args['id']),
355
+                'teeny'         => true,
356
+            );
357
+
358
+            // maybe set settings if array
359
+            if(is_array($args['wysiwyg'])){
360
+                $settings  = wp_parse_args( $args['wysiwyg'], $settings );
361
+            }
362
+
363
+            wp_editor( $content, $editor_id, $settings );
364
+            $output .= ob_get_clean();
365
+        }else{
366
+
367
+            // open
368
+            $output .= '<textarea ';
369
+
370
+            // name
371
+            if(!empty($args['name'])){
372
+                $output .= ' name="'.sanitize_html_class($args['name']).'" ';
373
+            }
374
+
375
+            // id
376
+            if(!empty($args['id'])){
377
+                $output .= ' id="'.sanitize_html_class($args['id']).'" ';
378
+            }
379
+
380
+            // placeholder
381
+            if(isset($args['placeholder']) && '' != $args['placeholder']){
382
+                $output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
383
+            }
384
+
385
+            // title
386
+            if(!empty($args['title'])){
387
+                $output .= ' title="'.esc_attr($args['title']).'" ';
388
+            }
389
+
390
+            // validation text
391
+            if(!empty($args['validation_text'])){
392
+                $output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
393
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
394
+            }
395
+
396
+            // validation_pattern
397
+            if(!empty($args['validation_pattern'])){
398
+                $output .= ' pattern="'.$args['validation_pattern'].'" ';
399
+            }
400
+
401
+            // required
402
+            if(!empty($args['required'])){
403
+                $output .= ' required ';
404
+            }
405
+
406
+            // rows
407
+            if(!empty($args['rows'])){
408
+                $output .= ' rows="'.absint($args['rows']).'" ';
409
+            }
410
+
411
+
412
+            // class
413
+            $class = !empty($args['class']) ? $args['class'] : '';
414
+            $output .= ' class="form-control '.$class.'" ';
415
+
416
+            // extra attributes
417
+            if(!empty($args['extra_attributes'])){
418
+                $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
419
+            }
420
+
421
+            // close tag
422
+            $output .= ' >';
423
+
424
+            // value
425
+            if ( ! empty( $args['value'] ) ) {
426
+                if ( ! empty( $args['allow_tags'] ) ) {
427
+                    $output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
428
+                } else {
429
+                    $output .= sanitize_textarea_field( $args['value'] );
430
+                }
431
+            }
432
+
433
+            // closing tag
434
+            $output .= '</textarea>';
435
+
436
+        }
437
+
438
+        if(!empty($args['label']) && $label_after){
439
+            $label_args = array(
440
+                'title'=> $args['label'],
441
+                'for'=> $args['id'],
442
+                'class' => $args['label_class']." ",
443
+                'label_type' => $args['label_type']
444
+            );
445
+            $output .= self::label( $label_args );
446
+        }
447
+
448
+        // help text
449
+        if(!empty($args['help_text'])){
450
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
451
+        }
452
+
453
+        // maybe horizontal label
454
+        if($args['label_type']=='horizontal'){
455
+            $output .= '</div>';
456
+        }
457
+
458
+
459
+        // wrap
460
+        if(!$args['no_wrap']){
461
+            $form_group_class = $args['label_type']=='floating' ? 'form-label-group' : 'form-group';
462
+            $wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
463
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
464
+            $output = self::wrap(array(
465
+                'content' => $output,
466
+                'class'   => $wrap_class,
467
+                'element_require'   => $args['element_require'],
468
+                'argument_id'  => $args['id']
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="'.sanitize_text_field($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
+        );
555
+
556
+        /**
557
+         * Parse incoming $args into an array and merge it with $defaults
558
+         */
559
+        $args   = wp_parse_args( $args, $defaults );
560
+        $output = '';
561
+        if($args['type']){
562
+
563
+            // open
564
+            $output .= '<'.sanitize_html_class($args['type']);
565
+
566
+            // element require
567
+            if(!empty($args['element_require'])){
568
+                $output .= AUI_Component_Helper::element_require($args['element_require']);
569
+                $args['class'] .= " aui-conditional-field";
570
+            }
571
+
572
+            // argument_id
573
+            if( !empty($args['argument_id']) ){
574
+                $output .= ' data-argument="'.esc_attr($args['argument_id']).'"';
575
+            }
576
+
577
+            // class
578
+            $class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
579
+            $output .= ' class="'.$class.'" ';
580
+
581
+            // close wrap
582
+            $output .= ' >';
583
+
584
+
585
+            // Input group left
586
+            if(!empty($args['input_group_left'])){
587
+                $position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
588
+                $input_group_left = strpos($args['input_group_left'], '<') !== false ? $args['input_group_left'] : '<span class="input-group-text">'.$args['input_group_left'].'</span>';
589
+                $output .= '<div class="input-group-prepend '.$position_class.'">'.$input_group_left.'</div>';
590
+            }
591
+
592
+            // content
593
+            $output .= $args['content'];
594
+
595
+            // Input group right
596
+            if(!empty($args['input_group_right'])){
597
+                $position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
598
+                $input_group_right = strpos($args['input_group_right'], '<') !== false ? $args['input_group_right'] : '<span class="input-group-text">'.$args['input_group_right'].'</span>';
599
+                $output .= '<div class="input-group-append '.$position_class.'">'.$input_group_right.'</div>';
600
+            }
601
+
602
+
603
+            // close wrap
604
+            $output .= '</'.sanitize_html_class($args['type']).'>';
605
+
606
+
607
+        }else{
608
+            $output = $args['content'];
609
+        }
610
+
611
+        return $output;
612
+    }
613
+
614
+    /**
615
+     * Build the component.
616
+     *
617
+     * @param array $args
618
+     *
619
+     * @return string The rendered component.
620
+     */
621
+    public static function select($args = array()){
622
+        $defaults = array(
623
+            'class'      => '',
624
+            'wrap_class' => '',
625
+            'id'         => '',
626
+            'title'      => '',
627
+            'value'      => '', // can be an array or a string
628
+            'required'   => false,
629
+            'label'      => '',
630
+            'label_after'=> false,
631
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
632
+            'label_class'      => '',
633
+            'help_text'  => '',
634
+            'placeholder'=> '',
635
+            'options'    => array(), // array or string
636
+            'icon'       => '',
637
+            'multiple'   => false,
638
+            'select2'    => false,
639
+            'no_wrap'    => false,
640
+            'element_require'   => '', // [%element_id%] == "1"
641
+            'extra_attributes'  => array(), // an array of extra attributes
642
+        );
643
+
644
+        /**
645
+         * Parse incoming $args into an array and merge it with $defaults
646
+         */
647
+        $args   = wp_parse_args( $args, $defaults );
648
+        $output = '';
649
+
650
+        // for now lets hide floating labels
651
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'hidden';}
652
+
653
+        // hidden label option needs to be empty
654
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
655
+
656
+
657
+        $label_after = $args['label_after'];
658
+
659
+        // floating labels need label after
660
+        if( $args['label_type'] == 'floating' ){
661
+            $label_after = true;
662
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
663
+        }
664
+
665
+        // Maybe setup select2
666
+        $is_select2 = false;
667
+        if(!empty($args['select2'])){
668
+            $args['class'] .= ' aui-select2';
669
+            $is_select2 = true;
670
+        }elseif( strpos($args['class'], 'aui-select2') !== false){
671
+            $is_select2 = true;
672
+        }
673
+
674
+        // select2 tags
675
+        if( !empty($args['select2']) && $args['select2'] === 'tags'){ // triple equals needed here for some reason
676
+            $args['data-tags'] = 'true';
677
+            $args['data-token-separators'] = "[',']";
678
+            $args['multiple'] = true;
679
+        }
680
+
681
+        // select2 placeholder
682
+        if($is_select2 && isset($args['placeholder']) && '' != $args['placeholder'] && empty($args['data-placeholder'])){
683
+            $args['data-placeholder'] = esc_attr($args['placeholder']);
684
+            $args['data-allow-clear'] = isset($args['data-allow-clear']) ? (bool) $args['data-allow-clear'] : true;
685
+        }
686
+
687
+        // label
688
+        if(!empty($args['label']) && is_array($args['label'])){
689
+        }elseif(!empty($args['label']) && !$label_after){
690
+            $label_args = array(
691
+                'title'=> $args['label'],
692
+                'for'=> $args['id'],
693
+                'class' => $args['label_class']." ",
694
+                'label_type' => $args['label_type']
695
+            );
696
+            $output .= self::label($label_args);
697
+        }
698
+
699
+        // maybe horizontal label
700
+        if($args['label_type']=='horizontal'){
701
+            $output .= '<div class="col-sm-10">';
702
+        }
703
+
704
+        // Set hidden input to save empty value for multiselect.
705
+        if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
706
+            $output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
707
+        }
708
+
709
+        // open/type
710
+        $output .= '<select ';
711
+
712
+        // style
713
+        if($is_select2){
714
+            $output .= " style='width:100%;' ";
715
+        }
716
+
717
+        // element require
718
+        if(!empty($args['element_require'])){
719
+            $output .= AUI_Component_Helper::element_require($args['element_require']);
720
+            $args['class'] .= " aui-conditional-field";
721
+        }
722
+
723
+        // class
724
+        $class = !empty($args['class']) ? $args['class'] : '';
725
+        $output .= AUI_Component_Helper::class_attr('custom-select '.$class);
726
+
727
+        // name
728
+        if(!empty($args['name'])){
729
+            $output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
730
+        }
731
+
732
+        // id
733
+        if(!empty($args['id'])){
734
+            $output .= AUI_Component_Helper::id($args['id']);
735
+        }
736
+
737
+        // title
738
+        if(!empty($args['title'])){
739
+            $output .= AUI_Component_Helper::title($args['title']);
740
+        }
741
+
742
+        // data-attributes
743
+        $output .= AUI_Component_Helper::data_attributes($args);
744
+
745
+        // aria-attributes
746
+        $output .= AUI_Component_Helper::aria_attributes($args);
747
+
748
+        // extra attributes
749
+        if(!empty($args['extra_attributes'])){
750
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
751
+        }
752
+
753
+        // required
754
+        if(!empty($args['required'])){
755
+            $output .= ' required ';
756
+        }
757
+
758
+        // multiple
759
+        if(!empty($args['multiple'])){
760
+            $output .= ' multiple ';
761
+        }
762
+
763
+        // close opening tag
764
+        $output .= ' >';
765
+
766
+        // placeholder
767
+        if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
768
+            $output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
769
+        }elseif($is_select2 && !empty($args['placeholder'])){
770
+            $output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
771
+        }
772
+
773
+        // Options
774
+        if(!empty($args['options'])){
775
+
776
+            if(!is_array($args['options'])){
777
+                $output .= $args['options']; // not the preferred way but an option
778
+            }else{
779
+                foreach($args['options'] as $val => $name){
780
+                    $selected = '';
781
+                    if(is_array($name)){
782
+                        if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
783
+                            $option_label = isset($name['label']) ? $name['label'] : '';
784
+
785
+                            $output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
786
+                        } else {
787
+                            $option_label = isset($name['label']) ? $name['label'] : '';
788
+                            $option_value = isset($name['value']) ? $name['value'] : '';
789
+                            if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
790
+                                $selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
791
+                            } elseif(!empty($args['value'])) {
792
+                                $selected = selected($option_value,stripslashes_deep($args['value']), false);
793
+                            }
794
+
795
+                            $output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
796
+                        }
797
+                    }else{
798
+                        if(!empty($args['value'])){
799
+                            if(is_array($args['value'])){
800
+                                $selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
801
+                            } elseif(!empty($args['value'])) {
802
+                                $selected = selected( $args['value'], $val, false);
803
+                            }
804
+                        }
805
+                        $output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
806
+                    }
807
+                }
808
+            }
809
+
810
+        }
811
+
812
+        // closing tag
813
+        $output .= '</select>';
814
+
815
+        if(!empty($args['label']) && $label_after){
816
+            $label_args = array(
817
+                'title'=> $args['label'],
818
+                'for'=> $args['id'],
819
+                'class' => $args['label_class']." ",
820
+                'label_type' => $args['label_type']
821
+            );
822
+            $output .= self::label($label_args);
823
+        }
824
+
825
+        // help text
826
+        if(!empty($args['help_text'])){
827
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
828
+        }
829
+
830
+        // maybe horizontal label
831
+        if($args['label_type']=='horizontal'){
832
+            $output .= '</div>';
833
+        }
834
+
835
+
836
+        // wrap
837
+        if(!$args['no_wrap']){
838
+            $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
839
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
840
+            $output = self::wrap(array(
841
+                'content' => $output,
842
+                'class'   => $wrap_class,
843
+                'element_require'   => $args['element_require'],
844
+                'argument_id'  => $args['id']
845
+            ));
846
+        }
847
+
848
+
849
+        return $output;
850
+    }
851
+
852
+    /**
853
+     * Build the component.
854
+     *
855
+     * @param array $args
856
+     *
857
+     * @return string The rendered component.
858
+     */
859
+    public static function radio($args = array()){
860
+        $defaults = array(
861
+            'class'      => '',
862
+            'wrap_class' => '',
863
+            'id'         => '',
864
+            'title'      => '',
865
+            'horizontal' => false, // sets the lable horizontal
866
+            'value'      => '',
867
+            'label'      => '',
868
+            'label_class'=> '',
869
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
870
+            'help_text'  => '',
871
+            'inline'     => true,
872
+            'required'   => false,
873
+            'options'    => array(),
874
+            'icon'       => '',
875
+            'no_wrap'    => false,
876
+            'element_require'   => '', // [%element_id%] == "1"
877
+            'extra_attributes'  => array() // an array of extra attributes
878
+        );
879
+
880
+        /**
881
+         * Parse incoming $args into an array and merge it with $defaults
882
+         */
883
+        $args   = wp_parse_args( $args, $defaults );
884
+
885
+        // for now lets use horizontal for floating
886
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
887
+
888
+        $label_args = array(
889
+            'title'=> $args['label'],
890
+            'class' => $args['label_class']." pt-0 ",
891
+            'label_type' => $args['label_type']
892
+        );
893
+
894
+        $output = '';
895
+
896
+
897
+
898
+        // label before
899
+        if(!empty($args['label'])){
900
+            $output .= self::label( $label_args, 'radio' );
901
+        }
902
+
903
+        // maybe horizontal label
904
+        if($args['label_type']=='horizontal'){
905
+            $output .= '<div class="col-sm-10">';
906
+        }
907
+
908
+        if(!empty($args['options'])){
909
+            $count = 0;
910
+            foreach($args['options'] as $value => $label){
911
+                $option_args = $args;
912
+                $option_args['value'] = $value;
913
+                $option_args['label'] = $label;
914
+                $option_args['checked'] = $value == $args['value'] ? true : false;
915
+                $output .= self::radio_option($option_args,$count);
916
+                $count++;
917
+            }
918
+        }
919
+
920
+        // help text
921
+        $help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
922
+        $output .= $help_text;
923
+
924
+        // maybe horizontal label
925
+        if($args['label_type']=='horizontal'){
926
+            $output .= '</div>';
927
+        }
928
+
929
+        // wrap
930
+        $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
931
+        $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
932
+        $output = self::wrap(array(
933
+            'content' => $output,
934
+            'class'   => $wrap_class,
935
+            'element_require'   => $args['element_require'],
936
+            'argument_id'  => $args['id']
937
+        ));
938
+
939
+
940
+        return $output;
941
+    }
942
+
943
+    /**
944
+     * Build the component.
945
+     *
946
+     * @param array $args
947
+     *
948
+     * @return string The rendered component.
949
+     */
950
+    public static function radio_option($args = array(),$count = ''){
951
+        $defaults = array(
952
+            'class'      => '',
953
+            'id'         => '',
954
+            'title'      => '',
955
+            'value'      => '',
956
+            'required'   => false,
957
+            'inline'     => true,
958
+            'label'      => '',
959
+            'options'    => array(),
960
+            'icon'       => '',
961
+            'no_wrap'    => false,
962
+            'extra_attributes'  => array() // an array of extra attributes
963
+        );
964
+
965
+        /**
966
+         * Parse incoming $args into an array and merge it with $defaults
967
+         */
968
+        $args   = wp_parse_args( $args, $defaults );
969
+
970
+        $output = '';
971
+
972
+        // open/type
973
+        $output .= '<input type="radio"';
974
+
975
+        // class
976
+        $output .= ' class="form-check-input" ';
977
+
978
+        // name
979
+        if(!empty($args['name'])){
980
+            $output .= AUI_Component_Helper::name($args['name']);
981
+        }
982
+
983
+        // id
984
+        if(!empty($args['id'])){
985
+            $output .= AUI_Component_Helper::id($args['id'].$count);
986
+        }
987
+
988
+        // title
989
+        if(!empty($args['title'])){
990
+            $output .= AUI_Component_Helper::title($args['title']);
991
+        }
992
+
993
+        // value
994
+        if(isset($args['value'])){
995
+            $output .= ' value="'.sanitize_text_field($args['value']).'" ';
996
+        }
997
+
998
+        // checked, for radio and checkboxes
999
+        if( $args['checked'] ){
1000
+            $output .= ' checked ';
1001
+        }
1002
+
1003
+        // data-attributes
1004
+        $output .= AUI_Component_Helper::data_attributes($args);
1005
+
1006
+        // aria-attributes
1007
+        $output .= AUI_Component_Helper::aria_attributes($args);
1008
+
1009
+        // extra attributes
1010
+        if(!empty($args['extra_attributes'])){
1011
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1012
+        }
1013
+
1014
+        // required
1015
+        if(!empty($args['required'])){
1016
+            $output .= ' required ';
1017
+        }
1018
+
1019
+        // close opening tag
1020
+        $output .= ' >';
1021
+
1022
+        // label
1023
+        if(!empty($args['label']) && is_array($args['label'])){
1024
+        }elseif(!empty($args['label'])){
1025
+            $output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1026
+        }
1027
+
1028
+        // wrap
1029
+        if(!$args['no_wrap']){
1030
+            $wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1031
+            $output = self::wrap(array(
1032
+                'content' => $output,
1033
+                'class' => $wrap_class
1034
+            ));
1035
+        }
1036
+
1037
+
1038
+        return $output;
1039
+    }
1040 1040
 
1041 1041
 }
1042 1042
\ 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.49';
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.49';
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-ayecode-ui/includes/ayecode-ui-settings.php 1 patch
Indentation   +1223 added lines, -1223 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,236 +21,236 @@  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.49';
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
-
115
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
116
-
117
-				do_action( 'ayecode_ui_settings_loaded' );
118
-			}
119
-
120
-			return self::$instance;
121
-		}
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
-		}
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
-			}
166
-
167
-
168
-		}
169
-
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
-
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
-		}
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.49';
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
+                }
198 114
 
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
-				);
215
-				$screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
216
-
217
-				$screen = get_current_screen();
115
+                add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
116
+
117
+                do_action( 'ayecode_ui_settings_loaded' );
118
+            }
119
+
120
+            return self::$instance;
121
+        }
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
+        }
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
+            }
166
+
167
+
168
+        }
169
+
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
+
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
+                );
215
+                $screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
216
+
217
+                $screen = get_current_screen();
218 218
 
219 219
 //				echo '###'.$screen->id;
220 220
 				
221
-				if ( $screen && in_array( $screen->id, $screen_ids ) ) {
222
-					$load = true;
223
-				}
224
-			}
221
+                if ( $screen && in_array( $screen->id, $screen_ids ) ) {
222
+                    $load = true;
223
+                }
224
+            }
225 225
 
226
-			return $load;
227
-		}
226
+            return $load;
227
+        }
228 228
 
229
-		/**
230
-		 * Adds the styles.
231
-		 */
232
-		public function enqueue_style() {
229
+        /**
230
+         * Adds the styles.
231
+         */
232
+        public function enqueue_style() {
233 233
 
234
-			if( is_admin() && !$this->is_aui_screen()){
235
-				// don't add wp-admin scripts if not requested to
236
-			}else{
237
-				$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
234
+            if( is_admin() && !$this->is_aui_screen()){
235
+                // don't add wp-admin scripts if not requested to
236
+            }else{
237
+                $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
238 238
 
239
-				$rtl = is_rtl() ? '-rtl' : '';
239
+                $rtl = is_rtl() ? '-rtl' : '';
240 240
 
241
-				if($this->settings[$css_setting]){
242
-					$compatibility = $this->settings[$css_setting]=='core' ? false : true;
243
-					$url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
244
-					wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
245
-					wp_enqueue_style( 'ayecode-ui' );
241
+                if($this->settings[$css_setting]){
242
+                    $compatibility = $this->settings[$css_setting]=='core' ? false : true;
243
+                    $url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
244
+                    wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
245
+                    wp_enqueue_style( 'ayecode-ui' );
246 246
 
247
-					// flatpickr
248
-					wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
247
+                    // flatpickr
248
+                    wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
249 249
 
250 250
 
251
-					// fix some wp-admin issues
252
-					if(is_admin()){
253
-						$custom_css = "
251
+                    // fix some wp-admin issues
252
+                    if(is_admin()){
253
+                        $custom_css = "
254 254
                 body{
255 255
                     background-color: #f1f1f1;
256 256
                     font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif;
@@ -292,35 +292,35 @@  discard block
 block discarded – undo
292 292
 				}
293 293
                 ";
294 294
 
295
-						// @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
296
-						$custom_css .= "
295
+                        // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
296
+                        $custom_css .= "
297 297
 						.edit-post-sidebar input[type=color].components-text-control__input{
298 298
 						    padding: 0;
299 299
 						}
300 300
 					";
301
-						wp_add_inline_style( 'ayecode-ui', $custom_css );
302
-					}
301
+                        wp_add_inline_style( 'ayecode-ui', $custom_css );
302
+                    }
303 303
 
304
-					// custom changes
305
-					wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
304
+                    // custom changes
305
+                    wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
306 306
 
307
-				}
308
-			}
307
+                }
308
+            }
309 309
 
310 310
 
311
-		}
311
+        }
312
+
313
+        /**
314
+         * Get inline script used if bootstrap enqueued
315
+         *
316
+         * If this remains small then its best to use this than to add another JS file.
317
+         */
318
+        public function inline_script() {
319
+            // Flatpickr calendar locale
320
+            $flatpickr_locale = self::flatpickr_locale();
312 321
 
313
-		/**
314
-		 * Get inline script used if bootstrap enqueued
315
-		 *
316
-		 * If this remains small then its best to use this than to add another JS file.
317
-		 */
318
-		public function inline_script() {
319
-			// Flatpickr calendar locale
320
-			$flatpickr_locale = self::flatpickr_locale();
321
-
322
-			ob_start();
323
-			?>
322
+            ob_start();
323
+            ?>
324 324
 			<script>
325 325
 				/**
326 326
 				 * An AUI bootstrap adaptation of GreedyNav.js ( by Luke Jackson ).
@@ -985,29 +985,29 @@  discard block
 block discarded – undo
985 985
 
986 986
 			</script>
987 987
 			<?php
988
-			$output = ob_get_clean();
988
+            $output = ob_get_clean();
989 989
 
990 990
 
991 991
 
992
-			/*
992
+            /*
993 993
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
994 994
 			 */
995
-			return str_replace( array(
996
-				'<script>',
997
-				'</script>'
998
-			), '', self::minify_js($output) );
999
-		}
1000
-
1001
-
1002
-		/**
1003
-		 * JS to help with conflict issues with other plugins and themes using bootstrap v3.
1004
-		 *
1005
-		 * @TODO we may need this when other conflicts arrise.
1006
-		 * @return mixed
1007
-		 */
1008
-		public static function bs3_compat_js() {
1009
-			ob_start();
1010
-			?>
995
+            return str_replace( array(
996
+                '<script>',
997
+                '</script>'
998
+            ), '', self::minify_js($output) );
999
+        }
1000
+
1001
+
1002
+        /**
1003
+         * JS to help with conflict issues with other plugins and themes using bootstrap v3.
1004
+         *
1005
+         * @TODO we may need this when other conflicts arrise.
1006
+         * @return mixed
1007
+         */
1008
+        public static function bs3_compat_js() {
1009
+            ob_start();
1010
+            ?>
1011 1011
 			<script>
1012 1012
 				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
1013 1013
 				/* With Avada builder */
@@ -1015,20 +1015,20 @@  discard block
 block discarded – undo
1015 1015
 				<?php } ?>
1016 1016
 			</script>
1017 1017
 			<?php
1018
-			return str_replace( array(
1019
-				'<script>',
1020
-				'</script>'
1021
-			), '', ob_get_clean());
1022
-		}
1023
-
1024
-		/**
1025
-		 * Get inline script used if bootstrap file browser enqueued.
1026
-		 *
1027
-		 * If this remains small then its best to use this than to add another JS file.
1028
-		 */
1029
-		public function inline_script_file_browser(){
1030
-			ob_start();
1031
-			?>
1018
+            return str_replace( array(
1019
+                '<script>',
1020
+                '</script>'
1021
+            ), '', ob_get_clean());
1022
+        }
1023
+
1024
+        /**
1025
+         * Get inline script used if bootstrap file browser enqueued.
1026
+         *
1027
+         * If this remains small then its best to use this than to add another JS file.
1028
+         */
1029
+        public function inline_script_file_browser(){
1030
+            ob_start();
1031
+            ?>
1032 1032
 			<script>
1033 1033
 				// run on doc ready
1034 1034
 				jQuery(document).ready(function () {
@@ -1036,192 +1036,192 @@  discard block
 block discarded – undo
1036 1036
 				});
1037 1037
 			</script>
1038 1038
 			<?php
1039
-			$output = ob_get_clean();
1039
+            $output = ob_get_clean();
1040 1040
 
1041
-			/*
1041
+            /*
1042 1042
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1043 1043
 			 */
1044
-			return str_replace( array(
1045
-				'<script>',
1046
-				'</script>'
1047
-			), '', $output );
1048
-		}
1049
-
1050
-		/**
1051
-		 * Adds the Font Awesome JS.
1052
-		 */
1053
-		public function enqueue_scripts() {
1054
-
1055
-			if( is_admin() && !$this->is_aui_screen()){
1056
-				// don't add wp-admin scripts if not requested to
1057
-			}else {
1058
-
1059
-				$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
1060
-
1061
-				// select2
1062
-				wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
1063
-
1064
-				// flatpickr
1065
-				wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->latest );
1066
-
1067
-				// Bootstrap file browser
1068
-				wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
1069
-				wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
1070
-
1071
-				$load_inline = false;
1072
-
1073
-				if ( $this->settings[ $js_setting ] == 'core-popper' ) {
1074
-					// Bootstrap bundle
1075
-					$url = $this->url . 'assets/js/bootstrap.bundle.min.js';
1076
-					wp_register_script( 'bootstrap-js-bundle', $url, array(
1077
-						'select2',
1078
-						'jquery'
1079
-					), $this->latest, $this->is_bs3_compat() );
1080
-					// if in admin then add to footer for compatibility.
1081
-					is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
1082
-					$script = $this->inline_script();
1083
-					wp_add_inline_script( 'bootstrap-js-bundle', $script );
1084
-				} elseif ( $this->settings[ $js_setting ] == 'popper' ) {
1085
-					$url = $this->url . 'assets/js/popper.min.js';
1086
-					wp_register_script( 'bootstrap-js-popper', $url, array( 'select2', 'jquery' ), $this->latest );
1087
-					wp_enqueue_script( 'bootstrap-js-popper' );
1088
-					$load_inline = true;
1089
-				} else {
1090
-					$load_inline = true;
1091
-				}
1092
-
1093
-				// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
1094
-				if ( $load_inline ) {
1095
-					wp_register_script( 'bootstrap-dummy', '', array( 'select2', 'jquery' ) );
1096
-					wp_enqueue_script( 'bootstrap-dummy' );
1097
-					$script = $this->inline_script();
1098
-					wp_add_inline_script( 'bootstrap-dummy', $script );
1099
-				}
1100
-			}
1101
-
1102
-		}
1103
-
1104
-		/**
1105
-		 * Enqueue flatpickr if called.
1106
-		 */
1107
-		public function enqueue_flatpickr(){
1108
-			wp_enqueue_style( 'flatpickr' );
1109
-			wp_enqueue_script( 'flatpickr' );
1110
-		}
1111
-
1112
-		/**
1113
-		 * Get the url path to the current folder.
1114
-		 *
1115
-		 * @return string
1116
-		 */
1117
-		public function get_url() {
1118
-
1119
-			$url = '';
1120
-			// check if we are inside a plugin
1121
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
1122
-
1123
-			// add check in-case user has changed wp-content dir name.
1124
-			$wp_content_folder_name = basename(WP_CONTENT_DIR);
1125
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
1126
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
1127
-
1128
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
1129
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
1130
-			}
1131
-
1132
-			return $url;
1133
-		}
1134
-
1135
-		/**
1136
-		 * Register the database settings with WordPress.
1137
-		 */
1138
-		public function register_settings() {
1139
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
1140
-		}
1141
-
1142
-		/**
1143
-		 * Add the WordPress settings menu item.
1144
-		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
1145
-		 */
1146
-		public function menu_item() {
1147
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
1148
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
1149
-				$this,
1150
-				'settings_page'
1151
-			) );
1152
-		}
1153
-
1154
-		/**
1155
-		 * Get a list of themes and their default JS settings.
1156
-		 *
1157
-		 * @return array
1158
-		 */
1159
-		public function theme_js_settings(){
1160
-			return array(
1161
-				'ayetheme' => 'popper',
1162
-				'listimia' => 'required',
1163
-				'listimia_backend' => 'core-popper',
1164
-				//'avada'    => 'required', // removed as we now add compatibility
1165
-			);
1166
-		}
1167
-
1168
-		/**
1169
-		 * Get the current Font Awesome output settings.
1170
-		 *
1171
-		 * @return array The array of settings.
1172
-		 */
1173
-		public function get_settings() {
1174
-
1175
-			$db_settings = get_option( 'ayecode-ui-settings' );
1176
-			$js_default = 'core-popper';
1177
-			$js_default_backend = $js_default;
1178
-
1179
-			// maybe set defaults (if no settings set)
1180
-			if(empty($db_settings)){
1181
-				$active_theme = strtolower( get_template() ); // active parent theme.
1182
-				$theme_js_settings = self::theme_js_settings();
1183
-				if(isset($theme_js_settings[$active_theme])){
1184
-					$js_default = $theme_js_settings[$active_theme];
1185
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
1186
-				}
1187
-			}
1188
-
1189
-			$defaults = array(
1190
-				'css'       => 'compatibility', // core, compatibility
1191
-				'js'        => $js_default, // js to load, core-popper, popper
1192
-				'html_font_size'        => '16', // js to load, core-popper, popper
1193
-				'css_backend'       => 'compatibility', // core, compatibility
1194
-				'js_backend'        => $js_default_backend, // js to load, core-popper, popper
1195
-				'disable_admin'     =>  '', // URL snippets to disable loading on admin
1196
-			);
1197
-
1198
-			$settings = wp_parse_args( $db_settings, $defaults );
1199
-
1200
-			/**
1201
-			 * Filter the Bootstrap settings.
1202
-			 *
1203
-			 * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
1204
-			 */
1205
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
1206
-		}
1207
-
1044
+            return str_replace( array(
1045
+                '<script>',
1046
+                '</script>'
1047
+            ), '', $output );
1048
+        }
1049
+
1050
+        /**
1051
+         * Adds the Font Awesome JS.
1052
+         */
1053
+        public function enqueue_scripts() {
1054
+
1055
+            if( is_admin() && !$this->is_aui_screen()){
1056
+                // don't add wp-admin scripts if not requested to
1057
+            }else {
1058
+
1059
+                $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
1060
+
1061
+                // select2
1062
+                wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
1063
+
1064
+                // flatpickr
1065
+                wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->latest );
1066
+
1067
+                // Bootstrap file browser
1068
+                wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
1069
+                wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
1070
+
1071
+                $load_inline = false;
1072
+
1073
+                if ( $this->settings[ $js_setting ] == 'core-popper' ) {
1074
+                    // Bootstrap bundle
1075
+                    $url = $this->url . 'assets/js/bootstrap.bundle.min.js';
1076
+                    wp_register_script( 'bootstrap-js-bundle', $url, array(
1077
+                        'select2',
1078
+                        'jquery'
1079
+                    ), $this->latest, $this->is_bs3_compat() );
1080
+                    // if in admin then add to footer for compatibility.
1081
+                    is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
1082
+                    $script = $this->inline_script();
1083
+                    wp_add_inline_script( 'bootstrap-js-bundle', $script );
1084
+                } elseif ( $this->settings[ $js_setting ] == 'popper' ) {
1085
+                    $url = $this->url . 'assets/js/popper.min.js';
1086
+                    wp_register_script( 'bootstrap-js-popper', $url, array( 'select2', 'jquery' ), $this->latest );
1087
+                    wp_enqueue_script( 'bootstrap-js-popper' );
1088
+                    $load_inline = true;
1089
+                } else {
1090
+                    $load_inline = true;
1091
+                }
1208 1092
 
1209
-		/**
1210
-		 * The settings page html output.
1211
-		 */
1212
-		public function settings_page() {
1213
-			if ( ! current_user_can( 'manage_options' ) ) {
1214
-				wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
1215
-			}
1216
-			?>
1093
+                // Load needed inline scripts by faking the loading of a script if the main script is not being loaded
1094
+                if ( $load_inline ) {
1095
+                    wp_register_script( 'bootstrap-dummy', '', array( 'select2', 'jquery' ) );
1096
+                    wp_enqueue_script( 'bootstrap-dummy' );
1097
+                    $script = $this->inline_script();
1098
+                    wp_add_inline_script( 'bootstrap-dummy', $script );
1099
+                }
1100
+            }
1101
+
1102
+        }
1103
+
1104
+        /**
1105
+         * Enqueue flatpickr if called.
1106
+         */
1107
+        public function enqueue_flatpickr(){
1108
+            wp_enqueue_style( 'flatpickr' );
1109
+            wp_enqueue_script( 'flatpickr' );
1110
+        }
1111
+
1112
+        /**
1113
+         * Get the url path to the current folder.
1114
+         *
1115
+         * @return string
1116
+         */
1117
+        public function get_url() {
1118
+
1119
+            $url = '';
1120
+            // check if we are inside a plugin
1121
+            $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
1122
+
1123
+            // add check in-case user has changed wp-content dir name.
1124
+            $wp_content_folder_name = basename(WP_CONTENT_DIR);
1125
+            $dir_parts = explode("/$wp_content_folder_name/",$file_dir);
1126
+            $url_parts = explode("/$wp_content_folder_name/",plugins_url());
1127
+
1128
+            if(!empty($url_parts[0]) && !empty($dir_parts[1])){
1129
+                $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
1130
+            }
1131
+
1132
+            return $url;
1133
+        }
1134
+
1135
+        /**
1136
+         * Register the database settings with WordPress.
1137
+         */
1138
+        public function register_settings() {
1139
+            register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
1140
+        }
1141
+
1142
+        /**
1143
+         * Add the WordPress settings menu item.
1144
+         * @since 1.0.10 Calling function name direct will fail theme check so we don't.
1145
+         */
1146
+        public function menu_item() {
1147
+            $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
1148
+            call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
1149
+                $this,
1150
+                'settings_page'
1151
+            ) );
1152
+        }
1153
+
1154
+        /**
1155
+         * Get a list of themes and their default JS settings.
1156
+         *
1157
+         * @return array
1158
+         */
1159
+        public function theme_js_settings(){
1160
+            return array(
1161
+                'ayetheme' => 'popper',
1162
+                'listimia' => 'required',
1163
+                'listimia_backend' => 'core-popper',
1164
+                //'avada'    => 'required', // removed as we now add compatibility
1165
+            );
1166
+        }
1167
+
1168
+        /**
1169
+         * Get the current Font Awesome output settings.
1170
+         *
1171
+         * @return array The array of settings.
1172
+         */
1173
+        public function get_settings() {
1174
+
1175
+            $db_settings = get_option( 'ayecode-ui-settings' );
1176
+            $js_default = 'core-popper';
1177
+            $js_default_backend = $js_default;
1178
+
1179
+            // maybe set defaults (if no settings set)
1180
+            if(empty($db_settings)){
1181
+                $active_theme = strtolower( get_template() ); // active parent theme.
1182
+                $theme_js_settings = self::theme_js_settings();
1183
+                if(isset($theme_js_settings[$active_theme])){
1184
+                    $js_default = $theme_js_settings[$active_theme];
1185
+                    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
1186
+                }
1187
+            }
1188
+
1189
+            $defaults = array(
1190
+                'css'       => 'compatibility', // core, compatibility
1191
+                'js'        => $js_default, // js to load, core-popper, popper
1192
+                'html_font_size'        => '16', // js to load, core-popper, popper
1193
+                'css_backend'       => 'compatibility', // core, compatibility
1194
+                'js_backend'        => $js_default_backend, // js to load, core-popper, popper
1195
+                'disable_admin'     =>  '', // URL snippets to disable loading on admin
1196
+            );
1197
+
1198
+            $settings = wp_parse_args( $db_settings, $defaults );
1199
+
1200
+            /**
1201
+             * Filter the Bootstrap settings.
1202
+             *
1203
+             * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
1204
+             */
1205
+            return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
1206
+        }
1207
+
1208
+
1209
+        /**
1210
+         * The settings page html output.
1211
+         */
1212
+        public function settings_page() {
1213
+            if ( ! current_user_can( 'manage_options' ) ) {
1214
+                wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
1215
+            }
1216
+            ?>
1217 1217
 			<div class="wrap">
1218 1218
 				<h1><?php echo $this->name; ?></h1>
1219 1219
 				<p><?php _e("Here you can adjust settings if you are having compatibility issues.",'aui');?></p>
1220 1220
 				<form method="post" action="options.php">
1221 1221
 					<?php
1222
-					settings_fields( 'ayecode-ui-settings' );
1223
-					do_settings_sections( 'ayecode-ui-settings' );
1224
-					?>
1222
+                    settings_fields( 'ayecode-ui-settings' );
1223
+                    do_settings_sections( 'ayecode-ui-settings' );
1224
+                    ?>
1225 1225
 
1226 1226
 					<h2><?php _e( 'Frontend', 'aui' ); ?></h2>
1227 1227
 					<table class="form-table wpbs-table-settings">
@@ -1301,60 +1301,60 @@  discard block
 block discarded – undo
1301 1301
 					</table>
1302 1302
 
1303 1303
 					<?php
1304
-					submit_button();
1305
-					?>
1304
+                    submit_button();
1305
+                    ?>
1306 1306
 				</form>
1307 1307
 
1308 1308
 				<div id="wpbs-version"><?php echo $this->version; ?></div>
1309 1309
 			</div>
1310 1310
 
1311 1311
 			<?php
1312
-		}
1313
-
1314
-		public function customizer_settings($wp_customize){
1315
-			$wp_customize->add_section('aui_settings', array(
1316
-				'title'    => __('AyeCode UI','aui'),
1317
-				'priority' => 120,
1318
-			));
1319
-
1320
-			//  =============================
1321
-			//  = Color Picker              =
1322
-			//  =============================
1323
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1324
-				'default'           => AUI_PRIMARY_COLOR,
1325
-				'sanitize_callback' => 'sanitize_hex_color',
1326
-				'capability'        => 'edit_theme_options',
1327
-				'type'              => 'option',
1328
-				'transport'         => 'refresh',
1329
-			));
1330
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1331
-				'label'    => __('Primary Color','aui'),
1332
-				'section'  => 'aui_settings',
1333
-				'settings' => 'aui_options[color_primary]',
1334
-			)));
1335
-
1336
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1337
-				'default'           => '#6c757d',
1338
-				'sanitize_callback' => 'sanitize_hex_color',
1339
-				'capability'        => 'edit_theme_options',
1340
-				'type'              => 'option',
1341
-				'transport'         => 'refresh',
1342
-			));
1343
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1344
-				'label'    => __('Secondary Color','aui'),
1345
-				'section'  => 'aui_settings',
1346
-				'settings' => 'aui_options[color_secondary]',
1347
-			)));
1348
-		}
1349
-
1350
-		/**
1351
-		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1352
-		 *
1353
-		 * @return mixed
1354
-		 */
1355
-		public static function bs3_compat_css() {
1356
-			ob_start();
1357
-			?>
1312
+        }
1313
+
1314
+        public function customizer_settings($wp_customize){
1315
+            $wp_customize->add_section('aui_settings', array(
1316
+                'title'    => __('AyeCode UI','aui'),
1317
+                'priority' => 120,
1318
+            ));
1319
+
1320
+            //  =============================
1321
+            //  = Color Picker              =
1322
+            //  =============================
1323
+            $wp_customize->add_setting('aui_options[color_primary]', array(
1324
+                'default'           => AUI_PRIMARY_COLOR,
1325
+                'sanitize_callback' => 'sanitize_hex_color',
1326
+                'capability'        => 'edit_theme_options',
1327
+                'type'              => 'option',
1328
+                'transport'         => 'refresh',
1329
+            ));
1330
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1331
+                'label'    => __('Primary Color','aui'),
1332
+                'section'  => 'aui_settings',
1333
+                'settings' => 'aui_options[color_primary]',
1334
+            )));
1335
+
1336
+            $wp_customize->add_setting('aui_options[color_secondary]', array(
1337
+                'default'           => '#6c757d',
1338
+                'sanitize_callback' => 'sanitize_hex_color',
1339
+                'capability'        => 'edit_theme_options',
1340
+                'type'              => 'option',
1341
+                'transport'         => 'refresh',
1342
+            ));
1343
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1344
+                'label'    => __('Secondary Color','aui'),
1345
+                'section'  => 'aui_settings',
1346
+                'settings' => 'aui_options[color_secondary]',
1347
+            )));
1348
+        }
1349
+
1350
+        /**
1351
+         * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1352
+         *
1353
+         * @return mixed
1354
+         */
1355
+        public static function bs3_compat_css() {
1356
+            ob_start();
1357
+            ?>
1358 1358
 			<style>
1359 1359
 			/* Bootstrap 3 compatibility */
1360 1360
 			body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1380,579 +1380,579 @@  discard block
 block discarded – undo
1380 1380
 			<?php } ?>
1381 1381
 			</style>
1382 1382
 			<?php
1383
-			return str_replace( array(
1384
-				'<style>',
1385
-				'</style>'
1386
-			), '', self::minify_css( ob_get_clean() ) );
1387
-		}
1383
+            return str_replace( array(
1384
+                '<style>',
1385
+                '</style>'
1386
+            ), '', self::minify_css( ob_get_clean() ) );
1387
+        }
1388 1388
 
1389 1389
 
1390
-		public static function custom_css($compatibility = true) {
1391
-			$settings = get_option('aui_options');
1390
+        public static function custom_css($compatibility = true) {
1391
+            $settings = get_option('aui_options');
1392 1392
 
1393
-			ob_start();
1393
+            ob_start();
1394 1394
 
1395
-			$primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1396
-			$secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1397
-				//AUI_PRIMARY_COLOR_ORIGINAL
1398
-			?>
1395
+            $primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1396
+            $secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1397
+                //AUI_PRIMARY_COLOR_ORIGINAL
1398
+            ?>
1399 1399
 			<style>
1400 1400
 				<?php
1401 1401
 
1402
-					// BS v3 compat
1403
-					if( self::is_bs3_compat() ){
1404
-					    echo self::bs3_compat_css();
1405
-					}
1402
+                    // BS v3 compat
1403
+                    if( self::is_bs3_compat() ){
1404
+                        echo self::bs3_compat_css();
1405
+                    }
1406 1406
 
1407
-					if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1408
-						echo self::css_primary($primary_color,$compatibility);
1409
-					}
1407
+                    if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1408
+                        echo self::css_primary($primary_color,$compatibility);
1409
+                    }
1410 1410
 
1411
-					if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1412
-						echo self::css_secondary($settings['color_secondary'],$compatibility);
1413
-					}
1411
+                    if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1412
+                        echo self::css_secondary($settings['color_secondary'],$compatibility);
1413
+                    }
1414 1414
 
1415
-					// Set admin bar z-index lower when modal is open.
1416
-					echo ' body.modal-open #wpadminbar{z-index:999}';
1415
+                    // Set admin bar z-index lower when modal is open.
1416
+                    echo ' body.modal-open #wpadminbar{z-index:999}';
1417 1417
                 ?>
1418 1418
 			</style>
1419 1419
 			<?php
1420 1420
 
1421 1421
 
1422
-			/*
1422
+            /*
1423 1423
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1424 1424
 			 */
1425
-			return str_replace( array(
1426
-				'<style>',
1427
-				'</style>'
1428
-			), '', self::minify_css( ob_get_clean() ) );
1429
-		}
1430
-
1431
-		/**
1432
-		 * Check if we should add booststrap 3 compatibility changes.
1433
-		 *
1434
-		 * @return bool
1435
-		 */
1436
-		public static function is_bs3_compat(){
1437
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1438
-		}
1439
-
1440
-		public static function css_primary($color_code,$compatibility){;
1441
-			$color_code = sanitize_hex_color($color_code);
1442
-			if(!$color_code){return '';}
1443
-			/**
1444
-			 * c = color, b = background color, o = border-color, f = fill
1445
-			 */
1446
-			$selectors = array(
1447
-				'a' => array('c'),
1448
-				'.btn-primary' => array('b','o'),
1449
-				'.btn-primary.disabled' => array('b','o'),
1450
-				'.btn-primary:disabled' => array('b','o'),
1451
-				'.btn-outline-primary' => array('c','o'),
1452
-				'.btn-outline-primary:hover' => array('b','o'),
1453
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1454
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1455
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1456
-				'.btn-link' => array('c'),
1457
-				'.dropdown-item.active' => array('b'),
1458
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1459
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1425
+            return str_replace( array(
1426
+                '<style>',
1427
+                '</style>'
1428
+            ), '', self::minify_css( ob_get_clean() ) );
1429
+        }
1430
+
1431
+        /**
1432
+         * Check if we should add booststrap 3 compatibility changes.
1433
+         *
1434
+         * @return bool
1435
+         */
1436
+        public static function is_bs3_compat(){
1437
+            return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1438
+        }
1439
+
1440
+        public static function css_primary($color_code,$compatibility){;
1441
+            $color_code = sanitize_hex_color($color_code);
1442
+            if(!$color_code){return '';}
1443
+            /**
1444
+             * c = color, b = background color, o = border-color, f = fill
1445
+             */
1446
+            $selectors = array(
1447
+                'a' => array('c'),
1448
+                '.btn-primary' => array('b','o'),
1449
+                '.btn-primary.disabled' => array('b','o'),
1450
+                '.btn-primary:disabled' => array('b','o'),
1451
+                '.btn-outline-primary' => array('c','o'),
1452
+                '.btn-outline-primary:hover' => array('b','o'),
1453
+                '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1454
+                '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1455
+                '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1456
+                '.btn-link' => array('c'),
1457
+                '.dropdown-item.active' => array('b'),
1458
+                '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1459
+                '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1460 1460
 //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1461 1461
 //				'.custom-range::-moz-range-thumb' => array('b'),
1462 1462
 //				'.custom-range::-ms-thumb' => array('b'),
1463
-				'.nav-pills .nav-link.active' => array('b'),
1464
-				'.nav-pills .show>.nav-link' => array('b'),
1465
-				'.page-link' => array('c'),
1466
-				'.page-item.active .page-link' => array('b','o'),
1467
-				'.badge-primary' => array('b'),
1468
-				'.alert-primary' => array('b','o'),
1469
-				'.progress-bar' => array('b'),
1470
-				'.list-group-item.active' => array('b','o'),
1471
-				'.bg-primary' => array('b','f'),
1472
-				'.btn-link.btn-primary' => array('c'),
1473
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1474
-			);
1475
-
1476
-			$important_selectors = array(
1477
-				'.bg-primary' => array('b','f'),
1478
-				'.border-primary' => array('o'),
1479
-				'.text-primary' => array('c'),
1480
-			);
1481
-
1482
-			$color = array();
1483
-			$color_i = array();
1484
-			$background = array();
1485
-			$background_i = array();
1486
-			$border = array();
1487
-			$border_i = array();
1488
-			$fill = array();
1489
-			$fill_i = array();
1490
-
1491
-			$output = '';
1492
-
1493
-			// build rules into each type
1494
-			foreach($selectors as $selector => $types){
1495
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1496
-				$types = array_combine($types,$types);
1497
-				if(isset($types['c'])){$color[] = $selector;}
1498
-				if(isset($types['b'])){$background[] = $selector;}
1499
-				if(isset($types['o'])){$border[] = $selector;}
1500
-				if(isset($types['f'])){$fill[] = $selector;}
1501
-			}
1502
-
1503
-			// build rules into each type
1504
-			foreach($important_selectors as $selector => $types){
1505
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1506
-				$types = array_combine($types,$types);
1507
-				if(isset($types['c'])){$color_i[] = $selector;}
1508
-				if(isset($types['b'])){$background_i[] = $selector;}
1509
-				if(isset($types['o'])){$border_i[] = $selector;}
1510
-				if(isset($types['f'])){$fill_i[] = $selector;}
1511
-			}
1512
-
1513
-			// add any color rules
1514
-			if(!empty($color)){
1515
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1516
-			}
1517
-			if(!empty($color_i)){
1518
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1519
-			}
1520
-
1521
-			// add any background color rules
1522
-			if(!empty($background)){
1523
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1524
-			}
1525
-			if(!empty($background_i)){
1526
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1527
-			}
1528
-
1529
-			// add any border color rules
1530
-			if(!empty($border)){
1531
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1532
-			}
1533
-			if(!empty($border_i)){
1534
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1535
-			}
1536
-
1537
-			// add any fill color rules
1538
-			if(!empty($fill)){
1539
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1540
-			}
1541
-			if(!empty($fill_i)){
1542
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1543
-			}
1544
-
1545
-
1546
-			$prefix = $compatibility ? ".bsui " : "";
1547
-
1548
-			// darken
1549
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1550
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1551
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1552
-
1553
-			// lighten
1554
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1555
-
1556
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1557
-			$op_25 = $color_code."40"; // 25% opacity
1558
-
1559
-
1560
-			// button states
1561
-			$output .= $prefix ." .btn-primary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1562
-			$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;} ";
1563
-			$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.";} ";
1564
-			$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;} ";
1565
-
1566
-
1567
-			// dropdown's
1568
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1569
-
1570
-
1571
-			// input states
1572
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1573
-
1574
-			// page link
1575
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1576
-
1577
-			return $output;
1578
-		}
1579
-
1580
-		public static function css_secondary($color_code,$compatibility){;
1581
-			$color_code = sanitize_hex_color($color_code);
1582
-			if(!$color_code){return '';}
1583
-			/**
1584
-			 * c = color, b = background color, o = border-color, f = fill
1585
-			 */
1586
-			$selectors = array(
1587
-				'.btn-secondary' => array('b','o'),
1588
-				'.btn-secondary.disabled' => array('b','o'),
1589
-				'.btn-secondary:disabled' => array('b','o'),
1590
-				'.btn-outline-secondary' => array('c','o'),
1591
-				'.btn-outline-secondary:hover' => array('b','o'),
1592
-				'.btn-outline-secondary.disabled' => array('c'),
1593
-				'.btn-outline-secondary:disabled' => array('c'),
1594
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1595
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1596
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1597
-				'.badge-secondary' => array('b'),
1598
-				'.alert-secondary' => array('b','o'),
1599
-				'.btn-link.btn-secondary' => array('c'),
1600
-			);
1601
-
1602
-			$important_selectors = array(
1603
-				'.bg-secondary' => array('b','f'),
1604
-				'.border-secondary' => array('o'),
1605
-				'.text-secondary' => array('c'),
1606
-			);
1607
-
1608
-			$color = array();
1609
-			$color_i = array();
1610
-			$background = array();
1611
-			$background_i = array();
1612
-			$border = array();
1613
-			$border_i = array();
1614
-			$fill = array();
1615
-			$fill_i = array();
1616
-
1617
-			$output = '';
1618
-
1619
-			// build rules into each type
1620
-			foreach($selectors as $selector => $types){
1621
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1622
-				$types = array_combine($types,$types);
1623
-				if(isset($types['c'])){$color[] = $selector;}
1624
-				if(isset($types['b'])){$background[] = $selector;}
1625
-				if(isset($types['o'])){$border[] = $selector;}
1626
-				if(isset($types['f'])){$fill[] = $selector;}
1627
-			}
1628
-
1629
-			// build rules into each type
1630
-			foreach($important_selectors as $selector => $types){
1631
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1632
-				$types = array_combine($types,$types);
1633
-				if(isset($types['c'])){$color_i[] = $selector;}
1634
-				if(isset($types['b'])){$background_i[] = $selector;}
1635
-				if(isset($types['o'])){$border_i[] = $selector;}
1636
-				if(isset($types['f'])){$fill_i[] = $selector;}
1637
-			}
1638
-
1639
-			// add any color rules
1640
-			if(!empty($color)){
1641
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1642
-			}
1643
-			if(!empty($color_i)){
1644
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1645
-			}
1646
-
1647
-			// add any background color rules
1648
-			if(!empty($background)){
1649
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1650
-			}
1651
-			if(!empty($background_i)){
1652
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1653
-			}
1654
-
1655
-			// add any border color rules
1656
-			if(!empty($border)){
1657
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1658
-			}
1659
-			if(!empty($border_i)){
1660
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1661
-			}
1662
-
1663
-			// add any fill color rules
1664
-			if(!empty($fill)){
1665
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1666
-			}
1667
-			if(!empty($fill_i)){
1668
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1669
-			}
1670
-
1671
-
1672
-			$prefix = $compatibility ? ".bsui " : "";
1673
-
1674
-			// darken
1675
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1676
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1677
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1678
-
1679
-			// lighten
1680
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1681
-
1682
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1683
-			$op_25 = $color_code."40"; // 25% opacity
1684
-
1685
-
1686
-			// button states
1687
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1688
-			$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;} ";
1689
-			$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.";} ";
1690
-			$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;} ";
1691
-
1692
-
1693
-			return $output;
1694
-		}
1695
-
1696
-		/**
1697
-		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
1698
-		 *
1699
-		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1700
-		 * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1701
-		 *
1702
-		 * @return  string
1703
-		 */
1704
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1705
-			$hexCode = ltrim($hexCode, '#');
1706
-
1707
-			if (strlen($hexCode) == 3) {
1708
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1709
-			}
1710
-
1711
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
1712
-
1713
-			foreach ($hexCode as & $color) {
1714
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1715
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
1716
-
1717
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1718
-			}
1719
-
1720
-			return '#' . implode($hexCode);
1721
-		}
1722
-
1723
-		/**
1724
-		 * Check if we should display examples.
1725
-		 */
1726
-		public function maybe_show_examples(){
1727
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1728
-				echo "<head>";
1729
-				wp_head();
1730
-				echo "</head>";
1731
-				echo "<body>";
1732
-				echo $this->get_examples();
1733
-				echo "</body>";
1734
-				exit;
1735
-			}
1736
-		}
1737
-
1738
-		/**
1739
-		 * Get developer examples.
1740
-		 *
1741
-		 * @return string
1742
-		 */
1743
-		public function get_examples(){
1744
-			$output = '';
1745
-
1746
-
1747
-			// open form
1748
-			$output .= "<form class='p-5 m-5 border rounded'>";
1749
-
1750
-			// input example
1751
-			$output .= aui()->input(array(
1752
-				'type'  =>  'text',
1753
-				'id'    =>  'text-example',
1754
-				'name'    =>  'text-example',
1755
-				'placeholder'   => 'text placeholder',
1756
-				'title'   => 'Text input example',
1757
-				'value' =>  '',
1758
-				'required'  => false,
1759
-				'help_text' => 'help text',
1760
-				'label' => 'Text input example label'
1761
-			));
1762
-
1763
-			// input example
1764
-			$output .= aui()->input(array(
1765
-				'type'  =>  'url',
1766
-				'id'    =>  'text-example2',
1767
-				'name'    =>  'text-example',
1768
-				'placeholder'   => 'url placeholder',
1769
-				'title'   => 'Text input example',
1770
-				'value' =>  '',
1771
-				'required'  => false,
1772
-				'help_text' => 'help text',
1773
-				'label' => 'Text input example label'
1774
-			));
1775
-
1776
-			// checkbox example
1777
-			$output .= aui()->input(array(
1778
-				'type'  =>  'checkbox',
1779
-				'id'    =>  'checkbox-example',
1780
-				'name'    =>  'checkbox-example',
1781
-				'placeholder'   => 'checkbox-example',
1782
-				'title'   => 'Checkbox example',
1783
-				'value' =>  '1',
1784
-				'checked'   => true,
1785
-				'required'  => false,
1786
-				'help_text' => 'help text',
1787
-				'label' => 'Checkbox checked'
1788
-			));
1789
-
1790
-			// checkbox example
1791
-			$output .= aui()->input(array(
1792
-				'type'  =>  'checkbox',
1793
-				'id'    =>  'checkbox-example2',
1794
-				'name'    =>  'checkbox-example2',
1795
-				'placeholder'   => 'checkbox-example',
1796
-				'title'   => 'Checkbox example',
1797
-				'value' =>  '1',
1798
-				'checked'   => false,
1799
-				'required'  => false,
1800
-				'help_text' => 'help text',
1801
-				'label' => 'Checkbox un-checked'
1802
-			));
1803
-
1804
-			// switch example
1805
-			$output .= aui()->input(array(
1806
-				'type'  =>  'checkbox',
1807
-				'id'    =>  'switch-example',
1808
-				'name'    =>  'switch-example',
1809
-				'placeholder'   => 'checkbox-example',
1810
-				'title'   => 'Switch example',
1811
-				'value' =>  '1',
1812
-				'checked'   => true,
1813
-				'switch'    => true,
1814
-				'required'  => false,
1815
-				'help_text' => 'help text',
1816
-				'label' => 'Switch on'
1817
-			));
1818
-
1819
-			// switch example
1820
-			$output .= aui()->input(array(
1821
-				'type'  =>  'checkbox',
1822
-				'id'    =>  'switch-example2',
1823
-				'name'    =>  'switch-example2',
1824
-				'placeholder'   => 'checkbox-example',
1825
-				'title'   => 'Switch example',
1826
-				'value' =>  '1',
1827
-				'checked'   => false,
1828
-				'switch'    => true,
1829
-				'required'  => false,
1830
-				'help_text' => 'help text',
1831
-				'label' => 'Switch off'
1832
-			));
1833
-
1834
-			// close form
1835
-			$output .= "</form>";
1836
-
1837
-			return $output;
1838
-		}
1839
-
1840
-		/**
1841
-		 * Calendar params.
1842
-		 *
1843
-		 * @since 0.1.44
1844
-		 *
1845
-		 * @return array Calendar params.
1846
-		 */
1847
-		public static function calendar_params() {
1848
-			$params = array(
1849
-				'month_long_1' => __( 'January', 'aui' ),
1850
-				'month_long_2' => __( 'February', 'aui' ),
1851
-				'month_long_3' => __( 'March', 'aui' ),
1852
-				'month_long_4' => __( 'April', 'aui' ),
1853
-				'month_long_5' => __( 'May', 'aui' ),
1854
-				'month_long_6' => __( 'June', 'aui' ),
1855
-				'month_long_7' => __( 'July', 'aui' ),
1856
-				'month_long_8' => __( 'August', 'aui' ),
1857
-				'month_long_9' => __( 'September', 'aui' ),
1858
-				'month_long_10' => __( 'October', 'aui' ),
1859
-				'month_long_11' => __( 'November', 'aui' ),
1860
-				'month_long_12' => __( 'December', 'aui' ),
1861
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'aui' ),
1862
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'aui' ),
1863
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'aui' ),
1864
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'aui' ),
1865
-				'month_s_5' => _x( 'May', 'May abbreviation', 'aui' ),
1866
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'aui' ),
1867
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'aui' ),
1868
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'aui' ),
1869
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'aui' ),
1870
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'aui' ),
1871
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'aui' ),
1872
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'aui' ),
1873
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'aui' ),
1874
-				'day_s1_2' => _x( 'M', 'Monday initial', 'aui' ),
1875
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'aui' ),
1876
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'aui' ),
1877
-				'day_s1_5' => _x( 'T', 'Friday initial', 'aui' ),
1878
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'aui' ),
1879
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'aui' ),
1880
-				'day_s2_1' => __( 'Su', 'aui' ),
1881
-				'day_s2_2' => __( 'Mo', 'aui' ),
1882
-				'day_s2_3' => __( 'Tu', 'aui' ),
1883
-				'day_s2_4' => __( 'We', 'aui' ),
1884
-				'day_s2_5' => __( 'Th', 'aui' ),
1885
-				'day_s2_6' => __( 'Fr', 'aui' ),
1886
-				'day_s2_7' => __( 'Sa', 'aui' ),
1887
-				'day_s3_1' => __( 'Sun', 'aui' ),
1888
-				'day_s3_2' => __( 'Mon', 'aui' ),
1889
-				'day_s3_3' => __( 'Tue', 'aui' ),
1890
-				'day_s3_4' => __( 'Wed', 'aui' ),
1891
-				'day_s3_5' => __( 'Thu', 'aui' ),
1892
-				'day_s3_6' => __( 'Fri', 'aui' ),
1893
-				'day_s3_7' => __( 'Sat', 'aui' ),
1894
-				'day_s5_1' => __( 'Sunday', 'aui' ),
1895
-				'day_s5_2' => __( 'Monday', 'aui' ),
1896
-				'day_s5_3' => __( 'Tuesday', 'aui' ),
1897
-				'day_s5_4' => __( 'Wednesday', 'aui' ),
1898
-				'day_s5_5' => __( 'Thursday', 'aui' ),
1899
-				'day_s5_6' => __( 'Friday', 'aui' ),
1900
-				'day_s5_7' => __( 'Saturday', 'aui' ),
1901
-				'am_lower' => __( 'am', 'aui' ),
1902
-				'pm_lower' => __( 'pm', 'aui' ),
1903
-				'am_upper' => __( 'AM', 'aui' ),
1904
-				'pm_upper' => __( 'PM', 'aui' ),
1905
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
1906
-				'time_24hr' => false,
1907
-				'year' => __( 'Year', 'aui' ),
1908
-				'hour' => __( 'Hour', 'aui' ),
1909
-				'minute' => __( 'Minute', 'aui' ),
1910
-				'weekAbbreviation' => __( 'Wk', 'aui' ),
1911
-				'rangeSeparator' => __( ' to ', 'aui' ),
1912
-				'scrollTitle' => __( 'Scroll to increment', 'aui' ),
1913
-				'toggleTitle' => __( 'Click to toggle', 'aui' )
1914
-			);
1915
-
1916
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
1917
-		}
1918
-
1919
-		/**
1920
-		 * Flatpickr calendar localize.
1921
-		 *
1922
-		 * @since 0.1.44
1923
-		 *
1924
-		 * @return string Calendar locale.
1925
-		 */
1926
-		public static function flatpickr_locale() {
1927
-			$params = self::calendar_params();
1928
-
1929
-			if ( is_string( $params ) ) {
1930
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
1931
-			} else {
1932
-				foreach ( (array) $params as $key => $value ) {
1933
-					if ( ! is_scalar( $value ) ) {
1934
-						continue;
1935
-					}
1936
-
1937
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
1938
-				}
1939
-			}
1463
+                '.nav-pills .nav-link.active' => array('b'),
1464
+                '.nav-pills .show>.nav-link' => array('b'),
1465
+                '.page-link' => array('c'),
1466
+                '.page-item.active .page-link' => array('b','o'),
1467
+                '.badge-primary' => array('b'),
1468
+                '.alert-primary' => array('b','o'),
1469
+                '.progress-bar' => array('b'),
1470
+                '.list-group-item.active' => array('b','o'),
1471
+                '.bg-primary' => array('b','f'),
1472
+                '.btn-link.btn-primary' => array('c'),
1473
+                '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1474
+            );
1475
+
1476
+            $important_selectors = array(
1477
+                '.bg-primary' => array('b','f'),
1478
+                '.border-primary' => array('o'),
1479
+                '.text-primary' => array('c'),
1480
+            );
1481
+
1482
+            $color = array();
1483
+            $color_i = array();
1484
+            $background = array();
1485
+            $background_i = array();
1486
+            $border = array();
1487
+            $border_i = array();
1488
+            $fill = array();
1489
+            $fill_i = array();
1490
+
1491
+            $output = '';
1492
+
1493
+            // build rules into each type
1494
+            foreach($selectors as $selector => $types){
1495
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1496
+                $types = array_combine($types,$types);
1497
+                if(isset($types['c'])){$color[] = $selector;}
1498
+                if(isset($types['b'])){$background[] = $selector;}
1499
+                if(isset($types['o'])){$border[] = $selector;}
1500
+                if(isset($types['f'])){$fill[] = $selector;}
1501
+            }
1502
+
1503
+            // build rules into each type
1504
+            foreach($important_selectors as $selector => $types){
1505
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1506
+                $types = array_combine($types,$types);
1507
+                if(isset($types['c'])){$color_i[] = $selector;}
1508
+                if(isset($types['b'])){$background_i[] = $selector;}
1509
+                if(isset($types['o'])){$border_i[] = $selector;}
1510
+                if(isset($types['f'])){$fill_i[] = $selector;}
1511
+            }
1512
+
1513
+            // add any color rules
1514
+            if(!empty($color)){
1515
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1516
+            }
1517
+            if(!empty($color_i)){
1518
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1519
+            }
1520
+
1521
+            // add any background color rules
1522
+            if(!empty($background)){
1523
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1524
+            }
1525
+            if(!empty($background_i)){
1526
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1527
+            }
1528
+
1529
+            // add any border color rules
1530
+            if(!empty($border)){
1531
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1532
+            }
1533
+            if(!empty($border_i)){
1534
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1535
+            }
1536
+
1537
+            // add any fill color rules
1538
+            if(!empty($fill)){
1539
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1540
+            }
1541
+            if(!empty($fill_i)){
1542
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1543
+            }
1544
+
1545
+
1546
+            $prefix = $compatibility ? ".bsui " : "";
1547
+
1548
+            // darken
1549
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1550
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1551
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1552
+
1553
+            // lighten
1554
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1555
+
1556
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1557
+            $op_25 = $color_code."40"; // 25% opacity
1558
+
1559
+
1560
+            // button states
1561
+            $output .= $prefix ." .btn-primary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1562
+            $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;} ";
1563
+            $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.";} ";
1564
+            $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;} ";
1565
+
1566
+
1567
+            // dropdown's
1568
+            $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1569
+
1570
+
1571
+            // input states
1572
+            $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1573
+
1574
+            // page link
1575
+            $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1576
+
1577
+            return $output;
1578
+        }
1579
+
1580
+        public static function css_secondary($color_code,$compatibility){;
1581
+            $color_code = sanitize_hex_color($color_code);
1582
+            if(!$color_code){return '';}
1583
+            /**
1584
+             * c = color, b = background color, o = border-color, f = fill
1585
+             */
1586
+            $selectors = array(
1587
+                '.btn-secondary' => array('b','o'),
1588
+                '.btn-secondary.disabled' => array('b','o'),
1589
+                '.btn-secondary:disabled' => array('b','o'),
1590
+                '.btn-outline-secondary' => array('c','o'),
1591
+                '.btn-outline-secondary:hover' => array('b','o'),
1592
+                '.btn-outline-secondary.disabled' => array('c'),
1593
+                '.btn-outline-secondary:disabled' => array('c'),
1594
+                '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1595
+                '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1596
+                '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1597
+                '.badge-secondary' => array('b'),
1598
+                '.alert-secondary' => array('b','o'),
1599
+                '.btn-link.btn-secondary' => array('c'),
1600
+            );
1601
+
1602
+            $important_selectors = array(
1603
+                '.bg-secondary' => array('b','f'),
1604
+                '.border-secondary' => array('o'),
1605
+                '.text-secondary' => array('c'),
1606
+            );
1607
+
1608
+            $color = array();
1609
+            $color_i = array();
1610
+            $background = array();
1611
+            $background_i = array();
1612
+            $border = array();
1613
+            $border_i = array();
1614
+            $fill = array();
1615
+            $fill_i = array();
1616
+
1617
+            $output = '';
1618
+
1619
+            // build rules into each type
1620
+            foreach($selectors as $selector => $types){
1621
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1622
+                $types = array_combine($types,$types);
1623
+                if(isset($types['c'])){$color[] = $selector;}
1624
+                if(isset($types['b'])){$background[] = $selector;}
1625
+                if(isset($types['o'])){$border[] = $selector;}
1626
+                if(isset($types['f'])){$fill[] = $selector;}
1627
+            }
1628
+
1629
+            // build rules into each type
1630
+            foreach($important_selectors as $selector => $types){
1631
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1632
+                $types = array_combine($types,$types);
1633
+                if(isset($types['c'])){$color_i[] = $selector;}
1634
+                if(isset($types['b'])){$background_i[] = $selector;}
1635
+                if(isset($types['o'])){$border_i[] = $selector;}
1636
+                if(isset($types['f'])){$fill_i[] = $selector;}
1637
+            }
1638
+
1639
+            // add any color rules
1640
+            if(!empty($color)){
1641
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1642
+            }
1643
+            if(!empty($color_i)){
1644
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1645
+            }
1646
+
1647
+            // add any background color rules
1648
+            if(!empty($background)){
1649
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1650
+            }
1651
+            if(!empty($background_i)){
1652
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1653
+            }
1654
+
1655
+            // add any border color rules
1656
+            if(!empty($border)){
1657
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1658
+            }
1659
+            if(!empty($border_i)){
1660
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1661
+            }
1662
+
1663
+            // add any fill color rules
1664
+            if(!empty($fill)){
1665
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1666
+            }
1667
+            if(!empty($fill_i)){
1668
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1669
+            }
1670
+
1671
+
1672
+            $prefix = $compatibility ? ".bsui " : "";
1673
+
1674
+            // darken
1675
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1676
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1677
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1678
+
1679
+            // lighten
1680
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1681
+
1682
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1683
+            $op_25 = $color_code."40"; // 25% opacity
1684
+
1685
+
1686
+            // button states
1687
+            $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1688
+            $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;} ";
1689
+            $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.";} ";
1690
+            $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;} ";
1691
+
1692
+
1693
+            return $output;
1694
+        }
1695
+
1696
+        /**
1697
+         * Increases or decreases the brightness of a color by a percentage of the current brightness.
1698
+         *
1699
+         * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1700
+         * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1701
+         *
1702
+         * @return  string
1703
+         */
1704
+        public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1705
+            $hexCode = ltrim($hexCode, '#');
1706
+
1707
+            if (strlen($hexCode) == 3) {
1708
+                $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1709
+            }
1710
+
1711
+            $hexCode = array_map('hexdec', str_split($hexCode, 2));
1712
+
1713
+            foreach ($hexCode as & $color) {
1714
+                $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1715
+                $adjustAmount = ceil($adjustableLimit * $adjustPercent);
1716
+
1717
+                $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1718
+            }
1719
+
1720
+            return '#' . implode($hexCode);
1721
+        }
1722
+
1723
+        /**
1724
+         * Check if we should display examples.
1725
+         */
1726
+        public function maybe_show_examples(){
1727
+            if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1728
+                echo "<head>";
1729
+                wp_head();
1730
+                echo "</head>";
1731
+                echo "<body>";
1732
+                echo $this->get_examples();
1733
+                echo "</body>";
1734
+                exit;
1735
+            }
1736
+        }
1737
+
1738
+        /**
1739
+         * Get developer examples.
1740
+         *
1741
+         * @return string
1742
+         */
1743
+        public function get_examples(){
1744
+            $output = '';
1745
+
1746
+
1747
+            // open form
1748
+            $output .= "<form class='p-5 m-5 border rounded'>";
1749
+
1750
+            // input example
1751
+            $output .= aui()->input(array(
1752
+                'type'  =>  'text',
1753
+                'id'    =>  'text-example',
1754
+                'name'    =>  'text-example',
1755
+                'placeholder'   => 'text placeholder',
1756
+                'title'   => 'Text input example',
1757
+                'value' =>  '',
1758
+                'required'  => false,
1759
+                'help_text' => 'help text',
1760
+                'label' => 'Text input example label'
1761
+            ));
1762
+
1763
+            // input example
1764
+            $output .= aui()->input(array(
1765
+                'type'  =>  'url',
1766
+                'id'    =>  'text-example2',
1767
+                'name'    =>  'text-example',
1768
+                'placeholder'   => 'url placeholder',
1769
+                'title'   => 'Text input example',
1770
+                'value' =>  '',
1771
+                'required'  => false,
1772
+                'help_text' => 'help text',
1773
+                'label' => 'Text input example label'
1774
+            ));
1775
+
1776
+            // checkbox example
1777
+            $output .= aui()->input(array(
1778
+                'type'  =>  'checkbox',
1779
+                'id'    =>  'checkbox-example',
1780
+                'name'    =>  'checkbox-example',
1781
+                'placeholder'   => 'checkbox-example',
1782
+                'title'   => 'Checkbox example',
1783
+                'value' =>  '1',
1784
+                'checked'   => true,
1785
+                'required'  => false,
1786
+                'help_text' => 'help text',
1787
+                'label' => 'Checkbox checked'
1788
+            ));
1789
+
1790
+            // checkbox example
1791
+            $output .= aui()->input(array(
1792
+                'type'  =>  'checkbox',
1793
+                'id'    =>  'checkbox-example2',
1794
+                'name'    =>  'checkbox-example2',
1795
+                'placeholder'   => 'checkbox-example',
1796
+                'title'   => 'Checkbox example',
1797
+                'value' =>  '1',
1798
+                'checked'   => false,
1799
+                'required'  => false,
1800
+                'help_text' => 'help text',
1801
+                'label' => 'Checkbox un-checked'
1802
+            ));
1803
+
1804
+            // switch example
1805
+            $output .= aui()->input(array(
1806
+                'type'  =>  'checkbox',
1807
+                'id'    =>  'switch-example',
1808
+                'name'    =>  'switch-example',
1809
+                'placeholder'   => 'checkbox-example',
1810
+                'title'   => 'Switch example',
1811
+                'value' =>  '1',
1812
+                'checked'   => true,
1813
+                'switch'    => true,
1814
+                'required'  => false,
1815
+                'help_text' => 'help text',
1816
+                'label' => 'Switch on'
1817
+            ));
1818
+
1819
+            // switch example
1820
+            $output .= aui()->input(array(
1821
+                'type'  =>  'checkbox',
1822
+                'id'    =>  'switch-example2',
1823
+                'name'    =>  'switch-example2',
1824
+                'placeholder'   => 'checkbox-example',
1825
+                'title'   => 'Switch example',
1826
+                'value' =>  '1',
1827
+                'checked'   => false,
1828
+                'switch'    => true,
1829
+                'required'  => false,
1830
+                'help_text' => 'help text',
1831
+                'label' => 'Switch off'
1832
+            ));
1833
+
1834
+            // close form
1835
+            $output .= "</form>";
1836
+
1837
+            return $output;
1838
+        }
1839
+
1840
+        /**
1841
+         * Calendar params.
1842
+         *
1843
+         * @since 0.1.44
1844
+         *
1845
+         * @return array Calendar params.
1846
+         */
1847
+        public static function calendar_params() {
1848
+            $params = array(
1849
+                'month_long_1' => __( 'January', 'aui' ),
1850
+                'month_long_2' => __( 'February', 'aui' ),
1851
+                'month_long_3' => __( 'March', 'aui' ),
1852
+                'month_long_4' => __( 'April', 'aui' ),
1853
+                'month_long_5' => __( 'May', 'aui' ),
1854
+                'month_long_6' => __( 'June', 'aui' ),
1855
+                'month_long_7' => __( 'July', 'aui' ),
1856
+                'month_long_8' => __( 'August', 'aui' ),
1857
+                'month_long_9' => __( 'September', 'aui' ),
1858
+                'month_long_10' => __( 'October', 'aui' ),
1859
+                'month_long_11' => __( 'November', 'aui' ),
1860
+                'month_long_12' => __( 'December', 'aui' ),
1861
+                'month_s_1' => _x( 'Jan', 'January abbreviation', 'aui' ),
1862
+                'month_s_2' => _x( 'Feb', 'February abbreviation', 'aui' ),
1863
+                'month_s_3' => _x( 'Mar', 'March abbreviation', 'aui' ),
1864
+                'month_s_4' => _x( 'Apr', 'April abbreviation', 'aui' ),
1865
+                'month_s_5' => _x( 'May', 'May abbreviation', 'aui' ),
1866
+                'month_s_6' => _x( 'Jun', 'June abbreviation', 'aui' ),
1867
+                'month_s_7' => _x( 'Jul', 'July abbreviation', 'aui' ),
1868
+                'month_s_8' => _x( 'Aug', 'August abbreviation', 'aui' ),
1869
+                'month_s_9' => _x( 'Sep', 'September abbreviation', 'aui' ),
1870
+                'month_s_10' => _x( 'Oct', 'October abbreviation', 'aui' ),
1871
+                'month_s_11' => _x( 'Nov', 'November abbreviation', 'aui' ),
1872
+                'month_s_12' => _x( 'Dec', 'December abbreviation', 'aui' ),
1873
+                'day_s1_1' => _x( 'S', 'Sunday initial', 'aui' ),
1874
+                'day_s1_2' => _x( 'M', 'Monday initial', 'aui' ),
1875
+                'day_s1_3' => _x( 'T', 'Tuesday initial', 'aui' ),
1876
+                'day_s1_4' => _x( 'W', 'Wednesday initial', 'aui' ),
1877
+                'day_s1_5' => _x( 'T', 'Friday initial', 'aui' ),
1878
+                'day_s1_6' => _x( 'F', 'Thursday initial', 'aui' ),
1879
+                'day_s1_7' => _x( 'S', 'Saturday initial', 'aui' ),
1880
+                'day_s2_1' => __( 'Su', 'aui' ),
1881
+                'day_s2_2' => __( 'Mo', 'aui' ),
1882
+                'day_s2_3' => __( 'Tu', 'aui' ),
1883
+                'day_s2_4' => __( 'We', 'aui' ),
1884
+                'day_s2_5' => __( 'Th', 'aui' ),
1885
+                'day_s2_6' => __( 'Fr', 'aui' ),
1886
+                'day_s2_7' => __( 'Sa', 'aui' ),
1887
+                'day_s3_1' => __( 'Sun', 'aui' ),
1888
+                'day_s3_2' => __( 'Mon', 'aui' ),
1889
+                'day_s3_3' => __( 'Tue', 'aui' ),
1890
+                'day_s3_4' => __( 'Wed', 'aui' ),
1891
+                'day_s3_5' => __( 'Thu', 'aui' ),
1892
+                'day_s3_6' => __( 'Fri', 'aui' ),
1893
+                'day_s3_7' => __( 'Sat', 'aui' ),
1894
+                'day_s5_1' => __( 'Sunday', 'aui' ),
1895
+                'day_s5_2' => __( 'Monday', 'aui' ),
1896
+                'day_s5_3' => __( 'Tuesday', 'aui' ),
1897
+                'day_s5_4' => __( 'Wednesday', 'aui' ),
1898
+                'day_s5_5' => __( 'Thursday', 'aui' ),
1899
+                'day_s5_6' => __( 'Friday', 'aui' ),
1900
+                'day_s5_7' => __( 'Saturday', 'aui' ),
1901
+                'am_lower' => __( 'am', 'aui' ),
1902
+                'pm_lower' => __( 'pm', 'aui' ),
1903
+                'am_upper' => __( 'AM', 'aui' ),
1904
+                'pm_upper' => __( 'PM', 'aui' ),
1905
+                'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
1906
+                'time_24hr' => false,
1907
+                'year' => __( 'Year', 'aui' ),
1908
+                'hour' => __( 'Hour', 'aui' ),
1909
+                'minute' => __( 'Minute', 'aui' ),
1910
+                'weekAbbreviation' => __( 'Wk', 'aui' ),
1911
+                'rangeSeparator' => __( ' to ', 'aui' ),
1912
+                'scrollTitle' => __( 'Scroll to increment', 'aui' ),
1913
+                'toggleTitle' => __( 'Click to toggle', 'aui' )
1914
+            );
1915
+
1916
+            return apply_filters( 'ayecode_ui_calendar_params', $params );
1917
+        }
1918
+
1919
+        /**
1920
+         * Flatpickr calendar localize.
1921
+         *
1922
+         * @since 0.1.44
1923
+         *
1924
+         * @return string Calendar locale.
1925
+         */
1926
+        public static function flatpickr_locale() {
1927
+            $params = self::calendar_params();
1928
+
1929
+            if ( is_string( $params ) ) {
1930
+                $params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
1931
+            } else {
1932
+                foreach ( (array) $params as $key => $value ) {
1933
+                    if ( ! is_scalar( $value ) ) {
1934
+                        continue;
1935
+                    }
1936
+
1937
+                    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
1938
+                }
1939
+            }
1940 1940
 
1941
-			$day_s3 = array();
1942
-			$day_s5 = array();
1941
+            $day_s3 = array();
1942
+            $day_s5 = array();
1943 1943
 
1944
-			for ( $i = 1; $i <= 7; $i ++ ) {
1945
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] );
1946
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] );
1947
-			}
1944
+            for ( $i = 1; $i <= 7; $i ++ ) {
1945
+                $day_s3[] = addslashes( $params[ 'day_s3_' . $i ] );
1946
+                $day_s5[] = addslashes( $params[ 'day_s3_' . $i ] );
1947
+            }
1948 1948
 
1949
-			$month_s = array();
1950
-			$month_long = array();
1949
+            $month_s = array();
1950
+            $month_long = array();
1951 1951
 
1952
-			for ( $i = 1; $i <= 12; $i ++ ) {
1953
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] );
1954
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] );
1955
-			}
1952
+            for ( $i = 1; $i <= 12; $i ++ ) {
1953
+                $month_s[] = addslashes( $params[ 'month_s_' . $i ] );
1954
+                $month_long[] = addslashes( $params[ 'month_long_' . $i ] );
1955
+            }
1956 1956
 
1957 1957
 ob_start();
1958 1958
 if ( 0 ) { ?><script><?php } ?>
@@ -1994,184 +1994,184 @@  discard block
 block discarded – undo
1994 1994
 }
1995 1995
 <?php if ( 0 ) { ?></script><?php } ?>
1996 1996
 <?php
1997
-			$locale = ob_get_clean();
1998
-
1999
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2000
-		}
2001
-
2002
-		/**
2003
-		 * Select2 JS params.
2004
-		 *
2005
-		 * @since 0.1.44
2006
-		 *
2007
-		 * @return array Select2 JS params.
2008
-		 */
2009
-		public static function select2_params() {
2010
-			$params = array(
2011
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'aui' ),
2012
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'aui' ),
2013
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'aui' ),
2014
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'aui' ),
2015
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'aui' ),
2016
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'aui' ),
2017
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'aui' ),
2018
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'aui' ),
2019
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'aui' ),
2020
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'aui' ),
2021
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'aui' )
2022
-			);
2023
-
2024
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2025
-		}
2026
-
2027
-		/**
2028
-		 * Select2 JS localize.
2029
-		 *
2030
-		 * @since 0.1.44
2031
-		 *
2032
-		 * @return string Select2 JS locale.
2033
-		 */
2034
-		public static function select2_locale() {
2035
-			$params = self::select2_params();
2036
-
2037
-			foreach ( (array) $params as $key => $value ) {
2038
-				if ( ! is_scalar( $value ) ) {
2039
-					continue;
2040
-				}
2041
-
2042
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2043
-			}
2044
-
2045
-			$locale = json_encode( $params );
2046
-
2047
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2048
-		}
2049
-
2050
-		/**
2051
-		 * Time ago JS localize.
2052
-		 *
2053
-		 * @since 0.1.47
2054
-		 *
2055
-		 * @return string Time ago JS locale.
2056
-		 */
2057
-		public static function timeago_locale() {
2058
-			$params = array(
2059
-				'prefix_ago' => '',
2060
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'aui' ),
2061
-				'prefix_after' => _x( 'after', 'time ago', 'aui' ) . ' ',
2062
-				'suffix_after' => '',
2063
-				'seconds' => _x( 'less than a minute', 'time ago', 'aui' ),
2064
-				'minute' => _x( 'about a minute', 'time ago', 'aui' ),
2065
-				'minutes' => _x( '%d minutes', 'time ago', 'aui' ),
2066
-				'hour' => _x( 'about an hour', 'time ago', 'aui' ),
2067
-				'hours' => _x( 'about %d hours', 'time ago', 'aui' ),
2068
-				'day' => _x( 'a day', 'time ago', 'aui' ),
2069
-				'days' => _x( '%d days', 'time ago', 'aui' ),
2070
-				'month' => _x( 'about a month', 'time ago', 'aui' ),
2071
-				'months' => _x( '%d months', 'time ago', 'aui' ),
2072
-				'year' => _x( 'about a year', 'time ago', 'aui' ),
2073
-				'years' => _x( '%d years', 'time ago', 'aui' ),
2074
-			);
2075
-
2076
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2077
-
2078
-			foreach ( (array) $params as $key => $value ) {
2079
-				if ( ! is_scalar( $value ) ) {
2080
-					continue;
2081
-				}
2082
-
2083
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2084
-			}
2085
-
2086
-			$locale = json_encode( $params );
2087
-
2088
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2089
-		}
2090
-
2091
-		/**
2092
-		 * JavaScript Minifier
2093
-		 *
2094
-		 * @param $input
2095
-		 *
2096
-		 * @return mixed
2097
-		 */
2098
-		public static function minify_js($input) {
2099
-			if(trim($input) === "") return $input;
2100
-			return preg_replace(
2101
-				array(
2102
-					// Remove comment(s)
2103
-					'#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2104
-					// Remove white-space(s) outside the string and regex
2105
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2106
-					// Remove the last semicolon
2107
-					'#;+\}#',
2108
-					// Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2109
-					'#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2110
-					// --ibid. From `foo['bar']` to `foo.bar`
2111
-					'#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2112
-				),
2113
-				array(
2114
-					'$1',
2115
-					'$1$2',
2116
-					'}',
2117
-					'$1$3',
2118
-					'$1.$3'
2119
-				),
2120
-				$input);
2121
-		}
1997
+            $locale = ob_get_clean();
1998
+
1999
+            return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2000
+        }
2001
+
2002
+        /**
2003
+         * Select2 JS params.
2004
+         *
2005
+         * @since 0.1.44
2006
+         *
2007
+         * @return array Select2 JS params.
2008
+         */
2009
+        public static function select2_params() {
2010
+            $params = array(
2011
+                'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'aui' ),
2012
+                'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'aui' ),
2013
+                'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'aui' ),
2014
+                'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'aui' ),
2015
+                'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'aui' ),
2016
+                'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'aui' ),
2017
+                'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'aui' ),
2018
+                'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'aui' ),
2019
+                'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'aui' ),
2020
+                'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'aui' ),
2021
+                'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'aui' )
2022
+            );
2023
+
2024
+            return apply_filters( 'ayecode_ui_select2_params', $params );
2025
+        }
2026
+
2027
+        /**
2028
+         * Select2 JS localize.
2029
+         *
2030
+         * @since 0.1.44
2031
+         *
2032
+         * @return string Select2 JS locale.
2033
+         */
2034
+        public static function select2_locale() {
2035
+            $params = self::select2_params();
2036
+
2037
+            foreach ( (array) $params as $key => $value ) {
2038
+                if ( ! is_scalar( $value ) ) {
2039
+                    continue;
2040
+                }
2122 2041
 
2123
-		/**
2124
-		 * Minify CSS
2125
-		 *
2126
-		 * @param $input
2127
-		 *
2128
-		 * @return mixed
2129
-		 */
2130
-		public static function minify_css($input) {
2131
-			if(trim($input) === "") return $input;
2132
-			return preg_replace(
2133
-				array(
2134
-					// Remove comment(s)
2135
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2136
-					// Remove unused white-space(s)
2137
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2138
-					// Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2139
-					'#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2140
-					// Replace `:0 0 0 0` with `:0`
2141
-					'#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2142
-					// Replace `background-position:0` with `background-position:0 0`
2143
-					'#(background-position):0(?=[;\}])#si',
2144
-					// Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2145
-					'#(?<=[\s:,\-])0+\.(\d+)#s',
2146
-					// Minify string value
2147
-					'#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2148
-					'#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2149
-					// Minify HEX color code
2150
-					'#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2151
-					// Replace `(border|outline):none` with `(border|outline):0`
2152
-					'#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2153
-					// Remove empty selector(s)
2154
-					'#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2155
-				),
2156
-				array(
2157
-					'$1',
2158
-					'$1$2$3$4$5$6$7',
2159
-					'$1',
2160
-					':0',
2161
-					'$1:0 0',
2162
-					'.$1',
2163
-					'$1$3',
2164
-					'$1$2$4$5',
2165
-					'$1$2$3',
2166
-					'$1:0',
2167
-					'$1$2'
2168
-				),
2169
-				$input);
2170
-		}
2171
-	}
2042
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2043
+            }
2044
+
2045
+            $locale = json_encode( $params );
2046
+
2047
+            return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2048
+        }
2049
+
2050
+        /**
2051
+         * Time ago JS localize.
2052
+         *
2053
+         * @since 0.1.47
2054
+         *
2055
+         * @return string Time ago JS locale.
2056
+         */
2057
+        public static function timeago_locale() {
2058
+            $params = array(
2059
+                'prefix_ago' => '',
2060
+                'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'aui' ),
2061
+                'prefix_after' => _x( 'after', 'time ago', 'aui' ) . ' ',
2062
+                'suffix_after' => '',
2063
+                'seconds' => _x( 'less than a minute', 'time ago', 'aui' ),
2064
+                'minute' => _x( 'about a minute', 'time ago', 'aui' ),
2065
+                'minutes' => _x( '%d minutes', 'time ago', 'aui' ),
2066
+                'hour' => _x( 'about an hour', 'time ago', 'aui' ),
2067
+                'hours' => _x( 'about %d hours', 'time ago', 'aui' ),
2068
+                'day' => _x( 'a day', 'time ago', 'aui' ),
2069
+                'days' => _x( '%d days', 'time ago', 'aui' ),
2070
+                'month' => _x( 'about a month', 'time ago', 'aui' ),
2071
+                'months' => _x( '%d months', 'time ago', 'aui' ),
2072
+                'year' => _x( 'about a year', 'time ago', 'aui' ),
2073
+                'years' => _x( '%d years', 'time ago', 'aui' ),
2074
+            );
2075
+
2076
+            $params = apply_filters( 'ayecode_ui_timeago_params', $params );
2077
+
2078
+            foreach ( (array) $params as $key => $value ) {
2079
+                if ( ! is_scalar( $value ) ) {
2080
+                    continue;
2081
+                }
2172 2082
 
2173
-	/**
2174
-	 * Run the class if found.
2175
-	 */
2176
-	AyeCode_UI_Settings::instance();
2083
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2084
+            }
2085
+
2086
+            $locale = json_encode( $params );
2087
+
2088
+            return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2089
+        }
2090
+
2091
+        /**
2092
+         * JavaScript Minifier
2093
+         *
2094
+         * @param $input
2095
+         *
2096
+         * @return mixed
2097
+         */
2098
+        public static function minify_js($input) {
2099
+            if(trim($input) === "") return $input;
2100
+            return preg_replace(
2101
+                array(
2102
+                    // Remove comment(s)
2103
+                    '#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2104
+                    // Remove white-space(s) outside the string and regex
2105
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2106
+                    // Remove the last semicolon
2107
+                    '#;+\}#',
2108
+                    // Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2109
+                    '#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2110
+                    // --ibid. From `foo['bar']` to `foo.bar`
2111
+                    '#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2112
+                ),
2113
+                array(
2114
+                    '$1',
2115
+                    '$1$2',
2116
+                    '}',
2117
+                    '$1$3',
2118
+                    '$1.$3'
2119
+                ),
2120
+                $input);
2121
+        }
2122
+
2123
+        /**
2124
+         * Minify CSS
2125
+         *
2126
+         * @param $input
2127
+         *
2128
+         * @return mixed
2129
+         */
2130
+        public static function minify_css($input) {
2131
+            if(trim($input) === "") return $input;
2132
+            return preg_replace(
2133
+                array(
2134
+                    // Remove comment(s)
2135
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2136
+                    // Remove unused white-space(s)
2137
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2138
+                    // Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2139
+                    '#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2140
+                    // Replace `:0 0 0 0` with `:0`
2141
+                    '#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2142
+                    // Replace `background-position:0` with `background-position:0 0`
2143
+                    '#(background-position):0(?=[;\}])#si',
2144
+                    // Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2145
+                    '#(?<=[\s:,\-])0+\.(\d+)#s',
2146
+                    // Minify string value
2147
+                    '#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2148
+                    '#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2149
+                    // Minify HEX color code
2150
+                    '#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2151
+                    // Replace `(border|outline):none` with `(border|outline):0`
2152
+                    '#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2153
+                    // Remove empty selector(s)
2154
+                    '#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2155
+                ),
2156
+                array(
2157
+                    '$1',
2158
+                    '$1$2$3$4$5$6$7',
2159
+                    '$1',
2160
+                    ':0',
2161
+                    '$1:0 0',
2162
+                    '.$1',
2163
+                    '$1$3',
2164
+                    '$1$2$4$5',
2165
+                    '$1$2$3',
2166
+                    '$1:0',
2167
+                    '$1$2'
2168
+                ),
2169
+                $input);
2170
+        }
2171
+    }
2172
+
2173
+    /**
2174
+     * Run the class if found.
2175
+     */
2176
+    AyeCode_UI_Settings::instance();
2177 2177
 }
2178 2178
\ No newline at end of file
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.49";
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.49";
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.