Passed
Push — master ( 32accd...dc49db )
by Brian
05:22
created
includes/class-getpaid-notification-email.php 1 patch
Indentation   +56 added lines, -56 removed lines patch added patch discarded remove patch
@@ -13,36 +13,36 @@  discard block
 block discarded – undo
13 13
 class GetPaid_Notification_Email {
14 14
 
15 15
     /**
16
-	 * Contains the type of this notification email.
17
-	 *
18
-	 * @var string
19
-	 */
16
+     * Contains the type of this notification email.
17
+     *
18
+     * @var string
19
+     */
20 20
     public $id;
21 21
 
22 22
     /**
23
-	 * Contains any object to use in filters.
24
-	 *
25
-	 * @var false|WPInv_Invoice|WPInv_Item|WPInv_Subscription
26
-	 */
23
+     * Contains any object to use in filters.
24
+     *
25
+     * @var false|WPInv_Invoice|WPInv_Item|WPInv_Subscription
26
+     */
27 27
     public $object;
28 28
 
29 29
     /**
30
-	 * Class constructor.
31
-	 *
30
+     * Class constructor.
31
+     *
32 32
      * @param string $id Email Type.
33 33
      * @param mixed $object Optional. Associated object.
34
-	 */
35
-	public function __construct( $id, $object = false ) {
34
+     */
35
+    public function __construct( $id, $object = false ) {
36 36
         $this->id     = $id;
37 37
         $this->object = $object;
38 38
     }
39 39
 
40 40
     /**
41
-	 * Retrieves an option
42
-	 *
41
+     * Retrieves an option
42
+     *
43 43
      * @return mixed
44
-	 */
45
-	public function get_option( $key ) {
44
+     */
45
+    public function get_option( $key ) {
46 46
 
47 47
         $key   = "email_{$this->id}_$key";
48 48
         $value = wpinv_get_option( $key, null );
@@ -60,80 +60,80 @@  discard block
 block discarded – undo
60 60
     }
61 61
 
62 62
     /**
63
-	 * Retrieves the email body.
64
-	 *
63
+     * Retrieves the email body.
64
+     *
65 65
      * @return string
66
-	 */
67
-	public function get_body() {
66
+     */
67
+    public function get_body() {
68 68
         $body = $this->get_option( 'body' );
69 69
         return apply_filters( 'getpaid_get_email_body', $body, $this->id, $this->object );
70 70
     }
71 71
 
72 72
     /**
73
-	 * Retrieves the email subject.
74
-	 *
73
+     * Retrieves the email subject.
74
+     *
75 75
      * @return string
76
-	 */
77
-	public function get_subject() {
76
+     */
77
+    public function get_subject() {
78 78
         $subject = $this->get_option( 'subject' );
79 79
         return apply_filters( 'getpaid_get_email_subject', $subject, $this->id, $this->object );
80 80
     }
81 81
 
82 82
     /**
83
-	 * Retrieves the email heading.
84
-	 *
83
+     * Retrieves the email heading.
84
+     *
85 85
      * @return string
86
-	 */
87
-	public function get_heading() {
86
+     */
87
+    public function get_heading() {
88 88
         $heading = $this->get_option( 'heading' );
89 89
         return apply_filters( 'getpaid_get_email_heading', $heading, $this->id, $this->object );
90 90
     }
91 91
 
92 92
     /**
93
-	 * Checks if an email is active.
94
-	 *
93
+     * Checks if an email is active.
94
+     *
95 95
      * @return bool
96
-	 */
97
-	public function is_active() {
96
+     */
97
+    public function is_active() {
98 98
         $is_active = ! empty( $this->get_option( 'active' ) );
99 99
         return apply_filters( 'getpaid_email_type_is_active', $is_active, $this->id, $this->object );
100 100
     }
101 101
 
102 102
     /**
103
-	 * Checks if the site's admin should receive email notifications.
104
-	 *
103
+     * Checks if the site's admin should receive email notifications.
104
+     *
105 105
      * @return bool
106
-	 */
107
-	public function include_admin_bcc() {
106
+     */
107
+    public function include_admin_bcc() {
108 108
         $include_admin_bcc = ! empty( $this->get_option( 'admin_bcc' ) );
109 109
         return apply_filters( 'getpaid_email_type_include_admin_bcc', $include_admin_bcc, $this->id, $this->object );
110 110
     }
111 111
 
112 112
     /**
113
-	 * Checks whether this email should be sent to the customer or admin.
114
-	 *
113
+     * Checks whether this email should be sent to the customer or admin.
114
+     *
115 115
      * @return bool
116
-	 */
117
-	public function is_admin_email() {
116
+     */
117
+    public function is_admin_email() {
118 118
         $is_admin_email = in_array( $this->id, array( 'new_invoice', 'failed_invoice' ) );
119 119
         return apply_filters( 'getpaid_email_type_is_admin_email', $is_admin_email, $this->id, $this->object );
120 120
     }
121 121
 
122 122
     /**
123
-	 * Returns email attachments.
124
-	 *
123
+     * Returns email attachments.
124
+     *
125 125
      * @return array
126
-	 */
127
-	public function get_attachments() {
126
+     */
127
+    public function get_attachments() {
128 128
         return apply_filters( 'getpaid_get_email_attachments', array(), $this->id, $this->object );
129 129
     }
130 130
 
131 131
     /**
132
-	 * Returns an array of merge tags.
133
-	 *
132
+     * Returns an array of merge tags.
133
+     *
134 134
      * @return array
135
-	 */
136
-	public function get_merge_tags() {
135
+     */
136
+    public function get_merge_tags() {
137 137
 
138 138
         $merge_tags = array(
139 139
             '{site_title}' => wpinv_get_blogname(),
@@ -144,13 +144,13 @@  discard block
 block discarded – undo
144 144
     }
145 145
 
146 146
     /**
147
-	 * Adds merge tags to a text.
148
-	 *
147
+     * Adds merge tags to a text.
148
+     *
149 149
      * @param string string $text
150 150
      * @param array $merge_tags
151 151
      * @return string
152
-	 */
153
-	public function add_merge_tags( $text, $merge_tags = array() ) {
152
+     */
153
+    public function add_merge_tags( $text, $merge_tags = array() ) {
154 154
 
155 155
         foreach ( $merge_tags as $key => $value ) {
156 156
             $text = str_replace( $key, $value, $text );
@@ -160,13 +160,13 @@  discard block
 block discarded – undo
160 160
     }
161 161
 
162 162
     /**
163
-	 * Returns the email content
164
-	 *
163
+     * Returns the email content
164
+     *
165 165
      * @param array $merge_tags
166 166
      * @param array $extra_args Extra template args
167 167
      * @return string
168
-	 */
169
-	public function get_content( $merge_tags = array(), $extra_args = array() ) {
168
+     */
169
+    public function get_content( $merge_tags = array(), $extra_args = array() ) {
170 170
 
171 171
         $content = wpinv_get_template_html(
172 172
             "emails/wpinv-email-{$this->id}.php",
Please login to merge, or discard this patch.
includes/reports/class-getpaid-reports-helper.php 1 patch
Indentation   +276 added lines, -276 removed lines patch added patch discarded remove patch
@@ -12,294 +12,294 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Reports_Helper {
14 14
 
15
-	/**
16
-	 * Get report totals such as invoice totals and discount amounts.
17
-	 *
18
-	 * Data example:
19
-	 *
20
-	 * 'subtotal' => array(
21
-	 *     'type'     => 'invoice_data',
22
-	 *     'function' => 'SUM',
23
-	 *     'name'     => 'subtotal'
24
-	 * )
25
-	 *
26
-	 * @param  array $args
27
-	 * @return mixed depending on query_type
28
-	 */
29
-	public static function get_invoice_report_data( $args = array() ) {
30
-		global $wpdb;
31
-
32
-		$default_args = array(
33
-			'data'                  => array(), // The data to retrieve.
34
-			'where'                 => array(), // An array of where queries.
35
-			'query_type'            => 'get_row', // wpdb query to run.
36
-			'group_by'              => '', // What to group results by.
37
-			'order_by'              => '', // What to order by.
38
-			'limit'                 => '', // Results limit.
39
-			'filter_range'          => array(), // An array of before and after dates to limit results by.
40
-			'invoice_types'         => array( 'wpi_invoice' ), // An array of post types to retrieve.
41
-			'invoice_status'        => array( 'publish', 'wpi-processing', 'wpi-onhold' ),
42
-			'parent_invoice_status' => false, // Optionally filter by parent invoice status.
43
-		);
44
-
45
-		$args         = apply_filters( 'getpaid_reports_get_invoice_report_data_args', $args );
46
-		$args         = wp_parse_args( $args, $default_args );
47
-
48
-		extract( $args );
49
-
50
-		if ( empty( $data ) ) {
51
-			return '';
52
-		}
53
-
54
-		$query           = array();
55
-		$query['select'] = 'SELECT ' . implode( ',', self::prepare_invoice_data( $data ) );
56
-		$query['from']   = "FROM {$wpdb->posts} AS posts";
57
-		$query['join']   = implode( ' ', self::prepare_invoice_joins( $data + $where, ! empty( $parent_invoice_status ) ) );
58
-
59
-		$query['where']  = "
15
+    /**
16
+     * Get report totals such as invoice totals and discount amounts.
17
+     *
18
+     * Data example:
19
+     *
20
+     * 'subtotal' => array(
21
+     *     'type'     => 'invoice_data',
22
+     *     'function' => 'SUM',
23
+     *     'name'     => 'subtotal'
24
+     * )
25
+     *
26
+     * @param  array $args
27
+     * @return mixed depending on query_type
28
+     */
29
+    public static function get_invoice_report_data( $args = array() ) {
30
+        global $wpdb;
31
+
32
+        $default_args = array(
33
+            'data'                  => array(), // The data to retrieve.
34
+            'where'                 => array(), // An array of where queries.
35
+            'query_type'            => 'get_row', // wpdb query to run.
36
+            'group_by'              => '', // What to group results by.
37
+            'order_by'              => '', // What to order by.
38
+            'limit'                 => '', // Results limit.
39
+            'filter_range'          => array(), // An array of before and after dates to limit results by.
40
+            'invoice_types'         => array( 'wpi_invoice' ), // An array of post types to retrieve.
41
+            'invoice_status'        => array( 'publish', 'wpi-processing', 'wpi-onhold' ),
42
+            'parent_invoice_status' => false, // Optionally filter by parent invoice status.
43
+        );
44
+
45
+        $args         = apply_filters( 'getpaid_reports_get_invoice_report_data_args', $args );
46
+        $args         = wp_parse_args( $args, $default_args );
47
+
48
+        extract( $args );
49
+
50
+        if ( empty( $data ) ) {
51
+            return '';
52
+        }
53
+
54
+        $query           = array();
55
+        $query['select'] = 'SELECT ' . implode( ',', self::prepare_invoice_data( $data ) );
56
+        $query['from']   = "FROM {$wpdb->posts} AS posts";
57
+        $query['join']   = implode( ' ', self::prepare_invoice_joins( $data + $where, ! empty( $parent_invoice_status ) ) );
58
+
59
+        $query['where']  = "
60 60
 			WHERE 	posts.post_type 	IN ( '" . implode( "','", $invoice_types ) . "' )
61 61
 			";
62 62
 
63
-		if ( ! empty( $invoice_status ) ) {
64
-			$query['where'] .= "
63
+        if ( ! empty( $invoice_status ) ) {
64
+            $query['where'] .= "
65 65
 				AND 	posts.post_status 	IN ( '" . implode( "','", $invoice_status ) . "' )
66 66
 			";
67
-		}
68
-
69
-		if ( ! empty( $parent_invoice_status ) ) {
70
-			if ( ! empty( $invoice_status ) ) {
71
-				$query['where'] .= " AND ( parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) OR parent.ID IS NULL ) ";
72
-			} else {
73
-				$query['where'] .= " AND parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) ";
74
-			}
75
-		}
76
-
77
-		if ( ! empty( $filter_range['before'] ) ) {
78
-			$query['where'] .= "
67
+        }
68
+
69
+        if ( ! empty( $parent_invoice_status ) ) {
70
+            if ( ! empty( $invoice_status ) ) {
71
+                $query['where'] .= " AND ( parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) OR parent.ID IS NULL ) ";
72
+            } else {
73
+                $query['where'] .= " AND parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) ";
74
+            }
75
+        }
76
+
77
+        if ( ! empty( $filter_range['before'] ) ) {
78
+            $query['where'] .= "
79 79
 				AND 	posts.post_date < '" . date( 'Y-m-d 23:59:59', strtotime( $filter_range['before'] ) ) . "'
80 80
 			";
81
-		}
81
+        }
82 82
 
83
-		if ( ! empty( $filter_range['after'] ) ) {
84
-			$query['where'] .= "
83
+        if ( ! empty( $filter_range['after'] ) ) {
84
+            $query['where'] .= "
85 85
 				AND 	posts.post_date > '" . date( 'Y-m-d H:i:s', strtotime( $filter_range['after'] ) ) . "'
86 86
 			";
87
-		}
87
+        }
88 88
 
89
-		if ( ! empty( $where ) ) {
89
+        if ( ! empty( $where ) ) {
90 90
 
91
-			foreach ( $where as $value ) {
91
+            foreach ( $where as $value ) {
92 92
 
93
-				if ( strtolower( $value['operator'] ) == 'in' || strtolower( $value['operator'] ) == 'not in' ) {
94
-
95
-					if ( is_array( $value['value'] ) ) {
96
-						$value['value'] = implode( "','", $value['value'] );
97
-					}
98
-
99
-					if ( ! empty( $value['value'] ) ) {
100
-						$where_value = "{$value['operator']} ('{$value['value']}')";
101
-					}
102
-				} else {
103
-					$where_value = "{$value['operator']} '{$value['value']}'";
104
-				}
105
-
106
-				if ( ! empty( $where_value ) ) {
107
-					$query['where'] .= " AND {$value['key']} {$where_value}";
108
-				}
109
-			}
110
-		}
111
-
112
-		if ( $group_by ) {
113
-			$query['group_by'] = "GROUP BY {$group_by}";
114
-		}
115
-
116
-		if ( $order_by ) {
117
-			$query['order_by'] = "ORDER BY {$order_by}";
118
-		}
119
-
120
-		if ( $limit ) {
121
-			$query['limit'] = "LIMIT {$limit}";
122
-		}
123
-
124
-		$query = apply_filters( 'getpaid_reports_get_invoice_report_query', $query, $data );
125
-		$query = implode( ' ', $query );
126
-
127
-		return self::execute( $query_type, $query );
128
-
129
-	}
130
-
131
-	/**
132
-	 * Prepares the data to select.
133
-	 *
134
-	 *
135
-	 * @param  array $data
136
-	 * @return array
137
-	 */
138
-	public static function prepare_invoice_data( $data ) {
139
-
140
-		$prepared = array();
141
-
142
-		foreach ( $data as $raw_key => $value ) {
143
-			$key      = sanitize_key( $raw_key );
144
-			$distinct = '';
145
-
146
-			if ( isset( $value['distinct'] ) ) {
147
-				$distinct = 'DISTINCT';
148
-			}
149
-
150
-			$get_key = self::get_invoice_table_key( $key, $value['type'] );
151
-
152
-			if ( false === $get_key ) {
153
-				// Skip to the next foreach iteration else the query will be invalid.
154
-				continue;
155
-			}
156
-
157
-			if ( ! empty( $value['function'] ) ) {
158
-				$get = "{$value['function']}({$distinct} {$get_key})";
159
-			} else {
160
-				$get = "{$distinct} {$get_key}";
161
-			}
162
-
163
-			$prepared[] = "{$get} as {$value['name']}";
164
-		}
165
-
166
-		return $prepared;
167
-
168
-	}
169
-
170
-	/**
171
-	 * Prepares the joins to use.
172
-	 *
173
-	 *
174
-	 * @param  array $data
175
-	 * @param  bool $with_parent
176
-	 * @return array
177
-	 */
178
-	public static function prepare_invoice_joins( $data, $with_parent ) {
179
-		global $wpdb;
180
-
181
-		$prepared = array();
182
-
183
-		foreach ( $data as $raw_key => $value ) {
184
-			$join_type = isset( $value['join_type'] ) ? $value['join_type'] : 'INNER';
185
-			$type      = isset( $value['type'] ) ? $value['type'] : false;
186
-			$key       = sanitize_key( $raw_key );
187
-
188
-			switch ( $type ) {
189
-				case 'meta':
190
-					$prepared[ "meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS meta_{$key} ON ( posts.ID = meta_{$key}.post_id AND meta_{$key}.meta_key = '{$raw_key}' )";
191
-					break;
192
-				case 'parent_meta':
193
-					$prepared[ "parent_meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS parent_meta_{$key} ON (posts.post_parent = parent_meta_{$key}.post_id) AND (parent_meta_{$key}.meta_key = '{$raw_key}')";
194
-					break;
195
-				case 'invoice_data':
196
-					$prepared['invoices'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoices AS invoices ON posts.ID = invoices.post_id";
197
-					break;
198
-				case 'invoice_item':
199
-					$prepared['invoice_items'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoice_items AS invoice_items ON posts.ID = invoice_items.post_id";
200
-					break;
201
-			}
202
-		}
203
-
204
-		if ( $with_parent ) {
205
-			$prepared['parent'] = "LEFT JOIN {$wpdb->posts} AS parent ON posts.post_parent = parent.ID";
206
-		}
207
-
208
-		return $prepared;
209
-
210
-	}
211
-
212
-	/**
213
-	 * Retrieves the appropriate table key to use.
214
-	 *
215
-	 *
216
-	 * @param  string $key
217
-	 * @param  string $table
218
-	 * @return string|false
219
-	 */
220
-	public static function get_invoice_table_key( $key, $table ) {
221
-
222
-		$keys = array(
223
-			'meta'         => "meta_{$key}.meta_value",
224
-			'parent_meta'  => "parent_meta_{$key}.meta_value",
225
-			'post_data'    => "posts.{$key}",
226
-			'invoice_data' => "invoices.{$key}",
227
-			'invoice_item' => "invoice_items.{$key}",
228
-		);
229
-
230
-		return isset( $keys[ $table ] ) ? $keys[ $table ] : false;
231
-
232
-	}
233
-
234
-	/**
235
-	 * Executes a query and caches the result for a minute.
236
-	 *
237
-	 *
238
-	 * @param  string $query_type
239
-	 * @param  string $query
240
-	 * @return mixed depending on query_type
241
-	 */
242
-	public static function execute( $query_type, $query ) {
243
-		global $wpdb;
244
-
245
-		$query_hash = md5( $query_type . $query );
246
-		$result     = self::get_cached_query( $query_hash );
247
-		if ( $result === false ) {
248
-			self::enable_big_selects();
249
-
250
-			$result = $wpdb->$query_type( $query );
251
-			self::set_cached_query( $query_hash, $result );
252
-		}
253
-
254
-		return $result;
255
-
256
-	}
257
-
258
-	/**
259
-	 * Enables big mysql selects for reports, just once for this session.
260
-	 */
261
-	protected static function enable_big_selects() {
262
-		static $big_selects = false;
263
-
264
-		global $wpdb;
265
-
266
-		if ( ! $big_selects ) {
267
-			$wpdb->query( 'SET SESSION SQL_BIG_SELECTS=1' );
268
-			$big_selects = true;
269
-		}
270
-	}
271
-
272
-	/**
273
-	 * Get the cached query result or null if it's not in the cache.
274
-	 *
275
-	 * @param string $query_hash The query hash.
276
-	 *
277
-	 * @return mixed|false The cache contents on success, false on failure to retrieve contents.
278
-	 */
279
-	protected static function get_cached_query( $query_hash ) {
280
-
281
-		return wp_cache_get(
282
-			$query_hash,
283
-			strtolower( __CLASS__ )
284
-		);
285
-
286
-	}
287
-
288
-	/**
289
-	 * Set the cached query result.
290
-	 *
291
-	 * @param string $query_hash The query hash.
292
-	 * @param mixed  $data The data to cache.
293
-	 */
294
-	protected static function set_cached_query( $query_hash, $data ) {
295
-
296
-		wp_cache_set(
297
-			$query_hash,
298
-			$data,
299
-			strtolower( __CLASS__ ),
300
-			MINUTE_IN_SECONDS
301
-		);
302
-
303
-	}
93
+                if ( strtolower( $value['operator'] ) == 'in' || strtolower( $value['operator'] ) == 'not in' ) {
94
+
95
+                    if ( is_array( $value['value'] ) ) {
96
+                        $value['value'] = implode( "','", $value['value'] );
97
+                    }
98
+
99
+                    if ( ! empty( $value['value'] ) ) {
100
+                        $where_value = "{$value['operator']} ('{$value['value']}')";
101
+                    }
102
+                } else {
103
+                    $where_value = "{$value['operator']} '{$value['value']}'";
104
+                }
105
+
106
+                if ( ! empty( $where_value ) ) {
107
+                    $query['where'] .= " AND {$value['key']} {$where_value}";
108
+                }
109
+            }
110
+        }
111
+
112
+        if ( $group_by ) {
113
+            $query['group_by'] = "GROUP BY {$group_by}";
114
+        }
115
+
116
+        if ( $order_by ) {
117
+            $query['order_by'] = "ORDER BY {$order_by}";
118
+        }
119
+
120
+        if ( $limit ) {
121
+            $query['limit'] = "LIMIT {$limit}";
122
+        }
123
+
124
+        $query = apply_filters( 'getpaid_reports_get_invoice_report_query', $query, $data );
125
+        $query = implode( ' ', $query );
126
+
127
+        return self::execute( $query_type, $query );
128
+
129
+    }
130
+
131
+    /**
132
+     * Prepares the data to select.
133
+     *
134
+     *
135
+     * @param  array $data
136
+     * @return array
137
+     */
138
+    public static function prepare_invoice_data( $data ) {
139
+
140
+        $prepared = array();
141
+
142
+        foreach ( $data as $raw_key => $value ) {
143
+            $key      = sanitize_key( $raw_key );
144
+            $distinct = '';
145
+
146
+            if ( isset( $value['distinct'] ) ) {
147
+                $distinct = 'DISTINCT';
148
+            }
149
+
150
+            $get_key = self::get_invoice_table_key( $key, $value['type'] );
151
+
152
+            if ( false === $get_key ) {
153
+                // Skip to the next foreach iteration else the query will be invalid.
154
+                continue;
155
+            }
156
+
157
+            if ( ! empty( $value['function'] ) ) {
158
+                $get = "{$value['function']}({$distinct} {$get_key})";
159
+            } else {
160
+                $get = "{$distinct} {$get_key}";
161
+            }
162
+
163
+            $prepared[] = "{$get} as {$value['name']}";
164
+        }
165
+
166
+        return $prepared;
167
+
168
+    }
169
+
170
+    /**
171
+     * Prepares the joins to use.
172
+     *
173
+     *
174
+     * @param  array $data
175
+     * @param  bool $with_parent
176
+     * @return array
177
+     */
178
+    public static function prepare_invoice_joins( $data, $with_parent ) {
179
+        global $wpdb;
180
+
181
+        $prepared = array();
182
+
183
+        foreach ( $data as $raw_key => $value ) {
184
+            $join_type = isset( $value['join_type'] ) ? $value['join_type'] : 'INNER';
185
+            $type      = isset( $value['type'] ) ? $value['type'] : false;
186
+            $key       = sanitize_key( $raw_key );
187
+
188
+            switch ( $type ) {
189
+                case 'meta':
190
+                    $prepared[ "meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS meta_{$key} ON ( posts.ID = meta_{$key}.post_id AND meta_{$key}.meta_key = '{$raw_key}' )";
191
+                    break;
192
+                case 'parent_meta':
193
+                    $prepared[ "parent_meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS parent_meta_{$key} ON (posts.post_parent = parent_meta_{$key}.post_id) AND (parent_meta_{$key}.meta_key = '{$raw_key}')";
194
+                    break;
195
+                case 'invoice_data':
196
+                    $prepared['invoices'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoices AS invoices ON posts.ID = invoices.post_id";
197
+                    break;
198
+                case 'invoice_item':
199
+                    $prepared['invoice_items'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoice_items AS invoice_items ON posts.ID = invoice_items.post_id";
200
+                    break;
201
+            }
202
+        }
203
+
204
+        if ( $with_parent ) {
205
+            $prepared['parent'] = "LEFT JOIN {$wpdb->posts} AS parent ON posts.post_parent = parent.ID";
206
+        }
207
+
208
+        return $prepared;
209
+
210
+    }
211
+
212
+    /**
213
+     * Retrieves the appropriate table key to use.
214
+     *
215
+     *
216
+     * @param  string $key
217
+     * @param  string $table
218
+     * @return string|false
219
+     */
220
+    public static function get_invoice_table_key( $key, $table ) {
221
+
222
+        $keys = array(
223
+            'meta'         => "meta_{$key}.meta_value",
224
+            'parent_meta'  => "parent_meta_{$key}.meta_value",
225
+            'post_data'    => "posts.{$key}",
226
+            'invoice_data' => "invoices.{$key}",
227
+            'invoice_item' => "invoice_items.{$key}",
228
+        );
229
+
230
+        return isset( $keys[ $table ] ) ? $keys[ $table ] : false;
231
+
232
+    }
233
+
234
+    /**
235
+     * Executes a query and caches the result for a minute.
236
+     *
237
+     *
238
+     * @param  string $query_type
239
+     * @param  string $query
240
+     * @return mixed depending on query_type
241
+     */
242
+    public static function execute( $query_type, $query ) {
243
+        global $wpdb;
244
+
245
+        $query_hash = md5( $query_type . $query );
246
+        $result     = self::get_cached_query( $query_hash );
247
+        if ( $result === false ) {
248
+            self::enable_big_selects();
249
+
250
+            $result = $wpdb->$query_type( $query );
251
+            self::set_cached_query( $query_hash, $result );
252
+        }
253
+
254
+        return $result;
255
+
256
+    }
257
+
258
+    /**
259
+     * Enables big mysql selects for reports, just once for this session.
260
+     */
261
+    protected static function enable_big_selects() {
262
+        static $big_selects = false;
263
+
264
+        global $wpdb;
265
+
266
+        if ( ! $big_selects ) {
267
+            $wpdb->query( 'SET SESSION SQL_BIG_SELECTS=1' );
268
+            $big_selects = true;
269
+        }
270
+    }
271
+
272
+    /**
273
+     * Get the cached query result or null if it's not in the cache.
274
+     *
275
+     * @param string $query_hash The query hash.
276
+     *
277
+     * @return mixed|false The cache contents on success, false on failure to retrieve contents.
278
+     */
279
+    protected static function get_cached_query( $query_hash ) {
280
+
281
+        return wp_cache_get(
282
+            $query_hash,
283
+            strtolower( __CLASS__ )
284
+        );
285
+
286
+    }
287
+
288
+    /**
289
+     * Set the cached query result.
290
+     *
291
+     * @param string $query_hash The query hash.
292
+     * @param mixed  $data The data to cache.
293
+     */
294
+    protected static function set_cached_query( $query_hash, $data ) {
295
+
296
+        wp_cache_set(
297
+            $query_hash,
298
+            $data,
299
+            strtolower( __CLASS__ ),
300
+            MINUTE_IN_SECONDS
301
+        );
302
+
303
+    }
304 304
 
305 305
 }
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-helper.php 1 patch
Indentation   +467 added lines, -467 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,470 +11,470 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI_Component_Helper {
13 13
 
14
-	/**
15
-	 * A component helper for generating a input name.
16
-	 *
17
-	 * @param $text
18
-	 * @param $multiple bool If the name is set to be multiple but no brackets found then we add some.
19
-	 *
20
-	 * @return string
21
-	 */
22
-	public static function name( $text, $multiple = false ) {
23
-		$output = '';
24
-
25
-		if ( $text ) {
26
-			$is_multiple = strpos( $text, '[' ) === false && $multiple ? '[]' : '';
27
-			$output      = ' name="' . esc_attr( $text ) . $is_multiple . '" ';
28
-		}
29
-
30
-		return $output;
31
-	}
32
-
33
-	/**
34
-	 * A component helper for generating a item id.
35
-	 *
36
-	 * @param $text string The text to be used as the value.
37
-	 *
38
-	 * @return string The sanitized item.
39
-	 */
40
-	public static function id( $text ) {
41
-		$output = '';
42
-
43
-		if ( $text ) {
44
-			$output = ' id="' . sanitize_html_class( $text ) . '" ';
45
-		}
46
-
47
-		return $output;
48
-	}
49
-
50
-	/**
51
-	 * A component helper for generating a item title.
52
-	 *
53
-	 * @param $text string The text to be used as the value.
54
-	 *
55
-	 * @return string The sanitized item.
56
-	 */
57
-	public static function title( $text ) {
58
-		$output = '';
59
-
60
-		if ( $text ) {
61
-			$output = ' title="' . esc_attr( $text ) . '" ';
62
-		}
63
-
64
-		return $output;
65
-	}
66
-
67
-	/**
68
-	 * A component helper for generating a item value.
69
-	 *
70
-	 * @param $text string The text to be used as the value.
71
-	 *
72
-	 * @return string The sanitized item.
73
-	 */
74
-	public static function value( $text ) {
75
-		$output = '';
76
-
77
-		if ( $text !== null && $text !== false ) {
78
-			$output = ' value="' . esc_attr( wp_unslash( $text ) ) . '" ';
79
-		}
80
-
81
-		return $output;
82
-	}
83
-
84
-	/**
85
-	 * A component helper for generating a item class attribute.
86
-	 *
87
-	 * @param $text string The text to be used as the value.
88
-	 *
89
-	 * @return string The sanitized item.
90
-	 */
91
-	public static function class_attr( $text ) {
92
-		$output = '';
93
-
94
-		if ( $text ) {
95
-			$classes = self::esc_classes( $text );
96
-			if ( ! empty( $classes ) ) {
97
-				$output = ' class="' . $classes . '" ';
98
-			}
99
-		}
100
-
101
-		return $output;
102
-	}
103
-
104
-	/**
105
-	 * Escape a string of classes.
106
-	 *
107
-	 * @param $text
108
-	 *
109
-	 * @return string
110
-	 */
111
-	public static function esc_classes( $text ) {
112
-		$output = '';
113
-
114
-		if ( $text ) {
115
-			$classes = explode( " ", $text );
116
-			$classes = array_map( "trim", $classes );
117
-			$classes = array_map( "sanitize_html_class", $classes );
118
-			if ( ! empty( $classes ) ) {
119
-				$output = implode( " ", $classes );
120
-			}
121
-		}
122
-
123
-		return $output;
124
-
125
-	}
126
-
127
-	/**
128
-	 * @param $args
129
-	 *
130
-	 * @return string
131
-	 */
132
-	public static function data_attributes( $args ) {
133
-		$output = '';
134
-
135
-		if ( ! empty( $args ) ) {
136
-
137
-			foreach ( $args as $key => $val ) {
138
-				if ( substr( $key, 0, 5 ) === "data-" ) {
139
-					$output .= ' ' . sanitize_html_class( $key ) . '="' . esc_attr( $val ) . '" ';
140
-				}
141
-			}
142
-		}
143
-
144
-		return $output;
145
-	}
146
-
147
-	/**
148
-	 * @param $args
149
-	 *
150
-	 * @return string
151
-	 */
152
-	public static function aria_attributes( $args ) {
153
-		$output = '';
154
-
155
-		if ( ! empty( $args ) ) {
156
-
157
-			foreach ( $args as $key => $val ) {
158
-				if ( substr( $key, 0, 5 ) === "aria-" ) {
159
-					$output .= ' ' . sanitize_html_class( $key ) . '="' . esc_attr( $val ) . '" ';
160
-				}
161
-			}
162
-		}
163
-
164
-		return $output;
165
-	}
166
-
167
-	/**
168
-	 * Build a font awesome icon from a class.
169
-	 *
170
-	 * @param $class
171
-	 * @param bool $space_after
172
-	 * @param array $extra_attributes An array of extra attributes.
173
-	 *
174
-	 * @return string
175
-	 */
176
-	public static function icon( $class, $space_after = false, $extra_attributes = array() ) {
177
-		$output = '';
178
-
179
-		if ( $class ) {
180
-			$classes = self::esc_classes( $class );
181
-			if ( ! empty( $classes ) ) {
182
-				$output = '<i class="' . $classes . '" ';
183
-				// extra attributes
184
-				if ( ! empty( $extra_attributes ) ) {
185
-					$output .= AUI_Component_Helper::extra_attributes( $extra_attributes );
186
-				}
187
-				$output .= '></i>';
188
-				if ( $space_after ) {
189
-					$output .= " ";
190
-				}
191
-			}
192
-		}
193
-
194
-		return $output;
195
-	}
196
-
197
-	/**
198
-	 * @param $args
199
-	 *
200
-	 * @return string
201
-	 */
202
-	public static function extra_attributes( $args ) {
203
-		$output = '';
204
-
205
-		if ( ! empty( $args ) ) {
206
-
207
-			if ( is_array( $args ) ) {
208
-				foreach ( $args as $key => $val ) {
209
-					$output .= ' ' . sanitize_html_class( $key ) . '="' . esc_attr( $val ) . '" ';
210
-				}
211
-			} else {
212
-				$output .= ' ' . $args . ' ';
213
-			}
214
-
215
-		}
216
-
217
-		return $output;
218
-	}
219
-
220
-	/**
221
-	 * @param $args
222
-	 *
223
-	 * @return string
224
-	 */
225
-	public static function help_text( $text ) {
226
-		$output = '';
227
-
228
-		if ( $text ) {
229
-			$output .= '<small class="form-text text-muted">' . wp_kses_post( $text ) . '</small>';
230
-		}
231
-
232
-
233
-		return $output;
234
-	}
235
-
236
-	/**
237
-	 * Replace element require context with JS.
238
-	 *
239
-	 * @param $input
240
-	 *
241
-	 * @return string|void
242
-	 */
243
-	public static function element_require( $input ) {
244
-
245
-		$input = str_replace( "'", '"', $input );// we only want double quotes
246
-
247
-		$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
248
-			"jQuery(form).find('[data-argument=\"",
249
-			"\"]').find('input,select,textarea').val()",
250
-			"\"]').find('input:checked').val()",
251
-		), $input ) );
252
-
253
-		if ( $output ) {
254
-			$output = ' data-element-require="' . $output . '" ';
255
-		}
256
-
257
-		return $output;
258
-	}
259
-
260
-	/**
261
-	 * Navigates through an array, object, or scalar, and removes slashes from the values.
262
-	 *
263
-	 * @since 0.1.41
264
-	 *
265
-	 * @param mixed $value The value to be stripped.
266
-	 * @param array $input Input Field.
267
-	 *
268
-	 * @return mixed Stripped value.
269
-	 */
270
-	public static function sanitize_html_field( $value, $input = array() ) {
271
-		$original = $value;
272
-
273
-		if ( is_array( $value ) ) {
274
-			foreach ( $value as $index => $item ) {
275
-				$value[ $index ] = self::_sanitize_html_field( $value, $input );
276
-			}
277
-		} elseif ( is_object( $value ) ) {
278
-			$object_vars = get_object_vars( $value );
279
-
280
-			foreach ( $object_vars as $property_name => $property_value ) {
281
-				$value->$property_name = self::_sanitize_html_field( $property_value, $input );
282
-			}
283
-		} else {
284
-			$value = self::_sanitize_html_field( $value, $input );
285
-		}
286
-
287
-		/**
288
-		 * Filters content and keeps only allowable HTML elements.
289
-		 *
290
-		 * @since 0.1.41
291
-		 *
292
-		 * @param string|array $value Content to filter through kses.
293
-		 * @param string|array $value Original content without filter.
294
-		 * @param array $input Input Field.
295
-		 */
296
-		return apply_filters( 'ayecode_ui_sanitize_html_field', $value, $original, $input );
297
-	}
298
-
299
-	/**
300
-	 * Filters content and keeps only allowable HTML elements.
301
-	 *
302
-	 * This function makes sure that only the allowed HTML element names, attribute
303
-	 * names and attribute values plus only sane HTML entities will occur in
304
-	 * $string. You have to remove any slashes from PHP's magic quotes before you
305
-	 * call this function.
306
-	 *
307
-	 * The default allowed protocols are 'http', 'https', 'ftp', 'mailto', 'news',
308
-	 * 'irc', 'gopher', 'nntp', 'feed', 'telnet, 'mms', 'rtsp' and 'svn'. This
309
-	 * covers all common link protocols, except for 'javascript' which should not
310
-	 * be allowed for untrusted users.
311
-	 *
312
-	 * @since 0.1.41
313
-	 *
314
-	 * @param string|array $value Content to filter through kses.
315
-	 * @param array $input Input Field.
316
-	 *
317
-	 * @return string Filtered content with only allowed HTML elements.
318
-	 */
319
-	public static function _sanitize_html_field( $value, $input = array() ) {
320
-		if ( $value === '' ) {
321
-			return $value;
322
-		}
323
-
324
-		$allowed_html = self::kses_allowed_html( 'post', $input );
325
-
326
-		if ( ! is_array( $allowed_html ) ) {
327
-			$allowed_html = wp_kses_allowed_html( 'post' );
328
-		}
329
-
330
-		$filtered = trim( wp_unslash( $value ) );
331
-		$filtered = wp_kses( $filtered, $allowed_html );
332
-		$filtered = balanceTags( $filtered ); // Balances tags
333
-
334
-		return $filtered;
335
-	}
336
-
337
-	/**
338
-	 * Returns an array of allowed HTML tags and attributes for a given context.
339
-	 *
340
-	 * @since 0.1.41
341
-	 *
342
-	 * @param string|array $context The context for which to retrieve tags. Allowed values are 'post',
343
-	 *                              'strip', 'data', 'entities', or the name of a field filter such as
344
-	 *                              'pre_user_description'.
345
-	 * @param array $input Input.
346
-	 *
347
-	 * @return array Array of allowed HTML tags and their allowed attributes.
348
-	 */
349
-	public static function kses_allowed_html( $context = 'post', $input = array() ) {
350
-		$allowed_html = wp_kses_allowed_html( $context );
351
-
352
-		if ( is_array( $allowed_html ) ) {
353
-			// <iframe>
354
-			if ( ! isset( $allowed_html['iframe'] ) && $context == 'post' ) {
355
-				$allowed_html['iframe'] = array(
356
-					'class'           => true,
357
-					'id'              => true,
358
-					'src'             => true,
359
-					'width'           => true,
360
-					'height'          => true,
361
-					'frameborder'     => true,
362
-					'marginwidth'     => true,
363
-					'marginheight'    => true,
364
-					'scrolling'       => true,
365
-					'style'           => true,
366
-					'title'           => true,
367
-					'allow'           => true,
368
-					'allowfullscreen' => true,
369
-					'data-*'          => true,
370
-				);
371
-			}
372
-		}
373
-
374
-		/**
375
-		 * Filters the allowed html tags.
376
-		 *
377
-		 * @since 0.1.41
378
-		 *
379
-		 * @param array[]|string $allowed_html Allowed html tags.
380
-		 * @param @param string|array $context The context for which to retrieve tags.
381
-		 * @param array $input Input field.
382
-		 */
383
-		return apply_filters( 'ayecode_ui_kses_allowed_html', $allowed_html, $context, $input );
384
-	}
385
-
386
-	public static function get_column_class( $label_number = 2, $type = 'label' ) {
387
-
388
-		$class = '';
389
-
390
-		// set default if empty
391
-		if( $label_number === '' ){
392
-			$label_number = 2;
393
-		}
394
-
395
-		if ( $label_number && $label_number < 12 && $label_number > 0 ) {
396
-			if ( $type == 'label' ) {
397
-				$class = 'col-sm-' . absint( $label_number );
398
-			} elseif ( $type == 'input' ) {
399
-				$class = 'col-sm-' . ( 12 - absint( $label_number ) );
400
-			}
401
-		}
402
-
403
-		return $class;
404
-	}
405
-
406
-	/**
407
-	 * Sanitizes a multiline string from user input or from the database.
408
-	 *
409
-	 * Emulate the WP native sanitize_textarea_field function in a %%variable%% safe way.
410
-	 *
411
-	 * @see   https://core.trac.wordpress.org/browser/trunk/src/wp-includes/formatting.php for the original
412
-	 *
413
-	 * @since 0.1.66
414
-	 *
415
-	 * @param string $str String to sanitize.
416
-	 * @return string Sanitized string.
417
-	 */
418
-	public static function sanitize_textarea_field( $str ) {
419
-		$filtered = self::_sanitize_text_fields( $str, true );
420
-
421
-		/**
422
-		 * Filters a sanitized textarea field string.
423
-		 *
424
-		 * @see https://core.trac.wordpress.org/browser/trunk/src/wp-includes/formatting.php
425
-		 *
426
-		 * @param string $filtered The sanitized string.
427
-		 * @param string $str      The string prior to being sanitized.
428
-		 */
429
-		return apply_filters( 'sanitize_textarea_field', $filtered, $str );
430
-	}
431
-
432
-	/**
433
-	 * Internal helper function to sanitize a string from user input or from the db.
434
-	 *
435
-	 * @since 0.1.66
436
-	 * @access private
437
-	 *
438
-	 * @param string $str           String to sanitize.
439
-	 * @param bool   $keep_newlines Optional. Whether to keep newlines. Default: false.
440
-	 * @return string Sanitized string.
441
-	 */
442
-	public static function _sanitize_text_fields( $str, $keep_newlines = false ) {
443
-		if ( is_object( $str ) || is_array( $str ) ) {
444
-			return '';
445
-		}
446
-
447
-		$str = (string) $str;
448
-
449
-		$filtered = wp_check_invalid_utf8( $str );
450
-
451
-		if ( strpos( $filtered, '<' ) !== false ) {
452
-			$filtered = wp_pre_kses_less_than( $filtered );
453
-			// This will strip extra whitespace for us.
454
-			$filtered = wp_strip_all_tags( $filtered, false );
455
-
456
-			// Use HTML entities in a special case to make sure no later
457
-			// newline stripping stage could lead to a functional tag.
458
-			$filtered = str_replace( "<\n", "&lt;\n", $filtered );
459
-		}
460
-
461
-		if ( ! $keep_newlines ) {
462
-			$filtered = preg_replace( '/[\r\n\t ]+/', ' ', $filtered );
463
-		}
464
-		$filtered = trim( $filtered );
465
-
466
-		$found = false;
467
-		while ( preg_match( '`[^%](%[a-f0-9]{2})`i', $filtered, $match ) ) {
468
-			$filtered = str_replace( $match[1], '', $filtered );
469
-			$found = true;
470
-		}
471
-		unset( $match );
472
-
473
-		if ( $found ) {
474
-			// Strip out the whitespace that may now exist after removing the octets.
475
-			$filtered = trim( preg_replace( '` +`', ' ', $filtered ) );
476
-		}
477
-
478
-		return $filtered;
479
-	}
14
+    /**
15
+     * A component helper for generating a input name.
16
+     *
17
+     * @param $text
18
+     * @param $multiple bool If the name is set to be multiple but no brackets found then we add some.
19
+     *
20
+     * @return string
21
+     */
22
+    public static function name( $text, $multiple = false ) {
23
+        $output = '';
24
+
25
+        if ( $text ) {
26
+            $is_multiple = strpos( $text, '[' ) === false && $multiple ? '[]' : '';
27
+            $output      = ' name="' . esc_attr( $text ) . $is_multiple . '" ';
28
+        }
29
+
30
+        return $output;
31
+    }
32
+
33
+    /**
34
+     * A component helper for generating a item id.
35
+     *
36
+     * @param $text string The text to be used as the value.
37
+     *
38
+     * @return string The sanitized item.
39
+     */
40
+    public static function id( $text ) {
41
+        $output = '';
42
+
43
+        if ( $text ) {
44
+            $output = ' id="' . sanitize_html_class( $text ) . '" ';
45
+        }
46
+
47
+        return $output;
48
+    }
49
+
50
+    /**
51
+     * A component helper for generating a item title.
52
+     *
53
+     * @param $text string The text to be used as the value.
54
+     *
55
+     * @return string The sanitized item.
56
+     */
57
+    public static function title( $text ) {
58
+        $output = '';
59
+
60
+        if ( $text ) {
61
+            $output = ' title="' . esc_attr( $text ) . '" ';
62
+        }
63
+
64
+        return $output;
65
+    }
66
+
67
+    /**
68
+     * A component helper for generating a item value.
69
+     *
70
+     * @param $text string The text to be used as the value.
71
+     *
72
+     * @return string The sanitized item.
73
+     */
74
+    public static function value( $text ) {
75
+        $output = '';
76
+
77
+        if ( $text !== null && $text !== false ) {
78
+            $output = ' value="' . esc_attr( wp_unslash( $text ) ) . '" ';
79
+        }
80
+
81
+        return $output;
82
+    }
83
+
84
+    /**
85
+     * A component helper for generating a item class attribute.
86
+     *
87
+     * @param $text string The text to be used as the value.
88
+     *
89
+     * @return string The sanitized item.
90
+     */
91
+    public static function class_attr( $text ) {
92
+        $output = '';
93
+
94
+        if ( $text ) {
95
+            $classes = self::esc_classes( $text );
96
+            if ( ! empty( $classes ) ) {
97
+                $output = ' class="' . $classes . '" ';
98
+            }
99
+        }
100
+
101
+        return $output;
102
+    }
103
+
104
+    /**
105
+     * Escape a string of classes.
106
+     *
107
+     * @param $text
108
+     *
109
+     * @return string
110
+     */
111
+    public static function esc_classes( $text ) {
112
+        $output = '';
113
+
114
+        if ( $text ) {
115
+            $classes = explode( " ", $text );
116
+            $classes = array_map( "trim", $classes );
117
+            $classes = array_map( "sanitize_html_class", $classes );
118
+            if ( ! empty( $classes ) ) {
119
+                $output = implode( " ", $classes );
120
+            }
121
+        }
122
+
123
+        return $output;
124
+
125
+    }
126
+
127
+    /**
128
+     * @param $args
129
+     *
130
+     * @return string
131
+     */
132
+    public static function data_attributes( $args ) {
133
+        $output = '';
134
+
135
+        if ( ! empty( $args ) ) {
136
+
137
+            foreach ( $args as $key => $val ) {
138
+                if ( substr( $key, 0, 5 ) === "data-" ) {
139
+                    $output .= ' ' . sanitize_html_class( $key ) . '="' . esc_attr( $val ) . '" ';
140
+                }
141
+            }
142
+        }
143
+
144
+        return $output;
145
+    }
146
+
147
+    /**
148
+     * @param $args
149
+     *
150
+     * @return string
151
+     */
152
+    public static function aria_attributes( $args ) {
153
+        $output = '';
154
+
155
+        if ( ! empty( $args ) ) {
156
+
157
+            foreach ( $args as $key => $val ) {
158
+                if ( substr( $key, 0, 5 ) === "aria-" ) {
159
+                    $output .= ' ' . sanitize_html_class( $key ) . '="' . esc_attr( $val ) . '" ';
160
+                }
161
+            }
162
+        }
163
+
164
+        return $output;
165
+    }
166
+
167
+    /**
168
+     * Build a font awesome icon from a class.
169
+     *
170
+     * @param $class
171
+     * @param bool $space_after
172
+     * @param array $extra_attributes An array of extra attributes.
173
+     *
174
+     * @return string
175
+     */
176
+    public static function icon( $class, $space_after = false, $extra_attributes = array() ) {
177
+        $output = '';
178
+
179
+        if ( $class ) {
180
+            $classes = self::esc_classes( $class );
181
+            if ( ! empty( $classes ) ) {
182
+                $output = '<i class="' . $classes . '" ';
183
+                // extra attributes
184
+                if ( ! empty( $extra_attributes ) ) {
185
+                    $output .= AUI_Component_Helper::extra_attributes( $extra_attributes );
186
+                }
187
+                $output .= '></i>';
188
+                if ( $space_after ) {
189
+                    $output .= " ";
190
+                }
191
+            }
192
+        }
193
+
194
+        return $output;
195
+    }
196
+
197
+    /**
198
+     * @param $args
199
+     *
200
+     * @return string
201
+     */
202
+    public static function extra_attributes( $args ) {
203
+        $output = '';
204
+
205
+        if ( ! empty( $args ) ) {
206
+
207
+            if ( is_array( $args ) ) {
208
+                foreach ( $args as $key => $val ) {
209
+                    $output .= ' ' . sanitize_html_class( $key ) . '="' . esc_attr( $val ) . '" ';
210
+                }
211
+            } else {
212
+                $output .= ' ' . $args . ' ';
213
+            }
214
+
215
+        }
216
+
217
+        return $output;
218
+    }
219
+
220
+    /**
221
+     * @param $args
222
+     *
223
+     * @return string
224
+     */
225
+    public static function help_text( $text ) {
226
+        $output = '';
227
+
228
+        if ( $text ) {
229
+            $output .= '<small class="form-text text-muted">' . wp_kses_post( $text ) . '</small>';
230
+        }
231
+
232
+
233
+        return $output;
234
+    }
235
+
236
+    /**
237
+     * Replace element require context with JS.
238
+     *
239
+     * @param $input
240
+     *
241
+     * @return string|void
242
+     */
243
+    public static function element_require( $input ) {
244
+
245
+        $input = str_replace( "'", '"', $input );// we only want double quotes
246
+
247
+        $output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
248
+            "jQuery(form).find('[data-argument=\"",
249
+            "\"]').find('input,select,textarea').val()",
250
+            "\"]').find('input:checked').val()",
251
+        ), $input ) );
252
+
253
+        if ( $output ) {
254
+            $output = ' data-element-require="' . $output . '" ';
255
+        }
256
+
257
+        return $output;
258
+    }
259
+
260
+    /**
261
+     * Navigates through an array, object, or scalar, and removes slashes from the values.
262
+     *
263
+     * @since 0.1.41
264
+     *
265
+     * @param mixed $value The value to be stripped.
266
+     * @param array $input Input Field.
267
+     *
268
+     * @return mixed Stripped value.
269
+     */
270
+    public static function sanitize_html_field( $value, $input = array() ) {
271
+        $original = $value;
272
+
273
+        if ( is_array( $value ) ) {
274
+            foreach ( $value as $index => $item ) {
275
+                $value[ $index ] = self::_sanitize_html_field( $value, $input );
276
+            }
277
+        } elseif ( is_object( $value ) ) {
278
+            $object_vars = get_object_vars( $value );
279
+
280
+            foreach ( $object_vars as $property_name => $property_value ) {
281
+                $value->$property_name = self::_sanitize_html_field( $property_value, $input );
282
+            }
283
+        } else {
284
+            $value = self::_sanitize_html_field( $value, $input );
285
+        }
286
+
287
+        /**
288
+         * Filters content and keeps only allowable HTML elements.
289
+         *
290
+         * @since 0.1.41
291
+         *
292
+         * @param string|array $value Content to filter through kses.
293
+         * @param string|array $value Original content without filter.
294
+         * @param array $input Input Field.
295
+         */
296
+        return apply_filters( 'ayecode_ui_sanitize_html_field', $value, $original, $input );
297
+    }
298
+
299
+    /**
300
+     * Filters content and keeps only allowable HTML elements.
301
+     *
302
+     * This function makes sure that only the allowed HTML element names, attribute
303
+     * names and attribute values plus only sane HTML entities will occur in
304
+     * $string. You have to remove any slashes from PHP's magic quotes before you
305
+     * call this function.
306
+     *
307
+     * The default allowed protocols are 'http', 'https', 'ftp', 'mailto', 'news',
308
+     * 'irc', 'gopher', 'nntp', 'feed', 'telnet, 'mms', 'rtsp' and 'svn'. This
309
+     * covers all common link protocols, except for 'javascript' which should not
310
+     * be allowed for untrusted users.
311
+     *
312
+     * @since 0.1.41
313
+     *
314
+     * @param string|array $value Content to filter through kses.
315
+     * @param array $input Input Field.
316
+     *
317
+     * @return string Filtered content with only allowed HTML elements.
318
+     */
319
+    public static function _sanitize_html_field( $value, $input = array() ) {
320
+        if ( $value === '' ) {
321
+            return $value;
322
+        }
323
+
324
+        $allowed_html = self::kses_allowed_html( 'post', $input );
325
+
326
+        if ( ! is_array( $allowed_html ) ) {
327
+            $allowed_html = wp_kses_allowed_html( 'post' );
328
+        }
329
+
330
+        $filtered = trim( wp_unslash( $value ) );
331
+        $filtered = wp_kses( $filtered, $allowed_html );
332
+        $filtered = balanceTags( $filtered ); // Balances tags
333
+
334
+        return $filtered;
335
+    }
336
+
337
+    /**
338
+     * Returns an array of allowed HTML tags and attributes for a given context.
339
+     *
340
+     * @since 0.1.41
341
+     *
342
+     * @param string|array $context The context for which to retrieve tags. Allowed values are 'post',
343
+     *                              'strip', 'data', 'entities', or the name of a field filter such as
344
+     *                              'pre_user_description'.
345
+     * @param array $input Input.
346
+     *
347
+     * @return array Array of allowed HTML tags and their allowed attributes.
348
+     */
349
+    public static function kses_allowed_html( $context = 'post', $input = array() ) {
350
+        $allowed_html = wp_kses_allowed_html( $context );
351
+
352
+        if ( is_array( $allowed_html ) ) {
353
+            // <iframe>
354
+            if ( ! isset( $allowed_html['iframe'] ) && $context == 'post' ) {
355
+                $allowed_html['iframe'] = array(
356
+                    'class'           => true,
357
+                    'id'              => true,
358
+                    'src'             => true,
359
+                    'width'           => true,
360
+                    'height'          => true,
361
+                    'frameborder'     => true,
362
+                    'marginwidth'     => true,
363
+                    'marginheight'    => true,
364
+                    'scrolling'       => true,
365
+                    'style'           => true,
366
+                    'title'           => true,
367
+                    'allow'           => true,
368
+                    'allowfullscreen' => true,
369
+                    'data-*'          => true,
370
+                );
371
+            }
372
+        }
373
+
374
+        /**
375
+         * Filters the allowed html tags.
376
+         *
377
+         * @since 0.1.41
378
+         *
379
+         * @param array[]|string $allowed_html Allowed html tags.
380
+         * @param @param string|array $context The context for which to retrieve tags.
381
+         * @param array $input Input field.
382
+         */
383
+        return apply_filters( 'ayecode_ui_kses_allowed_html', $allowed_html, $context, $input );
384
+    }
385
+
386
+    public static function get_column_class( $label_number = 2, $type = 'label' ) {
387
+
388
+        $class = '';
389
+
390
+        // set default if empty
391
+        if( $label_number === '' ){
392
+            $label_number = 2;
393
+        }
394
+
395
+        if ( $label_number && $label_number < 12 && $label_number > 0 ) {
396
+            if ( $type == 'label' ) {
397
+                $class = 'col-sm-' . absint( $label_number );
398
+            } elseif ( $type == 'input' ) {
399
+                $class = 'col-sm-' . ( 12 - absint( $label_number ) );
400
+            }
401
+        }
402
+
403
+        return $class;
404
+    }
405
+
406
+    /**
407
+     * Sanitizes a multiline string from user input or from the database.
408
+     *
409
+     * Emulate the WP native sanitize_textarea_field function in a %%variable%% safe way.
410
+     *
411
+     * @see   https://core.trac.wordpress.org/browser/trunk/src/wp-includes/formatting.php for the original
412
+     *
413
+     * @since 0.1.66
414
+     *
415
+     * @param string $str String to sanitize.
416
+     * @return string Sanitized string.
417
+     */
418
+    public static function sanitize_textarea_field( $str ) {
419
+        $filtered = self::_sanitize_text_fields( $str, true );
420
+
421
+        /**
422
+         * Filters a sanitized textarea field string.
423
+         *
424
+         * @see https://core.trac.wordpress.org/browser/trunk/src/wp-includes/formatting.php
425
+         *
426
+         * @param string $filtered The sanitized string.
427
+         * @param string $str      The string prior to being sanitized.
428
+         */
429
+        return apply_filters( 'sanitize_textarea_field', $filtered, $str );
430
+    }
431
+
432
+    /**
433
+     * Internal helper function to sanitize a string from user input or from the db.
434
+     *
435
+     * @since 0.1.66
436
+     * @access private
437
+     *
438
+     * @param string $str           String to sanitize.
439
+     * @param bool   $keep_newlines Optional. Whether to keep newlines. Default: false.
440
+     * @return string Sanitized string.
441
+     */
442
+    public static function _sanitize_text_fields( $str, $keep_newlines = false ) {
443
+        if ( is_object( $str ) || is_array( $str ) ) {
444
+            return '';
445
+        }
446
+
447
+        $str = (string) $str;
448
+
449
+        $filtered = wp_check_invalid_utf8( $str );
450
+
451
+        if ( strpos( $filtered, '<' ) !== false ) {
452
+            $filtered = wp_pre_kses_less_than( $filtered );
453
+            // This will strip extra whitespace for us.
454
+            $filtered = wp_strip_all_tags( $filtered, false );
455
+
456
+            // Use HTML entities in a special case to make sure no later
457
+            // newline stripping stage could lead to a functional tag.
458
+            $filtered = str_replace( "<\n", "&lt;\n", $filtered );
459
+        }
460
+
461
+        if ( ! $keep_newlines ) {
462
+            $filtered = preg_replace( '/[\r\n\t ]+/', ' ', $filtered );
463
+        }
464
+        $filtered = trim( $filtered );
465
+
466
+        $found = false;
467
+        while ( preg_match( '`[^%](%[a-f0-9]{2})`i', $filtered, $match ) ) {
468
+            $filtered = str_replace( $match[1], '', $filtered );
469
+            $found = true;
470
+        }
471
+        unset( $match );
472
+
473
+        if ( $found ) {
474
+            // Strip out the whitespace that may now exist after removing the octets.
475
+            $filtered = trim( preg_replace( '` +`', ' ', $filtered ) );
476
+        }
477
+
478
+        return $filtered;
479
+    }
480 480
 }
481 481
\ No newline at end of file
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-input.php 1 patch
Indentation   +1186 added lines, -1186 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,1210 +11,1210 @@  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_col'                => '2',
36
-			'label_type'               => '',
37
-			'label_force_left'         => false, // used to force checkbox label left when using horizontal
38
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
39
-			'help_text'                => '',
40
-			'validation_text'          => '',
41
-			'validation_pattern'       => '',
42
-			'no_wrap'                  => false,
43
-			'input_group_right'        => '',
44
-			'input_group_left'         => '',
45
-			'input_group_right_inside' => false,
46
-			// forces the input group inside the input
47
-			'input_group_left_inside'  => false,
48
-			// forces the input group inside the input
49
-			'step'                     => '',
50
-			'switch'                   => false,
51
-			// to show checkbox as a switch
52
-			'checked'                  => false,
53
-			// set a checkbox or radio as selected
54
-			'password_toggle'          => true,
55
-			// toggle view/hide password
56
-			'element_require'          => '',
57
-			// [%element_id%] == "1"
58
-			'extra_attributes'         => array(),
59
-			// an array of extra attributes
60
-			'wrap_attributes'          => array()
61
-		);
62
-
63
-		/**
64
-		 * Parse incoming $args into an array and merge it with $defaults
65
-		 */
66
-		$args   = wp_parse_args( $args, $defaults );
67
-		$output = '';
68
-		if ( ! empty( $args['type'] ) ) {
69
-			// hidden label option needs to be empty
70
-			$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
71
-
72
-			$type = sanitize_html_class( $args['type'] );
73
-
74
-			$help_text   = '';
75
-			$label       = '';
76
-			$label_after = $args['label_after'];
77
-			$label_args  = array(
78
-				'title'      => $args['label'],
79
-				'for'        => $args['id'],
80
-				'class'      => $args['label_class'] . " ",
81
-				'label_type' => $args['label_type'],
82
-				'label_col'  => $args['label_col']
83
-			);
84
-
85
-			// floating labels need label after
86
-			if ( $args['label_type'] == 'floating' && $type != 'checkbox' ) {
87
-				$label_after         = true;
88
-				$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
89
-			}
90
-
91
-			// Some special sauce for files
92
-			if ( $type == 'file' ) {
93
-				$label_after = true; // if type file we need the label after
94
-				$args['class'] .= ' custom-file-input ';
95
-			} elseif ( $type == 'checkbox' ) {
96
-				$label_after = true; // if type file we need the label after
97
-				$args['class'] .= ' custom-control-input ';
98
-			} elseif ( $type == 'datepicker' || $type == 'timepicker' ) {
99
-				$type = 'text';
100
-				//$args['class'] .= ' aui-flatpickr bg-initial ';
101
-				$args['class'] .= ' bg-initial ';
102
-
103
-				$args['extra_attributes']['data-aui-init'] = 'flatpickr';
104
-				// enqueue the script
105
-				$aui_settings = AyeCode_UI_Settings::instance();
106
-				$aui_settings->enqueue_flatpickr();
107
-			} elseif ( $type == 'iconpicker' ) {
108
-				$type = 'text';
109
-				//$args['class'] .= ' aui-flatpickr bg-initial ';
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_col'                => '2',
36
+            'label_type'               => '',
37
+            'label_force_left'         => false, // used to force checkbox label left when using horizontal
38
+            // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
39
+            'help_text'                => '',
40
+            'validation_text'          => '',
41
+            'validation_pattern'       => '',
42
+            'no_wrap'                  => false,
43
+            'input_group_right'        => '',
44
+            'input_group_left'         => '',
45
+            'input_group_right_inside' => false,
46
+            // forces the input group inside the input
47
+            'input_group_left_inside'  => false,
48
+            // forces the input group inside the input
49
+            'step'                     => '',
50
+            'switch'                   => false,
51
+            // to show checkbox as a switch
52
+            'checked'                  => false,
53
+            // set a checkbox or radio as selected
54
+            'password_toggle'          => true,
55
+            // toggle view/hide password
56
+            'element_require'          => '',
57
+            // [%element_id%] == "1"
58
+            'extra_attributes'         => array(),
59
+            // an array of extra attributes
60
+            'wrap_attributes'          => array()
61
+        );
62
+
63
+        /**
64
+         * Parse incoming $args into an array and merge it with $defaults
65
+         */
66
+        $args   = wp_parse_args( $args, $defaults );
67
+        $output = '';
68
+        if ( ! empty( $args['type'] ) ) {
69
+            // hidden label option needs to be empty
70
+            $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
71
+
72
+            $type = sanitize_html_class( $args['type'] );
73
+
74
+            $help_text   = '';
75
+            $label       = '';
76
+            $label_after = $args['label_after'];
77
+            $label_args  = array(
78
+                'title'      => $args['label'],
79
+                'for'        => $args['id'],
80
+                'class'      => $args['label_class'] . " ",
81
+                'label_type' => $args['label_type'],
82
+                'label_col'  => $args['label_col']
83
+            );
84
+
85
+            // floating labels need label after
86
+            if ( $args['label_type'] == 'floating' && $type != 'checkbox' ) {
87
+                $label_after         = true;
88
+                $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
89
+            }
90
+
91
+            // Some special sauce for files
92
+            if ( $type == 'file' ) {
93
+                $label_after = true; // if type file we need the label after
94
+                $args['class'] .= ' custom-file-input ';
95
+            } elseif ( $type == 'checkbox' ) {
96
+                $label_after = true; // if type file we need the label after
97
+                $args['class'] .= ' custom-control-input ';
98
+            } elseif ( $type == 'datepicker' || $type == 'timepicker' ) {
99
+                $type = 'text';
100
+                //$args['class'] .= ' aui-flatpickr bg-initial ';
101
+                $args['class'] .= ' bg-initial ';
102
+
103
+                $args['extra_attributes']['data-aui-init'] = 'flatpickr';
104
+                // enqueue the script
105
+                $aui_settings = AyeCode_UI_Settings::instance();
106
+                $aui_settings->enqueue_flatpickr();
107
+            } elseif ( $type == 'iconpicker' ) {
108
+                $type = 'text';
109
+                //$args['class'] .= ' aui-flatpickr bg-initial ';
110 110
 //				$args['class'] .= ' bg-initial ';
111 111
 
112
-				$args['extra_attributes']['data-aui-init'] = 'iconpicker';
113
-				$args['extra_attributes']['data-placement'] = 'bottomRight';
112
+                $args['extra_attributes']['data-aui-init'] = 'iconpicker';
113
+                $args['extra_attributes']['data-placement'] = 'bottomRight';
114 114
 
115
-				$args['input_group_right'] = '<span class="input-group-addon input-group-text c-pointer"></span>';
115
+                $args['input_group_right'] = '<span class="input-group-addon input-group-text c-pointer"></span>';
116 116
 //				$args['input_group_right_inside'] = true;
117
-				// enqueue the script
118
-				$aui_settings = AyeCode_UI_Settings::instance();
119
-				$aui_settings->enqueue_iconpicker();
120
-			}
121
-
122
-			if ( $type == 'checkbox' && !empty($args['name'] ) && strpos($args['name'], '[') === false ) {
123
-				$output .= '<input type="hidden" name="' . esc_attr( $args['name'] ) . '" value="0" />';
124
-			}
125
-
126
-
127
-			// open/type
128
-			$output .= '<input type="' . $type . '" ';
129
-
130
-			// name
131
-			if ( ! empty( $args['name'] ) ) {
132
-				$output .= ' name="' . esc_attr( $args['name'] ) . '" ';
133
-			}
134
-
135
-			// id
136
-			if ( ! empty( $args['id'] ) ) {
137
-				$output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
138
-			}
139
-
140
-			// placeholder
141
-			if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
142
-				$output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
143
-			}
144
-
145
-			// title
146
-			if ( ! empty( $args['title'] ) ) {
147
-				$output .= ' title="' . esc_attr( $args['title'] ) . '" ';
148
-			}
149
-
150
-			// value
151
-			if ( ! empty( $args['value'] ) ) {
152
-				$output .= AUI_Component_Helper::value( $args['value'] );
153
-			}
154
-
155
-			// checked, for radio and checkboxes
156
-			if ( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ) {
157
-				$output .= ' checked ';
158
-			}
159
-
160
-			// validation text
161
-			if ( ! empty( $args['validation_text'] ) ) {
162
-				$output .= ' oninvalid="setCustomValidity(\'' . esc_attr( $args['validation_text'] ) . '\')" ';
163
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
164
-			}
165
-
166
-			// validation_pattern
167
-			if ( ! empty( $args['validation_pattern'] ) ) {
168
-				$output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
169
-			}
170
-
171
-			// step (for numbers)
172
-			if ( ! empty( $args['step'] ) ) {
173
-				$output .= ' step="' . $args['step'] . '" ';
174
-			}
175
-
176
-			// required
177
-			if ( ! empty( $args['required'] ) ) {
178
-				$output .= ' required ';
179
-			}
180
-
181
-			// class
182
-			$class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
183
-			$output .= ' class="form-control ' . $class . '" ';
184
-
185
-			// data-attributes
186
-			$output .= AUI_Component_Helper::data_attributes( $args );
187
-
188
-			// extra attributes
189
-			if ( ! empty( $args['extra_attributes'] ) ) {
190
-				$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
191
-			}
192
-
193
-			// close
194
-			$output .= ' >';
195
-
196
-			// help text
197
-			if ( ! empty( $args['help_text'] ) ) {
198
-				$help_text = AUI_Component_Helper::help_text( $args['help_text'] );
199
-			}
200
-
201
-			// label
202
-			if ( ! empty( $args['label'] ) ) {
203
-				$label_base_class = '';
204
-				if ( $type == 'file' ) {
205
-					$label_base_class = ' custom-file-label';
206
-				} elseif ( $type == 'checkbox' ) {
207
-					if ( ! empty( $args['label_force_left'] ) ) {
208
-						$label_args['title'] = wp_kses_post( $args['help_text'] );
209
-						$help_text = '';
210
-						//$label_args['class'] .= ' d-inline ';
211
-						$args['wrap_class'] .= ' align-items-center ';
212
-					}else{
213
-
214
-					}
215
-
216
-					$label_base_class = ' custom-control-label';
217
-				}
218
-				$label_args['class'] .= $label_base_class;
219
-				$temp_label_args = $label_args;
220
-				if(! empty( $args['label_force_left'] )){$temp_label_args['class'] = $label_base_class." text-muted";}
221
-				$label = self::label( $temp_label_args, $type );
222
-			}
223
-
224
-
225
-
226
-
227
-			// set help text in the correct position
228
-			if ( $label_after ) {
229
-				$output .= $label . $help_text;
230
-			}
231
-
232
-			// some input types need a separate wrap
233
-			if ( $type == 'file' ) {
234
-				$output = self::wrap( array(
235
-					'content' => $output,
236
-					'class'   => 'form-group custom-file'
237
-				) );
238
-			} elseif ( $type == 'checkbox' ) {
239
-
240
-				$label_args['title'] = $args['label'];
241
-				$label_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'label' );
242
-				$label = !empty( $args['label_force_left'] ) ? self::label( $label_args, 'cb' ) : '<div class="' . $label_col . ' col-form-label"></div>';
243
-				$switch_size_class = $args['switch'] && !is_bool( $args['switch'] ) ? ' custom-switch-'.esc_attr( $args['switch'] ) : '';
244
-				$wrap_class = $args['switch'] ? 'custom-switch'.$switch_size_class : 'custom-checkbox';
245
-				if ( ! empty( $args['label_force_left'] ) ) {
246
-					$wrap_class .= ' d-flex align-content-center';
247
-					$label = str_replace("custom-control-label","", self::label( $label_args, 'cb' ) );
248
-				}
249
-				$output     = self::wrap( array(
250
-					'content' => $output,
251
-					'class'   => 'custom-control ' . $wrap_class
252
-				) );
253
-
254
-				if ( $args['label_type'] == 'horizontal' ) {
255
-					$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
256
-					$output    = $label . '<div class="' . $input_col . '">' . $output . '</div>';
257
-				}
258
-			} elseif ( $type == 'password' && $args['password_toggle'] && ! $args['input_group_right'] ) {
259
-
260
-
261
-				// allow password field to toggle view
262
-				$args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
117
+                // enqueue the script
118
+                $aui_settings = AyeCode_UI_Settings::instance();
119
+                $aui_settings->enqueue_iconpicker();
120
+            }
121
+
122
+            if ( $type == 'checkbox' && !empty($args['name'] ) && strpos($args['name'], '[') === false ) {
123
+                $output .= '<input type="hidden" name="' . esc_attr( $args['name'] ) . '" value="0" />';
124
+            }
125
+
126
+
127
+            // open/type
128
+            $output .= '<input type="' . $type . '" ';
129
+
130
+            // name
131
+            if ( ! empty( $args['name'] ) ) {
132
+                $output .= ' name="' . esc_attr( $args['name'] ) . '" ';
133
+            }
134
+
135
+            // id
136
+            if ( ! empty( $args['id'] ) ) {
137
+                $output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
138
+            }
139
+
140
+            // placeholder
141
+            if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
142
+                $output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
143
+            }
144
+
145
+            // title
146
+            if ( ! empty( $args['title'] ) ) {
147
+                $output .= ' title="' . esc_attr( $args['title'] ) . '" ';
148
+            }
149
+
150
+            // value
151
+            if ( ! empty( $args['value'] ) ) {
152
+                $output .= AUI_Component_Helper::value( $args['value'] );
153
+            }
154
+
155
+            // checked, for radio and checkboxes
156
+            if ( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ) {
157
+                $output .= ' checked ';
158
+            }
159
+
160
+            // validation text
161
+            if ( ! empty( $args['validation_text'] ) ) {
162
+                $output .= ' oninvalid="setCustomValidity(\'' . esc_attr( $args['validation_text'] ) . '\')" ';
163
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
164
+            }
165
+
166
+            // validation_pattern
167
+            if ( ! empty( $args['validation_pattern'] ) ) {
168
+                $output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
169
+            }
170
+
171
+            // step (for numbers)
172
+            if ( ! empty( $args['step'] ) ) {
173
+                $output .= ' step="' . $args['step'] . '" ';
174
+            }
175
+
176
+            // required
177
+            if ( ! empty( $args['required'] ) ) {
178
+                $output .= ' required ';
179
+            }
180
+
181
+            // class
182
+            $class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
183
+            $output .= ' class="form-control ' . $class . '" ';
184
+
185
+            // data-attributes
186
+            $output .= AUI_Component_Helper::data_attributes( $args );
187
+
188
+            // extra attributes
189
+            if ( ! empty( $args['extra_attributes'] ) ) {
190
+                $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
191
+            }
192
+
193
+            // close
194
+            $output .= ' >';
195
+
196
+            // help text
197
+            if ( ! empty( $args['help_text'] ) ) {
198
+                $help_text = AUI_Component_Helper::help_text( $args['help_text'] );
199
+            }
200
+
201
+            // label
202
+            if ( ! empty( $args['label'] ) ) {
203
+                $label_base_class = '';
204
+                if ( $type == 'file' ) {
205
+                    $label_base_class = ' custom-file-label';
206
+                } elseif ( $type == 'checkbox' ) {
207
+                    if ( ! empty( $args['label_force_left'] ) ) {
208
+                        $label_args['title'] = wp_kses_post( $args['help_text'] );
209
+                        $help_text = '';
210
+                        //$label_args['class'] .= ' d-inline ';
211
+                        $args['wrap_class'] .= ' align-items-center ';
212
+                    }else{
213
+
214
+                    }
215
+
216
+                    $label_base_class = ' custom-control-label';
217
+                }
218
+                $label_args['class'] .= $label_base_class;
219
+                $temp_label_args = $label_args;
220
+                if(! empty( $args['label_force_left'] )){$temp_label_args['class'] = $label_base_class." text-muted";}
221
+                $label = self::label( $temp_label_args, $type );
222
+            }
223
+
224
+
225
+
226
+
227
+            // set help text in the correct position
228
+            if ( $label_after ) {
229
+                $output .= $label . $help_text;
230
+            }
231
+
232
+            // some input types need a separate wrap
233
+            if ( $type == 'file' ) {
234
+                $output = self::wrap( array(
235
+                    'content' => $output,
236
+                    'class'   => 'form-group custom-file'
237
+                ) );
238
+            } elseif ( $type == 'checkbox' ) {
239
+
240
+                $label_args['title'] = $args['label'];
241
+                $label_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'label' );
242
+                $label = !empty( $args['label_force_left'] ) ? self::label( $label_args, 'cb' ) : '<div class="' . $label_col . ' col-form-label"></div>';
243
+                $switch_size_class = $args['switch'] && !is_bool( $args['switch'] ) ? ' custom-switch-'.esc_attr( $args['switch'] ) : '';
244
+                $wrap_class = $args['switch'] ? 'custom-switch'.$switch_size_class : 'custom-checkbox';
245
+                if ( ! empty( $args['label_force_left'] ) ) {
246
+                    $wrap_class .= ' d-flex align-content-center';
247
+                    $label = str_replace("custom-control-label","", self::label( $label_args, 'cb' ) );
248
+                }
249
+                $output     = self::wrap( array(
250
+                    'content' => $output,
251
+                    'class'   => 'custom-control ' . $wrap_class
252
+                ) );
253
+
254
+                if ( $args['label_type'] == 'horizontal' ) {
255
+                    $input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
256
+                    $output    = $label . '<div class="' . $input_col . '">' . $output . '</div>';
257
+                }
258
+            } elseif ( $type == 'password' && $args['password_toggle'] && ! $args['input_group_right'] ) {
259
+
260
+
261
+                // allow password field to toggle view
262
+                $args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
263 263
 onclick="var $el = jQuery(this).find(\'i\');$el.toggleClass(\'fa-eye fa-eye-slash\');
264 264
 var $eli = jQuery(this).parent().parent().find(\'input\');
265 265
 if($el.hasClass(\'fa-eye\'))
266 266
 {$eli.attr(\'type\',\'text\');}
267 267
 else{$eli.attr(\'type\',\'password\');}"
268 268
 ><i class="far fa-fw fa-eye-slash"></i></span>';
269
-			}
270
-
271
-			// input group wraps
272
-			if ( $args['input_group_left'] || $args['input_group_right'] ) {
273
-				$w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
274
-				if ( $args['input_group_left'] ) {
275
-					$output = self::wrap( array(
276
-						'content'                 => $output,
277
-						'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
278
-						'input_group_left'        => $args['input_group_left'],
279
-						'input_group_left_inside' => $args['input_group_left_inside']
280
-					) );
281
-				}
282
-				if ( $args['input_group_right'] ) {
283
-					$output = self::wrap( array(
284
-						'content'                  => $output,
285
-						'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
286
-						'input_group_right'        => $args['input_group_right'],
287
-						'input_group_right_inside' => $args['input_group_right_inside']
288
-					) );
289
-				}
290
-
291
-			}
292
-
293
-			if ( ! $label_after ) {
294
-				$output .= $help_text;
295
-			}
296
-
297
-
298
-			if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
299
-				$output = self::wrap( array(
300
-					'content' => $output,
301
-					'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
302
-				) );
303
-			}
304
-
305
-			if ( ! $label_after ) {
306
-				$output = $label . $output;
307
-			}
308
-
309
-			// wrap
310
-			if ( ! $args['no_wrap'] ) {
311
-				$form_group_class = $args['label_type'] == 'floating' && $type != 'checkbox' ? 'form-label-group' : 'form-group';
312
-				$wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
313
-				$wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
314
-				$output           = self::wrap( array(
315
-					'content'         => $output,
316
-					'class'           => $wrap_class,
317
-					'element_require' => $args['element_require'],
318
-					'argument_id'     => $args['id'],
319
-					'wrap_attributes' => $args['wrap_attributes'],
320
-				) );
321
-			}
322
-		}
323
-
324
-		return $output;
325
-	}
326
-
327
-	public static function label( $args = array(), $type = '' ) {
328
-		//<label for="exampleInputEmail1">Email address</label>
329
-		$defaults = array(
330
-			'title'      => 'div',
331
-			'for'        => '',
332
-			'class'      => '',
333
-			'label_type' => '', // empty = hidden, top, horizontal
334
-			'label_col'  => '',
335
-		);
336
-
337
-		/**
338
-		 * Parse incoming $args into an array and merge it with $defaults
339
-		 */
340
-		$args   = wp_parse_args( $args, $defaults );
341
-		$output = '';
342
-
343
-		if ( $args['title'] ) {
344
-
345
-			// maybe hide labels //@todo set a global option for visibility class
346
-			if ( $type == 'file' || $type == 'checkbox' || $type == 'radio' || ! empty( $args['label_type'] ) ) {
347
-				$class = $args['class'];
348
-			} else {
349
-				$class = 'sr-only ' . $args['class'];
350
-			}
351
-
352
-			// maybe horizontal
353
-			if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
354
-				$class .= ' ' . AUI_Component_Helper::get_column_class( $args['label_col'], 'label' ) . ' col-form-label';
355
-			}
356
-
357
-			// open
358
-			$output .= '<label ';
359
-
360
-			// for
361
-			if ( ! empty( $args['for'] ) ) {
362
-				$output .= ' for="' . esc_attr( $args['for'] ) . '" ';
363
-			}
364
-
365
-			// class
366
-			$class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
367
-			$output .= ' class="' . $class . '" ';
368
-
369
-			// close
370
-			$output .= '>';
371
-
372
-
373
-			// title, don't escape fully as can contain html
374
-			if ( ! empty( $args['title'] ) ) {
375
-				$output .= wp_kses_post( $args['title'] );
376
-			}
377
-
378
-			// close wrap
379
-			$output .= '</label>';
380
-
381
-
382
-		}
383
-
384
-
385
-		return $output;
386
-	}
387
-
388
-	/**
389
-	 * Wrap some content in a HTML wrapper.
390
-	 *
391
-	 * @param array $args
392
-	 *
393
-	 * @return string
394
-	 */
395
-	public static function wrap( $args = array() ) {
396
-		$defaults = array(
397
-			'type'                     => 'div',
398
-			'class'                    => 'form-group',
399
-			'content'                  => '',
400
-			'input_group_left'         => '',
401
-			'input_group_right'        => '',
402
-			'input_group_left_inside'  => false,
403
-			'input_group_right_inside' => false,
404
-			'element_require'          => '',
405
-			'argument_id'              => '',
406
-			'wrap_attributes'          => array()
407
-		);
408
-
409
-		/**
410
-		 * Parse incoming $args into an array and merge it with $defaults
411
-		 */
412
-		$args   = wp_parse_args( $args, $defaults );
413
-		$output = '';
414
-		if ( $args['type'] ) {
415
-
416
-			// open
417
-			$output .= '<' . sanitize_html_class( $args['type'] );
418
-
419
-			// element require
420
-			if ( ! empty( $args['element_require'] ) ) {
421
-				$output .= AUI_Component_Helper::element_require( $args['element_require'] );
422
-				$args['class'] .= " aui-conditional-field";
423
-			}
424
-
425
-			// argument_id
426
-			if ( ! empty( $args['argument_id'] ) ) {
427
-				$output .= ' data-argument="' . esc_attr( $args['argument_id'] ) . '"';
428
-			}
429
-
430
-			// class
431
-			$class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
432
-			$output .= ' class="' . $class . '" ';
433
-
434
-			// Attributes
435
-			if ( ! empty( $args['wrap_attributes'] ) ) {
436
-				$output .= AUI_Component_Helper::extra_attributes( $args['wrap_attributes'] );
437
-			}
438
-
439
-			// close wrap
440
-			$output .= ' >';
441
-
442
-
443
-			// Input group left
444
-			if ( ! empty( $args['input_group_left'] ) ) {
445
-				$position_class   = ! empty( $args['input_group_left_inside'] ) ? 'position-absolute h-100' : '';
446
-				$input_group_left = strpos( $args['input_group_left'], '<' ) !== false ? $args['input_group_left'] : '<span class="input-group-text">' . $args['input_group_left'] . '</span>';
447
-				$output .= '<div class="input-group-prepend ' . $position_class . '">' . $input_group_left . '</div>';
448
-			}
449
-
450
-			// content
451
-			$output .= $args['content'];
452
-
453
-			// Input group right
454
-			if ( ! empty( $args['input_group_right'] ) ) {
455
-				$position_class    = ! empty( $args['input_group_left_inside'] ) ? 'position-absolute h-100' : '';
456
-				$input_group_right = strpos( $args['input_group_right'], '<' ) !== false ? $args['input_group_right'] : '<span class="input-group-text">' . $args['input_group_right'] . '</span>';
457
-				$output .= '<div class="input-group-append ' . $position_class . '">' . $input_group_right . '</div>';
458
-			}
459
-
460
-
461
-			// close wrap
462
-			$output .= '</' . sanitize_html_class( $args['type'] ) . '>';
463
-
464
-
465
-		} else {
466
-			$output = $args['content'];
467
-		}
468
-
469
-		return $output;
470
-	}
471
-
472
-	/**
473
-	 * Build the component.
474
-	 *
475
-	 * @param array $args
476
-	 *
477
-	 * @return string The rendered component.
478
-	 */
479
-	public static function textarea( $args = array() ) {
480
-		$defaults = array(
481
-			'name'               => '',
482
-			'class'              => '',
483
-			'wrap_class'         => '',
484
-			'id'                 => '',
485
-			'placeholder'        => '',
486
-			'title'              => '',
487
-			'value'              => '',
488
-			'required'           => false,
489
-			'label'              => '',
490
-			'label_after'        => false,
491
-			'label_class'        => '',
492
-			'label_type'         => '',
493
-			'label_col'          => '',
494
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
495
-			'input_group_right'        => '',
496
-			'input_group_left'         => '',
497
-			'input_group_right_inside' => false,
498
-			'help_text'          => '',
499
-			'validation_text'    => '',
500
-			'validation_pattern' => '',
501
-			'no_wrap'            => false,
502
-			'rows'               => '',
503
-			'wysiwyg'            => false,
504
-			'allow_tags'         => false,
505
-			// Allow HTML tags
506
-			'element_require'    => '',
507
-			// [%element_id%] == "1"
508
-			'extra_attributes'   => array(),
509
-			// an array of extra attributes
510
-			'wrap_attributes'    => array(),
511
-		);
512
-
513
-		/**
514
-		 * Parse incoming $args into an array and merge it with $defaults
515
-		 */
516
-		$args   = wp_parse_args( $args, $defaults );
517
-		$output = '';
518
-
519
-		// hidden label option needs to be empty
520
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
521
-
522
-		// floating labels don't work with wysiwyg so set it as top
523
-		if ( $args['label_type'] == 'floating' && ! empty( $args['wysiwyg'] ) ) {
524
-			$args['label_type'] = 'top';
525
-		}
526
-
527
-		$label_after = $args['label_after'];
528
-
529
-		// floating labels need label after
530
-		if ( $args['label_type'] == 'floating' && empty( $args['wysiwyg'] ) ) {
531
-			$label_after         = true;
532
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
533
-		}
534
-
535
-		// label
536
-		if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
537
-		} elseif ( ! empty( $args['label'] ) && ! $label_after ) {
538
-			$label_args = array(
539
-				'title'      => $args['label'],
540
-				'for'        => $args['id'],
541
-				'class'      => $args['label_class'] . " ",
542
-				'label_type' => $args['label_type'],
543
-				'label_col'  => $args['label_col']
544
-			);
545
-			$output .= self::label( $label_args );
546
-		}
547
-
548
-		// maybe horizontal label
549
-		if ( $args['label_type'] == 'horizontal' ) {
550
-			$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
551
-			$output .= '<div class="' . $input_col . '">';
552
-		}
553
-
554
-		if ( ! empty( $args['wysiwyg'] ) ) {
555
-			ob_start();
556
-			$content   = $args['value'];
557
-			$editor_id = ! empty( $args['id'] ) ? sanitize_html_class( $args['id'] ) : 'wp_editor';
558
-			$settings  = array(
559
-				'textarea_rows' => ! empty( absint( $args['rows'] ) ) ? absint( $args['rows'] ) : 4,
560
-				'quicktags'     => false,
561
-				'media_buttons' => false,
562
-				'editor_class'  => 'form-control',
563
-				'textarea_name' => ! empty( $args['name'] ) ? sanitize_html_class( $args['name'] ) : sanitize_html_class( $args['id'] ),
564
-				'teeny'         => true,
565
-			);
566
-
567
-			// maybe set settings if array
568
-			if ( is_array( $args['wysiwyg'] ) ) {
569
-				$settings = wp_parse_args( $args['wysiwyg'], $settings );
570
-			}
571
-
572
-			wp_editor( $content, $editor_id, $settings );
573
-			$output .= ob_get_clean();
574
-		} else {
575
-
576
-			// open
577
-			$output .= '<textarea ';
578
-
579
-			// name
580
-			if ( ! empty( $args['name'] ) ) {
581
-				$output .= ' name="' . esc_attr( $args['name'] ) . '" ';
582
-			}
583
-
584
-			// id
585
-			if ( ! empty( $args['id'] ) ) {
586
-				$output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
587
-			}
588
-
589
-			// placeholder
590
-			if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
591
-				$output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
592
-			}
593
-
594
-			// title
595
-			if ( ! empty( $args['title'] ) ) {
596
-				$output .= ' title="' . esc_attr( $args['title'] ) . '" ';
597
-			}
598
-
599
-			// validation text
600
-			if ( ! empty( $args['validation_text'] ) ) {
601
-				$output .= ' oninvalid="setCustomValidity(\'' . esc_attr( $args['validation_text'] ) . '\')" ';
602
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
603
-			}
604
-
605
-			// validation_pattern
606
-			if ( ! empty( $args['validation_pattern'] ) ) {
607
-				$output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
608
-			}
609
-
610
-			// required
611
-			if ( ! empty( $args['required'] ) ) {
612
-				$output .= ' required ';
613
-			}
614
-
615
-			// rows
616
-			if ( ! empty( $args['rows'] ) ) {
617
-				$output .= ' rows="' . absint( $args['rows'] ) . '" ';
618
-			}
619
-
620
-
621
-			// class
622
-			$class = ! empty( $args['class'] ) ? $args['class'] : '';
623
-			$output .= ' class="form-control ' . $class . '" ';
624
-
625
-			// extra attributes
626
-			if ( ! empty( $args['extra_attributes'] ) ) {
627
-				$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
628
-			}
629
-
630
-			// close tag
631
-			$output .= ' >';
632
-
633
-			// value
634
-			if ( ! empty( $args['value'] ) ) {
635
-				if ( ! empty( $args['allow_tags'] ) ) {
636
-					$output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
637
-				} else {
638
-					$output .= AUI_Component_Helper::sanitize_textarea_field( $args['value'] );
639
-				}
640
-			}
641
-
642
-			// closing tag
643
-			$output .= '</textarea>';
644
-
645
-
646
-			// input group wraps
647
-			if ( $args['input_group_left'] || $args['input_group_right'] ) {
648
-				$w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
649
-				if ( $args['input_group_left'] ) {
650
-					$output = self::wrap( array(
651
-						'content'                 => $output,
652
-						'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
653
-						'input_group_left'        => $args['input_group_left'],
654
-						'input_group_left_inside' => $args['input_group_left_inside']
655
-					) );
656
-				}
657
-				if ( $args['input_group_right'] ) {
658
-					$output = self::wrap( array(
659
-						'content'                  => $output,
660
-						'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
661
-						'input_group_right'        => $args['input_group_right'],
662
-						'input_group_right_inside' => $args['input_group_right_inside']
663
-					) );
664
-				}
665
-
666
-			}
667
-
668
-
669
-		}
670
-
671
-		if ( ! empty( $args['label'] ) && $label_after ) {
672
-			$label_args = array(
673
-				'title'      => $args['label'],
674
-				'for'        => $args['id'],
675
-				'class'      => $args['label_class'] . " ",
676
-				'label_type' => $args['label_type'],
677
-				'label_col'  => $args['label_col']
678
-			);
679
-			$output .= self::label( $label_args );
680
-		}
681
-
682
-		// help text
683
-		if ( ! empty( $args['help_text'] ) ) {
684
-			$output .= AUI_Component_Helper::help_text( $args['help_text'] );
685
-		}
686
-
687
-		// maybe horizontal label
688
-		if ( $args['label_type'] == 'horizontal' ) {
689
-			$output .= '</div>';
690
-		}
691
-
692
-
693
-		// wrap
694
-		if ( ! $args['no_wrap'] ) {
695
-			$form_group_class = $args['label_type'] == 'floating' ? 'form-label-group' : 'form-group';
696
-			$wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
697
-			$wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
698
-			$output           = self::wrap( array(
699
-				'content'         => $output,
700
-				'class'           => $wrap_class,
701
-				'element_require' => $args['element_require'],
702
-				'argument_id'     => $args['id'],
703
-				'wrap_attributes' => $args['wrap_attributes'],
704
-			) );
705
-		}
706
-
707
-
708
-		return $output;
709
-	}
710
-
711
-	/**
712
-	 * Build the component.
713
-	 *
714
-	 * @param array $args
715
-	 *
716
-	 * @return string The rendered component.
717
-	 */
718
-	public static function select( $args = array() ) {
719
-		$defaults = array(
720
-			'class'            => '',
721
-			'wrap_class'       => '',
722
-			'id'               => '',
723
-			'title'            => '',
724
-			'value'            => '',
725
-			// can be an array or a string
726
-			'required'         => false,
727
-			'label'            => '',
728
-			'label_after'      => false,
729
-			'label_type'       => '',
730
-			'label_col'        => '',
731
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
732
-			'label_class'      => '',
733
-			'help_text'        => '',
734
-			'placeholder'      => '',
735
-			'options'          => array(),
736
-			// array or string
737
-			'icon'             => '',
738
-			'multiple'         => false,
739
-			'select2'          => false,
740
-			'no_wrap'          => false,
741
-			'input_group_right' => '',
742
-			'input_group_left' => '',
743
-			'input_group_right_inside' => false, // forces the input group inside the input
744
-			'input_group_left_inside' => false, // forces the input group inside the input
745
-			'element_require'  => '',
746
-			// [%element_id%] == "1"
747
-			'extra_attributes' => array(),
748
-			// an array of extra attributes
749
-			'wrap_attributes'  => array(),
750
-		);
751
-
752
-		/**
753
-		 * Parse incoming $args into an array and merge it with $defaults
754
-		 */
755
-		$args   = wp_parse_args( $args, $defaults );
756
-		$output = '';
757
-
758
-		// for now lets hide floating labels
759
-		if ( $args['label_type'] == 'floating' ) {
760
-			$args['label_type'] = 'hidden';
761
-		}
762
-
763
-		// hidden label option needs to be empty
764
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
765
-
766
-
767
-		$label_after = $args['label_after'];
768
-
769
-		// floating labels need label after
770
-		if ( $args['label_type'] == 'floating' ) {
771
-			$label_after         = true;
772
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
773
-		}
774
-
775
-		// Maybe setup select2
776
-		$is_select2 = false;
777
-		if ( ! empty( $args['select2'] ) ) {
778
-			$args['class'] .= ' aui-select2';
779
-			$is_select2 = true;
780
-		} elseif ( strpos( $args['class'], 'aui-select2' ) !== false ) {
781
-			$is_select2 = true;
782
-		}
783
-
784
-		// select2 tags
785
-		if ( ! empty( $args['select2'] ) && $args['select2'] === 'tags' ) { // triple equals needed here for some reason
786
-			$args['data-tags']             = 'true';
787
-			$args['data-token-separators'] = "[',']";
788
-			$args['multiple']              = true;
789
-		}
790
-
791
-		// select2 placeholder
792
-		if ( $is_select2 && isset( $args['placeholder'] ) && '' != $args['placeholder'] && empty( $args['data-placeholder'] ) ) {
793
-			$args['data-placeholder'] = esc_attr( $args['placeholder'] );
794
-			$args['data-allow-clear'] = isset( $args['data-allow-clear'] ) ? (bool) $args['data-allow-clear'] : true;
795
-		}
796
-
797
-
798
-
799
-		// maybe horizontal label
269
+            }
270
+
271
+            // input group wraps
272
+            if ( $args['input_group_left'] || $args['input_group_right'] ) {
273
+                $w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
274
+                if ( $args['input_group_left'] ) {
275
+                    $output = self::wrap( array(
276
+                        'content'                 => $output,
277
+                        'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
278
+                        'input_group_left'        => $args['input_group_left'],
279
+                        'input_group_left_inside' => $args['input_group_left_inside']
280
+                    ) );
281
+                }
282
+                if ( $args['input_group_right'] ) {
283
+                    $output = self::wrap( array(
284
+                        'content'                  => $output,
285
+                        'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
286
+                        'input_group_right'        => $args['input_group_right'],
287
+                        'input_group_right_inside' => $args['input_group_right_inside']
288
+                    ) );
289
+                }
290
+
291
+            }
292
+
293
+            if ( ! $label_after ) {
294
+                $output .= $help_text;
295
+            }
296
+
297
+
298
+            if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
299
+                $output = self::wrap( array(
300
+                    'content' => $output,
301
+                    'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
302
+                ) );
303
+            }
304
+
305
+            if ( ! $label_after ) {
306
+                $output = $label . $output;
307
+            }
308
+
309
+            // wrap
310
+            if ( ! $args['no_wrap'] ) {
311
+                $form_group_class = $args['label_type'] == 'floating' && $type != 'checkbox' ? 'form-label-group' : 'form-group';
312
+                $wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
313
+                $wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
314
+                $output           = self::wrap( array(
315
+                    'content'         => $output,
316
+                    'class'           => $wrap_class,
317
+                    'element_require' => $args['element_require'],
318
+                    'argument_id'     => $args['id'],
319
+                    'wrap_attributes' => $args['wrap_attributes'],
320
+                ) );
321
+            }
322
+        }
323
+
324
+        return $output;
325
+    }
326
+
327
+    public static function label( $args = array(), $type = '' ) {
328
+        //<label for="exampleInputEmail1">Email address</label>
329
+        $defaults = array(
330
+            'title'      => 'div',
331
+            'for'        => '',
332
+            'class'      => '',
333
+            'label_type' => '', // empty = hidden, top, horizontal
334
+            'label_col'  => '',
335
+        );
336
+
337
+        /**
338
+         * Parse incoming $args into an array and merge it with $defaults
339
+         */
340
+        $args   = wp_parse_args( $args, $defaults );
341
+        $output = '';
342
+
343
+        if ( $args['title'] ) {
344
+
345
+            // maybe hide labels //@todo set a global option for visibility class
346
+            if ( $type == 'file' || $type == 'checkbox' || $type == 'radio' || ! empty( $args['label_type'] ) ) {
347
+                $class = $args['class'];
348
+            } else {
349
+                $class = 'sr-only ' . $args['class'];
350
+            }
351
+
352
+            // maybe horizontal
353
+            if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
354
+                $class .= ' ' . AUI_Component_Helper::get_column_class( $args['label_col'], 'label' ) . ' col-form-label';
355
+            }
356
+
357
+            // open
358
+            $output .= '<label ';
359
+
360
+            // for
361
+            if ( ! empty( $args['for'] ) ) {
362
+                $output .= ' for="' . esc_attr( $args['for'] ) . '" ';
363
+            }
364
+
365
+            // class
366
+            $class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
367
+            $output .= ' class="' . $class . '" ';
368
+
369
+            // close
370
+            $output .= '>';
371
+
372
+
373
+            // title, don't escape fully as can contain html
374
+            if ( ! empty( $args['title'] ) ) {
375
+                $output .= wp_kses_post( $args['title'] );
376
+            }
377
+
378
+            // close wrap
379
+            $output .= '</label>';
380
+
381
+
382
+        }
383
+
384
+
385
+        return $output;
386
+    }
387
+
388
+    /**
389
+     * Wrap some content in a HTML wrapper.
390
+     *
391
+     * @param array $args
392
+     *
393
+     * @return string
394
+     */
395
+    public static function wrap( $args = array() ) {
396
+        $defaults = array(
397
+            'type'                     => 'div',
398
+            'class'                    => 'form-group',
399
+            'content'                  => '',
400
+            'input_group_left'         => '',
401
+            'input_group_right'        => '',
402
+            'input_group_left_inside'  => false,
403
+            'input_group_right_inside' => false,
404
+            'element_require'          => '',
405
+            'argument_id'              => '',
406
+            'wrap_attributes'          => array()
407
+        );
408
+
409
+        /**
410
+         * Parse incoming $args into an array and merge it with $defaults
411
+         */
412
+        $args   = wp_parse_args( $args, $defaults );
413
+        $output = '';
414
+        if ( $args['type'] ) {
415
+
416
+            // open
417
+            $output .= '<' . sanitize_html_class( $args['type'] );
418
+
419
+            // element require
420
+            if ( ! empty( $args['element_require'] ) ) {
421
+                $output .= AUI_Component_Helper::element_require( $args['element_require'] );
422
+                $args['class'] .= " aui-conditional-field";
423
+            }
424
+
425
+            // argument_id
426
+            if ( ! empty( $args['argument_id'] ) ) {
427
+                $output .= ' data-argument="' . esc_attr( $args['argument_id'] ) . '"';
428
+            }
429
+
430
+            // class
431
+            $class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
432
+            $output .= ' class="' . $class . '" ';
433
+
434
+            // Attributes
435
+            if ( ! empty( $args['wrap_attributes'] ) ) {
436
+                $output .= AUI_Component_Helper::extra_attributes( $args['wrap_attributes'] );
437
+            }
438
+
439
+            // close wrap
440
+            $output .= ' >';
441
+
442
+
443
+            // Input group left
444
+            if ( ! empty( $args['input_group_left'] ) ) {
445
+                $position_class   = ! empty( $args['input_group_left_inside'] ) ? 'position-absolute h-100' : '';
446
+                $input_group_left = strpos( $args['input_group_left'], '<' ) !== false ? $args['input_group_left'] : '<span class="input-group-text">' . $args['input_group_left'] . '</span>';
447
+                $output .= '<div class="input-group-prepend ' . $position_class . '">' . $input_group_left . '</div>';
448
+            }
449
+
450
+            // content
451
+            $output .= $args['content'];
452
+
453
+            // Input group right
454
+            if ( ! empty( $args['input_group_right'] ) ) {
455
+                $position_class    = ! empty( $args['input_group_left_inside'] ) ? 'position-absolute h-100' : '';
456
+                $input_group_right = strpos( $args['input_group_right'], '<' ) !== false ? $args['input_group_right'] : '<span class="input-group-text">' . $args['input_group_right'] . '</span>';
457
+                $output .= '<div class="input-group-append ' . $position_class . '">' . $input_group_right . '</div>';
458
+            }
459
+
460
+
461
+            // close wrap
462
+            $output .= '</' . sanitize_html_class( $args['type'] ) . '>';
463
+
464
+
465
+        } else {
466
+            $output = $args['content'];
467
+        }
468
+
469
+        return $output;
470
+    }
471
+
472
+    /**
473
+     * Build the component.
474
+     *
475
+     * @param array $args
476
+     *
477
+     * @return string The rendered component.
478
+     */
479
+    public static function textarea( $args = array() ) {
480
+        $defaults = array(
481
+            'name'               => '',
482
+            'class'              => '',
483
+            'wrap_class'         => '',
484
+            'id'                 => '',
485
+            'placeholder'        => '',
486
+            'title'              => '',
487
+            'value'              => '',
488
+            'required'           => false,
489
+            'label'              => '',
490
+            'label_after'        => false,
491
+            'label_class'        => '',
492
+            'label_type'         => '',
493
+            'label_col'          => '',
494
+            // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
495
+            'input_group_right'        => '',
496
+            'input_group_left'         => '',
497
+            'input_group_right_inside' => false,
498
+            'help_text'          => '',
499
+            'validation_text'    => '',
500
+            'validation_pattern' => '',
501
+            'no_wrap'            => false,
502
+            'rows'               => '',
503
+            'wysiwyg'            => false,
504
+            'allow_tags'         => false,
505
+            // Allow HTML tags
506
+            'element_require'    => '',
507
+            // [%element_id%] == "1"
508
+            'extra_attributes'   => array(),
509
+            // an array of extra attributes
510
+            'wrap_attributes'    => array(),
511
+        );
512
+
513
+        /**
514
+         * Parse incoming $args into an array and merge it with $defaults
515
+         */
516
+        $args   = wp_parse_args( $args, $defaults );
517
+        $output = '';
518
+
519
+        // hidden label option needs to be empty
520
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
521
+
522
+        // floating labels don't work with wysiwyg so set it as top
523
+        if ( $args['label_type'] == 'floating' && ! empty( $args['wysiwyg'] ) ) {
524
+            $args['label_type'] = 'top';
525
+        }
526
+
527
+        $label_after = $args['label_after'];
528
+
529
+        // floating labels need label after
530
+        if ( $args['label_type'] == 'floating' && empty( $args['wysiwyg'] ) ) {
531
+            $label_after         = true;
532
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
533
+        }
534
+
535
+        // label
536
+        if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
537
+        } elseif ( ! empty( $args['label'] ) && ! $label_after ) {
538
+            $label_args = array(
539
+                'title'      => $args['label'],
540
+                'for'        => $args['id'],
541
+                'class'      => $args['label_class'] . " ",
542
+                'label_type' => $args['label_type'],
543
+                'label_col'  => $args['label_col']
544
+            );
545
+            $output .= self::label( $label_args );
546
+        }
547
+
548
+        // maybe horizontal label
549
+        if ( $args['label_type'] == 'horizontal' ) {
550
+            $input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
551
+            $output .= '<div class="' . $input_col . '">';
552
+        }
553
+
554
+        if ( ! empty( $args['wysiwyg'] ) ) {
555
+            ob_start();
556
+            $content   = $args['value'];
557
+            $editor_id = ! empty( $args['id'] ) ? sanitize_html_class( $args['id'] ) : 'wp_editor';
558
+            $settings  = array(
559
+                'textarea_rows' => ! empty( absint( $args['rows'] ) ) ? absint( $args['rows'] ) : 4,
560
+                'quicktags'     => false,
561
+                'media_buttons' => false,
562
+                'editor_class'  => 'form-control',
563
+                'textarea_name' => ! empty( $args['name'] ) ? sanitize_html_class( $args['name'] ) : sanitize_html_class( $args['id'] ),
564
+                'teeny'         => true,
565
+            );
566
+
567
+            // maybe set settings if array
568
+            if ( is_array( $args['wysiwyg'] ) ) {
569
+                $settings = wp_parse_args( $args['wysiwyg'], $settings );
570
+            }
571
+
572
+            wp_editor( $content, $editor_id, $settings );
573
+            $output .= ob_get_clean();
574
+        } else {
575
+
576
+            // open
577
+            $output .= '<textarea ';
578
+
579
+            // name
580
+            if ( ! empty( $args['name'] ) ) {
581
+                $output .= ' name="' . esc_attr( $args['name'] ) . '" ';
582
+            }
583
+
584
+            // id
585
+            if ( ! empty( $args['id'] ) ) {
586
+                $output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
587
+            }
588
+
589
+            // placeholder
590
+            if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
591
+                $output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
592
+            }
593
+
594
+            // title
595
+            if ( ! empty( $args['title'] ) ) {
596
+                $output .= ' title="' . esc_attr( $args['title'] ) . '" ';
597
+            }
598
+
599
+            // validation text
600
+            if ( ! empty( $args['validation_text'] ) ) {
601
+                $output .= ' oninvalid="setCustomValidity(\'' . esc_attr( $args['validation_text'] ) . '\')" ';
602
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
603
+            }
604
+
605
+            // validation_pattern
606
+            if ( ! empty( $args['validation_pattern'] ) ) {
607
+                $output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
608
+            }
609
+
610
+            // required
611
+            if ( ! empty( $args['required'] ) ) {
612
+                $output .= ' required ';
613
+            }
614
+
615
+            // rows
616
+            if ( ! empty( $args['rows'] ) ) {
617
+                $output .= ' rows="' . absint( $args['rows'] ) . '" ';
618
+            }
619
+
620
+
621
+            // class
622
+            $class = ! empty( $args['class'] ) ? $args['class'] : '';
623
+            $output .= ' class="form-control ' . $class . '" ';
624
+
625
+            // extra attributes
626
+            if ( ! empty( $args['extra_attributes'] ) ) {
627
+                $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
628
+            }
629
+
630
+            // close tag
631
+            $output .= ' >';
632
+
633
+            // value
634
+            if ( ! empty( $args['value'] ) ) {
635
+                if ( ! empty( $args['allow_tags'] ) ) {
636
+                    $output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
637
+                } else {
638
+                    $output .= AUI_Component_Helper::sanitize_textarea_field( $args['value'] );
639
+                }
640
+            }
641
+
642
+            // closing tag
643
+            $output .= '</textarea>';
644
+
645
+
646
+            // input group wraps
647
+            if ( $args['input_group_left'] || $args['input_group_right'] ) {
648
+                $w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
649
+                if ( $args['input_group_left'] ) {
650
+                    $output = self::wrap( array(
651
+                        'content'                 => $output,
652
+                        'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
653
+                        'input_group_left'        => $args['input_group_left'],
654
+                        'input_group_left_inside' => $args['input_group_left_inside']
655
+                    ) );
656
+                }
657
+                if ( $args['input_group_right'] ) {
658
+                    $output = self::wrap( array(
659
+                        'content'                  => $output,
660
+                        'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
661
+                        'input_group_right'        => $args['input_group_right'],
662
+                        'input_group_right_inside' => $args['input_group_right_inside']
663
+                    ) );
664
+                }
665
+
666
+            }
667
+
668
+
669
+        }
670
+
671
+        if ( ! empty( $args['label'] ) && $label_after ) {
672
+            $label_args = array(
673
+                'title'      => $args['label'],
674
+                'for'        => $args['id'],
675
+                'class'      => $args['label_class'] . " ",
676
+                'label_type' => $args['label_type'],
677
+                'label_col'  => $args['label_col']
678
+            );
679
+            $output .= self::label( $label_args );
680
+        }
681
+
682
+        // help text
683
+        if ( ! empty( $args['help_text'] ) ) {
684
+            $output .= AUI_Component_Helper::help_text( $args['help_text'] );
685
+        }
686
+
687
+        // maybe horizontal label
688
+        if ( $args['label_type'] == 'horizontal' ) {
689
+            $output .= '</div>';
690
+        }
691
+
692
+
693
+        // wrap
694
+        if ( ! $args['no_wrap'] ) {
695
+            $form_group_class = $args['label_type'] == 'floating' ? 'form-label-group' : 'form-group';
696
+            $wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
697
+            $wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
698
+            $output           = self::wrap( array(
699
+                'content'         => $output,
700
+                'class'           => $wrap_class,
701
+                'element_require' => $args['element_require'],
702
+                'argument_id'     => $args['id'],
703
+                'wrap_attributes' => $args['wrap_attributes'],
704
+            ) );
705
+        }
706
+
707
+
708
+        return $output;
709
+    }
710
+
711
+    /**
712
+     * Build the component.
713
+     *
714
+     * @param array $args
715
+     *
716
+     * @return string The rendered component.
717
+     */
718
+    public static function select( $args = array() ) {
719
+        $defaults = array(
720
+            'class'            => '',
721
+            'wrap_class'       => '',
722
+            'id'               => '',
723
+            'title'            => '',
724
+            'value'            => '',
725
+            // can be an array or a string
726
+            'required'         => false,
727
+            'label'            => '',
728
+            'label_after'      => false,
729
+            'label_type'       => '',
730
+            'label_col'        => '',
731
+            // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
732
+            'label_class'      => '',
733
+            'help_text'        => '',
734
+            'placeholder'      => '',
735
+            'options'          => array(),
736
+            // array or string
737
+            'icon'             => '',
738
+            'multiple'         => false,
739
+            'select2'          => false,
740
+            'no_wrap'          => false,
741
+            'input_group_right' => '',
742
+            'input_group_left' => '',
743
+            'input_group_right_inside' => false, // forces the input group inside the input
744
+            'input_group_left_inside' => false, // forces the input group inside the input
745
+            'element_require'  => '',
746
+            // [%element_id%] == "1"
747
+            'extra_attributes' => array(),
748
+            // an array of extra attributes
749
+            'wrap_attributes'  => array(),
750
+        );
751
+
752
+        /**
753
+         * Parse incoming $args into an array and merge it with $defaults
754
+         */
755
+        $args   = wp_parse_args( $args, $defaults );
756
+        $output = '';
757
+
758
+        // for now lets hide floating labels
759
+        if ( $args['label_type'] == 'floating' ) {
760
+            $args['label_type'] = 'hidden';
761
+        }
762
+
763
+        // hidden label option needs to be empty
764
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
765
+
766
+
767
+        $label_after = $args['label_after'];
768
+
769
+        // floating labels need label after
770
+        if ( $args['label_type'] == 'floating' ) {
771
+            $label_after         = true;
772
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
773
+        }
774
+
775
+        // Maybe setup select2
776
+        $is_select2 = false;
777
+        if ( ! empty( $args['select2'] ) ) {
778
+            $args['class'] .= ' aui-select2';
779
+            $is_select2 = true;
780
+        } elseif ( strpos( $args['class'], 'aui-select2' ) !== false ) {
781
+            $is_select2 = true;
782
+        }
783
+
784
+        // select2 tags
785
+        if ( ! empty( $args['select2'] ) && $args['select2'] === 'tags' ) { // triple equals needed here for some reason
786
+            $args['data-tags']             = 'true';
787
+            $args['data-token-separators'] = "[',']";
788
+            $args['multiple']              = true;
789
+        }
790
+
791
+        // select2 placeholder
792
+        if ( $is_select2 && isset( $args['placeholder'] ) && '' != $args['placeholder'] && empty( $args['data-placeholder'] ) ) {
793
+            $args['data-placeholder'] = esc_attr( $args['placeholder'] );
794
+            $args['data-allow-clear'] = isset( $args['data-allow-clear'] ) ? (bool) $args['data-allow-clear'] : true;
795
+        }
796
+
797
+
798
+
799
+        // maybe horizontal label
800 800
 //		if ( $args['label_type'] == 'horizontal' ) {
801 801
 //			$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
802 802
 //			$output .= '<div class="' . $input_col . '">';
803 803
 //		}
804 804
 
805
-		// Set hidden input to save empty value for multiselect.
806
-		if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
807
-			$output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
808
-		}
809
-
810
-		// open/type
811
-		$output .= '<select ';
812
-
813
-		// style
814
-		if ( $is_select2 && !($args['input_group_left'] || $args['input_group_right'])) {
815
-			$output .= " style='width:100%;' ";
816
-		}
817
-
818
-		// element require
819
-		if ( ! empty( $args['element_require'] ) ) {
820
-			$output .= AUI_Component_Helper::element_require( $args['element_require'] );
821
-			$args['class'] .= " aui-conditional-field";
822
-		}
823
-
824
-		// class
825
-		$class = ! empty( $args['class'] ) ? $args['class'] : '';
826
-		$output .= AUI_Component_Helper::class_attr( 'custom-select ' . $class );
827
-
828
-		// name
829
-		if ( ! empty( $args['name'] ) ) {
830
-			$output .= AUI_Component_Helper::name( $args['name'], $args['multiple'] );
831
-		}
832
-
833
-		// id
834
-		if ( ! empty( $args['id'] ) ) {
835
-			$output .= AUI_Component_Helper::id( $args['id'] );
836
-		}
837
-
838
-		// title
839
-		if ( ! empty( $args['title'] ) ) {
840
-			$output .= AUI_Component_Helper::title( $args['title'] );
841
-		}
842
-
843
-		// data-attributes
844
-		$output .= AUI_Component_Helper::data_attributes( $args );
845
-
846
-		// aria-attributes
847
-		$output .= AUI_Component_Helper::aria_attributes( $args );
848
-
849
-		// extra attributes
850
-		if ( ! empty( $args['extra_attributes'] ) ) {
851
-			$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
852
-		}
853
-
854
-		// required
855
-		if ( ! empty( $args['required'] ) ) {
856
-			$output .= ' required ';
857
-		}
858
-
859
-		// multiple
860
-		if ( ! empty( $args['multiple'] ) ) {
861
-			$output .= ' multiple ';
862
-		}
863
-
864
-		// close opening tag
865
-		$output .= ' >';
866
-
867
-		// placeholder
868
-		if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] && ! $is_select2 ) {
869
-			$output .= '<option value="" disabled selected hidden>' . esc_attr( $args['placeholder'] ) . '</option>';
870
-		} elseif ( $is_select2 && ! empty( $args['placeholder'] ) ) {
871
-			$output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
872
-		}
873
-
874
-		// Options
875
-		if ( ! empty( $args['options'] ) ) {
876
-
877
-			if ( ! is_array( $args['options'] ) ) {
878
-				$output .= $args['options']; // not the preferred way but an option
879
-			} else {
880
-				foreach ( $args['options'] as $val => $name ) {
881
-					$selected = '';
882
-					if ( is_array( $name ) ) {
883
-						if ( isset( $name['optgroup'] ) && ( $name['optgroup'] == 'start' || $name['optgroup'] == 'end' ) ) {
884
-							$option_label = isset( $name['label'] ) ? $name['label'] : '';
885
-
886
-							$output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr( $option_label ) . '">' : '</optgroup>';
887
-						} else {
888
-							$option_label = isset( $name['label'] ) ? $name['label'] : '';
889
-							$option_value = isset( $name['value'] ) ? $name['value'] : '';
890
-							$extra_attributes = !empty($name['extra_attributes']) ? AUI_Component_Helper::extra_attributes( $name['extra_attributes'] ) : '';
891
-							if ( ! empty( $args['multiple'] ) && ! empty( $args['value'] ) && is_array( $args['value'] ) ) {
892
-								$selected = in_array( $option_value, stripslashes_deep( $args['value'] ) ) ? "selected" : "";
893
-							} elseif ( ! empty( $args['value'] ) ) {
894
-								$selected = selected( $option_value, stripslashes_deep( $args['value'] ), false );
895
-							} elseif ( empty( $args['value'] ) && $args['value'] === $option_value ) {
896
-								$selected = selected( $option_value, $args['value'], false );
897
-							}
898
-
899
-							$output .= '<option value="' . esc_attr( $option_value ) . '" ' . $selected . ' '.$extra_attributes .'>' . $option_label . '</option>';
900
-						}
901
-					} else {
902
-						if ( ! empty( $args['value'] ) ) {
903
-							if ( is_array( $args['value'] ) ) {
904
-								$selected = in_array( $val, $args['value'] ) ? 'selected="selected"' : '';
905
-							} elseif ( ! empty( $args['value'] ) ) {
906
-								$selected = selected( $args['value'], $val, false );
907
-							}
908
-						} elseif ( $args['value'] === $val ) {
909
-							$selected = selected( $args['value'], $val, false );
910
-						}
911
-						$output .= '<option value="' . esc_attr( $val ) . '" ' . $selected . '>' . esc_attr( $name ) . '</option>';
912
-					}
913
-				}
914
-			}
915
-
916
-		}
917
-
918
-		// closing tag
919
-		$output .= '</select>';
920
-
921
-		$label = '';
922
-		$help_text = '';
923
-		// label
924
-		if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
925
-		} elseif ( ! empty( $args['label'] ) && ! $label_after ) {
926
-			$label_args = array(
927
-				'title'      => $args['label'],
928
-				'for'        => $args['id'],
929
-				'class'      => $args['label_class'] . " ",
930
-				'label_type' => $args['label_type'],
931
-				'label_col'  => $args['label_col']
932
-			);
933
-			$label = self::label( $label_args );
934
-		}
935
-
936
-		// help text
937
-		if ( ! empty( $args['help_text'] ) ) {
938
-			$help_text = AUI_Component_Helper::help_text( $args['help_text'] );
939
-		}
940
-
941
-		// input group wraps
942
-		if ( $args['input_group_left'] || $args['input_group_right'] ) {
943
-			$w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
944
-			if ( $args['input_group_left'] ) {
945
-				$output = self::wrap( array(
946
-					'content'                 => $output,
947
-					'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
948
-					'input_group_left'        => $args['input_group_left'],
949
-					'input_group_left_inside' => $args['input_group_left_inside']
950
-				) );
951
-			}
952
-			if ( $args['input_group_right'] ) {
953
-				$output = self::wrap( array(
954
-					'content'                  => $output,
955
-					'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
956
-					'input_group_right'        => $args['input_group_right'],
957
-					'input_group_right_inside' => $args['input_group_right_inside']
958
-				) );
959
-			}
960
-
961
-		}
962
-
963
-		if ( ! $label_after ) {
964
-			$output .= $help_text;
965
-		}
966
-
967
-
968
-		if ( $args['label_type'] == 'horizontal' ) {
969
-			$output = self::wrap( array(
970
-				'content' => $output,
971
-				'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
972
-			) );
973
-		}
974
-
975
-		if ( ! $label_after ) {
976
-			$output = $label . $output;
977
-		}
978
-
979
-		// maybe horizontal label
805
+        // Set hidden input to save empty value for multiselect.
806
+        if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
807
+            $output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
808
+        }
809
+
810
+        // open/type
811
+        $output .= '<select ';
812
+
813
+        // style
814
+        if ( $is_select2 && !($args['input_group_left'] || $args['input_group_right'])) {
815
+            $output .= " style='width:100%;' ";
816
+        }
817
+
818
+        // element require
819
+        if ( ! empty( $args['element_require'] ) ) {
820
+            $output .= AUI_Component_Helper::element_require( $args['element_require'] );
821
+            $args['class'] .= " aui-conditional-field";
822
+        }
823
+
824
+        // class
825
+        $class = ! empty( $args['class'] ) ? $args['class'] : '';
826
+        $output .= AUI_Component_Helper::class_attr( 'custom-select ' . $class );
827
+
828
+        // name
829
+        if ( ! empty( $args['name'] ) ) {
830
+            $output .= AUI_Component_Helper::name( $args['name'], $args['multiple'] );
831
+        }
832
+
833
+        // id
834
+        if ( ! empty( $args['id'] ) ) {
835
+            $output .= AUI_Component_Helper::id( $args['id'] );
836
+        }
837
+
838
+        // title
839
+        if ( ! empty( $args['title'] ) ) {
840
+            $output .= AUI_Component_Helper::title( $args['title'] );
841
+        }
842
+
843
+        // data-attributes
844
+        $output .= AUI_Component_Helper::data_attributes( $args );
845
+
846
+        // aria-attributes
847
+        $output .= AUI_Component_Helper::aria_attributes( $args );
848
+
849
+        // extra attributes
850
+        if ( ! empty( $args['extra_attributes'] ) ) {
851
+            $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
852
+        }
853
+
854
+        // required
855
+        if ( ! empty( $args['required'] ) ) {
856
+            $output .= ' required ';
857
+        }
858
+
859
+        // multiple
860
+        if ( ! empty( $args['multiple'] ) ) {
861
+            $output .= ' multiple ';
862
+        }
863
+
864
+        // close opening tag
865
+        $output .= ' >';
866
+
867
+        // placeholder
868
+        if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] && ! $is_select2 ) {
869
+            $output .= '<option value="" disabled selected hidden>' . esc_attr( $args['placeholder'] ) . '</option>';
870
+        } elseif ( $is_select2 && ! empty( $args['placeholder'] ) ) {
871
+            $output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
872
+        }
873
+
874
+        // Options
875
+        if ( ! empty( $args['options'] ) ) {
876
+
877
+            if ( ! is_array( $args['options'] ) ) {
878
+                $output .= $args['options']; // not the preferred way but an option
879
+            } else {
880
+                foreach ( $args['options'] as $val => $name ) {
881
+                    $selected = '';
882
+                    if ( is_array( $name ) ) {
883
+                        if ( isset( $name['optgroup'] ) && ( $name['optgroup'] == 'start' || $name['optgroup'] == 'end' ) ) {
884
+                            $option_label = isset( $name['label'] ) ? $name['label'] : '';
885
+
886
+                            $output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr( $option_label ) . '">' : '</optgroup>';
887
+                        } else {
888
+                            $option_label = isset( $name['label'] ) ? $name['label'] : '';
889
+                            $option_value = isset( $name['value'] ) ? $name['value'] : '';
890
+                            $extra_attributes = !empty($name['extra_attributes']) ? AUI_Component_Helper::extra_attributes( $name['extra_attributes'] ) : '';
891
+                            if ( ! empty( $args['multiple'] ) && ! empty( $args['value'] ) && is_array( $args['value'] ) ) {
892
+                                $selected = in_array( $option_value, stripslashes_deep( $args['value'] ) ) ? "selected" : "";
893
+                            } elseif ( ! empty( $args['value'] ) ) {
894
+                                $selected = selected( $option_value, stripslashes_deep( $args['value'] ), false );
895
+                            } elseif ( empty( $args['value'] ) && $args['value'] === $option_value ) {
896
+                                $selected = selected( $option_value, $args['value'], false );
897
+                            }
898
+
899
+                            $output .= '<option value="' . esc_attr( $option_value ) . '" ' . $selected . ' '.$extra_attributes .'>' . $option_label . '</option>';
900
+                        }
901
+                    } else {
902
+                        if ( ! empty( $args['value'] ) ) {
903
+                            if ( is_array( $args['value'] ) ) {
904
+                                $selected = in_array( $val, $args['value'] ) ? 'selected="selected"' : '';
905
+                            } elseif ( ! empty( $args['value'] ) ) {
906
+                                $selected = selected( $args['value'], $val, false );
907
+                            }
908
+                        } elseif ( $args['value'] === $val ) {
909
+                            $selected = selected( $args['value'], $val, false );
910
+                        }
911
+                        $output .= '<option value="' . esc_attr( $val ) . '" ' . $selected . '>' . esc_attr( $name ) . '</option>';
912
+                    }
913
+                }
914
+            }
915
+
916
+        }
917
+
918
+        // closing tag
919
+        $output .= '</select>';
920
+
921
+        $label = '';
922
+        $help_text = '';
923
+        // label
924
+        if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
925
+        } elseif ( ! empty( $args['label'] ) && ! $label_after ) {
926
+            $label_args = array(
927
+                'title'      => $args['label'],
928
+                'for'        => $args['id'],
929
+                'class'      => $args['label_class'] . " ",
930
+                'label_type' => $args['label_type'],
931
+                'label_col'  => $args['label_col']
932
+            );
933
+            $label = self::label( $label_args );
934
+        }
935
+
936
+        // help text
937
+        if ( ! empty( $args['help_text'] ) ) {
938
+            $help_text = AUI_Component_Helper::help_text( $args['help_text'] );
939
+        }
940
+
941
+        // input group wraps
942
+        if ( $args['input_group_left'] || $args['input_group_right'] ) {
943
+            $w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
944
+            if ( $args['input_group_left'] ) {
945
+                $output = self::wrap( array(
946
+                    'content'                 => $output,
947
+                    'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
948
+                    'input_group_left'        => $args['input_group_left'],
949
+                    'input_group_left_inside' => $args['input_group_left_inside']
950
+                ) );
951
+            }
952
+            if ( $args['input_group_right'] ) {
953
+                $output = self::wrap( array(
954
+                    'content'                  => $output,
955
+                    'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
956
+                    'input_group_right'        => $args['input_group_right'],
957
+                    'input_group_right_inside' => $args['input_group_right_inside']
958
+                ) );
959
+            }
960
+
961
+        }
962
+
963
+        if ( ! $label_after ) {
964
+            $output .= $help_text;
965
+        }
966
+
967
+
968
+        if ( $args['label_type'] == 'horizontal' ) {
969
+            $output = self::wrap( array(
970
+                'content' => $output,
971
+                'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
972
+            ) );
973
+        }
974
+
975
+        if ( ! $label_after ) {
976
+            $output = $label . $output;
977
+        }
978
+
979
+        // maybe horizontal label
980 980
 //		if ( $args['label_type'] == 'horizontal' ) {
981 981
 //			$output .= '</div>';
982 982
 //		}
983 983
 
984 984
 
985
-		// wrap
986
-		if ( ! $args['no_wrap'] ) {
987
-			$wrap_class = $args['label_type'] == 'horizontal' ? 'form-group row' : 'form-group';
988
-			$wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
989
-			$output     = self::wrap( array(
990
-				'content'         => $output,
991
-				'class'           => $wrap_class,
992
-				'element_require' => $args['element_require'],
993
-				'argument_id'     => $args['id'],
994
-				'wrap_attributes' => $args['wrap_attributes'],
995
-			) );
996
-		}
997
-
998
-
999
-		return $output;
1000
-	}
1001
-
1002
-	/**
1003
-	 * Build the component.
1004
-	 *
1005
-	 * @param array $args
1006
-	 *
1007
-	 * @return string The rendered component.
1008
-	 */
1009
-	public static function radio( $args = array() ) {
1010
-		$defaults = array(
1011
-			'class'            => '',
1012
-			'wrap_class'       => '',
1013
-			'id'               => '',
1014
-			'title'            => '',
1015
-			'horizontal'       => false,
1016
-			// sets the lable horizontal
1017
-			'value'            => '',
1018
-			'label'            => '',
1019
-			'label_class'      => '',
1020
-			'label_type'       => '',
1021
-			'label_col'        => '',
1022
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
1023
-			'help_text'        => '',
1024
-			'inline'           => true,
1025
-			'required'         => false,
1026
-			'options'          => array(),
1027
-			'icon'             => '',
1028
-			'no_wrap'          => false,
1029
-			'element_require'  => '',
1030
-			// [%element_id%] == "1"
1031
-			'extra_attributes' => array(),
1032
-			// an array of extra attributes
1033
-			'wrap_attributes'  => array()
1034
-		);
1035
-
1036
-		/**
1037
-		 * Parse incoming $args into an array and merge it with $defaults
1038
-		 */
1039
-		$args = wp_parse_args( $args, $defaults );
1040
-
1041
-		// for now lets use horizontal for floating
1042
-		if ( $args['label_type'] == 'floating' ) {
1043
-			$args['label_type'] = 'horizontal';
1044
-		}
1045
-
1046
-		$label_args = array(
1047
-			'title'      => $args['label'],
1048
-			'class'      => $args['label_class'] . " pt-0 ",
1049
-			'label_type' => $args['label_type'],
1050
-			'label_col'  => $args['label_col']
1051
-		);
1052
-
1053
-		$output = '';
1054
-
1055
-
1056
-		// label before
1057
-		if ( ! empty( $args['label'] ) ) {
1058
-			$output .= self::label( $label_args, 'radio' );
1059
-		}
1060
-
1061
-		// maybe horizontal label
1062
-		if ( $args['label_type'] == 'horizontal' ) {
1063
-			$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
1064
-			$output .= '<div class="' . $input_col . '">';
1065
-		}
1066
-
1067
-		if ( ! empty( $args['options'] ) ) {
1068
-			$count = 0;
1069
-			foreach ( $args['options'] as $value => $label ) {
1070
-				$option_args            = $args;
1071
-				$option_args['value']   = $value;
1072
-				$option_args['label']   = $label;
1073
-				$option_args['checked'] = $value == $args['value'] ? true : false;
1074
-				$output .= self::radio_option( $option_args, $count );
1075
-				$count ++;
1076
-			}
1077
-		}
1078
-
1079
-		// help text
1080
-		$help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
1081
-		$output .= $help_text;
1082
-
1083
-		// maybe horizontal label
1084
-		if ( $args['label_type'] == 'horizontal' ) {
1085
-			$output .= '</div>';
1086
-		}
1087
-
1088
-		// wrap
1089
-		$wrap_class = $args['label_type'] == 'horizontal' ? 'form-group row' : 'form-group';
1090
-		$wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
1091
-		$output     = self::wrap( array(
1092
-			'content'         => $output,
1093
-			'class'           => $wrap_class,
1094
-			'element_require' => $args['element_require'],
1095
-			'argument_id'     => $args['id'],
1096
-			'wrap_attributes' => $args['wrap_attributes'],
1097
-		) );
1098
-
1099
-
1100
-		return $output;
1101
-	}
1102
-
1103
-	/**
1104
-	 * Build the component.
1105
-	 *
1106
-	 * @param array $args
1107
-	 *
1108
-	 * @return string The rendered component.
1109
-	 */
1110
-	public static function radio_option( $args = array(), $count = '' ) {
1111
-		$defaults = array(
1112
-			'class'            => '',
1113
-			'id'               => '',
1114
-			'title'            => '',
1115
-			'value'            => '',
1116
-			'required'         => false,
1117
-			'inline'           => true,
1118
-			'label'            => '',
1119
-			'options'          => array(),
1120
-			'icon'             => '',
1121
-			'no_wrap'          => false,
1122
-			'extra_attributes' => array() // an array of extra attributes
1123
-		);
1124
-
1125
-		/**
1126
-		 * Parse incoming $args into an array and merge it with $defaults
1127
-		 */
1128
-		$args = wp_parse_args( $args, $defaults );
1129
-
1130
-		$output = '';
1131
-
1132
-		// open/type
1133
-		$output .= '<input type="radio"';
1134
-
1135
-		// class
1136
-		$output .= ' class="form-check-input" ';
1137
-
1138
-		// name
1139
-		if ( ! empty( $args['name'] ) ) {
1140
-			$output .= AUI_Component_Helper::name( $args['name'] );
1141
-		}
1142
-
1143
-		// id
1144
-		if ( ! empty( $args['id'] ) ) {
1145
-			$output .= AUI_Component_Helper::id( $args['id'] . $count );
1146
-		}
1147
-
1148
-		// title
1149
-		if ( ! empty( $args['title'] ) ) {
1150
-			$output .= AUI_Component_Helper::title( $args['title'] );
1151
-		}
1152
-
1153
-		// value
1154
-		if ( isset( $args['value'] ) ) {
1155
-			$output .= AUI_Component_Helper::value( $args['value'] );
1156
-		}
1157
-
1158
-		// checked, for radio and checkboxes
1159
-		if ( $args['checked'] ) {
1160
-			$output .= ' checked ';
1161
-		}
1162
-
1163
-		// data-attributes
1164
-		$output .= AUI_Component_Helper::data_attributes( $args );
1165
-
1166
-		// aria-attributes
1167
-		$output .= AUI_Component_Helper::aria_attributes( $args );
1168
-
1169
-		// extra attributes
1170
-		if ( ! empty( $args['extra_attributes'] ) ) {
1171
-			$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
1172
-		}
1173
-
1174
-		// required
1175
-		if ( ! empty( $args['required'] ) ) {
1176
-			$output .= ' required ';
1177
-		}
1178
-
1179
-		// close opening tag
1180
-		$output .= ' >';
1181
-
1182
-		// label
1183
-		if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
1184
-		} elseif ( ! empty( $args['label'] ) ) {
1185
-			$output .= self::label( array(
1186
-				'title' => $args['label'],
1187
-				'for'   => $args['id'] . $count,
1188
-				'class' => 'form-check-label'
1189
-			), 'radio' );
1190
-		}
1191
-
1192
-		// wrap
1193
-		if ( ! $args['no_wrap'] ) {
1194
-			$wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1195
-
1196
-			// Unique wrap class
1197
-			$uniq_class = 'fwrap';
1198
-			if ( ! empty( $args['name'] ) ) {
1199
-				$uniq_class .= '-' . $args['name'];
1200
-			} else if ( ! empty( $args['id'] ) ) {
1201
-				$uniq_class .= '-' . $args['id'];
1202
-			}
1203
-
1204
-			if ( isset( $args['value'] ) || $args['value'] !== "" ) {
1205
-				$uniq_class .= '-' . $args['value'];
1206
-			} else {
1207
-				$uniq_class .= '-' . $count;
1208
-			}
1209
-			$wrap_class .= ' ' . sanitize_html_class( $uniq_class );
1210
-
1211
-			$output = self::wrap( array(
1212
-				'content' => $output,
1213
-				'class'   => $wrap_class
1214
-			) );
1215
-		}
1216
-
1217
-		return $output;
1218
-	}
985
+        // wrap
986
+        if ( ! $args['no_wrap'] ) {
987
+            $wrap_class = $args['label_type'] == 'horizontal' ? 'form-group row' : 'form-group';
988
+            $wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
989
+            $output     = self::wrap( array(
990
+                'content'         => $output,
991
+                'class'           => $wrap_class,
992
+                'element_require' => $args['element_require'],
993
+                'argument_id'     => $args['id'],
994
+                'wrap_attributes' => $args['wrap_attributes'],
995
+            ) );
996
+        }
997
+
998
+
999
+        return $output;
1000
+    }
1001
+
1002
+    /**
1003
+     * Build the component.
1004
+     *
1005
+     * @param array $args
1006
+     *
1007
+     * @return string The rendered component.
1008
+     */
1009
+    public static function radio( $args = array() ) {
1010
+        $defaults = array(
1011
+            'class'            => '',
1012
+            'wrap_class'       => '',
1013
+            'id'               => '',
1014
+            'title'            => '',
1015
+            'horizontal'       => false,
1016
+            // sets the lable horizontal
1017
+            'value'            => '',
1018
+            'label'            => '',
1019
+            'label_class'      => '',
1020
+            'label_type'       => '',
1021
+            'label_col'        => '',
1022
+            // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
1023
+            'help_text'        => '',
1024
+            'inline'           => true,
1025
+            'required'         => false,
1026
+            'options'          => array(),
1027
+            'icon'             => '',
1028
+            'no_wrap'          => false,
1029
+            'element_require'  => '',
1030
+            // [%element_id%] == "1"
1031
+            'extra_attributes' => array(),
1032
+            // an array of extra attributes
1033
+            'wrap_attributes'  => array()
1034
+        );
1035
+
1036
+        /**
1037
+         * Parse incoming $args into an array and merge it with $defaults
1038
+         */
1039
+        $args = wp_parse_args( $args, $defaults );
1040
+
1041
+        // for now lets use horizontal for floating
1042
+        if ( $args['label_type'] == 'floating' ) {
1043
+            $args['label_type'] = 'horizontal';
1044
+        }
1045
+
1046
+        $label_args = array(
1047
+            'title'      => $args['label'],
1048
+            'class'      => $args['label_class'] . " pt-0 ",
1049
+            'label_type' => $args['label_type'],
1050
+            'label_col'  => $args['label_col']
1051
+        );
1052
+
1053
+        $output = '';
1054
+
1055
+
1056
+        // label before
1057
+        if ( ! empty( $args['label'] ) ) {
1058
+            $output .= self::label( $label_args, 'radio' );
1059
+        }
1060
+
1061
+        // maybe horizontal label
1062
+        if ( $args['label_type'] == 'horizontal' ) {
1063
+            $input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
1064
+            $output .= '<div class="' . $input_col . '">';
1065
+        }
1066
+
1067
+        if ( ! empty( $args['options'] ) ) {
1068
+            $count = 0;
1069
+            foreach ( $args['options'] as $value => $label ) {
1070
+                $option_args            = $args;
1071
+                $option_args['value']   = $value;
1072
+                $option_args['label']   = $label;
1073
+                $option_args['checked'] = $value == $args['value'] ? true : false;
1074
+                $output .= self::radio_option( $option_args, $count );
1075
+                $count ++;
1076
+            }
1077
+        }
1078
+
1079
+        // help text
1080
+        $help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
1081
+        $output .= $help_text;
1082
+
1083
+        // maybe horizontal label
1084
+        if ( $args['label_type'] == 'horizontal' ) {
1085
+            $output .= '</div>';
1086
+        }
1087
+
1088
+        // wrap
1089
+        $wrap_class = $args['label_type'] == 'horizontal' ? 'form-group row' : 'form-group';
1090
+        $wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
1091
+        $output     = self::wrap( array(
1092
+            'content'         => $output,
1093
+            'class'           => $wrap_class,
1094
+            'element_require' => $args['element_require'],
1095
+            'argument_id'     => $args['id'],
1096
+            'wrap_attributes' => $args['wrap_attributes'],
1097
+        ) );
1098
+
1099
+
1100
+        return $output;
1101
+    }
1102
+
1103
+    /**
1104
+     * Build the component.
1105
+     *
1106
+     * @param array $args
1107
+     *
1108
+     * @return string The rendered component.
1109
+     */
1110
+    public static function radio_option( $args = array(), $count = '' ) {
1111
+        $defaults = array(
1112
+            'class'            => '',
1113
+            'id'               => '',
1114
+            'title'            => '',
1115
+            'value'            => '',
1116
+            'required'         => false,
1117
+            'inline'           => true,
1118
+            'label'            => '',
1119
+            'options'          => array(),
1120
+            'icon'             => '',
1121
+            'no_wrap'          => false,
1122
+            'extra_attributes' => array() // an array of extra attributes
1123
+        );
1124
+
1125
+        /**
1126
+         * Parse incoming $args into an array and merge it with $defaults
1127
+         */
1128
+        $args = wp_parse_args( $args, $defaults );
1129
+
1130
+        $output = '';
1131
+
1132
+        // open/type
1133
+        $output .= '<input type="radio"';
1134
+
1135
+        // class
1136
+        $output .= ' class="form-check-input" ';
1137
+
1138
+        // name
1139
+        if ( ! empty( $args['name'] ) ) {
1140
+            $output .= AUI_Component_Helper::name( $args['name'] );
1141
+        }
1142
+
1143
+        // id
1144
+        if ( ! empty( $args['id'] ) ) {
1145
+            $output .= AUI_Component_Helper::id( $args['id'] . $count );
1146
+        }
1147
+
1148
+        // title
1149
+        if ( ! empty( $args['title'] ) ) {
1150
+            $output .= AUI_Component_Helper::title( $args['title'] );
1151
+        }
1152
+
1153
+        // value
1154
+        if ( isset( $args['value'] ) ) {
1155
+            $output .= AUI_Component_Helper::value( $args['value'] );
1156
+        }
1157
+
1158
+        // checked, for radio and checkboxes
1159
+        if ( $args['checked'] ) {
1160
+            $output .= ' checked ';
1161
+        }
1162
+
1163
+        // data-attributes
1164
+        $output .= AUI_Component_Helper::data_attributes( $args );
1165
+
1166
+        // aria-attributes
1167
+        $output .= AUI_Component_Helper::aria_attributes( $args );
1168
+
1169
+        // extra attributes
1170
+        if ( ! empty( $args['extra_attributes'] ) ) {
1171
+            $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
1172
+        }
1173
+
1174
+        // required
1175
+        if ( ! empty( $args['required'] ) ) {
1176
+            $output .= ' required ';
1177
+        }
1178
+
1179
+        // close opening tag
1180
+        $output .= ' >';
1181
+
1182
+        // label
1183
+        if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
1184
+        } elseif ( ! empty( $args['label'] ) ) {
1185
+            $output .= self::label( array(
1186
+                'title' => $args['label'],
1187
+                'for'   => $args['id'] . $count,
1188
+                'class' => 'form-check-label'
1189
+            ), 'radio' );
1190
+        }
1191
+
1192
+        // wrap
1193
+        if ( ! $args['no_wrap'] ) {
1194
+            $wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1195
+
1196
+            // Unique wrap class
1197
+            $uniq_class = 'fwrap';
1198
+            if ( ! empty( $args['name'] ) ) {
1199
+                $uniq_class .= '-' . $args['name'];
1200
+            } else if ( ! empty( $args['id'] ) ) {
1201
+                $uniq_class .= '-' . $args['id'];
1202
+            }
1203
+
1204
+            if ( isset( $args['value'] ) || $args['value'] !== "" ) {
1205
+                $uniq_class .= '-' . $args['value'];
1206
+            } else {
1207
+                $uniq_class .= '-' . $count;
1208
+            }
1209
+            $wrap_class .= ' ' . sanitize_html_class( $uniq_class );
1210
+
1211
+            $output = self::wrap( array(
1212
+                'content' => $output,
1213
+                'class'   => $wrap_class
1214
+            ) );
1215
+        }
1216
+
1217
+        return $output;
1218
+    }
1219 1219
 
1220 1220
 }
1221 1221
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Indentation   +2049 added lines, -2049 removed lines patch added patch discarded remove patch
@@ -1,268 +1,268 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
3
+    exit;
4 4
 }
5 5
 
6 6
 if ( ! class_exists( 'WP_Super_Duper' ) ) {
7 7
 
8 8
 
9
-	/**
10
-	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
11
-	 *
12
-	 * Should not be called direct but extended instead.
13
-	 *
14
-	 * Class WP_Super_Duper
15
-	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
16
-	 * @ver 1.0.19
17
-	 */
18
-	class WP_Super_Duper extends WP_Widget {
19
-
20
-		public $version = "1.0.29";
21
-		public $font_awesome_icon_version = "5.11.2";
22
-		public $block_code;
23
-		public $options;
24
-		public $base_id;
25
-		public $settings_hash;
26
-		public $arguments = array();
27
-		public $instance = array();
28
-		private $class_name;
29
-
30
-		/**
31
-		 * The relative url to the current folder.
32
-		 *
33
-		 * @var string
34
-		 */
35
-		public $url = '';
36
-
37
-		/**
38
-		 * Take the array options and use them to build.
39
-		 */
40
-		public function __construct( $options ) {
41
-			global $sd_widgets;
42
-
43
-			$sd_widgets[ $options['base_id'] ] = array(
44
-				'name'       => $options['name'],
45
-				'class_name' => $options['class_name']
46
-			);
47
-			$this->base_id                     = $options['base_id'];
48
-			// lets filter the options before we do anything
49
-			$options       = apply_filters( "wp_super_duper_options", $options );
50
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
51
-			$options       = $this->add_name_from_key( $options );
52
-			$this->options = $options;
53
-
54
-			$this->base_id   = $options['base_id'];
55
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
56
-
57
-			// init parent
58
-			parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
59
-
60
-			if ( isset( $options['class_name'] ) ) {
61
-				// register widget
62
-				$this->class_name = $options['class_name'];
63
-
64
-				// register shortcode
65
-				$this->register_shortcode();
66
-
67
-				// Fusion Builder (avada) support
68
-				if ( function_exists( 'fusion_builder_map' ) ) {
69
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
70
-				}
71
-
72
-				// register block
73
-				add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
74
-			}
75
-
76
-			// add the CSS and JS we need ONCE
77
-			global $sd_widget_scripts;
78
-
79
-			if ( ! $sd_widget_scripts ) {
80
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
81
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
82
-				wp_add_inline_style( 'widgets', $this->widget_css() );
83
-
84
-				// maybe add elementor editor styles
85
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
86
-
87
-				$sd_widget_scripts = true;
88
-
89
-				// add shortcode insert button once
90
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
91
-				// generatepress theme sections compatibility
92
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
93
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
94
-				}
95
-				/* Load script on Divi theme builder page */
96
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
97
-					add_thickbox();
98
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
99
-				}
100
-
101
-				if ( $this->is_preview() ) {
102
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
103
-					// this makes the insert button work for elementor
104
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
105
-						$this,
106
-						'shortcode_insert_button_script'
107
-					) ); // for elementor
108
-				}
109
-				// this makes the insert button work for cornerstone
110
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
111
-
112
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
113
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
114
-
115
-				// add generator text to admin head
116
-				add_action( 'admin_head', array( $this, 'generator' ) );
117
-			}
118
-
119
-			do_action( 'wp_super_duper_widget_init', $options, $this );
120
-		}
121
-
122
-		/**
123
-		 * Add our widget CSS to elementor editor.
124
-		 */
125
-		public function elementor_editor_styles() {
126
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
127
-		}
128
-
129
-		public function register_fusion_element() {
130
-
131
-			$options = $this->options;
132
-
133
-			if ( $this->base_id ) {
134
-
135
-				$params = $this->get_fusion_params();
136
-
137
-				$args = array(
138
-					'name'            => $options['name'],
139
-					'shortcode'       => $this->base_id,
140
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
141
-					'allow_generator' => true,
142
-				);
143
-
144
-				if ( ! empty( $params ) ) {
145
-					$args['params'] = $params;
146
-				}
147
-
148
-				fusion_builder_map( $args );
149
-			}
150
-
151
-		}
152
-
153
-		public function get_fusion_params() {
154
-			$params    = array();
155
-			$arguments = $this->get_arguments();
156
-
157
-			if ( ! empty( $arguments ) ) {
158
-				foreach ( $arguments as $key => $val ) {
159
-					$param = array();
160
-					// type
161
-					$param['type'] = str_replace(
162
-						array(
163
-							"text",
164
-							"number",
165
-							"email",
166
-							"color",
167
-							"checkbox"
168
-						),
169
-						array(
170
-							"textfield",
171
-							"textfield",
172
-							"textfield",
173
-							"colorpicker",
174
-							"select",
175
-
176
-						),
177
-						$val['type'] );
178
-
179
-					// multiselect
180
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
181
-						$param['type']     = 'multiple_select';
182
-						$param['multiple'] = true;
183
-					}
184
-
185
-					// heading
186
-					$param['heading'] = $val['title'];
187
-
188
-					// description
189
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
190
-
191
-					// param_name
192
-					$param['param_name'] = $key;
193
-
194
-					// Default
195
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
196
-
197
-					// Group
198
-					if ( isset( $val['group'] ) ) {
199
-						$param['group'] = $val['group'];
200
-					}
201
-
202
-					// value
203
-					if ( $val['type'] == 'checkbox' ) {
204
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
205
-							unset( $param['default'] );
206
-						}
207
-						$param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
208
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
209
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
210
-					} else {
211
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
212
-					}
213
-
214
-					// setup the param
215
-					$params[] = $param;
216
-
217
-				}
218
-			}
219
-
220
-
221
-			return $params;
222
-		}
223
-
224
-		/**
225
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
226
-		 */
227
-		public static function maybe_cornerstone_builder() {
228
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
229
-				self::shortcode_insert_button_script();
230
-			}
231
-		}
232
-
233
-		/**
234
-		 * A function to ge the shortcode builder picker html.
235
-		 *
236
-		 * @param string $editor_id
237
-		 *
238
-		 * @return string
239
-		 */
240
-		public static function get_picker( $editor_id = '' ) {
241
-
242
-			ob_start();
243
-			if ( isset( $_POST['editor_id'] ) ) {
244
-				$editor_id = sanitize_text_field( $_POST['editor_id'] );
245
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
246
-				$editor_id = 'main_content_content_vb_tiny_mce';
247
-			}
248
-
249
-			global $sd_widgets;
250
-			?>
9
+    /**
10
+     * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
11
+     *
12
+     * Should not be called direct but extended instead.
13
+     *
14
+     * Class WP_Super_Duper
15
+     * @since 1.0.16 change log moved to file change-log.txt - CHANGED
16
+     * @ver 1.0.19
17
+     */
18
+    class WP_Super_Duper extends WP_Widget {
19
+
20
+        public $version = "1.0.29";
21
+        public $font_awesome_icon_version = "5.11.2";
22
+        public $block_code;
23
+        public $options;
24
+        public $base_id;
25
+        public $settings_hash;
26
+        public $arguments = array();
27
+        public $instance = array();
28
+        private $class_name;
29
+
30
+        /**
31
+         * The relative url to the current folder.
32
+         *
33
+         * @var string
34
+         */
35
+        public $url = '';
36
+
37
+        /**
38
+         * Take the array options and use them to build.
39
+         */
40
+        public function __construct( $options ) {
41
+            global $sd_widgets;
42
+
43
+            $sd_widgets[ $options['base_id'] ] = array(
44
+                'name'       => $options['name'],
45
+                'class_name' => $options['class_name']
46
+            );
47
+            $this->base_id                     = $options['base_id'];
48
+            // lets filter the options before we do anything
49
+            $options       = apply_filters( "wp_super_duper_options", $options );
50
+            $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
51
+            $options       = $this->add_name_from_key( $options );
52
+            $this->options = $options;
53
+
54
+            $this->base_id   = $options['base_id'];
55
+            $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
56
+
57
+            // init parent
58
+            parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
59
+
60
+            if ( isset( $options['class_name'] ) ) {
61
+                // register widget
62
+                $this->class_name = $options['class_name'];
63
+
64
+                // register shortcode
65
+                $this->register_shortcode();
66
+
67
+                // Fusion Builder (avada) support
68
+                if ( function_exists( 'fusion_builder_map' ) ) {
69
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
70
+                }
71
+
72
+                // register block
73
+                add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
74
+            }
75
+
76
+            // add the CSS and JS we need ONCE
77
+            global $sd_widget_scripts;
78
+
79
+            if ( ! $sd_widget_scripts ) {
80
+                wp_add_inline_script( 'admin-widgets', $this->widget_js() );
81
+                wp_add_inline_script( 'customize-controls', $this->widget_js() );
82
+                wp_add_inline_style( 'widgets', $this->widget_css() );
83
+
84
+                // maybe add elementor editor styles
85
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
86
+
87
+                $sd_widget_scripts = true;
88
+
89
+                // add shortcode insert button once
90
+                add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
91
+                // generatepress theme sections compatibility
92
+                if ( function_exists( 'generate_sections_sections_metabox' ) ) {
93
+                    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
94
+                }
95
+                /* Load script on Divi theme builder page */
96
+                if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
97
+                    add_thickbox();
98
+                    add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
99
+                }
100
+
101
+                if ( $this->is_preview() ) {
102
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
103
+                    // this makes the insert button work for elementor
104
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
105
+                        $this,
106
+                        'shortcode_insert_button_script'
107
+                    ) ); // for elementor
108
+                }
109
+                // this makes the insert button work for cornerstone
110
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
111
+
112
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
113
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
114
+
115
+                // add generator text to admin head
116
+                add_action( 'admin_head', array( $this, 'generator' ) );
117
+            }
118
+
119
+            do_action( 'wp_super_duper_widget_init', $options, $this );
120
+        }
121
+
122
+        /**
123
+         * Add our widget CSS to elementor editor.
124
+         */
125
+        public function elementor_editor_styles() {
126
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
127
+        }
128
+
129
+        public function register_fusion_element() {
130
+
131
+            $options = $this->options;
132
+
133
+            if ( $this->base_id ) {
134
+
135
+                $params = $this->get_fusion_params();
136
+
137
+                $args = array(
138
+                    'name'            => $options['name'],
139
+                    'shortcode'       => $this->base_id,
140
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
141
+                    'allow_generator' => true,
142
+                );
143
+
144
+                if ( ! empty( $params ) ) {
145
+                    $args['params'] = $params;
146
+                }
147
+
148
+                fusion_builder_map( $args );
149
+            }
150
+
151
+        }
152
+
153
+        public function get_fusion_params() {
154
+            $params    = array();
155
+            $arguments = $this->get_arguments();
156
+
157
+            if ( ! empty( $arguments ) ) {
158
+                foreach ( $arguments as $key => $val ) {
159
+                    $param = array();
160
+                    // type
161
+                    $param['type'] = str_replace(
162
+                        array(
163
+                            "text",
164
+                            "number",
165
+                            "email",
166
+                            "color",
167
+                            "checkbox"
168
+                        ),
169
+                        array(
170
+                            "textfield",
171
+                            "textfield",
172
+                            "textfield",
173
+                            "colorpicker",
174
+                            "select",
175
+
176
+                        ),
177
+                        $val['type'] );
178
+
179
+                    // multiselect
180
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
181
+                        $param['type']     = 'multiple_select';
182
+                        $param['multiple'] = true;
183
+                    }
184
+
185
+                    // heading
186
+                    $param['heading'] = $val['title'];
187
+
188
+                    // description
189
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
190
+
191
+                    // param_name
192
+                    $param['param_name'] = $key;
193
+
194
+                    // Default
195
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
196
+
197
+                    // Group
198
+                    if ( isset( $val['group'] ) ) {
199
+                        $param['group'] = $val['group'];
200
+                    }
201
+
202
+                    // value
203
+                    if ( $val['type'] == 'checkbox' ) {
204
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
205
+                            unset( $param['default'] );
206
+                        }
207
+                        $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
208
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
209
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
210
+                    } else {
211
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
212
+                    }
213
+
214
+                    // setup the param
215
+                    $params[] = $param;
216
+
217
+                }
218
+            }
219
+
220
+
221
+            return $params;
222
+        }
223
+
224
+        /**
225
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
226
+         */
227
+        public static function maybe_cornerstone_builder() {
228
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
229
+                self::shortcode_insert_button_script();
230
+            }
231
+        }
232
+
233
+        /**
234
+         * A function to ge the shortcode builder picker html.
235
+         *
236
+         * @param string $editor_id
237
+         *
238
+         * @return string
239
+         */
240
+        public static function get_picker( $editor_id = '' ) {
241
+
242
+            ob_start();
243
+            if ( isset( $_POST['editor_id'] ) ) {
244
+                $editor_id = sanitize_text_field( $_POST['editor_id'] );
245
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
246
+                $editor_id = 'main_content_content_vb_tiny_mce';
247
+            }
248
+
249
+            global $sd_widgets;
250
+            ?>
251 251
 
252 252
 			<div class="sd-shortcode-left-wrap">
253 253
 				<?php
254
-				ksort( $sd_widgets );
255
-				//				print_r($sd_widgets);exit;
256
-				if ( ! empty( $sd_widgets ) ) {
257
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
258
-					echo "<option>" . __( 'Select shortcode' ) . "</option>";
259
-					foreach ( $sd_widgets as $shortcode => $class ) {
260
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
261
-					}
262
-					echo "</select>";
263
-
264
-				}
265
-				?>
254
+                ksort( $sd_widgets );
255
+                //				print_r($sd_widgets);exit;
256
+                if ( ! empty( $sd_widgets ) ) {
257
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
258
+                    echo "<option>" . __( 'Select shortcode' ) . "</option>";
259
+                    foreach ( $sd_widgets as $shortcode => $class ) {
260
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
261
+                    }
262
+                    echo "</select>";
263
+
264
+                }
265
+                ?>
266 266
 				<div class="sd-shortcode-settings"></div>
267 267
 
268 268
 			</div>
@@ -273,8 +273,8 @@  discard block
 block discarded – undo
273 273
 					<?php if ( $editor_id != '' ) { ?>
274 274
 						<button class="button sd-insert-shortcode-button"
275 275
 						        onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
276
-							        echo "'" . $editor_id . "'";
277
-						        } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
276
+                                    echo "'" . $editor_id . "'";
277
+                                } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
278 278
 					<?php } ?>
279 279
 					<button class="button"
280 280
 					        onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -282,134 +282,134 @@  discard block
 block discarded – undo
282 282
 			</div>
283 283
 			<?php
284 284
 
285
-			$html = ob_get_clean();
286
-
287
-			if ( wp_doing_ajax() ) {
288
-				echo $html;
289
-				$should_die = true;
290
-
291
-				// some builder get the editor via ajax so we should not die on those occasions
292
-				$dont_die = array(
293
-					'parent_tag',// WP Bakery
294
-					'avia_request' // enfold
295
-				);
296
-
297
-				foreach ( $dont_die as $request ) {
298
-					if ( isset( $_REQUEST[ $request ] ) ) {
299
-						$should_die = false;
300
-					}
301
-				}
302
-
303
-				if ( $should_die ) {
304
-					wp_die();
305
-				}
306
-
307
-			} else {
308
-				return $html;
309
-			}
310
-
311
-			return '';
312
-
313
-		}
314
-
315
-		/**
316
-		 * Output the version in the admin header.
317
-		 */
318
-		public function generator() {
319
-			echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
320
-		}
321
-
322
-		/**
323
-		 * Get widget settings.
324
-		 *
325
-		 * @since 1.0.0
326
-		 */
327
-		public static function get_widget_settings() {
328
-			global $sd_widgets;
329
-
330
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
331
-			if ( ! $shortcode ) {
332
-				wp_die();
333
-			}
334
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
335
-			if ( ! $widget_args ) {
336
-				wp_die();
337
-			}
338
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
339
-			if ( ! $class_name ) {
340
-				wp_die();
341
-			}
342
-
343
-			// invoke an instance method
344
-			$widget = new $class_name;
345
-
346
-			ob_start();
347
-			$widget->form( array() );
348
-			$form = ob_get_clean();
349
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
350
-			echo "<style>" . $widget->widget_css() . "</style>";
351
-			echo "<script>" . $widget->widget_js() . "</script>";
352
-			?>
285
+            $html = ob_get_clean();
286
+
287
+            if ( wp_doing_ajax() ) {
288
+                echo $html;
289
+                $should_die = true;
290
+
291
+                // some builder get the editor via ajax so we should not die on those occasions
292
+                $dont_die = array(
293
+                    'parent_tag',// WP Bakery
294
+                    'avia_request' // enfold
295
+                );
296
+
297
+                foreach ( $dont_die as $request ) {
298
+                    if ( isset( $_REQUEST[ $request ] ) ) {
299
+                        $should_die = false;
300
+                    }
301
+                }
302
+
303
+                if ( $should_die ) {
304
+                    wp_die();
305
+                }
306
+
307
+            } else {
308
+                return $html;
309
+            }
310
+
311
+            return '';
312
+
313
+        }
314
+
315
+        /**
316
+         * Output the version in the admin header.
317
+         */
318
+        public function generator() {
319
+            echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
320
+        }
321
+
322
+        /**
323
+         * Get widget settings.
324
+         *
325
+         * @since 1.0.0
326
+         */
327
+        public static function get_widget_settings() {
328
+            global $sd_widgets;
329
+
330
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
331
+            if ( ! $shortcode ) {
332
+                wp_die();
333
+            }
334
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
335
+            if ( ! $widget_args ) {
336
+                wp_die();
337
+            }
338
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
339
+            if ( ! $class_name ) {
340
+                wp_die();
341
+            }
342
+
343
+            // invoke an instance method
344
+            $widget = new $class_name;
345
+
346
+            ob_start();
347
+            $widget->form( array() );
348
+            $form = ob_get_clean();
349
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
350
+            echo "<style>" . $widget->widget_css() . "</style>";
351
+            echo "<script>" . $widget->widget_js() . "</script>";
352
+            ?>
353 353
 			<?php
354
-			wp_die();
355
-		}
356
-
357
-		/**
358
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
359
-		 *
360
-		 * @since 1.0.0
361
-		 *
362
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
363
-		 * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
364
-		 */
365
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
366
-			global $sd_widgets, $shortcode_insert_button_once;
367
-			if ( $shortcode_insert_button_once ) {
368
-				return;
369
-			}
370
-			add_thickbox();
371
-
372
-
373
-			/**
374
-			 * Cornerstone makes us play dirty tricks :/
375
-			 * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
376
-			 */
377
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
378
-				echo '<span id="insert-media-button">';
379
-			}
380
-
381
-			echo self::shortcode_button( 'this', 'true' );
382
-
383
-			// see opening note
384
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
385
-				echo '</span>'; // end #insert-media-button
386
-			}
387
-
388
-			// Add separate script for generatepress theme sections
389
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
390
-			} else {
391
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
392
-			}
393
-
394
-			$shortcode_insert_button_once = true;
395
-		}
396
-
397
-		/**
398
-		 * Gets the shortcode insert button html.
399
-		 *
400
-		 * @param string $id
401
-		 * @param string $search_for_id
402
-		 *
403
-		 * @return mixed
404
-		 */
405
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
406
-			ob_start();
407
-			?>
354
+            wp_die();
355
+        }
356
+
357
+        /**
358
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
359
+         *
360
+         * @since 1.0.0
361
+         *
362
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
363
+         * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
364
+         */
365
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
366
+            global $sd_widgets, $shortcode_insert_button_once;
367
+            if ( $shortcode_insert_button_once ) {
368
+                return;
369
+            }
370
+            add_thickbox();
371
+
372
+
373
+            /**
374
+             * Cornerstone makes us play dirty tricks :/
375
+             * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed.
376
+             */
377
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
378
+                echo '<span id="insert-media-button">';
379
+            }
380
+
381
+            echo self::shortcode_button( 'this', 'true' );
382
+
383
+            // see opening note
384
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
385
+                echo '</span>'; // end #insert-media-button
386
+            }
387
+
388
+            // Add separate script for generatepress theme sections
389
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
390
+            } else {
391
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
392
+            }
393
+
394
+            $shortcode_insert_button_once = true;
395
+        }
396
+
397
+        /**
398
+         * Gets the shortcode insert button html.
399
+         *
400
+         * @param string $id
401
+         * @param string $search_for_id
402
+         *
403
+         * @return mixed
404
+         */
405
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
406
+            ob_start();
407
+            ?>
408 408
 			<span class="sd-lable-shortcode-inserter">
409 409
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
410
-				if ( $search_for_id ) {
411
-					echo "," . $search_for_id;
412
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
410
+                if ( $search_for_id ) {
411
+                    echo "," . $search_for_id;
412
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
413 413
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
414 414
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
415 415
 					      class="dashicons dashicons-screenoptions"></span>
@@ -420,21 +420,21 @@  discard block
 block discarded – undo
420 420
 			</span>
421 421
 
422 422
 			<?php
423
-			$html = ob_get_clean();
424
-
425
-			// remove line breaks so we can use it in js
426
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
427
-		}
428
-
429
-		/**
430
-		 * Makes SD work with the siteOrigin page builder.
431
-		 *
432
-		 * @since 1.0.6
433
-		 * @return mixed
434
-		 */
435
-		public static function siteorigin_js() {
436
-			ob_start();
437
-			?>
423
+            $html = ob_get_clean();
424
+
425
+            // remove line breaks so we can use it in js
426
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
427
+        }
428
+
429
+        /**
430
+         * Makes SD work with the siteOrigin page builder.
431
+         *
432
+         * @since 1.0.6
433
+         * @return mixed
434
+         */
435
+        public static function siteorigin_js() {
436
+            ob_start();
437
+            ?>
438 438
 			<script>
439 439
 				/**
440 440
 				 * Check a form to see what items should be shown or hidden.
@@ -512,28 +512,28 @@  discard block
 block discarded – undo
512 512
 				});
513 513
 			</script>
514 514
 			<?php
515
-			$output = ob_get_clean();
515
+            $output = ob_get_clean();
516 516
 
517
-			/*
517
+            /*
518 518
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
519 519
 			 */
520 520
 
521
-			return str_replace( array(
522
-				'<script>',
523
-				'</script>'
524
-			), '', $output );
525
-		}
526
-
527
-		/**
528
-		 * Output the JS and CSS for the shortcode insert button.
529
-		 *
530
-		 * @since 1.0.6
531
-		 *
532
-		 * @param string $editor_id
533
-		 * @param string $insert_shortcode_function
534
-		 */
535
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
536
-			?>
521
+            return str_replace( array(
522
+                '<script>',
523
+                '</script>'
524
+            ), '', $output );
525
+        }
526
+
527
+        /**
528
+         * Output the JS and CSS for the shortcode insert button.
529
+         *
530
+         * @since 1.0.6
531
+         *
532
+         * @param string $editor_id
533
+         * @param string $insert_shortcode_function
534
+         */
535
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
536
+            ?>
537 537
 			<style>
538 538
 				.sd-shortcode-left-wrap {
539 539
 					float: left;
@@ -661,35 +661,35 @@  discard block
 block discarded – undo
661 661
 				<?php } ?>
662 662
 			</style>
663 663
 			<?php
664
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
665
-				echo "<script>" . self::siteorigin_js() . "</script>";
666
-			}
667
-			?>
664
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
665
+                echo "<script>" . self::siteorigin_js() . "</script>";
666
+            }
667
+            ?>
668 668
 			<script>
669 669
 				<?php
670
-				if(! empty( $insert_shortcode_function )){
671
-					echo $insert_shortcode_function;
672
-				}else{
673
-
674
-				/**
675
-				 * Function for super duper insert shortcode.
676
-				 *
677
-				 * @since 1.0.0
678
-				 */
679
-				?>
670
+                if(! empty( $insert_shortcode_function )){
671
+                    echo $insert_shortcode_function;
672
+                }else{
673
+
674
+                /**
675
+                 * Function for super duper insert shortcode.
676
+                 *
677
+                 * @since 1.0.0
678
+                 */
679
+                ?>
680 680
 				function sd_insert_shortcode($editor_id) {
681 681
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
682 682
 					if ($shortcode) {
683 683
 						if (!$editor_id) {
684 684
 							<?php
685
-							if ( isset( $_REQUEST['et_fb'] ) ) {
686
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
687
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
688
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
689
-							} else {
690
-								echo '$editor_id = "#wp-content-editor-container textarea";';
691
-							}
692
-							?>
685
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
686
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
687
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
688
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
689
+                            } else {
690
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
691
+                            }
692
+                            ?>
693 693
 						} else {
694 694
 							$editor_id = '#' + $editor_id;
695 695
 						}
@@ -1016,18 +1016,18 @@  discard block
 block discarded – undo
1016 1016
 
1017 1017
 			</script>
1018 1018
 			<?php
1019
-		}
1020
-
1021
-		/**
1022
-		 * Gets some CSS for the widgets screen.
1023
-		 *
1024
-		 * @param bool $advanced If we should include advanced CSS.
1025
-		 *
1026
-		 * @return mixed
1027
-		 */
1028
-		public function widget_css( $advanced = true ) {
1029
-			ob_start();
1030
-			?>
1019
+        }
1020
+
1021
+        /**
1022
+         * Gets some CSS for the widgets screen.
1023
+         *
1024
+         * @param bool $advanced If we should include advanced CSS.
1025
+         *
1026
+         * @return mixed
1027
+         */
1028
+        public function widget_css( $advanced = true ) {
1029
+            ob_start();
1030
+            ?>
1031 1031
 			<style>
1032 1032
 				<?php if( $advanced ){ ?>
1033 1033
 				.sd-advanced-setting {
@@ -1065,26 +1065,26 @@  discard block
 block discarded – undo
1065 1065
 				}
1066 1066
 			</style>
1067 1067
 			<?php
1068
-			$output = ob_get_clean();
1068
+            $output = ob_get_clean();
1069 1069
 
1070
-			/*
1070
+            /*
1071 1071
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1072 1072
 			 */
1073 1073
 
1074
-			return str_replace( array(
1075
-				'<style>',
1076
-				'</style>'
1077
-			), '', $output );
1078
-		}
1079
-
1080
-		/**
1081
-		 * Gets some JS for the widgets screen.
1082
-		 *
1083
-		 * @return mixed
1084
-		 */
1085
-		public function widget_js() {
1086
-			ob_start();
1087
-			?>
1074
+            return str_replace( array(
1075
+                '<style>',
1076
+                '</style>'
1077
+            ), '', $output );
1078
+        }
1079
+
1080
+        /**
1081
+         * Gets some JS for the widgets screen.
1082
+         *
1083
+         * @return mixed
1084
+         */
1085
+        public function widget_js() {
1086
+            ob_start();
1087
+            ?>
1088 1088
 			<script>
1089 1089
 
1090 1090
 				/**
@@ -1242,435 +1242,435 @@  discard block
 block discarded – undo
1242 1242
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1243 1243
 			</script>
1244 1244
 			<?php
1245
-			$output = ob_get_clean();
1245
+            $output = ob_get_clean();
1246 1246
 
1247
-			/*
1247
+            /*
1248 1248
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1249 1249
 			 */
1250 1250
 
1251
-			return str_replace( array(
1252
-				'<script>',
1253
-				'</script>'
1254
-			), '', $output );
1255
-		}
1256
-
1257
-
1258
-		/**
1259
-		 * Set the name from the argument key.
1260
-		 *
1261
-		 * @param $options
1262
-		 *
1263
-		 * @return mixed
1264
-		 */
1265
-		private function add_name_from_key( $options, $arguments = false ) {
1266
-			if ( ! empty( $options['arguments'] ) ) {
1267
-				foreach ( $options['arguments'] as $key => $val ) {
1268
-					$options['arguments'][ $key ]['name'] = $key;
1269
-				}
1270
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1271
-				foreach ( $options as $key => $val ) {
1272
-					$options[ $key ]['name'] = $key;
1273
-				}
1274
-			}
1275
-
1276
-			return $options;
1277
-		}
1278
-
1279
-		/**
1280
-		 * Register the parent shortcode.
1281
-		 *
1282
-		 * @since 1.0.0
1283
-		 */
1284
-		public function register_shortcode() {
1285
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1286
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1287
-		}
1288
-
1289
-		/**
1290
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1291
-		 *
1292
-		 * @since 1.0.0
1293
-		 */
1294
-		public function render_shortcode() {
1295
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1296
-			if ( ! current_user_can( 'manage_options' ) ) {
1297
-				wp_die();
1298
-			}
1299
-
1300
-			// we might need the $post value here so lets set it.
1301
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1302
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1303
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1304
-					global $post;
1305
-					$post = $post_obj;
1306
-				}
1307
-			}
1308
-
1309
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1310
-				$is_preview = $this->is_preview();
1311
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1312
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1313
-				$attributes       = '';
1314
-				if ( ! empty( $attributes_array ) ) {
1315
-					foreach ( $attributes_array as $key => $value ) {
1316
-						if ( is_array( $value ) ) {
1317
-							$value = implode( ",", $value );
1318
-						}
1319
-
1320
-						if ( ! empty( $value ) ) {
1321
-							$value = wp_unslash( $value );
1322
-
1323
-							// Encode [ and ].
1324
-							if ( $is_preview ) {
1325
-								$value = $this->encode_shortcodes( $value );
1326
-							}
1327
-						}
1328
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1329
-					}
1330
-				}
1331
-
1332
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1333
-
1334
-				$content = do_shortcode( $shortcode );
1335
-
1336
-				// Decode [ and ].
1337
-				if ( ! empty( $content ) && $is_preview ) {
1338
-					$content = $this->decode_shortcodes( $content );
1339
-				}
1340
-
1341
-				echo $content;
1342
-			}
1343
-			wp_die();
1344
-		}
1345
-
1346
-		/**
1347
-		 * Output the shortcode.
1348
-		 *
1349
-		 * @param array $args
1350
-		 * @param string $content
1351
-		 *
1352
-		 * @return string
1353
-		 */
1354
-		public function shortcode_output( $args = array(), $content = '' ) {
1355
-			$_instance = $args;
1356
-
1357
-			$args = $this->argument_values( $args );
1358
-
1359
-			// add extra argument so we know its a output to gutenberg
1360
-			//$args
1361
-			$args = $this->string_to_bool( $args );
1362
-
1363
-			// if we have a enclosed shortcode we add it to the special `html` argument
1364
-			if ( ! empty( $content ) ) {
1365
-				$args['html'] = $content;
1366
-			}
1367
-
1368
-			if ( ! $this->is_preview() ) {
1369
-				/**
1370
-				 * Filters the settings for a particular widget args.
1371
-				 *
1372
-				 * @since 1.0.28
1373
-				 *
1374
-				 * @param array          $args      The current widget instance's settings.
1375
-				 * @param WP_Super_Duper $widget    The current widget settings.
1376
-				 * @param array          $_instance An array of default widget arguments.
1377
-				 */
1378
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1379
-
1380
-				if ( ! is_array( $args ) ) {
1381
-					return $args;
1382
-				}
1383
-			}
1384
-
1385
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1386
-			$class .= " sdel-".$this->get_instance_hash();
1387
-
1388
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1389
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1390
-
1391
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1392
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1393
-
1394
-			$shortcode_args = array();
1395
-			$output         = '';
1396
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1397
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1398
-				$no_wrap = true;
1399
-			}
1400
-			$main_content = $this->output( $args, $shortcode_args, $content );
1401
-			if ( $main_content && ! $no_wrap ) {
1402
-				// wrap the shortcode in a div with the same class as the widget
1403
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1404
-				if ( ! empty( $args['title'] ) ) {
1405
-					// if its a shortcode and there is a title try to grab the title wrappers
1406
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1407
-					if ( empty( $instance ) ) {
1408
-						global $wp_registered_sidebars;
1409
-						if ( ! empty( $wp_registered_sidebars ) ) {
1410
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1411
-								if ( ! empty( $sidebar['before_title'] ) ) {
1412
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1413
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1414
-									break;
1415
-								}
1416
-							}
1417
-						}
1418
-					}
1419
-					$output .= $this->output_title( $shortcode_args, $args );
1420
-				}
1421
-				$output .= $main_content;
1422
-				$output .= '</div>';
1423
-			} elseif ( $main_content && $no_wrap ) {
1424
-				$output .= $main_content;
1425
-			}
1426
-
1427
-			// if preview show a placeholder if empty
1428
-			if ( $this->is_preview() && $output == '' ) {
1429
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1430
-			}
1431
-
1432
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1433
-		}
1434
-
1435
-		/**
1436
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1437
-		 *
1438
-		 * @param string $name
1439
-		 *
1440
-		 * @return string
1441
-		 */
1442
-		public function preview_placeholder_text( $name = '' ) {
1443
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1444
-		}
1445
-
1446
-		/**
1447
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1448
-		 *
1449
-		 * @param $options
1450
-		 *
1451
-		 * @return mixed
1452
-		 */
1453
-		public function string_to_bool( $options ) {
1454
-			// convert bool strings to booleans
1455
-			foreach ( $options as $key => $val ) {
1456
-				if ( $val == 'false' ) {
1457
-					$options[ $key ] = false;
1458
-				} elseif ( $val == 'true' ) {
1459
-					$options[ $key ] = true;
1460
-				}
1461
-			}
1462
-
1463
-			return $options;
1464
-		}
1465
-
1466
-		/**
1467
-		 * Get the argument values that are also filterable.
1468
-		 *
1469
-		 * @param $instance
1470
-		 *
1471
-		 * @since 1.0.12 Don't set checkbox default value if the value is empty.
1472
-		 *
1473
-		 * @return array
1474
-		 */
1475
-		public function argument_values( $instance ) {
1476
-			$argument_values = array();
1477
-
1478
-			// set widget instance
1479
-			$this->instance = $instance;
1480
-
1481
-			if ( empty( $this->arguments ) ) {
1482
-				$this->arguments = $this->get_arguments();
1483
-			}
1484
-
1485
-			if ( ! empty( $this->arguments ) ) {
1486
-				foreach ( $this->arguments as $key => $args ) {
1487
-					// set the input name from the key
1488
-					$args['name'] = $key;
1489
-					//
1490
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1491
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1492
-						// don't set default for an empty checkbox
1493
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1494
-						$argument_values[ $key ] = $args['default'];
1495
-					}
1496
-				}
1497
-			}
1498
-
1499
-			return $argument_values;
1500
-		}
1501
-
1502
-		/**
1503
-		 * Set arguments in super duper.
1504
-		 *
1505
-		 * @since 1.0.0
1506
-		 *
1507
-		 * @return array Set arguments.
1508
-		 */
1509
-		public function set_arguments() {
1510
-			return $this->arguments;
1511
-		}
1512
-
1513
-		/**
1514
-		 * Get arguments in super duper.
1515
-		 *
1516
-		 * @since 1.0.0
1517
-		 *
1518
-		 * @return array Get arguments.
1519
-		 */
1520
-		public function get_arguments() {
1521
-			if ( empty( $this->arguments ) ) {
1522
-				$this->arguments = $this->set_arguments();
1523
-			}
1524
-
1525
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1526
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1527
-
1528
-			return $this->arguments;
1529
-		}
1530
-
1531
-		/**
1532
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1533
-		 *
1534
-		 * @param array $args
1535
-		 * @param array $widget_args
1536
-		 * @param string $content
1537
-		 */
1538
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1539
-
1540
-		}
1541
-
1542
-		/**
1543
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1544
-		 */
1545
-		public function register_block() {
1546
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1547
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1548
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1549
-			}
1550
-		}
1551
-
1552
-		/**
1553
-		 * Check if we need to show advanced options.
1554
-		 *
1555
-		 * @return bool
1556
-		 */
1557
-		public function block_show_advanced() {
1558
-
1559
-			$show      = false;
1560
-			$arguments = $this->get_arguments();
1251
+            return str_replace( array(
1252
+                '<script>',
1253
+                '</script>'
1254
+            ), '', $output );
1255
+        }
1256
+
1257
+
1258
+        /**
1259
+         * Set the name from the argument key.
1260
+         *
1261
+         * @param $options
1262
+         *
1263
+         * @return mixed
1264
+         */
1265
+        private function add_name_from_key( $options, $arguments = false ) {
1266
+            if ( ! empty( $options['arguments'] ) ) {
1267
+                foreach ( $options['arguments'] as $key => $val ) {
1268
+                    $options['arguments'][ $key ]['name'] = $key;
1269
+                }
1270
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1271
+                foreach ( $options as $key => $val ) {
1272
+                    $options[ $key ]['name'] = $key;
1273
+                }
1274
+            }
1275
+
1276
+            return $options;
1277
+        }
1278
+
1279
+        /**
1280
+         * Register the parent shortcode.
1281
+         *
1282
+         * @since 1.0.0
1283
+         */
1284
+        public function register_shortcode() {
1285
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1286
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1287
+        }
1288
+
1289
+        /**
1290
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1291
+         *
1292
+         * @since 1.0.0
1293
+         */
1294
+        public function render_shortcode() {
1295
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1296
+            if ( ! current_user_can( 'manage_options' ) ) {
1297
+                wp_die();
1298
+            }
1299
+
1300
+            // we might need the $post value here so lets set it.
1301
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1302
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1303
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1304
+                    global $post;
1305
+                    $post = $post_obj;
1306
+                }
1307
+            }
1308
+
1309
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1310
+                $is_preview = $this->is_preview();
1311
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1312
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1313
+                $attributes       = '';
1314
+                if ( ! empty( $attributes_array ) ) {
1315
+                    foreach ( $attributes_array as $key => $value ) {
1316
+                        if ( is_array( $value ) ) {
1317
+                            $value = implode( ",", $value );
1318
+                        }
1319
+
1320
+                        if ( ! empty( $value ) ) {
1321
+                            $value = wp_unslash( $value );
1322
+
1323
+                            // Encode [ and ].
1324
+                            if ( $is_preview ) {
1325
+                                $value = $this->encode_shortcodes( $value );
1326
+                            }
1327
+                        }
1328
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1329
+                    }
1330
+                }
1331
+
1332
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1333
+
1334
+                $content = do_shortcode( $shortcode );
1335
+
1336
+                // Decode [ and ].
1337
+                if ( ! empty( $content ) && $is_preview ) {
1338
+                    $content = $this->decode_shortcodes( $content );
1339
+                }
1340
+
1341
+                echo $content;
1342
+            }
1343
+            wp_die();
1344
+        }
1345
+
1346
+        /**
1347
+         * Output the shortcode.
1348
+         *
1349
+         * @param array $args
1350
+         * @param string $content
1351
+         *
1352
+         * @return string
1353
+         */
1354
+        public function shortcode_output( $args = array(), $content = '' ) {
1355
+            $_instance = $args;
1356
+
1357
+            $args = $this->argument_values( $args );
1358
+
1359
+            // add extra argument so we know its a output to gutenberg
1360
+            //$args
1361
+            $args = $this->string_to_bool( $args );
1362
+
1363
+            // if we have a enclosed shortcode we add it to the special `html` argument
1364
+            if ( ! empty( $content ) ) {
1365
+                $args['html'] = $content;
1366
+            }
1367
+
1368
+            if ( ! $this->is_preview() ) {
1369
+                /**
1370
+                 * Filters the settings for a particular widget args.
1371
+                 *
1372
+                 * @since 1.0.28
1373
+                 *
1374
+                 * @param array          $args      The current widget instance's settings.
1375
+                 * @param WP_Super_Duper $widget    The current widget settings.
1376
+                 * @param array          $_instance An array of default widget arguments.
1377
+                 */
1378
+                $args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1379
+
1380
+                if ( ! is_array( $args ) ) {
1381
+                    return $args;
1382
+                }
1383
+            }
1384
+
1385
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1386
+            $class .= " sdel-".$this->get_instance_hash();
1387
+
1388
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1389
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1390
+
1391
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1392
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1393
+
1394
+            $shortcode_args = array();
1395
+            $output         = '';
1396
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1397
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1398
+                $no_wrap = true;
1399
+            }
1400
+            $main_content = $this->output( $args, $shortcode_args, $content );
1401
+            if ( $main_content && ! $no_wrap ) {
1402
+                // wrap the shortcode in a div with the same class as the widget
1403
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1404
+                if ( ! empty( $args['title'] ) ) {
1405
+                    // if its a shortcode and there is a title try to grab the title wrappers
1406
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1407
+                    if ( empty( $instance ) ) {
1408
+                        global $wp_registered_sidebars;
1409
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1410
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1411
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1412
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1413
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1414
+                                    break;
1415
+                                }
1416
+                            }
1417
+                        }
1418
+                    }
1419
+                    $output .= $this->output_title( $shortcode_args, $args );
1420
+                }
1421
+                $output .= $main_content;
1422
+                $output .= '</div>';
1423
+            } elseif ( $main_content && $no_wrap ) {
1424
+                $output .= $main_content;
1425
+            }
1426
+
1427
+            // if preview show a placeholder if empty
1428
+            if ( $this->is_preview() && $output == '' ) {
1429
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1430
+            }
1431
+
1432
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1433
+        }
1434
+
1435
+        /**
1436
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1437
+         *
1438
+         * @param string $name
1439
+         *
1440
+         * @return string
1441
+         */
1442
+        public function preview_placeholder_text( $name = '' ) {
1443
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1444
+        }
1445
+
1446
+        /**
1447
+         * Sometimes booleans values can be turned to strings, so we fix that.
1448
+         *
1449
+         * @param $options
1450
+         *
1451
+         * @return mixed
1452
+         */
1453
+        public function string_to_bool( $options ) {
1454
+            // convert bool strings to booleans
1455
+            foreach ( $options as $key => $val ) {
1456
+                if ( $val == 'false' ) {
1457
+                    $options[ $key ] = false;
1458
+                } elseif ( $val == 'true' ) {
1459
+                    $options[ $key ] = true;
1460
+                }
1461
+            }
1462
+
1463
+            return $options;
1464
+        }
1465
+
1466
+        /**
1467
+         * Get the argument values that are also filterable.
1468
+         *
1469
+         * @param $instance
1470
+         *
1471
+         * @since 1.0.12 Don't set checkbox default value if the value is empty.
1472
+         *
1473
+         * @return array
1474
+         */
1475
+        public function argument_values( $instance ) {
1476
+            $argument_values = array();
1477
+
1478
+            // set widget instance
1479
+            $this->instance = $instance;
1480
+
1481
+            if ( empty( $this->arguments ) ) {
1482
+                $this->arguments = $this->get_arguments();
1483
+            }
1484
+
1485
+            if ( ! empty( $this->arguments ) ) {
1486
+                foreach ( $this->arguments as $key => $args ) {
1487
+                    // set the input name from the key
1488
+                    $args['name'] = $key;
1489
+                    //
1490
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1491
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1492
+                        // don't set default for an empty checkbox
1493
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1494
+                        $argument_values[ $key ] = $args['default'];
1495
+                    }
1496
+                }
1497
+            }
1498
+
1499
+            return $argument_values;
1500
+        }
1501
+
1502
+        /**
1503
+         * Set arguments in super duper.
1504
+         *
1505
+         * @since 1.0.0
1506
+         *
1507
+         * @return array Set arguments.
1508
+         */
1509
+        public function set_arguments() {
1510
+            return $this->arguments;
1511
+        }
1512
+
1513
+        /**
1514
+         * Get arguments in super duper.
1515
+         *
1516
+         * @since 1.0.0
1517
+         *
1518
+         * @return array Get arguments.
1519
+         */
1520
+        public function get_arguments() {
1521
+            if ( empty( $this->arguments ) ) {
1522
+                $this->arguments = $this->set_arguments();
1523
+            }
1524
+
1525
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1526
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1527
+
1528
+            return $this->arguments;
1529
+        }
1530
+
1531
+        /**
1532
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1533
+         *
1534
+         * @param array $args
1535
+         * @param array $widget_args
1536
+         * @param string $content
1537
+         */
1538
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1539
+
1540
+        }
1541
+
1542
+        /**
1543
+         * Add the dynamic block code inline when the wp-block in enqueued.
1544
+         */
1545
+        public function register_block() {
1546
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1547
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1548
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1549
+            }
1550
+        }
1551
+
1552
+        /**
1553
+         * Check if we need to show advanced options.
1554
+         *
1555
+         * @return bool
1556
+         */
1557
+        public function block_show_advanced() {
1558
+
1559
+            $show      = false;
1560
+            $arguments = $this->get_arguments();
1561 1561
 			
1562
-			if ( ! empty( $arguments ) ) {
1563
-				foreach ( $arguments as $argument ) {
1564
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1565
-						$show = true;
1566
-						break; // no need to continue if we know we have it
1567
-					}
1568
-				}
1569
-			}
1570
-
1571
-			return $show;
1572
-		}
1573
-
1574
-		/**
1575
-		 * Get the url path to the current folder.
1576
-		 *
1577
-		 * @return string
1578
-		 */
1579
-		public function get_url() {
1580
-
1581
-			$url = $this->url;
1582
-
1583
-			if ( ! $url ) {
1584
-				// check if we are inside a plugin
1585
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1586
-
1587
-				$dir_parts = explode( "/wp-content/", $file_dir );
1588
-				$url_parts = explode( "/wp-content/", plugins_url() );
1589
-
1590
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1591
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1592
-					$this->url = $url;
1593
-				}
1594
-			}
1595
-
1596
-
1597
-			return $url;
1598
-		}
1599
-
1600
-		/**
1601
-		 * Generate the block icon.
1602
-		 *
1603
-		 * Enables the use of Font Awesome icons.
1604
-		 *
1605
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1606
-		 *
1607
-		 * @param $icon
1608
-		 *
1609
-		 * @since 1.1.0
1610
-		 * @return string
1611
-		 */
1612
-		public function get_block_icon( $icon ) {
1613
-
1614
-			// check if we have a Font Awesome icon
1615
-			$fa_type = '';
1616
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1617
-				$fa_type = 'solid';
1618
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1619
-				$fa_type = 'regular';
1620
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1621
-				$fa_type = 'brands';
1622
-			} else {
1623
-				$icon = "'" . $icon . "'";
1624
-			}
1625
-
1626
-			// set the icon if we found one
1627
-			if ( $fa_type ) {
1628
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1629
-				$icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1630
-			}
1631
-
1632
-			return $icon;
1633
-		}
1634
-
1635
-		public function group_arguments( $arguments ) {
1562
+            if ( ! empty( $arguments ) ) {
1563
+                foreach ( $arguments as $argument ) {
1564
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1565
+                        $show = true;
1566
+                        break; // no need to continue if we know we have it
1567
+                    }
1568
+                }
1569
+            }
1570
+
1571
+            return $show;
1572
+        }
1573
+
1574
+        /**
1575
+         * Get the url path to the current folder.
1576
+         *
1577
+         * @return string
1578
+         */
1579
+        public function get_url() {
1580
+
1581
+            $url = $this->url;
1582
+
1583
+            if ( ! $url ) {
1584
+                // check if we are inside a plugin
1585
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1586
+
1587
+                $dir_parts = explode( "/wp-content/", $file_dir );
1588
+                $url_parts = explode( "/wp-content/", plugins_url() );
1589
+
1590
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1591
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1592
+                    $this->url = $url;
1593
+                }
1594
+            }
1595
+
1596
+
1597
+            return $url;
1598
+        }
1599
+
1600
+        /**
1601
+         * Generate the block icon.
1602
+         *
1603
+         * Enables the use of Font Awesome icons.
1604
+         *
1605
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1606
+         *
1607
+         * @param $icon
1608
+         *
1609
+         * @since 1.1.0
1610
+         * @return string
1611
+         */
1612
+        public function get_block_icon( $icon ) {
1613
+
1614
+            // check if we have a Font Awesome icon
1615
+            $fa_type = '';
1616
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1617
+                $fa_type = 'solid';
1618
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1619
+                $fa_type = 'regular';
1620
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1621
+                $fa_type = 'brands';
1622
+            } else {
1623
+                $icon = "'" . $icon . "'";
1624
+            }
1625
+
1626
+            // set the icon if we found one
1627
+            if ( $fa_type ) {
1628
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1629
+                $icon    = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))";
1630
+            }
1631
+
1632
+            return $icon;
1633
+        }
1634
+
1635
+        public function group_arguments( $arguments ) {
1636 1636
 //			echo '###';print_r($arguments);
1637
-			if ( ! empty( $arguments ) ) {
1638
-				$temp_arguments = array();
1639
-				$general        = __( "General" );
1640
-				$add_sections   = false;
1641
-				foreach ( $arguments as $key => $args ) {
1642
-					if ( isset( $args['group'] ) ) {
1643
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1644
-						$add_sections                             = true;
1645
-					} else {
1646
-						$temp_arguments[ $general ][ $key ] = $args;
1647
-					}
1648
-				}
1649
-
1650
-				// only add sections if more than one
1651
-				if ( $add_sections ) {
1652
-					$arguments = $temp_arguments;
1653
-				}
1654
-			}
1637
+            if ( ! empty( $arguments ) ) {
1638
+                $temp_arguments = array();
1639
+                $general        = __( "General" );
1640
+                $add_sections   = false;
1641
+                foreach ( $arguments as $key => $args ) {
1642
+                    if ( isset( $args['group'] ) ) {
1643
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1644
+                        $add_sections                             = true;
1645
+                    } else {
1646
+                        $temp_arguments[ $general ][ $key ] = $args;
1647
+                    }
1648
+                }
1649
+
1650
+                // only add sections if more than one
1651
+                if ( $add_sections ) {
1652
+                    $arguments = $temp_arguments;
1653
+                }
1654
+            }
1655 1655
 
1656 1656
 //			echo '###';print_r($arguments);
1657
-			return $arguments;
1658
-		}
1659
-
1660
-
1661
-		/**
1662
-		 * Output the JS for building the dynamic Guntenberg block.
1663
-		 *
1664
-		 * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap.
1665
-		 * @since 1.0.9 Save numbers as numbers and not strings.
1666
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1667
-		 * @return mixed
1668
-		 */
1669
-		public function block() {
1670
-			ob_start();
1671
-
1672
-			$show_advanced = $this->block_show_advanced();
1673
-			?>
1657
+            return $arguments;
1658
+        }
1659
+
1660
+
1661
+        /**
1662
+         * Output the JS for building the dynamic Guntenberg block.
1663
+         *
1664
+         * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap.
1665
+         * @since 1.0.9 Save numbers as numbers and not strings.
1666
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1667
+         * @return mixed
1668
+         */
1669
+        public function block() {
1670
+            ob_start();
1671
+
1672
+            $show_advanced = $this->block_show_advanced();
1673
+            ?>
1674 1674
 			<script>
1675 1675
 				/**
1676 1676
 				 * BLOCK: Basic
@@ -1714,97 +1714,97 @@  discard block
 block discarded – undo
1714 1714
 						icon: <?php echo $this->get_block_icon( $this->options['block-icon'] );?>,//'<?php echo isset( $this->options['block-icon'] ) ? esc_attr( $this->options['block-icon'] ) : 'shield-alt';?>', // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/.
1715 1715
 						supports: {
1716 1716
 							<?php
1717
-							if ( isset( $this->options['block-supports'] ) ) {
1718
-								echo $this->array_to_attributes( $this->options['block-supports'] );
1719
-							}
1720
-							?>
1717
+                            if ( isset( $this->options['block-supports'] ) ) {
1718
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
1719
+                            }
1720
+                            ?>
1721 1721
 						},
1722 1722
 						category: '<?php echo isset( $this->options['block-category'] ) ? esc_attr( $this->options['block-category'] ) : 'common';?>', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed.
1723 1723
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
1724
-						echo "keywords : " . $this->options['block-keywords'] . ",";
1725
-					}?>
1724
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
1725
+                    }?>
1726 1726
 
1727 1727
 						<?php
1728 1728
 
1729
-						// maybe set no_wrap
1730
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1731
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1732
-							$no_wrap = true;
1733
-						}
1734
-						if ( $no_wrap ) {
1735
-							$this->options['block-wrap'] = '';
1736
-						}
1729
+                        // maybe set no_wrap
1730
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1731
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
1732
+                            $no_wrap = true;
1733
+                        }
1734
+                        if ( $no_wrap ) {
1735
+                            $this->options['block-wrap'] = '';
1736
+                        }
1737 1737
 
1738 1738
 
1739 1739
 
1740
-						$show_alignment = false;
1741
-						// align feature
1742
-						/*echo "supports: {";
1740
+                        $show_alignment = false;
1741
+                        // align feature
1742
+                        /*echo "supports: {";
1743 1743
 						echo "	align: true,";
1744 1744
 						echo "  html: false";
1745 1745
 						echo "},";*/
1746 1746
 
1747
-						if ( ! empty( $this->arguments ) ) {
1748
-							echo "attributes : {";
1749
-
1750
-							if ( $show_advanced ) {
1751
-								echo "show_advanced: {";
1752
-								echo "	type: 'boolean',";
1753
-								echo "  default: false,";
1754
-								echo "},";
1755
-							}
1756
-
1757
-							// block wrap element
1758
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1759
-								echo "block_wrap: {";
1760
-								echo "	type: 'string',";
1761
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1762
-								echo "},";
1763
-							}
1764
-
1765
-							foreach ( $this->arguments as $key => $args ) {
1766
-
1767
-								// set if we should show alignment
1768
-								if ( $key == 'alignment' ) {
1769
-									$show_alignment = true;
1770
-								}
1771
-
1772
-								$extra = '';
1773
-
1774
-								if ( $args['type'] == 'checkbox' ) {
1775
-									$type    = 'boolean';
1776
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1777
-								} elseif ( $args['type'] == 'number' ) {
1778
-									$type    = 'number';
1779
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1780
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1781
-									$type = 'array';
1782
-									if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
1783
-										$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1784
-									} else {
1785
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1786
-									}
1787
-								} elseif ( $args['type'] == 'multiselect' ) {
1788
-									$type    = 'array';
1789
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1790
-								} else {
1791
-									$type    = 'string';
1792
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1793
-								}
1794
-								echo $key . " : {";
1795
-								echo "type : '$type',";
1796
-								echo "default : $default,";
1797
-								echo "},";
1798
-							}
1799
-
1800
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1801
-							echo "className: { type: 'string', default: '' },";
1802
-
1803
-							echo "},";
1804
-
1805
-						}
1806
-
1807
-						?>
1747
+                        if ( ! empty( $this->arguments ) ) {
1748
+                            echo "attributes : {";
1749
+
1750
+                            if ( $show_advanced ) {
1751
+                                echo "show_advanced: {";
1752
+                                echo "	type: 'boolean',";
1753
+                                echo "  default: false,";
1754
+                                echo "},";
1755
+                            }
1756
+
1757
+                            // block wrap element
1758
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
1759
+                                echo "block_wrap: {";
1760
+                                echo "	type: 'string',";
1761
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
1762
+                                echo "},";
1763
+                            }
1764
+
1765
+                            foreach ( $this->arguments as $key => $args ) {
1766
+
1767
+                                // set if we should show alignment
1768
+                                if ( $key == 'alignment' ) {
1769
+                                    $show_alignment = true;
1770
+                                }
1771
+
1772
+                                $extra = '';
1773
+
1774
+                                if ( $args['type'] == 'checkbox' ) {
1775
+                                    $type    = 'boolean';
1776
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
1777
+                                } elseif ( $args['type'] == 'number' ) {
1778
+                                    $type    = 'number';
1779
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1780
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
1781
+                                    $type = 'array';
1782
+                                    if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
1783
+                                        $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
1784
+                                    } else {
1785
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1786
+                                    }
1787
+                                } elseif ( $args['type'] == 'multiselect' ) {
1788
+                                    $type    = 'array';
1789
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1790
+                                } else {
1791
+                                    $type    = 'string';
1792
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
1793
+                                }
1794
+                                echo $key . " : {";
1795
+                                echo "type : '$type',";
1796
+                                echo "default : $default,";
1797
+                                echo "},";
1798
+                            }
1799
+
1800
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
1801
+                            echo "className: { type: 'string', default: '' },";
1802
+
1803
+                            echo "},";
1804
+
1805
+                        }
1806
+
1807
+                        ?>
1808 1808
 
1809 1809
 						// The "edit" property must be a valid function.
1810 1810
 						edit: function (props) {
@@ -1812,9 +1812,9 @@  discard block
 block discarded – undo
1812 1812
 
1813 1813
 							var $value = '';
1814 1814
 							<?php
1815
-							// if we have a post_type and a category then link them
1816
-							if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1817
-							?>
1815
+                            // if we have a post_type and a category then link them
1816
+                            if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
1817
+                            ?>
1818 1818
 							if(typeof(prev_attributes[props.id]) != 'undefined' ){
1819 1819
 								$pt = props.attributes.post_type;
1820 1820
 								if(post_type_rest_slugs.length){
@@ -1898,8 +1898,8 @@  discard block
 block discarded – undo
1898 1898
 										'shortcode': '<?php echo $this->options['base_id'];?>',
1899 1899
 										'attributes': props.attributes,
1900 1900
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
1901
-										echo $post->ID;
1902
-									}else{echo '0';}?>,
1901
+                                        echo $post->ID;
1902
+                                    }else{echo '0';}?>,
1903 1903
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
1904 1904
 									};
1905 1905
 
@@ -1951,10 +1951,10 @@  discard block
 block discarded – undo
1951 1951
 
1952 1952
 									<?php
1953 1953
 
1954
-									if(! empty( $this->arguments )){
1954
+                                    if(! empty( $this->arguments )){
1955 1955
 
1956
-									if ( $show_advanced ) {
1957
-									?>
1956
+                                    if ( $show_advanced ) {
1957
+                                    ?>
1958 1958
 									el('div', {
1959 1959
 											style: {'padding-left': '16px','padding-right': '16px'}
1960 1960
 										},
@@ -1972,79 +1972,79 @@  discard block
 block discarded – undo
1972 1972
 									,
1973 1973
 									<?php
1974 1974
 
1975
-									}
1975
+                                    }
1976 1976
 
1977
-									$arguments = $this->group_arguments( $this->arguments );
1977
+                                    $arguments = $this->group_arguments( $this->arguments );
1978 1978
 
1979
-									// Do we have sections?
1980
-									$has_sections = $arguments == $this->arguments ? false : true;
1979
+                                    // Do we have sections?
1980
+                                    $has_sections = $arguments == $this->arguments ? false : true;
1981 1981
 
1982 1982
 
1983
-									if($has_sections){
1984
-									$panel_count = 0;
1985
-									foreach($arguments as $key => $args){
1986
-									?>
1983
+                                    if($has_sections){
1984
+                                    $panel_count = 0;
1985
+                                    foreach($arguments as $key => $args){
1986
+                                    ?>
1987 1987
 									el(wp.components.PanelBody, {
1988 1988
 											title: '<?php esc_attr_e( $key ); ?>',
1989 1989
 											initialOpen: <?php if ( $panel_count ) {
1990
-											echo "false";
1991
-										} else {
1992
-											echo "true";
1993
-										}?>
1990
+                                            echo "false";
1991
+                                        } else {
1992
+                                            echo "true";
1993
+                                        }?>
1994 1994
 										},
1995 1995
 										<?php
1996 1996
 
1997 1997
 
1998 1998
 
1999
-										foreach ( $args as $k => $a ) {
1999
+                                        foreach ( $args as $k => $a ) {
2000 2000
 
2001
-											$this->block_row_start( $k, $a );
2002
-											$this->build_block_arguments( $k, $a );
2003
-											$this->block_row_end( $k, $a );
2004
-										}
2005
-										?>
2001
+                                            $this->block_row_start( $k, $a );
2002
+                                            $this->build_block_arguments( $k, $a );
2003
+                                            $this->block_row_end( $k, $a );
2004
+                                        }
2005
+                                        ?>
2006 2006
 									),
2007 2007
 									<?php
2008
-									$panel_count ++;
2008
+                                    $panel_count ++;
2009 2009
 
2010
-									}
2011
-									}else {
2012
-									?>
2010
+                                    }
2011
+                                    }else {
2012
+                                    ?>
2013 2013
 									el(wp.components.PanelBody, {
2014 2014
 											title: '<?php esc_attr_e( "Settings" ); ?>',
2015 2015
 											initialOpen: true
2016 2016
 										},
2017 2017
 										<?php
2018
-										foreach ( $this->arguments as $key => $args ) {
2019
-											$this->block_row_start( $key, $args );
2020
-											$this->build_block_arguments( $key, $args );
2021
-											$this->block_row_end( $key, $args );
2022
-										}
2023
-										?>
2018
+                                        foreach ( $this->arguments as $key => $args ) {
2019
+                                            $this->block_row_start( $key, $args );
2020
+                                            $this->build_block_arguments( $key, $args );
2021
+                                            $this->block_row_end( $key, $args );
2022
+                                        }
2023
+                                        ?>
2024 2024
 									),
2025 2025
 									<?php
2026
-									}
2026
+                                    }
2027 2027
 
2028
-									}
2029
-									?>
2028
+                                    }
2029
+                                    ?>
2030 2030
 
2031 2031
 								),
2032 2032
 
2033 2033
 								<?php
2034
-								// If the user sets block-output array then build it
2035
-								if ( ! empty( $this->options['block-output'] ) ) {
2036
-								$this->block_element( $this->options['block-output'] );
2037
-							}else{
2038
-								// if no block-output is set then we try and get the shortcode html output via ajax.
2039
-								?>
2034
+                                // If the user sets block-output array then build it
2035
+                                if ( ! empty( $this->options['block-output'] ) ) {
2036
+                                $this->block_element( $this->options['block-output'] );
2037
+                            }else{
2038
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
2039
+                                ?>
2040 2040
 								el('div', {
2041 2041
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
2042 2042
 									className: props.className,
2043 2043
 									style: {'minHeight': '30px'}
2044 2044
 								})
2045 2045
 								<?php
2046
-								}
2047
-								?>
2046
+                                }
2047
+                                ?>
2048 2048
 							]; // end return
2049 2049
 						},
2050 2050
 
@@ -2062,10 +2062,10 @@  discard block
 block discarded – undo
2062 2062
 							$html = '';
2063 2063
 							<?php
2064 2064
 
2065
-							if(! empty( $this->arguments )){
2065
+                            if(! empty( $this->arguments )){
2066 2066
 
2067
-							foreach($this->arguments as $key => $args){
2068
-							?>
2067
+                            foreach($this->arguments as $key => $args){
2068
+                            ?>
2069 2069
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2070 2070
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
2071 2071
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -2074,10 +2074,10 @@  discard block
 block discarded – undo
2074 2074
 								}
2075 2075
 							}
2076 2076
 							<?php
2077
-							}
2078
-							}
2077
+                            }
2078
+                            }
2079 2079
 
2080
-							?>
2080
+                            ?>
2081 2081
 							content += "]";
2082 2082
 
2083 2083
 							// if has html element
@@ -2100,20 +2100,20 @@  discard block
 block discarded – undo
2100 2100
 							}
2101 2101
 
2102 2102
 							<?php
2103
-							if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2104
-							?>
2103
+                            if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2104
+                            ?>
2105 2105
 							return content;
2106 2106
 							<?php
2107
-							}else{
2108
-							?>
2107
+                            }else{
2108
+                            ?>
2109 2109
 							var block_wrap = 'div';
2110 2110
 							if (attr.hasOwnProperty("block_wrap")) {
2111 2111
 								block_wrap = attr.block_wrap;
2112 2112
 							}
2113 2113
 							return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align});
2114 2114
 							<?php
2115
-							}
2116
-							?>
2115
+                            }
2116
+                            ?>
2117 2117
 
2118 2118
 
2119 2119
 						}
@@ -2121,30 +2121,30 @@  discard block
 block discarded – undo
2121 2121
 				})();
2122 2122
 			</script>
2123 2123
 			<?php
2124
-			$output = ob_get_clean();
2124
+            $output = ob_get_clean();
2125 2125
 
2126
-			/*
2126
+            /*
2127 2127
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
2128 2128
 			 */
2129 2129
 
2130
-			return str_replace( array(
2131
-				'<script>',
2132
-				'</script>'
2133
-			), '', $output );
2134
-		}
2130
+            return str_replace( array(
2131
+                '<script>',
2132
+                '</script>'
2133
+            ), '', $output );
2134
+        }
2135 2135
 
2136
-		public function block_row_start($key, $args){
2136
+        public function block_row_start($key, $args){
2137 2137
 
2138
-			// check for row
2139
-			if(!empty($args['row'])){
2138
+            // check for row
2139
+            if(!empty($args['row'])){
2140 2140
 
2141
-				if(!empty($args['row']['open'])){
2141
+                if(!empty($args['row']['open'])){
2142 2142
 
2143
-				// element require
2144
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2145
-				echo $element_require;
2143
+                // element require
2144
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2145
+                echo $element_require;
2146 2146
 
2147
-					if(false){?><script><?php }?>
2147
+                    if(false){?><script><?php }?>
2148 2148
 						el('div', {
2149 2149
 								className: 'bsui components-base-control',
2150 2150
 							},
@@ -2174,87 +2174,87 @@  discard block
 block discarded – undo
2174 2174
 									},
2175 2175
 
2176 2176
 					<?php
2177
-					if(false){?></script><?php }
2178
-				}elseif(!empty($args['row']['close'])){
2179
-					if(false){?><script><?php }?>
2177
+                    if(false){?></script><?php }
2178
+                }elseif(!empty($args['row']['close'])){
2179
+                    if(false){?><script><?php }?>
2180 2180
 						el(
2181 2181
 							'div',
2182 2182
 							{
2183 2183
 								className: 'col pl-0',
2184 2184
 							},
2185 2185
 					<?php
2186
-					if(false){?></script><?php }
2187
-				}else{
2188
-					if(false){?><script><?php }?>
2186
+                    if(false){?></script><?php }
2187
+                }else{
2188
+                    if(false){?><script><?php }?>
2189 2189
 						el(
2190 2190
 							'div',
2191 2191
 							{
2192 2192
 								className: 'col pl-0 pr-2',
2193 2193
 							},
2194 2194
 					<?php
2195
-					if(false){?></script><?php }
2196
-				}
2197
-
2198
-			}
2199
-
2200
-		}
2201
-
2202
-		public function block_row_end($key, $args){
2203
-
2204
-			if(!empty($args['row'])){
2205
-				// maybe close
2206
-				if(!empty($args['row']['close'])){
2207
-					echo "))";
2208
-				}
2209
-
2210
-				echo "),";
2211
-			}
2212
-		}
2213
-
2214
-		public function build_block_arguments( $key, $args ) {
2215
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2216
-			$options           = '';
2217
-			$extra             = '';
2218
-			$require           = '';
2219
-
2220
-			// `content` is a protected and special argument
2221
-			if ( $key == 'content' ) {
2222
-				return;
2223
-			}
2224
-
2225
-
2226
-			// icon
2227
-			$icon = '';
2228
-			if( !empty( $args['icon'] ) ){
2229
-				$icon .= "el('div', {";
2230
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2231
-									$icon .= "className: 'text-center',";
2232
-									$icon .= "title: '".addslashes( $args['title'] )."',";
2233
-								$icon .= "}),";
2234
-
2235
-				// blank title as its added to the icon.
2236
-				$args['title'] = '';
2237
-			}
2238
-
2239
-			// require advanced
2240
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2241
-
2242
-			// element require
2243
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2244
-
2245
-
2246
-			$onchange  = "props.setAttributes({ $key: $key } )";
2247
-			$onchangecomplete  = "";
2248
-			$value     = "props.attributes.$key";
2249
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2250
-			if ( in_array( $args['type'], $text_type ) ) {
2251
-				$type = 'TextControl';
2252
-				// Save numbers as numbers and not strings
2253
-				if ( $args['type'] == 'number' ) {
2254
-					$onchange = "props.setAttributes({ $key: Number($key) } )";
2255
-				}
2256
-			}
2257
-			/*
2195
+                    if(false){?></script><?php }
2196
+                }
2197
+
2198
+            }
2199
+
2200
+        }
2201
+
2202
+        public function block_row_end($key, $args){
2203
+
2204
+            if(!empty($args['row'])){
2205
+                // maybe close
2206
+                if(!empty($args['row']['close'])){
2207
+                    echo "))";
2208
+                }
2209
+
2210
+                echo "),";
2211
+            }
2212
+        }
2213
+
2214
+        public function build_block_arguments( $key, $args ) {
2215
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
2216
+            $options           = '';
2217
+            $extra             = '';
2218
+            $require           = '';
2219
+
2220
+            // `content` is a protected and special argument
2221
+            if ( $key == 'content' ) {
2222
+                return;
2223
+            }
2224
+
2225
+
2226
+            // icon
2227
+            $icon = '';
2228
+            if( !empty( $args['icon'] ) ){
2229
+                $icon .= "el('div', {";
2230
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
2231
+                                    $icon .= "className: 'text-center',";
2232
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
2233
+                                $icon .= "}),";
2234
+
2235
+                // blank title as its added to the icon.
2236
+                $args['title'] = '';
2237
+            }
2238
+
2239
+            // require advanced
2240
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
2241
+
2242
+            // element require
2243
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
2244
+
2245
+
2246
+            $onchange  = "props.setAttributes({ $key: $key } )";
2247
+            $onchangecomplete  = "";
2248
+            $value     = "props.attributes.$key";
2249
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' );
2250
+            if ( in_array( $args['type'], $text_type ) ) {
2251
+                $type = 'TextControl';
2252
+                // Save numbers as numbers and not strings
2253
+                if ( $args['type'] == 'number' ) {
2254
+                    $onchange = "props.setAttributes({ $key: Number($key) } )";
2255
+                }
2256
+            }
2257
+            /*
2258 2258
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
2259 2259
 						elseif($args['type']=='tabs'){
2260 2260
 							?>
@@ -2288,85 +2288,85 @@  discard block
 block discarded – undo
2288 2288
 							return;
2289 2289
 						}
2290 2290
 			*/
2291
-			elseif ( $args['type'] == 'color' ) {
2292
-				$type = 'ColorPicker';
2293
-				$onchange = "";
2294
-				$extra = "color: $value,";
2295
-				if(!empty($args['disable_alpha'])){
2296
-					$extra .= "disableAlpha: true,";
2297
-				}
2298
-				$onchangecomplete = "onChangeComplete: function($key) {
2291
+            elseif ( $args['type'] == 'color' ) {
2292
+                $type = 'ColorPicker';
2293
+                $onchange = "";
2294
+                $extra = "color: $value,";
2295
+                if(!empty($args['disable_alpha'])){
2296
+                    $extra .= "disableAlpha: true,";
2297
+                }
2298
+                $onchangecomplete = "onChangeComplete: function($key) {
2299 2299
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
2300 2300
                         props.setAttributes({
2301 2301
                             $key: value
2302 2302
                         });
2303 2303
                     },";
2304
-			}
2305
-			elseif ( $args['type'] == 'checkbox' ) {
2306
-				$type = 'CheckboxControl';
2307
-				$extra .= "checked: props.attributes.$key,";
2308
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2309
-			} elseif ( $args['type'] == 'textarea' ) {
2310
-				$type = 'TextareaControl';
2311
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2312
-				$type = 'SelectControl';
2313
-
2314
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2315
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2316
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2317
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2318
-				}else {
2319
-
2320
-					if ( ! empty( $args['options'] ) ) {
2321
-						$options .= "options: [";
2322
-						foreach ( $args['options'] as $option_val => $option_label ) {
2323
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2324
-						}
2325
-						$options .= "],";
2326
-					}
2327
-				}
2328
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2329
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px"}, ';
2330
-				}
2331
-			} elseif ( $args['type'] == 'alignment' ) {
2332
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2333
-			}elseif ( $args['type'] == 'margins' ) {
2334
-
2335
-			} else {
2336
-				return;// if we have not implemented the control then don't break the JS.
2337
-			}
2338
-
2339
-
2340
-
2341
-			// color input does not show the labels so we add them
2342
-			if($args['type']=='color'){
2343
-				// add show only if advanced
2344
-				echo $require_advanced;
2345
-				// add setting require if defined
2346
-				echo $element_require;
2347
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2348
-			}
2349
-
2350
-			// add show only if advanced
2351
-			echo $require_advanced;
2352
-			// add setting require if defined
2353
-			echo $element_require;
2354
-
2355
-			// icon
2356
-			echo $icon;
2357
-			?>
2304
+            }
2305
+            elseif ( $args['type'] == 'checkbox' ) {
2306
+                $type = 'CheckboxControl';
2307
+                $extra .= "checked: props.attributes.$key,";
2308
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
2309
+            } elseif ( $args['type'] == 'textarea' ) {
2310
+                $type = 'TextareaControl';
2311
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
2312
+                $type = 'SelectControl';
2313
+
2314
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
2315
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
2316
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
2317
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
2318
+                }else {
2319
+
2320
+                    if ( ! empty( $args['options'] ) ) {
2321
+                        $options .= "options: [";
2322
+                        foreach ( $args['options'] as $option_val => $option_label ) {
2323
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
2324
+                        }
2325
+                        $options .= "],";
2326
+                    }
2327
+                }
2328
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
2329
+                    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px"}, ';
2330
+                }
2331
+            } elseif ( $args['type'] == 'alignment' ) {
2332
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
2333
+            }elseif ( $args['type'] == 'margins' ) {
2334
+
2335
+            } else {
2336
+                return;// if we have not implemented the control then don't break the JS.
2337
+            }
2338
+
2339
+
2340
+
2341
+            // color input does not show the labels so we add them
2342
+            if($args['type']=='color'){
2343
+                // add show only if advanced
2344
+                echo $require_advanced;
2345
+                // add setting require if defined
2346
+                echo $element_require;
2347
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
2348
+            }
2349
+
2350
+            // add show only if advanced
2351
+            echo $require_advanced;
2352
+            // add setting require if defined
2353
+            echo $element_require;
2354
+
2355
+            // icon
2356
+            echo $icon;
2357
+            ?>
2358 2358
 			el( wp.components.<?php echo $type; ?>, {
2359 2359
 			label: '<?php echo addslashes( $args['title'] ); ?>',
2360 2360
 			help: '<?php if ( isset( $args['desc'] ) ) {
2361
-				echo addslashes( $args['desc'] );
2362
-			} ?>',
2361
+                echo addslashes( $args['desc'] );
2362
+            } ?>',
2363 2363
 			value: <?php echo $value; ?>,
2364 2364
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
2365
-				echo "type: '" . addslashes( $args['type'] ) . "',";
2366
-			} ?>
2365
+                echo "type: '" . addslashes( $args['type'] ) . "',";
2366
+            } ?>
2367 2367
 			<?php if ( ! empty( $args['placeholder'] ) ) {
2368
-				echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2369
-			} ?>
2368
+                echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
2369
+            } ?>
2370 2370
 			<?php echo $options; ?>
2371 2371
 			<?php echo $extra; ?>
2372 2372
 			<?php echo $custom_attributes; ?>
@@ -2378,608 +2378,608 @@  discard block
 block discarded – undo
2378 2378
 			<?php
2379 2379
 
2380 2380
 
2381
-		}
2382
-
2383
-		/**
2384
-		 * Convert an array of attributes to block string.
2385
-		 *
2386
-		 * @todo there is prob a faster way to do this, also we could add some validation here.
2387
-		 *
2388
-		 * @param $custom_attributes
2389
-		 *
2390
-		 * @return string
2391
-		 */
2392
-		public function array_to_attributes( $custom_attributes, $html = false ) {
2393
-			$attributes = '';
2394
-			if ( ! empty( $custom_attributes ) ) {
2395
-
2396
-				if ( $html ) {
2397
-					foreach ( $custom_attributes as $key => $val ) {
2398
-						$attributes .= " $key='$val' ";
2399
-					}
2400
-				} else {
2401
-					foreach ( $custom_attributes as $key => $val ) {
2402
-						$attributes .= "'$key': '$val',";
2403
-					}
2404
-				}
2405
-			}
2406
-
2407
-			return $attributes;
2408
-		}
2409
-
2410
-		/**
2411
-		 * A self looping function to create the output for JS block elements.
2412
-		 *
2413
-		 * This is what is output in the WP Editor visual view.
2414
-		 *
2415
-		 * @param $args
2416
-		 */
2417
-		public function block_element( $args ) {
2418
-
2419
-
2420
-			if ( ! empty( $args ) ) {
2421
-				foreach ( $args as $element => $new_args ) {
2422
-
2423
-					if ( is_array( $new_args ) ) { // its an element
2424
-
2425
-
2426
-						if ( isset( $new_args['element'] ) ) {
2427
-
2428
-							if ( isset( $new_args['element_require'] ) ) {
2429
-								echo str_replace( array(
2430
-										"'+",
2431
-										"+'"
2432
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2433
-								unset( $new_args['element_require'] );
2434
-							}
2435
-
2436
-							echo "\n el( '" . $new_args['element'] . "', {";
2437
-
2438
-							// get the attributes
2439
-							foreach ( $new_args as $new_key => $new_value ) {
2440
-
2441
-
2442
-								if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2443
-									// do nothing
2444
-								} else {
2445
-									echo $this->block_element( array( $new_key => $new_value ) );
2446
-								}
2447
-							}
2448
-
2449
-							echo "},";// end attributes
2450
-
2451
-							// get the content
2452
-							$first_item = 0;
2453
-							foreach ( $new_args as $new_key => $new_value ) {
2454
-								if ( $new_key === 'content' || is_array( $new_value ) ) {
2455
-
2456
-									if ( $new_key === 'content' ) {
2457
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2458
-									}
2459
-
2460
-									if ( is_array( $new_value ) ) {
2461
-
2462
-										if ( isset( $new_value['element_require'] ) ) {
2463
-											echo str_replace( array(
2464
-													"'+",
2465
-													"+'"
2466
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2467
-											unset( $new_value['element_require'] );
2468
-										}
2469
-
2470
-										if ( isset( $new_value['element_repeat'] ) ) {
2471
-											$x = 1;
2472
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
2473
-												$this->block_element( array( '' => $new_value ) );
2474
-												$x ++;
2475
-											}
2476
-										} else {
2477
-											$this->block_element( array( '' => $new_value ) );
2478
-										}
2479
-									}
2480
-									$first_item ++;
2481
-								}
2482
-							}
2483
-
2484
-							echo ")";// end content
2485
-
2486
-							echo ", \n";
2487
-
2488
-						}
2489
-					} else {
2490
-
2491
-						if ( substr( $element, 0, 3 ) === "if_" ) {
2492
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2493
-						} elseif ( $element == 'style' ) {
2494
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2495
-						} else {
2496
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2497
-						}
2498
-
2499
-					}
2500
-				}
2501
-			}
2502
-		}
2503
-
2504
-		/**
2505
-		 * Replace block attributes placeholders with the proper naming.
2506
-		 *
2507
-		 * @param $string
2508
-		 *
2509
-		 * @return mixed
2510
-		 */
2511
-		public function block_props_replace( $string, $no_wrap = false ) {
2512
-
2513
-			if ( $no_wrap ) {
2514
-				$string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2515
-			} else {
2516
-				$string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2517
-			}
2518
-
2519
-			return $string;
2520
-		}
2521
-
2522
-		/**
2523
-		 * Outputs the content of the widget
2524
-		 *
2525
-		 * @param array $args
2526
-		 * @param array $instance
2527
-		 */
2528
-		public function widget( $args, $instance ) {
2529
-
2530
-			// get the filtered values
2531
-			$argument_values = $this->argument_values( $instance );
2532
-			$argument_values = $this->string_to_bool( $argument_values );
2533
-			$output          = $this->output( $argument_values, $args );
2534
-
2535
-			$no_wrap = false;
2536
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2537
-				$no_wrap = true;
2538
-			}
2539
-
2540
-			ob_start();
2541
-			if ( $output && ! $no_wrap ) {
2542
-
2543
-				$class_original = $this->options['widget_ops']['classname'];
2544
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2545
-
2546
-				// Before widget
2547
-				$before_widget = $args['before_widget'];
2548
-				$before_widget = str_replace($class_original,$class,$before_widget);
2549
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2550
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2551
-
2552
-				// After widget
2553
-				$after_widget = $args['after_widget'];
2554
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2555
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2556
-
2557
-				echo $before_widget;
2558
-				// elementor strips the widget wrapping div so we check for and add it back if needed
2559
-				if ( $this->is_elementor_widget_output() ) {
2560
-					// Filter class & attrs for elementor widget output.
2561
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
2562
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
2563
-
2564
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
2565
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
2566
-
2567
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
2568
-				}
2569
-				echo $this->output_title( $args, $instance );
2570
-				echo $output;
2571
-				if ( $this->is_elementor_widget_output() ) {
2572
-					echo "</span>";
2573
-				}
2574
-				echo $after_widget;
2575
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2576
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2577
-				echo $output;
2578
-			} elseif ( $output && $no_wrap ) {
2579
-				echo $output;
2580
-			}
2581
-			$output = ob_get_clean();
2582
-
2583
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2584
-
2585
-			echo $output;
2586
-		}
2587
-
2588
-		/**
2589
-		 * Tests if the current output is inside a elementor container.
2590
-		 *
2591
-		 * @since 1.0.4
2592
-		 * @return bool
2593
-		 */
2594
-		public function is_elementor_widget_output() {
2595
-			$result = false;
2596
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2597
-				$result = true;
2598
-			}
2599
-
2600
-			return $result;
2601
-		}
2602
-
2603
-		/**
2604
-		 * Tests if the current output is inside a elementor preview.
2605
-		 *
2606
-		 * @since 1.0.4
2607
-		 * @return bool
2608
-		 */
2609
-		public function is_elementor_preview() {
2610
-			$result = false;
2611
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2612
-				$result = true;
2613
-			}
2614
-
2615
-			return $result;
2616
-		}
2617
-
2618
-		/**
2619
-		 * Tests if the current output is inside a Divi preview.
2620
-		 *
2621
-		 * @since 1.0.6
2622
-		 * @return bool
2623
-		 */
2624
-		public function is_divi_preview() {
2625
-			$result = false;
2626
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2627
-				$result = true;
2628
-			}
2629
-
2630
-			return $result;
2631
-		}
2632
-
2633
-		/**
2634
-		 * Tests if the current output is inside a Beaver builder preview.
2635
-		 *
2636
-		 * @since 1.0.6
2637
-		 * @return bool
2638
-		 */
2639
-		public function is_beaver_preview() {
2640
-			$result = false;
2641
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
2642
-				$result = true;
2643
-			}
2644
-
2645
-			return $result;
2646
-		}
2647
-
2648
-		/**
2649
-		 * Tests if the current output is inside a siteorigin builder preview.
2650
-		 *
2651
-		 * @since 1.0.6
2652
-		 * @return bool
2653
-		 */
2654
-		public function is_siteorigin_preview() {
2655
-			$result = false;
2656
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2657
-				$result = true;
2658
-			}
2659
-
2660
-			return $result;
2661
-		}
2662
-
2663
-		/**
2664
-		 * Tests if the current output is inside a cornerstone builder preview.
2665
-		 *
2666
-		 * @since 1.0.8
2667
-		 * @return bool
2668
-		 */
2669
-		public function is_cornerstone_preview() {
2670
-			$result = false;
2671
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2672
-				$result = true;
2673
-			}
2674
-
2675
-			return $result;
2676
-		}
2677
-
2678
-		/**
2679
-		 * Tests if the current output is inside a fusion builder preview.
2680
-		 *
2681
-		 * @since 1.1.0
2682
-		 * @return bool
2683
-		 */
2684
-		public function is_fusion_preview() {
2685
-			$result = false;
2686
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2687
-				$result = true;
2688
-			}
2689
-
2690
-			return $result;
2691
-		}
2692
-
2693
-		/**
2694
-		 * Tests if the current output is inside a Oxygen builder preview.
2695
-		 *
2696
-		 * @since 1.0.18
2697
-		 * @return bool
2698
-		 */
2699
-		public function is_oxygen_preview() {
2700
-			$result = false;
2701
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2702
-				$result = true;
2703
-			}
2704
-
2705
-			return $result;
2706
-		}
2707
-
2708
-		/**
2709
-		 * General function to check if we are in a preview situation.
2710
-		 *
2711
-		 * @since 1.0.6
2712
-		 * @return bool
2713
-		 */
2714
-		public function is_preview() {
2715
-			$preview = false;
2716
-			if ( $this->is_divi_preview() ) {
2717
-				$preview = true;
2718
-			} elseif ( $this->is_elementor_preview() ) {
2719
-				$preview = true;
2720
-			} elseif ( $this->is_beaver_preview() ) {
2721
-				$preview = true;
2722
-			} elseif ( $this->is_siteorigin_preview() ) {
2723
-				$preview = true;
2724
-			} elseif ( $this->is_cornerstone_preview() ) {
2725
-				$preview = true;
2726
-			} elseif ( $this->is_fusion_preview() ) {
2727
-				$preview = true;
2728
-			} elseif ( $this->is_oxygen_preview() ) {
2729
-				$preview = true;
2730
-			} elseif( $this->is_block_content_call() ) {
2731
-				$preview = true;
2732
-			}
2733
-
2734
-			return $preview;
2735
-		}
2736
-
2737
-		/**
2738
-		 * Output the super title.
2739
-		 *
2740
-		 * @param $args
2741
-		 * @param array $instance
2742
-		 *
2743
-		 * @return string
2744
-		 */
2745
-		public function output_title( $args, $instance = array() ) {
2746
-			$output = '';
2747
-			if ( ! empty( $instance['title'] ) ) {
2748
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2749
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2750
-
2751
-				if(empty($instance['widget_title_tag'])){
2752
-					$output = $args['before_title'] . $title . $args['after_title'];
2753
-				}else{
2754
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
2755
-
2756
-					// classes
2757
-					$title_classes = array();
2758
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2759
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2760
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2761
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2762
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2763
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2764
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2765
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2766
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2767
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2768
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2769
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2770
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2771
-
2772
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2773
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
2774
-				}
2775
-
2776
-			}
2777
-
2778
-			return $output;
2779
-		}
2780
-
2781
-		/**
2782
-		 * Outputs the options form inputs for the widget.
2783
-		 *
2784
-		 * @param array $instance The widget options.
2785
-		 */
2786
-		public function form( $instance ) {
2787
-
2788
-			// set widget instance
2789
-			$this->instance = $instance;
2790
-
2791
-			// set it as a SD widget
2792
-			echo $this->widget_advanced_toggle();
2793
-
2794
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2795
-			$arguments_raw = $this->get_arguments();
2796
-
2797
-			if ( is_array( $arguments_raw ) ) {
2798
-
2799
-				$arguments = $this->group_arguments( $arguments_raw );
2800
-
2801
-				// Do we have sections?
2802
-				$has_sections = $arguments == $arguments_raw ? false : true;
2803
-
2804
-
2805
-				if ( $has_sections ) {
2806
-					$panel_count = 0;
2807
-					foreach ( $arguments as $key => $args ) {
2808
-
2809
-						?>
2381
+        }
2382
+
2383
+        /**
2384
+         * Convert an array of attributes to block string.
2385
+         *
2386
+         * @todo there is prob a faster way to do this, also we could add some validation here.
2387
+         *
2388
+         * @param $custom_attributes
2389
+         *
2390
+         * @return string
2391
+         */
2392
+        public function array_to_attributes( $custom_attributes, $html = false ) {
2393
+            $attributes = '';
2394
+            if ( ! empty( $custom_attributes ) ) {
2395
+
2396
+                if ( $html ) {
2397
+                    foreach ( $custom_attributes as $key => $val ) {
2398
+                        $attributes .= " $key='$val' ";
2399
+                    }
2400
+                } else {
2401
+                    foreach ( $custom_attributes as $key => $val ) {
2402
+                        $attributes .= "'$key': '$val',";
2403
+                    }
2404
+                }
2405
+            }
2406
+
2407
+            return $attributes;
2408
+        }
2409
+
2410
+        /**
2411
+         * A self looping function to create the output for JS block elements.
2412
+         *
2413
+         * This is what is output in the WP Editor visual view.
2414
+         *
2415
+         * @param $args
2416
+         */
2417
+        public function block_element( $args ) {
2418
+
2419
+
2420
+            if ( ! empty( $args ) ) {
2421
+                foreach ( $args as $element => $new_args ) {
2422
+
2423
+                    if ( is_array( $new_args ) ) { // its an element
2424
+
2425
+
2426
+                        if ( isset( $new_args['element'] ) ) {
2427
+
2428
+                            if ( isset( $new_args['element_require'] ) ) {
2429
+                                echo str_replace( array(
2430
+                                        "'+",
2431
+                                        "+'"
2432
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
2433
+                                unset( $new_args['element_require'] );
2434
+                            }
2435
+
2436
+                            echo "\n el( '" . $new_args['element'] . "', {";
2437
+
2438
+                            // get the attributes
2439
+                            foreach ( $new_args as $new_key => $new_value ) {
2440
+
2441
+
2442
+                                if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
2443
+                                    // do nothing
2444
+                                } else {
2445
+                                    echo $this->block_element( array( $new_key => $new_value ) );
2446
+                                }
2447
+                            }
2448
+
2449
+                            echo "},";// end attributes
2450
+
2451
+                            // get the content
2452
+                            $first_item = 0;
2453
+                            foreach ( $new_args as $new_key => $new_value ) {
2454
+                                if ( $new_key === 'content' || is_array( $new_value ) ) {
2455
+
2456
+                                    if ( $new_key === 'content' ) {
2457
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
2458
+                                    }
2459
+
2460
+                                    if ( is_array( $new_value ) ) {
2461
+
2462
+                                        if ( isset( $new_value['element_require'] ) ) {
2463
+                                            echo str_replace( array(
2464
+                                                    "'+",
2465
+                                                    "+'"
2466
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
2467
+                                            unset( $new_value['element_require'] );
2468
+                                        }
2469
+
2470
+                                        if ( isset( $new_value['element_repeat'] ) ) {
2471
+                                            $x = 1;
2472
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
2473
+                                                $this->block_element( array( '' => $new_value ) );
2474
+                                                $x ++;
2475
+                                            }
2476
+                                        } else {
2477
+                                            $this->block_element( array( '' => $new_value ) );
2478
+                                        }
2479
+                                    }
2480
+                                    $first_item ++;
2481
+                                }
2482
+                            }
2483
+
2484
+                            echo ")";// end content
2485
+
2486
+                            echo ", \n";
2487
+
2488
+                        }
2489
+                    } else {
2490
+
2491
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
2492
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
2493
+                        } elseif ( $element == 'style' ) {
2494
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
2495
+                        } else {
2496
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
2497
+                        }
2498
+
2499
+                    }
2500
+                }
2501
+            }
2502
+        }
2503
+
2504
+        /**
2505
+         * Replace block attributes placeholders with the proper naming.
2506
+         *
2507
+         * @param $string
2508
+         *
2509
+         * @return mixed
2510
+         */
2511
+        public function block_props_replace( $string, $no_wrap = false ) {
2512
+
2513
+            if ( $no_wrap ) {
2514
+                $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
2515
+            } else {
2516
+                $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
2517
+            }
2518
+
2519
+            return $string;
2520
+        }
2521
+
2522
+        /**
2523
+         * Outputs the content of the widget
2524
+         *
2525
+         * @param array $args
2526
+         * @param array $instance
2527
+         */
2528
+        public function widget( $args, $instance ) {
2529
+
2530
+            // get the filtered values
2531
+            $argument_values = $this->argument_values( $instance );
2532
+            $argument_values = $this->string_to_bool( $argument_values );
2533
+            $output          = $this->output( $argument_values, $args );
2534
+
2535
+            $no_wrap = false;
2536
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
2537
+                $no_wrap = true;
2538
+            }
2539
+
2540
+            ob_start();
2541
+            if ( $output && ! $no_wrap ) {
2542
+
2543
+                $class_original = $this->options['widget_ops']['classname'];
2544
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
2545
+
2546
+                // Before widget
2547
+                $before_widget = $args['before_widget'];
2548
+                $before_widget = str_replace($class_original,$class,$before_widget);
2549
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
2550
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
2551
+
2552
+                // After widget
2553
+                $after_widget = $args['after_widget'];
2554
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
2555
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
2556
+
2557
+                echo $before_widget;
2558
+                // elementor strips the widget wrapping div so we check for and add it back if needed
2559
+                if ( $this->is_elementor_widget_output() ) {
2560
+                    // Filter class & attrs for elementor widget output.
2561
+                    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
2562
+                    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
2563
+
2564
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
2565
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
2566
+
2567
+                    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
2568
+                }
2569
+                echo $this->output_title( $args, $instance );
2570
+                echo $output;
2571
+                if ( $this->is_elementor_widget_output() ) {
2572
+                    echo "</span>";
2573
+                }
2574
+                echo $after_widget;
2575
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
2576
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
2577
+                echo $output;
2578
+            } elseif ( $output && $no_wrap ) {
2579
+                echo $output;
2580
+            }
2581
+            $output = ob_get_clean();
2582
+
2583
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
2584
+
2585
+            echo $output;
2586
+        }
2587
+
2588
+        /**
2589
+         * Tests if the current output is inside a elementor container.
2590
+         *
2591
+         * @since 1.0.4
2592
+         * @return bool
2593
+         */
2594
+        public function is_elementor_widget_output() {
2595
+            $result = false;
2596
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
2597
+                $result = true;
2598
+            }
2599
+
2600
+            return $result;
2601
+        }
2602
+
2603
+        /**
2604
+         * Tests if the current output is inside a elementor preview.
2605
+         *
2606
+         * @since 1.0.4
2607
+         * @return bool
2608
+         */
2609
+        public function is_elementor_preview() {
2610
+            $result = false;
2611
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
2612
+                $result = true;
2613
+            }
2614
+
2615
+            return $result;
2616
+        }
2617
+
2618
+        /**
2619
+         * Tests if the current output is inside a Divi preview.
2620
+         *
2621
+         * @since 1.0.6
2622
+         * @return bool
2623
+         */
2624
+        public function is_divi_preview() {
2625
+            $result = false;
2626
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
2627
+                $result = true;
2628
+            }
2629
+
2630
+            return $result;
2631
+        }
2632
+
2633
+        /**
2634
+         * Tests if the current output is inside a Beaver builder preview.
2635
+         *
2636
+         * @since 1.0.6
2637
+         * @return bool
2638
+         */
2639
+        public function is_beaver_preview() {
2640
+            $result = false;
2641
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
2642
+                $result = true;
2643
+            }
2644
+
2645
+            return $result;
2646
+        }
2647
+
2648
+        /**
2649
+         * Tests if the current output is inside a siteorigin builder preview.
2650
+         *
2651
+         * @since 1.0.6
2652
+         * @return bool
2653
+         */
2654
+        public function is_siteorigin_preview() {
2655
+            $result = false;
2656
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
2657
+                $result = true;
2658
+            }
2659
+
2660
+            return $result;
2661
+        }
2662
+
2663
+        /**
2664
+         * Tests if the current output is inside a cornerstone builder preview.
2665
+         *
2666
+         * @since 1.0.8
2667
+         * @return bool
2668
+         */
2669
+        public function is_cornerstone_preview() {
2670
+            $result = false;
2671
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
2672
+                $result = true;
2673
+            }
2674
+
2675
+            return $result;
2676
+        }
2677
+
2678
+        /**
2679
+         * Tests if the current output is inside a fusion builder preview.
2680
+         *
2681
+         * @since 1.1.0
2682
+         * @return bool
2683
+         */
2684
+        public function is_fusion_preview() {
2685
+            $result = false;
2686
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
2687
+                $result = true;
2688
+            }
2689
+
2690
+            return $result;
2691
+        }
2692
+
2693
+        /**
2694
+         * Tests if the current output is inside a Oxygen builder preview.
2695
+         *
2696
+         * @since 1.0.18
2697
+         * @return bool
2698
+         */
2699
+        public function is_oxygen_preview() {
2700
+            $result = false;
2701
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
2702
+                $result = true;
2703
+            }
2704
+
2705
+            return $result;
2706
+        }
2707
+
2708
+        /**
2709
+         * General function to check if we are in a preview situation.
2710
+         *
2711
+         * @since 1.0.6
2712
+         * @return bool
2713
+         */
2714
+        public function is_preview() {
2715
+            $preview = false;
2716
+            if ( $this->is_divi_preview() ) {
2717
+                $preview = true;
2718
+            } elseif ( $this->is_elementor_preview() ) {
2719
+                $preview = true;
2720
+            } elseif ( $this->is_beaver_preview() ) {
2721
+                $preview = true;
2722
+            } elseif ( $this->is_siteorigin_preview() ) {
2723
+                $preview = true;
2724
+            } elseif ( $this->is_cornerstone_preview() ) {
2725
+                $preview = true;
2726
+            } elseif ( $this->is_fusion_preview() ) {
2727
+                $preview = true;
2728
+            } elseif ( $this->is_oxygen_preview() ) {
2729
+                $preview = true;
2730
+            } elseif( $this->is_block_content_call() ) {
2731
+                $preview = true;
2732
+            }
2733
+
2734
+            return $preview;
2735
+        }
2736
+
2737
+        /**
2738
+         * Output the super title.
2739
+         *
2740
+         * @param $args
2741
+         * @param array $instance
2742
+         *
2743
+         * @return string
2744
+         */
2745
+        public function output_title( $args, $instance = array() ) {
2746
+            $output = '';
2747
+            if ( ! empty( $instance['title'] ) ) {
2748
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
2749
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
2750
+
2751
+                if(empty($instance['widget_title_tag'])){
2752
+                    $output = $args['before_title'] . $title . $args['after_title'];
2753
+                }else{
2754
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
2755
+
2756
+                    // classes
2757
+                    $title_classes = array();
2758
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
2759
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
2760
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
2761
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
2762
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
2763
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
2764
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
2765
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
2766
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
2767
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
2768
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
2769
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
2770
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
2771
+
2772
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
2773
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
2774
+                }
2775
+
2776
+            }
2777
+
2778
+            return $output;
2779
+        }
2780
+
2781
+        /**
2782
+         * Outputs the options form inputs for the widget.
2783
+         *
2784
+         * @param array $instance The widget options.
2785
+         */
2786
+        public function form( $instance ) {
2787
+
2788
+            // set widget instance
2789
+            $this->instance = $instance;
2790
+
2791
+            // set it as a SD widget
2792
+            echo $this->widget_advanced_toggle();
2793
+
2794
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
2795
+            $arguments_raw = $this->get_arguments();
2796
+
2797
+            if ( is_array( $arguments_raw ) ) {
2798
+
2799
+                $arguments = $this->group_arguments( $arguments_raw );
2800
+
2801
+                // Do we have sections?
2802
+                $has_sections = $arguments == $arguments_raw ? false : true;
2803
+
2804
+
2805
+                if ( $has_sections ) {
2806
+                    $panel_count = 0;
2807
+                    foreach ( $arguments as $key => $args ) {
2808
+
2809
+                        ?>
2810 2810
 						<script>
2811 2811
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
2812 2812
 						</script>
2813 2813
 						<?php
2814 2814
 
2815
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
2816
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2817
-						echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
2818
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2815
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
2816
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
2817
+                        echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>";
2818
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
2819 2819
 
2820
-						foreach ( $args as $k => $a ) {
2820
+                        foreach ( $args as $k => $a ) {
2821 2821
 
2822
-							$this->widget_inputs_row_start($k, $a);
2823
-							$this->widget_inputs( $a, $instance );
2824
-							$this->widget_inputs_row_end($k, $a);
2822
+                            $this->widget_inputs_row_start($k, $a);
2823
+                            $this->widget_inputs( $a, $instance );
2824
+                            $this->widget_inputs_row_end($k, $a);
2825 2825
 
2826
-						}
2826
+                        }
2827 2827
 
2828
-						echo "</div>";
2828
+                        echo "</div>";
2829 2829
 
2830
-						$panel_count ++;
2830
+                        $panel_count ++;
2831 2831
 
2832
-					}
2833
-				} else {
2834
-					foreach ( $arguments as $key => $args ) {
2835
-						$this->widget_inputs_row_start($key, $args);
2836
-						$this->widget_inputs( $args, $instance );
2837
-						$this->widget_inputs_row_end($key, $args);
2838
-					}
2839
-				}
2832
+                    }
2833
+                } else {
2834
+                    foreach ( $arguments as $key => $args ) {
2835
+                        $this->widget_inputs_row_start($key, $args);
2836
+                        $this->widget_inputs( $args, $instance );
2837
+                        $this->widget_inputs_row_end($key, $args);
2838
+                    }
2839
+                }
2840 2840
 
2841
-			}
2842
-		}
2841
+            }
2842
+        }
2843 2843
 
2844
-		public function widget_inputs_row_start($key, $args){
2845
-			if(!empty($args['row'])){
2846
-				// maybe open
2847
-				if(!empty($args['row']['open'])){
2848
-					?>
2844
+        public function widget_inputs_row_start($key, $args){
2845
+            if(!empty($args['row'])){
2846
+                // maybe open
2847
+                if(!empty($args['row']['open'])){
2848
+                    ?>
2849 2849
 					<div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) {
2850
-						echo $this->convert_element_require( $args['row']['element_require'] );
2851
-					} ?>'>
2850
+                        echo $this->convert_element_require( $args['row']['element_require'] );
2851
+                    } ?>'>
2852 2852
 					<?php if(!empty($args['row']['title'])){ ?>
2853 2853
 					<label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
2854 2854
 					<?php }?>
2855 2855
 					<div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'>
2856 2856
 					<div class='col pr-2'>
2857 2857
 					<?php
2858
-				}elseif(!empty($args['row']['close'])){
2859
-					echo "<div class='col pl-0'>";
2860
-				}else{
2861
-					echo "<div class='col pl-0 pr-2'>";
2862
-				}
2863
-			}
2864
-		}
2865
-
2866
-		public function widget_inputs_row_end($key, $args){
2867
-
2868
-			if(!empty($args['row'])){
2869
-				// maybe close
2870
-				if(!empty($args['row']['close'])){
2871
-					echo "</div></div>";
2872
-				}
2873
-
2874
-				echo "</div>";
2875
-			}
2876
-		}
2877
-
2878
-		/**
2879
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
2880
-		 *
2881
-		 * @return string
2882
-		 */
2883
-		public function widget_advanced_toggle() {
2884
-
2885
-			$output = '';
2886
-			if ( $this->block_show_advanced() ) {
2887
-				$val = 1;
2888
-			} else {
2889
-				$val = 0;
2890
-			}
2891
-
2892
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2893
-
2894
-			return $output;
2895
-		}
2896
-
2897
-		/**
2898
-		 * Convert require element.
2899
-		 *
2900
-		 * @since 1.0.0
2901
-		 *
2902
-		 * @param string $input Input element.
2903
-		 *
2904
-		 * @return string $output
2905
-		 */
2906
-		public function convert_element_require( $input ) {
2907
-
2908
-			$input = str_replace( "'", '"', $input );// we only want double quotes
2909
-
2910
-			$output = esc_attr( str_replace( array( "[%", "%]" ), array(
2911
-				"jQuery(form).find('[data-argument=\"",
2912
-				"\"]').find('input,select,textarea').val()"
2913
-			), $input ) );
2914
-
2915
-			return $output;
2916
-		}
2917
-
2918
-		/**
2919
-		 * Builds the inputs for the widget options.
2920
-		 *
2921
-		 * @param $args
2922
-		 * @param $instance
2923
-		 */
2924
-		public function widget_inputs( $args, $instance ) {
2925
-
2926
-			$class             = "";
2927
-			$element_require   = "";
2928
-			$custom_attributes = "";
2929
-
2930
-			// get value
2931
-			if ( isset( $instance[ $args['name'] ] ) ) {
2932
-				$value = $instance[ $args['name'] ];
2933
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2934
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2935
-			} else {
2936
-				$value = '';
2937
-			}
2938
-
2939
-			// get placeholder
2940
-			if ( ! empty( $args['placeholder'] ) ) {
2941
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2942
-			} else {
2943
-				$placeholder = '';
2944
-			}
2945
-
2946
-			// get if advanced
2947
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2948
-				$class .= " sd-advanced-setting ";
2949
-			}
2950
-
2951
-			// element_require
2952
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2953
-				$element_require = $args['element_require'];
2954
-			}
2955
-
2956
-			// custom_attributes
2957
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2958
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2959
-			}
2960
-
2961
-
2962
-			// before wrapper
2963
-			?>
2858
+                }elseif(!empty($args['row']['close'])){
2859
+                    echo "<div class='col pl-0'>";
2860
+                }else{
2861
+                    echo "<div class='col pl-0 pr-2'>";
2862
+                }
2863
+            }
2864
+        }
2865
+
2866
+        public function widget_inputs_row_end($key, $args){
2867
+
2868
+            if(!empty($args['row'])){
2869
+                // maybe close
2870
+                if(!empty($args['row']['close'])){
2871
+                    echo "</div></div>";
2872
+                }
2873
+
2874
+                echo "</div>";
2875
+            }
2876
+        }
2877
+
2878
+        /**
2879
+         * Get the hidden input that when added makes the advanced button show on widget settings.
2880
+         *
2881
+         * @return string
2882
+         */
2883
+        public function widget_advanced_toggle() {
2884
+
2885
+            $output = '';
2886
+            if ( $this->block_show_advanced() ) {
2887
+                $val = 1;
2888
+            } else {
2889
+                $val = 0;
2890
+            }
2891
+
2892
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
2893
+
2894
+            return $output;
2895
+        }
2896
+
2897
+        /**
2898
+         * Convert require element.
2899
+         *
2900
+         * @since 1.0.0
2901
+         *
2902
+         * @param string $input Input element.
2903
+         *
2904
+         * @return string $output
2905
+         */
2906
+        public function convert_element_require( $input ) {
2907
+
2908
+            $input = str_replace( "'", '"', $input );// we only want double quotes
2909
+
2910
+            $output = esc_attr( str_replace( array( "[%", "%]" ), array(
2911
+                "jQuery(form).find('[data-argument=\"",
2912
+                "\"]').find('input,select,textarea').val()"
2913
+            ), $input ) );
2914
+
2915
+            return $output;
2916
+        }
2917
+
2918
+        /**
2919
+         * Builds the inputs for the widget options.
2920
+         *
2921
+         * @param $args
2922
+         * @param $instance
2923
+         */
2924
+        public function widget_inputs( $args, $instance ) {
2925
+
2926
+            $class             = "";
2927
+            $element_require   = "";
2928
+            $custom_attributes = "";
2929
+
2930
+            // get value
2931
+            if ( isset( $instance[ $args['name'] ] ) ) {
2932
+                $value = $instance[ $args['name'] ];
2933
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
2934
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
2935
+            } else {
2936
+                $value = '';
2937
+            }
2938
+
2939
+            // get placeholder
2940
+            if ( ! empty( $args['placeholder'] ) ) {
2941
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
2942
+            } else {
2943
+                $placeholder = '';
2944
+            }
2945
+
2946
+            // get if advanced
2947
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
2948
+                $class .= " sd-advanced-setting ";
2949
+            }
2950
+
2951
+            // element_require
2952
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
2953
+                $element_require = $args['element_require'];
2954
+            }
2955
+
2956
+            // custom_attributes
2957
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
2958
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
2959
+            }
2960
+
2961
+
2962
+            // before wrapper
2963
+            ?>
2964 2964
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>"
2965 2965
 			data-argument='<?php echo esc_attr( $args['name'] ); ?>'
2966 2966
 			data-element_require='<?php if ( $element_require ) {
2967
-				echo $this->convert_element_require( $element_require );
2968
-			} ?>'
2967
+                echo $this->convert_element_require( $element_require );
2968
+            } ?>'
2969 2969
 			>
2970 2970
 			<?php
2971 2971
 
2972 2972
 
2973
-			switch ( $args['type'] ) {
2974
-				//array('text','password','number','email','tel','url','color')
2975
-				case "text":
2976
-				case "password":
2977
-				case "number":
2978
-				case "email":
2979
-				case "tel":
2980
-				case "url":
2981
-				case "color":
2982
-					?>
2973
+            switch ( $args['type'] ) {
2974
+                //array('text','password','number','email','tel','url','color')
2975
+                case "text":
2976
+                case "password":
2977
+                case "number":
2978
+                case "email":
2979
+                case "tel":
2980
+                case "url":
2981
+                case "color":
2982
+                    ?>
2983 2983
 					<label
2984 2984
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
2985 2985
 					<input <?php echo $placeholder; ?> class="widefat"
@@ -2990,47 +2990,47 @@  discard block
 block discarded – undo
2990 2990
 						                               value="<?php echo esc_attr( $value ); ?>">
2991 2991
 					<?php
2992 2992
 
2993
-					break;
2994
-				case "select":
2995
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2996
-					if ( $multiple ) {
2997
-						if ( empty( $value ) ) {
2998
-							$value = array();
2999
-						}
3000
-					}
3001
-					?>
2993
+                    break;
2994
+                case "select":
2995
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
2996
+                    if ( $multiple ) {
2997
+                        if ( empty( $value ) ) {
2998
+                            $value = array();
2999
+                        }
3000
+                    }
3001
+                    ?>
3002 3002
 					<label
3003 3003
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
3004 3004
 					<select <?php echo $placeholder; ?> class="widefat"
3005 3005
 						<?php echo $custom_attributes; ?>
3006 3006
 						                                id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3007 3007
 						                                name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) );
3008
-						                                if ( $multiple ) {
3009
-							                                echo "[]";
3010
-						                                } ?>"
3008
+                                                        if ( $multiple ) {
3009
+                                                            echo "[]";
3010
+                                                        } ?>"
3011 3011
 						<?php if ( $multiple ) {
3012
-							echo "multiple";
3013
-						} //@todo not implemented yet due to gutenberg not supporting it
3014
-						?>
3012
+                            echo "multiple";
3013
+                        } //@todo not implemented yet due to gutenberg not supporting it
3014
+                        ?>
3015 3015
 					>
3016 3016
 						<?php
3017 3017
 
3018
-						if ( ! empty( $args['options'] ) ) {
3019
-							foreach ( $args['options'] as $val => $label ) {
3020
-								if ( $multiple ) {
3021
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
3022
-								} else {
3023
-									$selected = selected( $value, $val, false );
3024
-								}
3025
-								echo "<option value='$val' " . $selected . ">$label</option>";
3026
-							}
3027
-						}
3028
-						?>
3018
+                        if ( ! empty( $args['options'] ) ) {
3019
+                            foreach ( $args['options'] as $val => $label ) {
3020
+                                if ( $multiple ) {
3021
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
3022
+                                } else {
3023
+                                    $selected = selected( $value, $val, false );
3024
+                                }
3025
+                                echo "<option value='$val' " . $selected . ">$label</option>";
3026
+                            }
3027
+                        }
3028
+                        ?>
3029 3029
 					</select>
3030 3030
 					<?php
3031
-					break;
3032
-				case "checkbox":
3033
-					?>
3031
+                    break;
3032
+                case "checkbox":
3033
+                    ?>
3034 3034
 					<input <?php echo $placeholder; ?>
3035 3035
 						<?php checked( 1, $value, true ) ?>
3036 3036
 						<?php echo $custom_attributes; ?>
@@ -3040,9 +3040,9 @@  discard block
 block discarded – undo
3040 3040
 					<label
3041 3041
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label>
3042 3042
 					<?php
3043
-					break;
3044
-				case "textarea":
3045
-					?>
3043
+                    break;
3044
+                case "textarea":
3045
+                    ?>
3046 3046
 					<label
3047 3047
 						for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label>
3048 3048
 					<textarea <?php echo $placeholder; ?> class="widefat"
@@ -3052,280 +3052,280 @@  discard block
 block discarded – undo
3052 3052
 					><?php echo esc_attr( $value ); ?></textarea>
3053 3053
 					<?php
3054 3054
 
3055
-					break;
3056
-				case "hidden":
3057
-					?>
3055
+                    break;
3056
+                case "hidden":
3057
+                    ?>
3058 3058
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
3059 3059
 					       name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden"
3060 3060
 					       value="<?php echo esc_attr( $value ); ?>">
3061 3061
 					<?php
3062
-					break;
3063
-				default:
3064
-					echo "No input type found!"; // @todo we need to add more input types.
3065
-			}
3062
+                    break;
3063
+                default:
3064
+                    echo "No input type found!"; // @todo we need to add more input types.
3065
+            }
3066 3066
 
3067
-			// after wrapper
3068
-			?>
3067
+            // after wrapper
3068
+            ?>
3069 3069
 			</p>
3070 3070
 			<?php
3071 3071
 
3072 3072
 
3073
-		}
3074
-
3075
-		public function get_widget_icon($icon = 'box-top', $title = ''){
3076
-			if($icon=='box-top'){
3077
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
3078
-			}elseif($icon=='box-right'){
3079
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
3080
-			}elseif($icon=='box-bottom'){
3081
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
3082
-			}elseif($icon=='box-left'){
3083
-				return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
3084
-			}
3085
-		}
3086
-
3087
-		/**
3088
-		 * Get the widget input description html.
3089
-		 *
3090
-		 * @param $args
3091
-		 *
3092
-		 * @return string
3093
-		 * @todo, need to make its own tooltip script
3094
-		 */
3095
-		public function widget_field_desc( $args ) {
3096
-
3097
-			$description = '';
3098
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
3099
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3100
-					$description = $this->desc_tip( $args['desc'] );
3101
-				} else {
3102
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3103
-				}
3104
-			}
3105
-
3106
-			return $description;
3107
-		}
3108
-
3109
-		/**
3110
-		 * Get the widget input title html.
3111
-		 *
3112
-		 * @param $args
3113
-		 *
3114
-		 * @return string
3115
-		 */
3116
-		public function widget_field_title( $args ) {
3117
-
3118
-			$title = '';
3119
-			if ( isset( $args['title'] ) && $args['title'] ) {
3120
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
3121
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
3122
-				} else {
3123
-					$title = esc_attr($args['title']);
3124
-				}
3125
-			}
3126
-
3127
-			return $title;
3128
-		}
3129
-
3130
-		/**
3131
-		 * Get the tool tip html.
3132
-		 *
3133
-		 * @param $tip
3134
-		 * @param bool $allow_html
3135
-		 *
3136
-		 * @return string
3137
-		 */
3138
-		function desc_tip( $tip, $allow_html = false ) {
3139
-			if ( $allow_html ) {
3140
-				$tip = $this->sanitize_tooltip( $tip );
3141
-			} else {
3142
-				$tip = esc_attr( $tip );
3143
-			}
3144
-
3145
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3146
-		}
3147
-
3148
-		/**
3149
-		 * Sanitize a string destined to be a tooltip.
3150
-		 *
3151
-		 * @param string $var
3152
-		 *
3153
-		 * @return string
3154
-		 */
3155
-		public function sanitize_tooltip( $var ) {
3156
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3157
-				'br'     => array(),
3158
-				'em'     => array(),
3159
-				'strong' => array(),
3160
-				'small'  => array(),
3161
-				'span'   => array(),
3162
-				'ul'     => array(),
3163
-				'li'     => array(),
3164
-				'ol'     => array(),
3165
-				'p'      => array(),
3166
-			) ) );
3167
-		}
3168
-
3169
-		/**
3170
-		 * Processing widget options on save
3171
-		 *
3172
-		 * @param array $new_instance The new options
3173
-		 * @param array $old_instance The previous options
3174
-		 *
3175
-		 * @return array
3176
-		 * @todo we should add some sanitation here.
3177
-		 */
3178
-		public function update( $new_instance, $old_instance ) {
3179
-
3180
-			//save the widget
3181
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
3182
-
3183
-			// set widget instance
3184
-			$this->instance = $instance;
3185
-
3186
-			if ( empty( $this->arguments ) ) {
3187
-				$this->get_arguments();
3188
-			}
3189
-
3190
-			// check for checkboxes
3191
-			if ( ! empty( $this->arguments ) ) {
3192
-				foreach ( $this->arguments as $argument ) {
3193
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3194
-						$instance[ $argument['name'] ] = '0';
3195
-					}
3196
-				}
3197
-			}
3198
-
3199
-			return $instance;
3200
-		}
3201
-
3202
-		/**
3203
-		 * Checks if the current call is a ajax call to get the block content.
3204
-		 *
3205
-		 * This can be used in your widget to return different content as the block content.
3206
-		 *
3207
-		 * @since 1.0.3
3208
-		 * @return bool
3209
-		 */
3210
-		public function is_block_content_call() {
3211
-			$result = false;
3212
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3213
-				$result = true;
3214
-			}
3215
-
3216
-			return $result;
3217
-		}
3218
-
3219
-		/**
3220
-		 * Get an instance hash that will be unique to the type and settings.
3221
-		 *
3222
-		 * @since 1.0.20
3223
-		 * @return string
3224
-		 */
3225
-		public function get_instance_hash(){
3226
-			$instance_string = $this->base_id.serialize($this->instance);
3227
-			return hash('crc32b',$instance_string);
3228
-		}
3229
-
3230
-		/**
3231
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3232
-		 *
3233
-		 * @param array $rules
3234
-		 *
3235
-		 * @since 1.0.20
3236
-		 * @return string
3237
-		 */
3238
-		public function get_instance_style($rules = array()){
3239
-			$css = '';
3240
-
3241
-			if(!empty($rules)){
3242
-				$rules = array_unique($rules);
3243
-				$instance_hash = $this->get_instance_hash();
3244
-				$css .= "<style>";
3245
-				foreach($rules as $rule){
3246
-					$css .= ".sdel-$instance_hash $rule";
3247
-				}
3248
-				$css .= "</style>";
3249
-			}
3250
-
3251
-			return $css;
3252
-		}
3253
-
3254
-		/**
3255
-		 * Encode shortcodes tags.
3256
-		 *
3257
-		 * @since 1.0.28
3258
-		 *
3259
-		 * @param string $content Content to search for shortcode tags.
3260
-		 * @return string Content with shortcode tags removed.
3261
-		 */
3262
-		public function encode_shortcodes( $content ) {
3263
-			// Avoids existing encoded tags.
3264
-			$trans   = array(
3265
-				'&#91;' => '&#091;',
3266
-				'&#93;' => '&#093;',
3267
-				'&amp;#91;' => '&#091;',
3268
-				'&amp;#93;' => '&#093;',
3269
-				'&lt;' => '&0lt;',
3270
-				'&gt;' => '&0gt;',
3271
-				'&amp;lt;' => '&0lt;',
3272
-				'&amp;gt;' => '&0gt;',
3273
-			);
3274
-
3275
-			$content = strtr( $content, $trans );
3276
-
3277
-			$trans   = array(
3278
-				'[' => '&#91;',
3279
-				']' => '&#93;',
3280
-				'<' => '&lt;',
3281
-				'>' => '&gt;',
3282
-				'"' => '&quot;',
3283
-				"'" => '&apos;',
3284
-			);
3285
-
3286
-			$content = strtr( $content, $trans );
3287
-
3288
-			return $content;
3289
-		}
3290
-
3291
-		/**
3292
-		 * Remove encoded shortcod tags.
3293
-		 *
3294
-		 * @since 1.0.28
3295
-		 *
3296
-		 * @param string $content Content to search for shortcode tags.
3297
-		 * @return string Content with decoded shortcode tags.
3298
-		 */
3299
-		public function decode_shortcodes( $content ) {
3300
-			$trans   = array(
3301
-				'&#91;' => '[',
3302
-				'&#93;' => ']',
3303
-				'&amp;#91;' => '[',
3304
-				'&amp;#93;' => ']',
3305
-				'&lt;' => '<',
3306
-				'&gt;' => '>',
3307
-				'&amp;lt;' => '<',
3308
-				'&amp;gt;' => '>',
3309
-				'&quot;' => '"',
3310
-				'&apos;' => "'",
3311
-			);
3312
-
3313
-			$content = strtr( $content, $trans );
3314
-
3315
-			$trans   = array(
3316
-				'&#091;' => '&#91;',
3317
-				'&#093;' => '&#93;',
3318
-				'&amp;#091;' => '&#91;',
3319
-				'&amp;#093;' => '&#93;',
3320
-				'&0lt;' => '&lt;',
3321
-				'&0gt;' => '&gt;',
3322
-				'&amp;0lt;' => '&lt;',
3323
-				'&amp;0gt;' => '&gt;',
3324
-			);
3325
-
3326
-			$content = strtr( $content, $trans );
3327
-
3328
-			return $content;
3329
-		}
3330
-	}
3073
+        }
3074
+
3075
+        public function get_widget_icon($icon = 'box-top', $title = ''){
3076
+            if($icon=='box-top'){
3077
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>';
3078
+            }elseif($icon=='box-right'){
3079
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>';
3080
+            }elseif($icon=='box-bottom'){
3081
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>';
3082
+            }elseif($icon=='box-left'){
3083
+                return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>';
3084
+            }
3085
+        }
3086
+
3087
+        /**
3088
+         * Get the widget input description html.
3089
+         *
3090
+         * @param $args
3091
+         *
3092
+         * @return string
3093
+         * @todo, need to make its own tooltip script
3094
+         */
3095
+        public function widget_field_desc( $args ) {
3096
+
3097
+            $description = '';
3098
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
3099
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
3100
+                    $description = $this->desc_tip( $args['desc'] );
3101
+                } else {
3102
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
3103
+                }
3104
+            }
3105
+
3106
+            return $description;
3107
+        }
3108
+
3109
+        /**
3110
+         * Get the widget input title html.
3111
+         *
3112
+         * @param $args
3113
+         *
3114
+         * @return string
3115
+         */
3116
+        public function widget_field_title( $args ) {
3117
+
3118
+            $title = '';
3119
+            if ( isset( $args['title'] ) && $args['title'] ) {
3120
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
3121
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
3122
+                } else {
3123
+                    $title = esc_attr($args['title']);
3124
+                }
3125
+            }
3126
+
3127
+            return $title;
3128
+        }
3129
+
3130
+        /**
3131
+         * Get the tool tip html.
3132
+         *
3133
+         * @param $tip
3134
+         * @param bool $allow_html
3135
+         *
3136
+         * @return string
3137
+         */
3138
+        function desc_tip( $tip, $allow_html = false ) {
3139
+            if ( $allow_html ) {
3140
+                $tip = $this->sanitize_tooltip( $tip );
3141
+            } else {
3142
+                $tip = esc_attr( $tip );
3143
+            }
3144
+
3145
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
3146
+        }
3147
+
3148
+        /**
3149
+         * Sanitize a string destined to be a tooltip.
3150
+         *
3151
+         * @param string $var
3152
+         *
3153
+         * @return string
3154
+         */
3155
+        public function sanitize_tooltip( $var ) {
3156
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
3157
+                'br'     => array(),
3158
+                'em'     => array(),
3159
+                'strong' => array(),
3160
+                'small'  => array(),
3161
+                'span'   => array(),
3162
+                'ul'     => array(),
3163
+                'li'     => array(),
3164
+                'ol'     => array(),
3165
+                'p'      => array(),
3166
+            ) ) );
3167
+        }
3168
+
3169
+        /**
3170
+         * Processing widget options on save
3171
+         *
3172
+         * @param array $new_instance The new options
3173
+         * @param array $old_instance The previous options
3174
+         *
3175
+         * @return array
3176
+         * @todo we should add some sanitation here.
3177
+         */
3178
+        public function update( $new_instance, $old_instance ) {
3179
+
3180
+            //save the widget
3181
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
3182
+
3183
+            // set widget instance
3184
+            $this->instance = $instance;
3185
+
3186
+            if ( empty( $this->arguments ) ) {
3187
+                $this->get_arguments();
3188
+            }
3189
+
3190
+            // check for checkboxes
3191
+            if ( ! empty( $this->arguments ) ) {
3192
+                foreach ( $this->arguments as $argument ) {
3193
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
3194
+                        $instance[ $argument['name'] ] = '0';
3195
+                    }
3196
+                }
3197
+            }
3198
+
3199
+            return $instance;
3200
+        }
3201
+
3202
+        /**
3203
+         * Checks if the current call is a ajax call to get the block content.
3204
+         *
3205
+         * This can be used in your widget to return different content as the block content.
3206
+         *
3207
+         * @since 1.0.3
3208
+         * @return bool
3209
+         */
3210
+        public function is_block_content_call() {
3211
+            $result = false;
3212
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3213
+                $result = true;
3214
+            }
3215
+
3216
+            return $result;
3217
+        }
3218
+
3219
+        /**
3220
+         * Get an instance hash that will be unique to the type and settings.
3221
+         *
3222
+         * @since 1.0.20
3223
+         * @return string
3224
+         */
3225
+        public function get_instance_hash(){
3226
+            $instance_string = $this->base_id.serialize($this->instance);
3227
+            return hash('crc32b',$instance_string);
3228
+        }
3229
+
3230
+        /**
3231
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
3232
+         *
3233
+         * @param array $rules
3234
+         *
3235
+         * @since 1.0.20
3236
+         * @return string
3237
+         */
3238
+        public function get_instance_style($rules = array()){
3239
+            $css = '';
3240
+
3241
+            if(!empty($rules)){
3242
+                $rules = array_unique($rules);
3243
+                $instance_hash = $this->get_instance_hash();
3244
+                $css .= "<style>";
3245
+                foreach($rules as $rule){
3246
+                    $css .= ".sdel-$instance_hash $rule";
3247
+                }
3248
+                $css .= "</style>";
3249
+            }
3250
+
3251
+            return $css;
3252
+        }
3253
+
3254
+        /**
3255
+         * Encode shortcodes tags.
3256
+         *
3257
+         * @since 1.0.28
3258
+         *
3259
+         * @param string $content Content to search for shortcode tags.
3260
+         * @return string Content with shortcode tags removed.
3261
+         */
3262
+        public function encode_shortcodes( $content ) {
3263
+            // Avoids existing encoded tags.
3264
+            $trans   = array(
3265
+                '&#91;' => '&#091;',
3266
+                '&#93;' => '&#093;',
3267
+                '&amp;#91;' => '&#091;',
3268
+                '&amp;#93;' => '&#093;',
3269
+                '&lt;' => '&0lt;',
3270
+                '&gt;' => '&0gt;',
3271
+                '&amp;lt;' => '&0lt;',
3272
+                '&amp;gt;' => '&0gt;',
3273
+            );
3274
+
3275
+            $content = strtr( $content, $trans );
3276
+
3277
+            $trans   = array(
3278
+                '[' => '&#91;',
3279
+                ']' => '&#93;',
3280
+                '<' => '&lt;',
3281
+                '>' => '&gt;',
3282
+                '"' => '&quot;',
3283
+                "'" => '&apos;',
3284
+            );
3285
+
3286
+            $content = strtr( $content, $trans );
3287
+
3288
+            return $content;
3289
+        }
3290
+
3291
+        /**
3292
+         * Remove encoded shortcod tags.
3293
+         *
3294
+         * @since 1.0.28
3295
+         *
3296
+         * @param string $content Content to search for shortcode tags.
3297
+         * @return string Content with decoded shortcode tags.
3298
+         */
3299
+        public function decode_shortcodes( $content ) {
3300
+            $trans   = array(
3301
+                '&#91;' => '[',
3302
+                '&#93;' => ']',
3303
+                '&amp;#91;' => '[',
3304
+                '&amp;#93;' => ']',
3305
+                '&lt;' => '<',
3306
+                '&gt;' => '>',
3307
+                '&amp;lt;' => '<',
3308
+                '&amp;gt;' => '>',
3309
+                '&quot;' => '"',
3310
+                '&apos;' => "'",
3311
+            );
3312
+
3313
+            $content = strtr( $content, $trans );
3314
+
3315
+            $trans   = array(
3316
+                '&#091;' => '&#91;',
3317
+                '&#093;' => '&#93;',
3318
+                '&amp;#091;' => '&#91;',
3319
+                '&amp;#093;' => '&#93;',
3320
+                '&0lt;' => '&lt;',
3321
+                '&0gt;' => '&gt;',
3322
+                '&amp;0lt;' => '&lt;',
3323
+                '&amp;0gt;' => '&gt;',
3324
+            );
3325
+
3326
+            $content = strtr( $content, $trans );
3327
+
3328
+            return $content;
3329
+        }
3330
+    }
3331 3331
 }
Please login to merge, or discard this patch.
vendor/ayecode/wp-font-awesome-settings/wp-font-awesome-settings.php 1 patch
Indentation   +403 added lines, -403 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,300 +21,300 @@  discard block
 block discarded – undo
21 21
  */
22 22
 if ( ! class_exists( 'WP_Font_Awesome_Settings' ) ) {
23 23
 
24
-	/**
25
-	 * A Class to be able to change settings for Font Awesome.
26
-	 *
27
-	 * Class WP_Font_Awesome_Settings
28
-	 * @since 1.0.10 Now able to pass wp.org theme check.
29
-	 * @since 1.0.11 Font Awesome Pro now supported.
30
-	 * @since 1.0.11 Font Awesome Kits now supported.
31
-	 * @since 1.0.13 RTL language support added.
32
-	 * @ver 1.0.13
33
-	 * @todo decide how to implement textdomain
34
-	 */
35
-	class WP_Font_Awesome_Settings {
36
-
37
-		/**
38
-		 * Class version version.
39
-		 *
40
-		 * @var string
41
-		 */
42
-		public $version = '1.0.13';
43
-
44
-		/**
45
-		 * Class textdomain.
46
-		 *
47
-		 * @var string
48
-		 */
49
-		public $textdomain = 'font-awesome-settings';
50
-
51
-		/**
52
-		 * Latest version of Font Awesome at time of publish published.
53
-		 *
54
-		 * @var string
55
-		 */
56
-		public $latest = "5.8.2";
57
-
58
-		/**
59
-		 * The title.
60
-		 *
61
-		 * @var string
62
-		 */
63
-		public $name = 'Font Awesome';
64
-
65
-		/**
66
-		 * Holds the settings values.
67
-		 *
68
-		 * @var array
69
-		 */
70
-		private $settings;
71
-
72
-		/**
73
-		 * WP_Font_Awesome_Settings instance.
74
-		 *
75
-		 * @access private
76
-		 * @since  1.0.0
77
-		 * @var    WP_Font_Awesome_Settings There can be only one!
78
-		 */
79
-		private static $instance = null;
80
-
81
-		/**
82
-		 * Main WP_Font_Awesome_Settings Instance.
83
-		 *
84
-		 * Ensures only one instance of WP_Font_Awesome_Settings is loaded or can be loaded.
85
-		 *
86
-		 * @since 1.0.0
87
-		 * @static
88
-		 * @return WP_Font_Awesome_Settings - Main instance.
89
-		 */
90
-		public static function instance() {
91
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof WP_Font_Awesome_Settings ) ) {
92
-				self::$instance = new WP_Font_Awesome_Settings;
93
-
94
-				add_action( 'init', array( self::$instance, 'init' ) ); // set settings
95
-
96
-				if ( is_admin() ) {
97
-					add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
98
-					add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
99
-				}
100
-
101
-				do_action( 'wp_font_awesome_settings_loaded' );
102
-			}
103
-
104
-			return self::$instance;
105
-		}
106
-
107
-		/**
108
-		 * Initiate the settings and add the required action hooks.
109
-		 *
110
-		 * @since 1.0.8 Settings name wrong - FIXED
111
-		 */
112
-		public function init() {
113
-			$this->settings = $this->get_settings();
114
-
115
-			if ( $this->settings['type'] == 'CSS' ) {
116
-
117
-				if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'frontend' ) {
118
-					add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 5000 );
119
-				}
120
-
121
-				if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'backend' ) {
122
-					add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 5000 );
123
-				}
124
-
125
-			} else {
126
-
127
-				if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'frontend' ) {
128
-					add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), 5000 );
129
-				}
130
-
131
-				if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'backend' ) {
132
-					add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 5000 );
133
-				}
134
-			}
135
-
136
-			// remove font awesome if set to do so
137
-			if ( $this->settings['dequeue'] == '1' ) {
138
-				add_action( 'clean_url', array( $this, 'remove_font_awesome' ), 5000, 3 );
139
-			}
140
-
141
-		}
142
-
143
-		/**
144
-		 * Adds the Font Awesome styles.
145
-		 */
146
-		public function enqueue_style() {
147
-			// build url
148
-			$url = $this->get_url();
149
-
150
-			wp_deregister_style( 'font-awesome' ); // deregister in case its already there
151
-			wp_register_style( 'font-awesome', $url, array(), null );
152
-			wp_enqueue_style( 'font-awesome' );
153
-
154
-			// RTL language support CSS.
155
-			if ( is_rtl() ) {
156
-				wp_add_inline_style( 'font-awesome', $this->rtl_inline_css() );
157
-			}
158
-
159
-			if ( $this->settings['shims'] ) {
160
-				$url = $this->get_url( true );
161
-				wp_deregister_style( 'font-awesome-shims' ); // deregister in case its already there
162
-				wp_register_style( 'font-awesome-shims', $url, array(), null );
163
-				wp_enqueue_style( 'font-awesome-shims' );
164
-			}
165
-		}
166
-
167
-		/**
168
-		 * Adds the Font Awesome JS.
169
-		 */
170
-		public function enqueue_scripts() {
171
-			// build url
172
-			$url = $this->get_url();
173
-
174
-			$deregister_function = 'wp' . '_' . 'deregister' . '_' . 'script';
175
-			call_user_func( $deregister_function, 'font-awesome' ); // deregister in case its already there
176
-			wp_register_script( 'font-awesome', $url, array(), null );
177
-			wp_enqueue_script( 'font-awesome' );
178
-
179
-			if ( $this->settings['shims'] ) {
180
-				$url = $this->get_url( true );
181
-				call_user_func( $deregister_function, 'font-awesome-shims' ); // deregister in case its already there
182
-				wp_register_script( 'font-awesome-shims', $url, array(), null );
183
-				wp_enqueue_script( 'font-awesome-shims' );
184
-			}
185
-		}
186
-
187
-		/**
188
-		 * Get the url of the Font Awesome files.
189
-		 *
190
-		 * @param bool $shims If this is a shim file or not.
191
-		 *
192
-		 * @return string The url to the file.
193
-		 */
194
-		public function get_url( $shims = false ) {
195
-			$script  = $shims ? 'v4-shims' : 'all';
196
-			$sub     = $this->settings['pro'] ? 'pro' : 'use';
197
-			$type    = $this->settings['type'];
198
-			$version = $this->settings['version'];
199
-			$kit_url = $this->settings['kit-url'] ? esc_url( $this->settings['kit-url'] ) : '';
200
-			$url     = '';
201
-
202
-			if ( $type == 'KIT' && $kit_url ) {
203
-				if ( $shims ) {
204
-					// if its a kit then we don't add shims here
205
-					return '';
206
-				}
207
-				$url .= $kit_url; // CDN
208
-				$url .= "?wpfas=true"; // set our var so our version is not removed
209
-			} else {
210
-				$url .= "https://$sub.fontawesome.com/releases/"; // CDN
211
-				$url .= ! empty( $version ) ? "v" . $version . '/' : "v" . $this->get_latest_version() . '/'; // version
212
-				$url .= $type == 'CSS' ? 'css/' : 'js/'; // type
213
-				$url .= $type == 'CSS' ? $script . '.css' : $script . '.js'; // type
214
-				$url .= "?wpfas=true"; // set our var so our version is not removed
215
-			}
216
-
217
-			return $url;
218
-		}
219
-
220
-		/**
221
-		 * Try and remove any other versions of Font Awesome added by other plugins/themes.
222
-		 *
223
-		 * Uses the clean_url filter to try and remove any other Font Awesome files added, it can also add pseudo-elements flag for the JS version.
224
-		 *
225
-		 * @param $url
226
-		 * @param $original_url
227
-		 * @param $_context
228
-		 *
229
-		 * @return string The filtered url.
230
-		 */
231
-		public function remove_font_awesome( $url, $original_url, $_context ) {
232
-
233
-			if ( $_context == 'display'
234
-			     && ( strstr( $url, "fontawesome" ) !== false || strstr( $url, "font-awesome" ) !== false )
235
-			     && ( strstr( $url, ".js" ) !== false || strstr( $url, ".css" ) !== false )
236
-			) {// it's a font-awesome-url (probably)
237
-
238
-				if ( strstr( $url, "wpfas=true" ) !== false ) {
239
-					if ( $this->settings['type'] == 'JS' ) {
240
-						if ( $this->settings['js-pseudo'] ) {
241
-							$url .= "' data-search-pseudo-elements defer='defer";
242
-						} else {
243
-							$url .= "' defer='defer";
244
-						}
245
-					}
246
-				} else {
247
-					$url = ''; // removing the url removes the file
248
-				}
249
-
250
-			}
251
-
252
-			return $url;
253
-		}
254
-
255
-		/**
256
-		 * Register the database settings with WordPress.
257
-		 */
258
-		public function register_settings() {
259
-			register_setting( 'wp-font-awesome-settings', 'wp-font-awesome-settings' );
260
-		}
261
-
262
-		/**
263
-		 * Add the WordPress settings menu item.
264
-		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
265
-		 */
266
-		public function menu_item() {
267
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
268
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'wp-font-awesome-settings', array(
269
-				$this,
270
-				'settings_page'
271
-			) );
272
-		}
273
-
274
-		/**
275
-		 * Get the current Font Awesome output settings.
276
-		 *
277
-		 * @return array The array of settings.
278
-		 */
279
-		public function get_settings() {
280
-
281
-			$db_settings = get_option( 'wp-font-awesome-settings' );
282
-
283
-			$defaults = array(
284
-				'type'      => 'CSS', // type to use, CSS or JS or KIT
285
-				'version'   => '', // latest
286
-				'enqueue'   => '', // front and backend
287
-				'shims'     => '0', // default OFF now in 2020
288
-				'js-pseudo' => '0', // if the pseudo elements flag should be set (CPU intensive)
289
-				'dequeue'   => '0', // if we should try to remove other versions added by other plugins/themes
290
-				'pro'       => '0', // if pro CDN url should be used
291
-				'kit-url'   => '', // the kit url
292
-			);
293
-
294
-			$settings = wp_parse_args( $db_settings, $defaults );
295
-
296
-			/**
297
-			 * Filter the Font Awesome settings.
298
-			 *
299
-			 * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
300
-			 */
301
-			return $this->settings = apply_filters( 'wp-font-awesome-settings', $settings, $db_settings, $defaults );
302
-		}
303
-
304
-
305
-		/**
306
-		 * The settings page html output.
307
-		 */
308
-		public function settings_page() {
309
-			if ( ! current_user_can( 'manage_options' ) ) {
310
-				wp_die( __( 'You do not have sufficient permissions to access this page.', 'font-awesome-settings' ) );
311
-			}
312
-
313
-			// a hidden way to force the update of the version number via api instead of waiting the 48 hours
314
-			if ( isset( $_REQUEST['force-version-check'] ) ) {
315
-				$this->get_latest_version( $force_api = true );
316
-			}
317
-			?>
24
+    /**
25
+     * A Class to be able to change settings for Font Awesome.
26
+     *
27
+     * Class WP_Font_Awesome_Settings
28
+     * @since 1.0.10 Now able to pass wp.org theme check.
29
+     * @since 1.0.11 Font Awesome Pro now supported.
30
+     * @since 1.0.11 Font Awesome Kits now supported.
31
+     * @since 1.0.13 RTL language support added.
32
+     * @ver 1.0.13
33
+     * @todo decide how to implement textdomain
34
+     */
35
+    class WP_Font_Awesome_Settings {
36
+
37
+        /**
38
+         * Class version version.
39
+         *
40
+         * @var string
41
+         */
42
+        public $version = '1.0.13';
43
+
44
+        /**
45
+         * Class textdomain.
46
+         *
47
+         * @var string
48
+         */
49
+        public $textdomain = 'font-awesome-settings';
50
+
51
+        /**
52
+         * Latest version of Font Awesome at time of publish published.
53
+         *
54
+         * @var string
55
+         */
56
+        public $latest = "5.8.2";
57
+
58
+        /**
59
+         * The title.
60
+         *
61
+         * @var string
62
+         */
63
+        public $name = 'Font Awesome';
64
+
65
+        /**
66
+         * Holds the settings values.
67
+         *
68
+         * @var array
69
+         */
70
+        private $settings;
71
+
72
+        /**
73
+         * WP_Font_Awesome_Settings instance.
74
+         *
75
+         * @access private
76
+         * @since  1.0.0
77
+         * @var    WP_Font_Awesome_Settings There can be only one!
78
+         */
79
+        private static $instance = null;
80
+
81
+        /**
82
+         * Main WP_Font_Awesome_Settings Instance.
83
+         *
84
+         * Ensures only one instance of WP_Font_Awesome_Settings is loaded or can be loaded.
85
+         *
86
+         * @since 1.0.0
87
+         * @static
88
+         * @return WP_Font_Awesome_Settings - Main instance.
89
+         */
90
+        public static function instance() {
91
+            if ( ! isset( self::$instance ) && ! ( self::$instance instanceof WP_Font_Awesome_Settings ) ) {
92
+                self::$instance = new WP_Font_Awesome_Settings;
93
+
94
+                add_action( 'init', array( self::$instance, 'init' ) ); // set settings
95
+
96
+                if ( is_admin() ) {
97
+                    add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
98
+                    add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
99
+                }
100
+
101
+                do_action( 'wp_font_awesome_settings_loaded' );
102
+            }
103
+
104
+            return self::$instance;
105
+        }
106
+
107
+        /**
108
+         * Initiate the settings and add the required action hooks.
109
+         *
110
+         * @since 1.0.8 Settings name wrong - FIXED
111
+         */
112
+        public function init() {
113
+            $this->settings = $this->get_settings();
114
+
115
+            if ( $this->settings['type'] == 'CSS' ) {
116
+
117
+                if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'frontend' ) {
118
+                    add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 5000 );
119
+                }
120
+
121
+                if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'backend' ) {
122
+                    add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 5000 );
123
+                }
124
+
125
+            } else {
126
+
127
+                if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'frontend' ) {
128
+                    add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), 5000 );
129
+                }
130
+
131
+                if ( $this->settings['enqueue'] == '' || $this->settings['enqueue'] == 'backend' ) {
132
+                    add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 5000 );
133
+                }
134
+            }
135
+
136
+            // remove font awesome if set to do so
137
+            if ( $this->settings['dequeue'] == '1' ) {
138
+                add_action( 'clean_url', array( $this, 'remove_font_awesome' ), 5000, 3 );
139
+            }
140
+
141
+        }
142
+
143
+        /**
144
+         * Adds the Font Awesome styles.
145
+         */
146
+        public function enqueue_style() {
147
+            // build url
148
+            $url = $this->get_url();
149
+
150
+            wp_deregister_style( 'font-awesome' ); // deregister in case its already there
151
+            wp_register_style( 'font-awesome', $url, array(), null );
152
+            wp_enqueue_style( 'font-awesome' );
153
+
154
+            // RTL language support CSS.
155
+            if ( is_rtl() ) {
156
+                wp_add_inline_style( 'font-awesome', $this->rtl_inline_css() );
157
+            }
158
+
159
+            if ( $this->settings['shims'] ) {
160
+                $url = $this->get_url( true );
161
+                wp_deregister_style( 'font-awesome-shims' ); // deregister in case its already there
162
+                wp_register_style( 'font-awesome-shims', $url, array(), null );
163
+                wp_enqueue_style( 'font-awesome-shims' );
164
+            }
165
+        }
166
+
167
+        /**
168
+         * Adds the Font Awesome JS.
169
+         */
170
+        public function enqueue_scripts() {
171
+            // build url
172
+            $url = $this->get_url();
173
+
174
+            $deregister_function = 'wp' . '_' . 'deregister' . '_' . 'script';
175
+            call_user_func( $deregister_function, 'font-awesome' ); // deregister in case its already there
176
+            wp_register_script( 'font-awesome', $url, array(), null );
177
+            wp_enqueue_script( 'font-awesome' );
178
+
179
+            if ( $this->settings['shims'] ) {
180
+                $url = $this->get_url( true );
181
+                call_user_func( $deregister_function, 'font-awesome-shims' ); // deregister in case its already there
182
+                wp_register_script( 'font-awesome-shims', $url, array(), null );
183
+                wp_enqueue_script( 'font-awesome-shims' );
184
+            }
185
+        }
186
+
187
+        /**
188
+         * Get the url of the Font Awesome files.
189
+         *
190
+         * @param bool $shims If this is a shim file or not.
191
+         *
192
+         * @return string The url to the file.
193
+         */
194
+        public function get_url( $shims = false ) {
195
+            $script  = $shims ? 'v4-shims' : 'all';
196
+            $sub     = $this->settings['pro'] ? 'pro' : 'use';
197
+            $type    = $this->settings['type'];
198
+            $version = $this->settings['version'];
199
+            $kit_url = $this->settings['kit-url'] ? esc_url( $this->settings['kit-url'] ) : '';
200
+            $url     = '';
201
+
202
+            if ( $type == 'KIT' && $kit_url ) {
203
+                if ( $shims ) {
204
+                    // if its a kit then we don't add shims here
205
+                    return '';
206
+                }
207
+                $url .= $kit_url; // CDN
208
+                $url .= "?wpfas=true"; // set our var so our version is not removed
209
+            } else {
210
+                $url .= "https://$sub.fontawesome.com/releases/"; // CDN
211
+                $url .= ! empty( $version ) ? "v" . $version . '/' : "v" . $this->get_latest_version() . '/'; // version
212
+                $url .= $type == 'CSS' ? 'css/' : 'js/'; // type
213
+                $url .= $type == 'CSS' ? $script . '.css' : $script . '.js'; // type
214
+                $url .= "?wpfas=true"; // set our var so our version is not removed
215
+            }
216
+
217
+            return $url;
218
+        }
219
+
220
+        /**
221
+         * Try and remove any other versions of Font Awesome added by other plugins/themes.
222
+         *
223
+         * Uses the clean_url filter to try and remove any other Font Awesome files added, it can also add pseudo-elements flag for the JS version.
224
+         *
225
+         * @param $url
226
+         * @param $original_url
227
+         * @param $_context
228
+         *
229
+         * @return string The filtered url.
230
+         */
231
+        public function remove_font_awesome( $url, $original_url, $_context ) {
232
+
233
+            if ( $_context == 'display'
234
+                 && ( strstr( $url, "fontawesome" ) !== false || strstr( $url, "font-awesome" ) !== false )
235
+                 && ( strstr( $url, ".js" ) !== false || strstr( $url, ".css" ) !== false )
236
+            ) {// it's a font-awesome-url (probably)
237
+
238
+                if ( strstr( $url, "wpfas=true" ) !== false ) {
239
+                    if ( $this->settings['type'] == 'JS' ) {
240
+                        if ( $this->settings['js-pseudo'] ) {
241
+                            $url .= "' data-search-pseudo-elements defer='defer";
242
+                        } else {
243
+                            $url .= "' defer='defer";
244
+                        }
245
+                    }
246
+                } else {
247
+                    $url = ''; // removing the url removes the file
248
+                }
249
+
250
+            }
251
+
252
+            return $url;
253
+        }
254
+
255
+        /**
256
+         * Register the database settings with WordPress.
257
+         */
258
+        public function register_settings() {
259
+            register_setting( 'wp-font-awesome-settings', 'wp-font-awesome-settings' );
260
+        }
261
+
262
+        /**
263
+         * Add the WordPress settings menu item.
264
+         * @since 1.0.10 Calling function name direct will fail theme check so we don't.
265
+         */
266
+        public function menu_item() {
267
+            $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
268
+            call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'wp-font-awesome-settings', array(
269
+                $this,
270
+                'settings_page'
271
+            ) );
272
+        }
273
+
274
+        /**
275
+         * Get the current Font Awesome output settings.
276
+         *
277
+         * @return array The array of settings.
278
+         */
279
+        public function get_settings() {
280
+
281
+            $db_settings = get_option( 'wp-font-awesome-settings' );
282
+
283
+            $defaults = array(
284
+                'type'      => 'CSS', // type to use, CSS or JS or KIT
285
+                'version'   => '', // latest
286
+                'enqueue'   => '', // front and backend
287
+                'shims'     => '0', // default OFF now in 2020
288
+                'js-pseudo' => '0', // if the pseudo elements flag should be set (CPU intensive)
289
+                'dequeue'   => '0', // if we should try to remove other versions added by other plugins/themes
290
+                'pro'       => '0', // if pro CDN url should be used
291
+                'kit-url'   => '', // the kit url
292
+            );
293
+
294
+            $settings = wp_parse_args( $db_settings, $defaults );
295
+
296
+            /**
297
+             * Filter the Font Awesome settings.
298
+             *
299
+             * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
300
+             */
301
+            return $this->settings = apply_filters( 'wp-font-awesome-settings', $settings, $db_settings, $defaults );
302
+        }
303
+
304
+
305
+        /**
306
+         * The settings page html output.
307
+         */
308
+        public function settings_page() {
309
+            if ( ! current_user_can( 'manage_options' ) ) {
310
+                wp_die( __( 'You do not have sufficient permissions to access this page.', 'font-awesome-settings' ) );
311
+            }
312
+
313
+            // a hidden way to force the update of the version number via api instead of waiting the 48 hours
314
+            if ( isset( $_REQUEST['force-version-check'] ) ) {
315
+                $this->get_latest_version( $force_api = true );
316
+            }
317
+            ?>
318 318
 			<style>
319 319
 				.wpfas-kit-show {
320 320
 					display: none;
@@ -332,10 +332,10 @@  discard block
 block discarded – undo
332 332
 				<h1><?php echo esc_html( $this->name ); ?></h1>
333 333
 				<form method="post" action="options.php">
334 334
 					<?php
335
-					settings_fields( 'wp-font-awesome-settings' );
336
-					do_settings_sections( 'wp-font-awesome-settings' );
337
-					$kit_set = $this->settings['type'] == 'KIT' ? 'wpfas-kit-set' : '';
338
-					?>
335
+                    settings_fields( 'wp-font-awesome-settings' );
336
+                    do_settings_sections( 'wp-font-awesome-settings' );
337
+                    $kit_set = $this->settings['type'] == 'KIT' ? 'wpfas-kit-set' : '';
338
+                    ?>
339 339
 					<table class="form-table wpfas-table-settings <?php echo esc_attr( $kit_set ); ?>">
340 340
 						<tr valign="top">
341 341
 							<th scope="row"><label
@@ -361,12 +361,12 @@  discard block
 block discarded – undo
361 361
 								       value="<?php echo esc_attr( $this->settings['kit-url'] ); ?>"
362 362
 								       placeholder="<?php echo 'https://kit.font';echo 'awesome.com/123abc.js'; // this won't pass theme check :(?>"/>
363 363
 								<span><?php
364
-									echo sprintf(
365
-										__( 'Requires a free account with Font Awesome. %sGet kit url%s', 'font-awesome-settings' ),
366
-										'<a rel="noopener noreferrer" target="_blank" href="https://fontawesome.com/kits"><i class="fas fa-external-link-alt"></i>',
367
-										'</a>'
368
-									);
369
-									?></span>
364
+                                    echo sprintf(
365
+                                        __( 'Requires a free account with Font Awesome. %sGet kit url%s', 'font-awesome-settings' ),
366
+                                        '<a rel="noopener noreferrer" target="_blank" href="https://fontawesome.com/kits"><i class="fas fa-external-link-alt"></i>',
367
+                                        '</a>'
368
+                                    );
369
+                                    ?></span>
370 370
 							</td>
371 371
 						</tr>
372 372
 
@@ -426,14 +426,14 @@  discard block
 block discarded – undo
426 426
 								<input type="checkbox" name="wp-font-awesome-settings[pro]"
427 427
 								       value="1" <?php checked( $this->settings['pro'], '1' ); ?> id="wpfas-pro"/>
428 428
 								<span><?php
429
-									echo sprintf(
430
-										__( 'Requires a subscription. %sLearn more%s %sManage my allowed domains%s', 'font-awesome-settings' ),
431
-										'<a rel="noopener noreferrer" target="_blank" href="https://fontawesome.com/pro"><i class="fas fa-external-link-alt"></i>',
432
-										'</a>',
433
-										'<a rel="noopener noreferrer" target="_blank" href="https://fontawesome.com/account/cdn"><i class="fas fa-external-link-alt"></i>',
434
-										'</a>'
435
-									);
436
-									?></span>
429
+                                    echo sprintf(
430
+                                        __( 'Requires a subscription. %sLearn more%s %sManage my allowed domains%s', 'font-awesome-settings' ),
431
+                                        '<a rel="noopener noreferrer" target="_blank" href="https://fontawesome.com/pro"><i class="fas fa-external-link-alt"></i>',
432
+                                        '</a>',
433
+                                        '<a rel="noopener noreferrer" target="_blank" href="https://fontawesome.com/account/cdn"><i class="fas fa-external-link-alt"></i>',
434
+                                        '</a>'
435
+                                    );
436
+                                    ?></span>
437 437
 							</td>
438 438
 						</tr>
439 439
 
@@ -476,100 +476,100 @@  discard block
 block discarded – undo
476 476
 
477 477
 					</table>
478 478
 					<?php
479
-					submit_button();
480
-					?>
479
+                    submit_button();
480
+                    ?>
481 481
 				</form>
482 482
 
483 483
 				<div id="wpfas-version"><?php echo esc_html( $this->version ); ?></div>
484 484
 			</div>
485 485
 
486 486
 			<?php
487
-		}
488
-
489
-		/**
490
-		 * Check a version number is valid and if so return it or else return an empty string.
491
-		 *
492
-		 * @param $version string The version number to check.
493
-		 *
494
-		 * @since 1.0.6
495
-		 *
496
-		 * @return string Either a valid version number or an empty string.
497
-		 */
498
-		public function validate_version_number( $version ) {
499
-
500
-			if ( version_compare( $version, '0.0.1', '>=' ) >= 0 ) {
501
-				// valid
502
-			} else {
503
-				$version = '';// not validated
504
-			}
505
-
506
-			return $version;
507
-		}
508
-
509
-
510
-		/**
511
-		 * Get the latest version of Font Awesome.
512
-		 *
513
-		 * We check for a cached version and if none we will check for a live version via API and then cache it for 48 hours.
514
-		 *
515
-		 * @since 1.0.7
516
-		 * @return mixed|string The latest version number found.
517
-		 */
518
-		public function get_latest_version( $force_api = false ) {
519
-			$latest_version = $this->latest;
520
-
521
-			$cache = get_transient( 'wp-font-awesome-settings-version' );
522
-
523
-			if ( $cache === false || $force_api ) { // its not set
524
-				$api_ver = $this->get_latest_version_from_api();
525
-				if ( version_compare( $api_ver, $this->latest, '>=' ) >= 0 ) {
526
-					$latest_version = $api_ver;
527
-					set_transient( 'wp-font-awesome-settings-version', $api_ver, 48 * HOUR_IN_SECONDS );
528
-				}
529
-			} elseif ( $this->validate_version_number( $cache ) ) {
530
-				if ( version_compare( $cache, $this->latest, '>=' ) >= 0 ) {
531
-					$latest_version = $cache;
532
-				}
533
-			}
534
-
535
-			return $latest_version;
536
-		}
537
-
538
-		/**
539
-		 * Get the latest Font Awesome version from the github API.
540
-		 *
541
-		 * @since 1.0.7
542
-		 * @return string The latest version number or `0` on API fail.
543
-		 */
544
-		public function get_latest_version_from_api() {
545
-			$version  = "0";
546
-			$response = wp_remote_get( "https://api.github.com/repos/FortAwesome/Font-Awesome/releases/latest" );
547
-			if ( ! is_wp_error( $response ) && is_array( $response ) ) {
548
-				$api_response = json_decode( wp_remote_retrieve_body( $response ), true );
549
-				if ( isset( $api_response['tag_name'] ) && version_compare( $api_response['tag_name'], $this->latest, '>=' ) >= 0 && empty( $api_response['prerelease'] ) ) {
550
-					$version = $api_response['tag_name'];
551
-				}
552
-			}
553
-
554
-			return $version;
555
-		}
556
-
557
-		/**
558
-		 * Inline CSS for RTL language support.
559
-		 *
560
-		 * @since 1.0.13
561
-		 * @return string Inline CSS.
562
-		 */
563
-		public function rtl_inline_css() {
564
-			$inline_css = '[dir=rtl] .fa-address,[dir=rtl] .fa-address-card,[dir=rtl] .fa-adjust,[dir=rtl] .fa-alarm-clock,[dir=rtl] .fa-align-left,[dir=rtl] .fa-align-right,[dir=rtl] .fa-analytics,[dir=rtl] .fa-angle-double-left,[dir=rtl] .fa-angle-double-right,[dir=rtl] .fa-angle-left,[dir=rtl] .fa-angle-right,[dir=rtl] .fa-arrow-alt-circle-left,[dir=rtl] .fa-arrow-alt-circle-right,[dir=rtl] .fa-arrow-alt-from-left,[dir=rtl] .fa-arrow-alt-from-right,[dir=rtl] .fa-arrow-alt-left,[dir=rtl] .fa-arrow-alt-right,[dir=rtl] .fa-arrow-alt-square-left,[dir=rtl] .fa-arrow-alt-square-right,[dir=rtl] .fa-arrow-alt-to-left,[dir=rtl] .fa-arrow-alt-to-right,[dir=rtl] .fa-arrow-circle-left,[dir=rtl] .fa-arrow-circle-right,[dir=rtl] .fa-arrow-from-left,[dir=rtl] .fa-arrow-from-right,[dir=rtl] .fa-arrow-left,[dir=rtl] .fa-arrow-right,[dir=rtl] .fa-arrow-square-left,[dir=rtl] .fa-arrow-square-right,[dir=rtl] .fa-arrow-to-left,[dir=rtl] .fa-arrow-to-right,[dir=rtl] .fa-balance-scale-left,[dir=rtl] .fa-balance-scale-right,[dir=rtl] .fa-bed,[dir=rtl] .fa-bed-bunk,[dir=rtl] .fa-bed-empty,[dir=rtl] .fa-border-left,[dir=rtl] .fa-border-right,[dir=rtl] .fa-calendar-check,[dir=rtl] .fa-caret-circle-left,[dir=rtl] .fa-caret-circle-right,[dir=rtl] .fa-caret-left,[dir=rtl] .fa-caret-right,[dir=rtl] .fa-caret-square-left,[dir=rtl] .fa-caret-square-right,[dir=rtl] .fa-cart-arrow-down,[dir=rtl] .fa-cart-plus,[dir=rtl] .fa-chart-area,[dir=rtl] .fa-chart-bar,[dir=rtl] .fa-chart-line,[dir=rtl] .fa-chart-line-down,[dir=rtl] .fa-chart-network,[dir=rtl] .fa-chart-pie,[dir=rtl] .fa-chart-pie-alt,[dir=rtl] .fa-chart-scatter,[dir=rtl] .fa-check-circle,[dir=rtl] .fa-check-square,[dir=rtl] .fa-chevron-circle-left,[dir=rtl] .fa-chevron-circle-right,[dir=rtl] .fa-chevron-double-left,[dir=rtl] .fa-chevron-double-right,[dir=rtl] .fa-chevron-left,[dir=rtl] .fa-chevron-right,[dir=rtl] .fa-chevron-square-left,[dir=rtl] .fa-chevron-square-right,[dir=rtl] .fa-clock,[dir=rtl] .fa-file,[dir=rtl] .fa-file-alt,[dir=rtl] .fa-file-archive,[dir=rtl] .fa-file-audio,[dir=rtl] .fa-file-chart-line,[dir=rtl] .fa-file-chart-pie,[dir=rtl] .fa-file-code,[dir=rtl] .fa-file-excel,[dir=rtl] .fa-file-image,[dir=rtl] .fa-file-pdf,[dir=rtl] .fa-file-powerpoint,[dir=rtl] .fa-file-video,[dir=rtl] .fa-file-word,[dir=rtl] .fa-flag,[dir=rtl] .fa-folder,[dir=rtl] .fa-folder-open,[dir=rtl] .fa-hand-lizard,[dir=rtl] .fa-hand-point-down,[dir=rtl] .fa-hand-point-left,[dir=rtl] .fa-hand-point-right,[dir=rtl] .fa-hand-point-up,[dir=rtl] .fa-hand-scissors,[dir=rtl] .fa-image,[dir=rtl] .fa-long-arrow-alt-left,[dir=rtl] .fa-long-arrow-alt-right,[dir=rtl] .fa-long-arrow-left,[dir=rtl] .fa-long-arrow-right,[dir=rtl] .fa-luggage-cart,[dir=rtl] .fa-moon,[dir=rtl] .fa-pencil,[dir=rtl] .fa-pencil-alt,[dir=rtl] .fa-play-circle,[dir=rtl] .fa-project-diagram,[dir=rtl] .fa-quote-left,[dir=rtl] .fa-quote-right,[dir=rtl] .fa-shopping-cart,[dir=rtl] .fa-thumbs-down,[dir=rtl] .fa-thumbs-up,[dir=rtl] .fa-user-chart{filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);transform:scale(-1,1)}[dir=rtl] .fa-spin{animation-direction:reverse}';
565
-
566
-			return $inline_css;
567
-		}
568
-
569
-	}
570
-
571
-	/**
572
-	 * Run the class if found.
573
-	 */
574
-	WP_Font_Awesome_Settings::instance();
487
+        }
488
+
489
+        /**
490
+         * Check a version number is valid and if so return it or else return an empty string.
491
+         *
492
+         * @param $version string The version number to check.
493
+         *
494
+         * @since 1.0.6
495
+         *
496
+         * @return string Either a valid version number or an empty string.
497
+         */
498
+        public function validate_version_number( $version ) {
499
+
500
+            if ( version_compare( $version, '0.0.1', '>=' ) >= 0 ) {
501
+                // valid
502
+            } else {
503
+                $version = '';// not validated
504
+            }
505
+
506
+            return $version;
507
+        }
508
+
509
+
510
+        /**
511
+         * Get the latest version of Font Awesome.
512
+         *
513
+         * We check for a cached version and if none we will check for a live version via API and then cache it for 48 hours.
514
+         *
515
+         * @since 1.0.7
516
+         * @return mixed|string The latest version number found.
517
+         */
518
+        public function get_latest_version( $force_api = false ) {
519
+            $latest_version = $this->latest;
520
+
521
+            $cache = get_transient( 'wp-font-awesome-settings-version' );
522
+
523
+            if ( $cache === false || $force_api ) { // its not set
524
+                $api_ver = $this->get_latest_version_from_api();
525
+                if ( version_compare( $api_ver, $this->latest, '>=' ) >= 0 ) {
526
+                    $latest_version = $api_ver;
527
+                    set_transient( 'wp-font-awesome-settings-version', $api_ver, 48 * HOUR_IN_SECONDS );
528
+                }
529
+            } elseif ( $this->validate_version_number( $cache ) ) {
530
+                if ( version_compare( $cache, $this->latest, '>=' ) >= 0 ) {
531
+                    $latest_version = $cache;
532
+                }
533
+            }
534
+
535
+            return $latest_version;
536
+        }
537
+
538
+        /**
539
+         * Get the latest Font Awesome version from the github API.
540
+         *
541
+         * @since 1.0.7
542
+         * @return string The latest version number or `0` on API fail.
543
+         */
544
+        public function get_latest_version_from_api() {
545
+            $version  = "0";
546
+            $response = wp_remote_get( "https://api.github.com/repos/FortAwesome/Font-Awesome/releases/latest" );
547
+            if ( ! is_wp_error( $response ) && is_array( $response ) ) {
548
+                $api_response = json_decode( wp_remote_retrieve_body( $response ), true );
549
+                if ( isset( $api_response['tag_name'] ) && version_compare( $api_response['tag_name'], $this->latest, '>=' ) >= 0 && empty( $api_response['prerelease'] ) ) {
550
+                    $version = $api_response['tag_name'];
551
+                }
552
+            }
553
+
554
+            return $version;
555
+        }
556
+
557
+        /**
558
+         * Inline CSS for RTL language support.
559
+         *
560
+         * @since 1.0.13
561
+         * @return string Inline CSS.
562
+         */
563
+        public function rtl_inline_css() {
564
+            $inline_css = '[dir=rtl] .fa-address,[dir=rtl] .fa-address-card,[dir=rtl] .fa-adjust,[dir=rtl] .fa-alarm-clock,[dir=rtl] .fa-align-left,[dir=rtl] .fa-align-right,[dir=rtl] .fa-analytics,[dir=rtl] .fa-angle-double-left,[dir=rtl] .fa-angle-double-right,[dir=rtl] .fa-angle-left,[dir=rtl] .fa-angle-right,[dir=rtl] .fa-arrow-alt-circle-left,[dir=rtl] .fa-arrow-alt-circle-right,[dir=rtl] .fa-arrow-alt-from-left,[dir=rtl] .fa-arrow-alt-from-right,[dir=rtl] .fa-arrow-alt-left,[dir=rtl] .fa-arrow-alt-right,[dir=rtl] .fa-arrow-alt-square-left,[dir=rtl] .fa-arrow-alt-square-right,[dir=rtl] .fa-arrow-alt-to-left,[dir=rtl] .fa-arrow-alt-to-right,[dir=rtl] .fa-arrow-circle-left,[dir=rtl] .fa-arrow-circle-right,[dir=rtl] .fa-arrow-from-left,[dir=rtl] .fa-arrow-from-right,[dir=rtl] .fa-arrow-left,[dir=rtl] .fa-arrow-right,[dir=rtl] .fa-arrow-square-left,[dir=rtl] .fa-arrow-square-right,[dir=rtl] .fa-arrow-to-left,[dir=rtl] .fa-arrow-to-right,[dir=rtl] .fa-balance-scale-left,[dir=rtl] .fa-balance-scale-right,[dir=rtl] .fa-bed,[dir=rtl] .fa-bed-bunk,[dir=rtl] .fa-bed-empty,[dir=rtl] .fa-border-left,[dir=rtl] .fa-border-right,[dir=rtl] .fa-calendar-check,[dir=rtl] .fa-caret-circle-left,[dir=rtl] .fa-caret-circle-right,[dir=rtl] .fa-caret-left,[dir=rtl] .fa-caret-right,[dir=rtl] .fa-caret-square-left,[dir=rtl] .fa-caret-square-right,[dir=rtl] .fa-cart-arrow-down,[dir=rtl] .fa-cart-plus,[dir=rtl] .fa-chart-area,[dir=rtl] .fa-chart-bar,[dir=rtl] .fa-chart-line,[dir=rtl] .fa-chart-line-down,[dir=rtl] .fa-chart-network,[dir=rtl] .fa-chart-pie,[dir=rtl] .fa-chart-pie-alt,[dir=rtl] .fa-chart-scatter,[dir=rtl] .fa-check-circle,[dir=rtl] .fa-check-square,[dir=rtl] .fa-chevron-circle-left,[dir=rtl] .fa-chevron-circle-right,[dir=rtl] .fa-chevron-double-left,[dir=rtl] .fa-chevron-double-right,[dir=rtl] .fa-chevron-left,[dir=rtl] .fa-chevron-right,[dir=rtl] .fa-chevron-square-left,[dir=rtl] .fa-chevron-square-right,[dir=rtl] .fa-clock,[dir=rtl] .fa-file,[dir=rtl] .fa-file-alt,[dir=rtl] .fa-file-archive,[dir=rtl] .fa-file-audio,[dir=rtl] .fa-file-chart-line,[dir=rtl] .fa-file-chart-pie,[dir=rtl] .fa-file-code,[dir=rtl] .fa-file-excel,[dir=rtl] .fa-file-image,[dir=rtl] .fa-file-pdf,[dir=rtl] .fa-file-powerpoint,[dir=rtl] .fa-file-video,[dir=rtl] .fa-file-word,[dir=rtl] .fa-flag,[dir=rtl] .fa-folder,[dir=rtl] .fa-folder-open,[dir=rtl] .fa-hand-lizard,[dir=rtl] .fa-hand-point-down,[dir=rtl] .fa-hand-point-left,[dir=rtl] .fa-hand-point-right,[dir=rtl] .fa-hand-point-up,[dir=rtl] .fa-hand-scissors,[dir=rtl] .fa-image,[dir=rtl] .fa-long-arrow-alt-left,[dir=rtl] .fa-long-arrow-alt-right,[dir=rtl] .fa-long-arrow-left,[dir=rtl] .fa-long-arrow-right,[dir=rtl] .fa-luggage-cart,[dir=rtl] .fa-moon,[dir=rtl] .fa-pencil,[dir=rtl] .fa-pencil-alt,[dir=rtl] .fa-play-circle,[dir=rtl] .fa-project-diagram,[dir=rtl] .fa-quote-left,[dir=rtl] .fa-quote-right,[dir=rtl] .fa-shopping-cart,[dir=rtl] .fa-thumbs-down,[dir=rtl] .fa-thumbs-up,[dir=rtl] .fa-user-chart{filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1);transform:scale(-1,1)}[dir=rtl] .fa-spin{animation-direction:reverse}';
565
+
566
+            return $inline_css;
567
+        }
568
+
569
+    }
570
+
571
+    /**
572
+     * Run the class if found.
573
+     */
574
+    WP_Font_Awesome_Settings::instance();
575 575
 }
576 576
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/ayecode-connect-helper/ayecode-connect-helper.php 1 patch
Indentation   +310 added lines, -310 removed lines patch added patch discarded remove patch
@@ -1,271 +1,271 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit;
4
+    exit;
5 5
 }
6 6
 
7 7
 if ( ! class_exists( "AyeCode_Connect_Helper" ) ) {
8
-	/**
9
-	 * Allow the quick setup and connection of our AyeCode Connect plugin.
10
-	 *
11
-	 * Class AyeCode_Connect_Helper
12
-	 */
13
-	class AyeCode_Connect_Helper {
14
-
15
-		// Hold the version number
16
-		var $version = "1.0.3";
17
-
18
-		// Hold the default strings.
19
-		var $strings = array();
20
-
21
-		// Hold the default pages.
22
-		var $pages = array();
23
-
24
-		/**
25
-		 * The constructor.
26
-		 *
27
-		 * AyeCode_Connect_Helper constructor.
28
-		 *
29
-		 * @param array $strings
30
-		 * @param array $pages
31
-		 */
32
-		public function __construct( $strings = array(), $pages = array() ) {
33
-
34
-			// Only fire if not localhost and the current user has the right permissions.
35
-			if ( ! $this->is_localhost() && current_user_can( 'manage_options' ) ) {
36
-
37
-
38
-				// set default strings
39
-				$default_strings = array(
40
-					'connect_title'     => __( "Thanks for choosing an AyeCode Product!" ),
41
-					'connect_external'  => __( "Please confirm you wish to connect your site?" ),
42
-					'connect'           => sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s" ), "<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>", "</a>" ),
43
-					'connect_button'    => __( "Connect Site" ),
44
-					'connecting_button' => __( "Connecting..." ),
45
-					'error_localhost'   => __( "This service will only work with a live domain, not a localhost." ),
46
-					'error'             => __( "Something went wrong, please refresh and try again." ),
47
-				);
48
-				$this->strings   = array_merge( $default_strings, $strings );
49
-
50
-
51
-				// set default pages
52
-				$default_pages = array();
53
-				$this->pages   = array_merge( $default_pages, $pages );
54
-
55
-				// maybe show connect site notice
56
-				add_action( 'admin_notices', array( $this, 'ayecode_connect_install_notice' ) );
57
-
58
-				// add ajax action if not already added
59
-				if ( ! has_action( 'wp_ajax_ayecode_connect_helper' ) ) {
60
-					add_action( 'wp_ajax_ayecode_connect_helper', array( $this, 'ayecode_connect_install' ) );
61
-				}
62
-			}
63
-
64
-			// add ajax action if not already added
65
-			if ( ! has_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed' ) ) {
66
-				add_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed', array( $this, 'ayecode_connect_helper_installed' ) );
67
-			}
68
-
69
-		}
70
-
71
-		/**
72
-		 * Give a way to check we can connect via a external redirect.
73
-		 */
74
-		public function ayecode_connect_helper_installed(){
75
-			$active = array(
76
-				'gd'    =>  defined('GEODIRECTORY_VERSION') && version_compare(GEODIRECTORY_VERSION,'2.0.0.79','>') ? 1 : 0,
77
-				'uwp'    =>  defined('USERSWP_VERSION') && version_compare(USERSWP_VERSION,'1.2.1.5','>') ? 1 : 0,
78
-				'wpi'    =>  defined('WPINV_VERSION') && version_compare(WPINV_VERSION,'1.0.14','>') ? 1 : 0,
79
-			);
80
-			wp_send_json_success( $active );
81
-			wp_die();
82
-		}
83
-
84
-		/**
85
-		 * Get slug from path
86
-		 *
87
-		 * @param  string $key
88
-		 *
89
-		 * @return string
90
-		 */
91
-		private function format_plugin_slug( $key ) {
92
-			$slug = explode( '/', $key );
93
-			$slug = explode( '.', end( $slug ) );
94
-
95
-			return $slug[0];
96
-		}
97
-
98
-		/**
99
-		 * Install and activate the AyeCode Connect Plugin
100
-		 */
101
-		public function ayecode_connect_install() {
102
-
103
-			// bail if localhost
104
-			if ( $this->is_localhost() ) {
105
-				wp_send_json_error( $this->strings['error_localhost'] );
106
-			}
107
-
108
-			// Explicitly clear the event.
109
-			wp_clear_scheduled_hook( 'geodir_plugin_background_installer', func_get_args() );
110
-
111
-			$success     = true;
112
-			$plugin_slug = "ayecode-connect";
113
-			if ( ! empty( $plugin_slug ) ) {
114
-				require_once( ABSPATH . 'wp-admin/includes/file.php' );
115
-				require_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );
116
-				require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
117
-				require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
118
-
119
-				WP_Filesystem();
120
-
121
-				$skin              = new Automatic_Upgrader_Skin;
122
-				$upgrader          = new WP_Upgrader( $skin );
123
-				$installed_plugins = array_map( array( $this, 'format_plugin_slug' ), array_keys( get_plugins() ) );
124
-				$plugin_slug       = $plugin_slug;
125
-				$plugin            = $plugin_slug . '/' . $plugin_slug . '.php';
126
-				$installed         = false;
127
-				$activate          = false;
128
-
129
-				// See if the plugin is installed already
130
-				if ( in_array( $plugin_slug, $installed_plugins ) ) {
131
-					$installed = true;
132
-					$activate  = ! is_plugin_active( $plugin );
133
-				}
134
-
135
-				// Install this thing!
136
-				if ( ! $installed ) {
137
-
138
-					// Suppress feedback
139
-					ob_start();
140
-
141
-					try {
142
-						$plugin_information = plugins_api( 'plugin_information', array(
143
-							'slug'   => $plugin_slug,
144
-							'fields' => array(
145
-								'short_description' => false,
146
-								'sections'          => false,
147
-								'requires'          => false,
148
-								'rating'            => false,
149
-								'ratings'           => false,
150
-								'downloaded'        => false,
151
-								'last_updated'      => false,
152
-								'added'             => false,
153
-								'tags'              => false,
154
-								'homepage'          => false,
155
-								'donate_link'       => false,
156
-								'author_profile'    => false,
157
-								'author'            => false,
158
-							),
159
-						) );
160
-
161
-						if ( is_wp_error( $plugin_information ) ) {
162
-							throw new Exception( $plugin_information->get_error_message() );
163
-						}
164
-
165
-						$package  = $plugin_information->download_link;
166
-						$download = $upgrader->download_package( $package );
167
-
168
-						if ( is_wp_error( $download ) ) {
169
-							throw new Exception( $download->get_error_message() );
170
-						}
171
-
172
-						$working_dir = $upgrader->unpack_package( $download, true );
173
-
174
-						if ( is_wp_error( $working_dir ) ) {
175
-							throw new Exception( $working_dir->get_error_message() );
176
-						}
177
-
178
-						$result = $upgrader->install_package( array(
179
-							'source'                      => $working_dir,
180
-							'destination'                 => WP_PLUGIN_DIR,
181
-							'clear_destination'           => false,
182
-							'abort_if_destination_exists' => false,
183
-							'clear_working'               => true,
184
-							'hook_extra'                  => array(
185
-								'type'   => 'plugin',
186
-								'action' => 'install',
187
-							),
188
-						) );
189
-
190
-						if ( is_wp_error( $result ) ) {
191
-							throw new Exception( $result->get_error_message() );
192
-						}
193
-
194
-						$activate = true;
195
-
196
-					} catch ( Exception $e ) {
197
-						$success = false;
198
-					}
199
-
200
-					// Discard feedback
201
-					ob_end_clean();
202
-				}
203
-
204
-				wp_clean_plugins_cache();
205
-
206
-				// Activate this thing
207
-				if ( $activate ) {
208
-					try {
209
-						$result = activate_plugin( $plugin );
210
-
211
-						if ( is_wp_error( $result ) ) {
212
-							$success = false;
213
-						} else {
214
-							$success = true;
215
-						}
216
-					} catch ( Exception $e ) {
217
-						$success = false;
218
-					}
219
-				}
220
-			}
221
-
222
-			if ( $success && function_exists( 'ayecode_connect_args' ) ) {
223
-				ayecode_connect();// init
224
-				$args        = ayecode_connect_args();
225
-				$client      = new AyeCode_Connect( $args );
226
-				$redirect_to = ! empty( $_POST['redirect_to'] ) ? esc_url_raw( $_POST['redirect_to'] ) : '';
227
-				$redirect    = $client->build_connect_url( $redirect_to );
228
-				wp_send_json_success( array( 'connect_url' => $redirect ) );
229
-			} else {
230
-				wp_send_json_error( $this->strings['error_localhost'] );
231
-			}
232
-			wp_die();
233
-		}
234
-
235
-		/**
236
-		 * Check if maybe localhost.
237
-		 *
238
-		 * @return bool
239
-		 */
240
-		public function is_localhost() {
241
-			$localhost = false;
242
-
243
-			$host              = isset( $_SERVER['HTTP_HOST'] ) ? $_SERVER['HTTP_HOST'] : '';
244
-			$localhost_domains = array(
245
-				'localhost',
246
-				'localhost.localdomain',
247
-				'127.0.0.1',
248
-				'::1'
249
-			);
250
-
251
-			if ( in_array( $host, $localhost_domains ) ) {
252
-				$localhost = true;
253
-			}
254
-
255
-			return $localhost;
256
-		}
257
-
258
-		/**
259
-		 * Show notice to connect site.
260
-		 */
261
-		public function ayecode_connect_install_notice() {
262
-			if ( $this->maybe_show() ) {
263
-				$connect_title_string     = $this->strings['connect_title'];
264
-				$connect_external_string  = $this->strings['connect_external'];
265
-				$connect_string           = $this->strings['connect'];
266
-				$connect_button_string    = $this->strings['connect_button'];
267
-				$connecting_button_string = $this->strings['connecting_button'];
268
-				?>
8
+    /**
9
+     * Allow the quick setup and connection of our AyeCode Connect plugin.
10
+     *
11
+     * Class AyeCode_Connect_Helper
12
+     */
13
+    class AyeCode_Connect_Helper {
14
+
15
+        // Hold the version number
16
+        var $version = "1.0.3";
17
+
18
+        // Hold the default strings.
19
+        var $strings = array();
20
+
21
+        // Hold the default pages.
22
+        var $pages = array();
23
+
24
+        /**
25
+         * The constructor.
26
+         *
27
+         * AyeCode_Connect_Helper constructor.
28
+         *
29
+         * @param array $strings
30
+         * @param array $pages
31
+         */
32
+        public function __construct( $strings = array(), $pages = array() ) {
33
+
34
+            // Only fire if not localhost and the current user has the right permissions.
35
+            if ( ! $this->is_localhost() && current_user_can( 'manage_options' ) ) {
36
+
37
+
38
+                // set default strings
39
+                $default_strings = array(
40
+                    'connect_title'     => __( "Thanks for choosing an AyeCode Product!" ),
41
+                    'connect_external'  => __( "Please confirm you wish to connect your site?" ),
42
+                    'connect'           => sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s" ), "<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>", "</a>" ),
43
+                    'connect_button'    => __( "Connect Site" ),
44
+                    'connecting_button' => __( "Connecting..." ),
45
+                    'error_localhost'   => __( "This service will only work with a live domain, not a localhost." ),
46
+                    'error'             => __( "Something went wrong, please refresh and try again." ),
47
+                );
48
+                $this->strings   = array_merge( $default_strings, $strings );
49
+
50
+
51
+                // set default pages
52
+                $default_pages = array();
53
+                $this->pages   = array_merge( $default_pages, $pages );
54
+
55
+                // maybe show connect site notice
56
+                add_action( 'admin_notices', array( $this, 'ayecode_connect_install_notice' ) );
57
+
58
+                // add ajax action if not already added
59
+                if ( ! has_action( 'wp_ajax_ayecode_connect_helper' ) ) {
60
+                    add_action( 'wp_ajax_ayecode_connect_helper', array( $this, 'ayecode_connect_install' ) );
61
+                }
62
+            }
63
+
64
+            // add ajax action if not already added
65
+            if ( ! has_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed' ) ) {
66
+                add_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed', array( $this, 'ayecode_connect_helper_installed' ) );
67
+            }
68
+
69
+        }
70
+
71
+        /**
72
+         * Give a way to check we can connect via a external redirect.
73
+         */
74
+        public function ayecode_connect_helper_installed(){
75
+            $active = array(
76
+                'gd'    =>  defined('GEODIRECTORY_VERSION') && version_compare(GEODIRECTORY_VERSION,'2.0.0.79','>') ? 1 : 0,
77
+                'uwp'    =>  defined('USERSWP_VERSION') && version_compare(USERSWP_VERSION,'1.2.1.5','>') ? 1 : 0,
78
+                'wpi'    =>  defined('WPINV_VERSION') && version_compare(WPINV_VERSION,'1.0.14','>') ? 1 : 0,
79
+            );
80
+            wp_send_json_success( $active );
81
+            wp_die();
82
+        }
83
+
84
+        /**
85
+         * Get slug from path
86
+         *
87
+         * @param  string $key
88
+         *
89
+         * @return string
90
+         */
91
+        private function format_plugin_slug( $key ) {
92
+            $slug = explode( '/', $key );
93
+            $slug = explode( '.', end( $slug ) );
94
+
95
+            return $slug[0];
96
+        }
97
+
98
+        /**
99
+         * Install and activate the AyeCode Connect Plugin
100
+         */
101
+        public function ayecode_connect_install() {
102
+
103
+            // bail if localhost
104
+            if ( $this->is_localhost() ) {
105
+                wp_send_json_error( $this->strings['error_localhost'] );
106
+            }
107
+
108
+            // Explicitly clear the event.
109
+            wp_clear_scheduled_hook( 'geodir_plugin_background_installer', func_get_args() );
110
+
111
+            $success     = true;
112
+            $plugin_slug = "ayecode-connect";
113
+            if ( ! empty( $plugin_slug ) ) {
114
+                require_once( ABSPATH . 'wp-admin/includes/file.php' );
115
+                require_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );
116
+                require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
117
+                require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
118
+
119
+                WP_Filesystem();
120
+
121
+                $skin              = new Automatic_Upgrader_Skin;
122
+                $upgrader          = new WP_Upgrader( $skin );
123
+                $installed_plugins = array_map( array( $this, 'format_plugin_slug' ), array_keys( get_plugins() ) );
124
+                $plugin_slug       = $plugin_slug;
125
+                $plugin            = $plugin_slug . '/' . $plugin_slug . '.php';
126
+                $installed         = false;
127
+                $activate          = false;
128
+
129
+                // See if the plugin is installed already
130
+                if ( in_array( $plugin_slug, $installed_plugins ) ) {
131
+                    $installed = true;
132
+                    $activate  = ! is_plugin_active( $plugin );
133
+                }
134
+
135
+                // Install this thing!
136
+                if ( ! $installed ) {
137
+
138
+                    // Suppress feedback
139
+                    ob_start();
140
+
141
+                    try {
142
+                        $plugin_information = plugins_api( 'plugin_information', array(
143
+                            'slug'   => $plugin_slug,
144
+                            'fields' => array(
145
+                                'short_description' => false,
146
+                                'sections'          => false,
147
+                                'requires'          => false,
148
+                                'rating'            => false,
149
+                                'ratings'           => false,
150
+                                'downloaded'        => false,
151
+                                'last_updated'      => false,
152
+                                'added'             => false,
153
+                                'tags'              => false,
154
+                                'homepage'          => false,
155
+                                'donate_link'       => false,
156
+                                'author_profile'    => false,
157
+                                'author'            => false,
158
+                            ),
159
+                        ) );
160
+
161
+                        if ( is_wp_error( $plugin_information ) ) {
162
+                            throw new Exception( $plugin_information->get_error_message() );
163
+                        }
164
+
165
+                        $package  = $plugin_information->download_link;
166
+                        $download = $upgrader->download_package( $package );
167
+
168
+                        if ( is_wp_error( $download ) ) {
169
+                            throw new Exception( $download->get_error_message() );
170
+                        }
171
+
172
+                        $working_dir = $upgrader->unpack_package( $download, true );
173
+
174
+                        if ( is_wp_error( $working_dir ) ) {
175
+                            throw new Exception( $working_dir->get_error_message() );
176
+                        }
177
+
178
+                        $result = $upgrader->install_package( array(
179
+                            'source'                      => $working_dir,
180
+                            'destination'                 => WP_PLUGIN_DIR,
181
+                            'clear_destination'           => false,
182
+                            'abort_if_destination_exists' => false,
183
+                            'clear_working'               => true,
184
+                            'hook_extra'                  => array(
185
+                                'type'   => 'plugin',
186
+                                'action' => 'install',
187
+                            ),
188
+                        ) );
189
+
190
+                        if ( is_wp_error( $result ) ) {
191
+                            throw new Exception( $result->get_error_message() );
192
+                        }
193
+
194
+                        $activate = true;
195
+
196
+                    } catch ( Exception $e ) {
197
+                        $success = false;
198
+                    }
199
+
200
+                    // Discard feedback
201
+                    ob_end_clean();
202
+                }
203
+
204
+                wp_clean_plugins_cache();
205
+
206
+                // Activate this thing
207
+                if ( $activate ) {
208
+                    try {
209
+                        $result = activate_plugin( $plugin );
210
+
211
+                        if ( is_wp_error( $result ) ) {
212
+                            $success = false;
213
+                        } else {
214
+                            $success = true;
215
+                        }
216
+                    } catch ( Exception $e ) {
217
+                        $success = false;
218
+                    }
219
+                }
220
+            }
221
+
222
+            if ( $success && function_exists( 'ayecode_connect_args' ) ) {
223
+                ayecode_connect();// init
224
+                $args        = ayecode_connect_args();
225
+                $client      = new AyeCode_Connect( $args );
226
+                $redirect_to = ! empty( $_POST['redirect_to'] ) ? esc_url_raw( $_POST['redirect_to'] ) : '';
227
+                $redirect    = $client->build_connect_url( $redirect_to );
228
+                wp_send_json_success( array( 'connect_url' => $redirect ) );
229
+            } else {
230
+                wp_send_json_error( $this->strings['error_localhost'] );
231
+            }
232
+            wp_die();
233
+        }
234
+
235
+        /**
236
+         * Check if maybe localhost.
237
+         *
238
+         * @return bool
239
+         */
240
+        public function is_localhost() {
241
+            $localhost = false;
242
+
243
+            $host              = isset( $_SERVER['HTTP_HOST'] ) ? $_SERVER['HTTP_HOST'] : '';
244
+            $localhost_domains = array(
245
+                'localhost',
246
+                'localhost.localdomain',
247
+                '127.0.0.1',
248
+                '::1'
249
+            );
250
+
251
+            if ( in_array( $host, $localhost_domains ) ) {
252
+                $localhost = true;
253
+            }
254
+
255
+            return $localhost;
256
+        }
257
+
258
+        /**
259
+         * Show notice to connect site.
260
+         */
261
+        public function ayecode_connect_install_notice() {
262
+            if ( $this->maybe_show() ) {
263
+                $connect_title_string     = $this->strings['connect_title'];
264
+                $connect_external_string  = $this->strings['connect_external'];
265
+                $connect_string           = $this->strings['connect'];
266
+                $connect_button_string    = $this->strings['connect_button'];
267
+                $connecting_button_string = $this->strings['connecting_button'];
268
+                ?>
269 269
 				<div class="notice notice-info acch-notice">
270 270
 					<span class="acch-float-left">
271 271
 						<svg width="61px" height="61px" viewBox="0 0 61 61" version="1.1"
@@ -304,8 +304,8 @@  discard block
 block discarded – undo
304 304
 						<h3 class="acch-title"><?php echo esc_html( $connect_title_string ); ?></h3>
305 305
 					<p>
306 306
 						<?php
307
-						echo wp_kses_post( $connect_string );
308
-						?>
307
+                        echo wp_kses_post( $connect_string );
308
+                        ?>
309 309
 					</p>
310 310
 					</span>
311 311
 
@@ -318,9 +318,9 @@  discard block
 block discarded – undo
318 318
 				</div>
319 319
 
320 320
 				<?php
321
-				// only include the popup HTML if needed.
322
-				if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
323
-					?>
321
+                // only include the popup HTML if needed.
322
+                if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
323
+                    ?>
324 324
 					<div id="ayecode-connect-helper-external-confirm" style="display:none;">
325 325
 						<div class="noticex notice-info acch-notice" style="border: none;">
326 326
 					<span class="acch-float-left">
@@ -369,23 +369,23 @@  discard block
 block discarded – undo
369 369
 						</div>
370 370
 					</div>
371 371
 					<?php
372
-				}
373
-
374
-				// add required scripts
375
-				$this->script();
376
-			}
377
-		}
378
-
379
-		/**
380
-		 * Get the JS Script.
381
-		 */
382
-		public function script() {
383
-
384
-			// add thickbox if external request is requested
385
-			if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
386
-				add_thickbox();
387
-			}
388
-			?>
372
+                }
373
+
374
+                // add required scripts
375
+                $this->script();
376
+            }
377
+        }
378
+
379
+        /**
380
+         * Get the JS Script.
381
+         */
382
+        public function script() {
383
+
384
+            // add thickbox if external request is requested
385
+            if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
386
+                add_thickbox();
387
+            }
388
+            ?>
389 389
 			<style>
390 390
 				.acch-title {
391 391
 					margin: 0;
@@ -454,43 +454,43 @@  discard block
 block discarded – undo
454 454
 
455 455
 
456 456
 				<?php
457
-				// add thickbox if external request is requested
458
-				if(! empty( $_REQUEST['external-connect-request'] )) {
459
-				?>
457
+                // add thickbox if external request is requested
458
+                if(! empty( $_REQUEST['external-connect-request'] )) {
459
+                ?>
460 460
 				jQuery(function () {
461 461
 					setTimeout(function () {
462 462
 						tb_show("AyeCode Connect", "?TB_inline?width=300&height=80&inlineId=ayecode-connect-helper-external-confirm");
463 463
 					}, 200);
464 464
 				});
465 465
 				<?php
466
-				}
467
-				?>
466
+                }
467
+                ?>
468 468
 
469 469
 			</script>
470 470
 			<?php
471
-		}
472
-
473
-		/**
474
-		 * Decide what pages to show on.
475
-		 *
476
-		 * @return bool
477
-		 */
478
-		public function maybe_show() {
479
-			$show = false;
480
-
481
-			// check if on a page set to show
482
-			if ( isset( $_REQUEST['page'] ) && in_array( $_REQUEST['page'], $this->pages ) ) {
483
-
484
-				// check if not active and connected
485
-				if ( ! defined( 'AYECODE_CONNECT_VERSION' ) || ! get_option( 'ayecode_connect_blog_token' ) ) {
486
-					$show = true;
487
-				}
471
+        }
472
+
473
+        /**
474
+         * Decide what pages to show on.
475
+         *
476
+         * @return bool
477
+         */
478
+        public function maybe_show() {
479
+            $show = false;
480
+
481
+            // check if on a page set to show
482
+            if ( isset( $_REQUEST['page'] ) && in_array( $_REQUEST['page'], $this->pages ) ) {
483
+
484
+                // check if not active and connected
485
+                if ( ! defined( 'AYECODE_CONNECT_VERSION' ) || ! get_option( 'ayecode_connect_blog_token' ) ) {
486
+                    $show = true;
487
+                }
488 488
 
489
-			}
489
+            }
490 490
 
491
-			return $show;
492
-		}
491
+            return $show;
492
+        }
493 493
 
494
-	}
494
+    }
495 495
 
496 496
 }
Please login to merge, or discard this patch.
widgets/buy-item.php 1 patch
Indentation   +49 added lines, -49 removed lines patch added patch discarded remove patch
@@ -37,29 +37,29 @@  discard block
 block discarded – undo
37 37
                     'advanced' => false,
38 38
                 ),
39 39
                 'items'   => array(
40
-	                'title'       => __( 'Items to buy', 'invoicing' ),
41
-	                'desc'        => __( 'Enter comma separated list of invoicing item id and quantity (item_id|quantity). Ex. 101|2 ', 'invoicing' ),
42
-	                'type'        => 'text',
43
-	                'desc_tip'    => true,
44
-	                'default'     => '',
45
-	                'placeholder' => __( 'Items to buy', 'invoicing' ),
46
-	                'advanced'    => false,
40
+                    'title'       => __( 'Items to buy', 'invoicing' ),
41
+                    'desc'        => __( 'Enter comma separated list of invoicing item id and quantity (item_id|quantity). Ex. 101|2 ', 'invoicing' ),
42
+                    'type'        => 'text',
43
+                    'desc_tip'    => true,
44
+                    'default'     => '',
45
+                    'placeholder' => __( 'Items to buy', 'invoicing' ),
46
+                    'advanced'    => false,
47 47
                 ),
48 48
                 'label'   => array(
49
-	                'title'    => __( 'Button Label', 'invoicing' ),
50
-	                'desc'     => __( 'Enter button label. Default "Buy Now".', 'invoicing' ),
51
-	                'type'     => 'text',
52
-	                'desc_tip' => true,
53
-	                'default'  => __( 'Buy Now', 'invoicing' ),
54
-	                'advanced' => false,
49
+                    'title'    => __( 'Button Label', 'invoicing' ),
50
+                    'desc'     => __( 'Enter button label. Default "Buy Now".', 'invoicing' ),
51
+                    'type'     => 'text',
52
+                    'desc_tip' => true,
53
+                    'default'  => __( 'Buy Now', 'invoicing' ),
54
+                    'advanced' => false,
55 55
                 ),
56 56
                 'post_id' => array(
57
-	                'title'    => __( 'Post ID', 'invoicing' ),
58
-	                'desc'     => __( 'Enter related post ID. This is for 3rd party add ons and not mandatory field.', 'invoicing' ),
59
-	                'type'     => 'number',
60
-	                'desc_tip' => true,
61
-	                'default'  => '',
62
-	                'advanced' => true,
57
+                    'title'    => __( 'Post ID', 'invoicing' ),
58
+                    'desc'     => __( 'Enter related post ID. This is for 3rd party add ons and not mandatory field.', 'invoicing' ),
59
+                    'type'     => 'number',
60
+                    'desc_tip' => true,
61
+                    'default'  => '',
62
+                    'advanced' => true,
63 63
                 ),
64 64
             ),
65 65
 
@@ -68,43 +68,43 @@  discard block
 block discarded – undo
68 68
         parent::__construct( $options );
69 69
     }
70 70
 
71
-	/**
72
-	 * The Super block output function.
73
-	 *
74
-	 * @param array $args
75
-	 * @param array $widget_args
76
-	 * @param string $content
77
-	 *
78
-	 * @return string
79
-	 */
71
+    /**
72
+     * The Super block output function.
73
+     *
74
+     * @param array $args
75
+     * @param array $widget_args
76
+     * @param string $content
77
+     *
78
+     * @return string
79
+     */
80 80
     public function output( $args = array(), $widget_args = array(), $content = '' ) {
81 81
 
82
-	    $defaults = array(
83
-		    'items'   => '', // should be used like: item_id|quantity,item_id|quantity,item_id|quantity
84
-		    'label'   => __( 'Buy Now', 'invoicing' ), // the button title
85
-		    'post_id' => '', // any related post_id
86
-	    );
82
+        $defaults = array(
83
+            'items'   => '', // should be used like: item_id|quantity,item_id|quantity,item_id|quantity
84
+            'label'   => __( 'Buy Now', 'invoicing' ), // the button title
85
+            'post_id' => '', // any related post_id
86
+        );
87 87
 
88
-	    /**
89
-	     * Parse incoming $args into an array and merge it with $defaults
90
-	     */
91
-	    $args = wp_parse_args( $args, $defaults );
88
+        /**
89
+         * Parse incoming $args into an array and merge it with $defaults
90
+         */
91
+        $args = wp_parse_args( $args, $defaults );
92 92
 
93
-		$html = '<div class="wpi-buy-button-wrapper wpi-g">';
93
+        $html = '<div class="wpi-buy-button-wrapper wpi-g">';
94 94
 
95
-		if ( empty( $args['items'] ) ) {
96
-			$html .= __( 'No items selected', 'invoicing' );
97
-		} else {
98
-			$post_id = isset( $args['post_id'] ) && is_numeric( $args['post_id'] ) ? sanitize_text_field( $args['post_id'] ) : 0;
99
-			$label   = isset( $args['label'] ) ? sanitize_text_field( $args['label'] ) : __( 'Buy Now', 'invoicing' );
100
-			$items   = esc_attr( $args['items'] );
101
-			$html   .= "<button class='button button-primary wpi-buy-button' type='button' onclick=\"wpi_buy(this, '$items','$post_id');\">$label</button>";
102
-		}
95
+        if ( empty( $args['items'] ) ) {
96
+            $html .= __( 'No items selected', 'invoicing' );
97
+        } else {
98
+            $post_id = isset( $args['post_id'] ) && is_numeric( $args['post_id'] ) ? sanitize_text_field( $args['post_id'] ) : 0;
99
+            $label   = isset( $args['label'] ) ? sanitize_text_field( $args['label'] ) : __( 'Buy Now', 'invoicing' );
100
+            $items   = esc_attr( $args['items'] );
101
+            $html   .= "<button class='button button-primary wpi-buy-button' type='button' onclick=\"wpi_buy(this, '$items','$post_id');\">$label</button>";
102
+        }
103 103
 
104
-	    $html .= wp_nonce_field( 'wpinv_buy_items', 'wpinv_buy_nonce', true, false );
105
-	    $html .= '</div>';
104
+        $html .= wp_nonce_field( 'wpinv_buy_items', 'wpinv_buy_nonce', true, false );
105
+        $html .= '</div>';
106 106
 
107
-	    return $html;
107
+        return $html;
108 108
 
109 109
     }
110 110
 
Please login to merge, or discard this patch.
widgets/invoice.php 1 patch
Indentation   +25 added lines, -25 removed lines patch added patch discarded remove patch
@@ -36,14 +36,14 @@  discard block
 block discarded – undo
36 36
                     'advanced' => false,
37 37
                 ),
38 38
                 'id'    => array(
39
-	                'title'       => __( 'Invoice', 'invoicing' ),
40
-	                'desc'        => __( 'Enter the invoice ID', 'invoicing' ),
41
-	                'type'        => 'text',
42
-	                'desc_tip'    => true,
43
-	                'default'     => '',
44
-	                'placeholder' => __( '1', 'invoicing' ),
45
-	                'advanced'    => false,
46
-				),
39
+                    'title'       => __( 'Invoice', 'invoicing' ),
40
+                    'desc'        => __( 'Enter the invoice ID', 'invoicing' ),
41
+                    'type'        => 'text',
42
+                    'desc_tip'    => true,
43
+                    'default'     => '',
44
+                    'placeholder' => __( '1', 'invoicing' ),
45
+                    'advanced'    => false,
46
+                ),
47 47
             ),
48 48
 
49 49
         );
@@ -51,26 +51,26 @@  discard block
 block discarded – undo
51 51
         parent::__construct( $options );
52 52
     }
53 53
 
54
-	/**
55
-	 * The Super block output function.
56
-	 *
57
-	 * @param array $args
58
-	 * @param array $widget_args
59
-	 * @param string $content
60
-	 *
61
-	 * @return mixed|string|bool
62
-	 */
54
+    /**
55
+     * The Super block output function.
56
+     *
57
+     * @param array $args
58
+     * @param array $widget_args
59
+     * @param string $content
60
+     *
61
+     * @return mixed|string|bool
62
+     */
63 63
     public function output( $args = array(), $widget_args = array(), $content = '' ) {
64 64
 
65 65
         // Is the shortcode set up correctly?
66
-		if ( empty( $args['id'] ) ) {
67
-			return aui()->alert(
68
-				array(
69
-					'type'    => 'warning',
70
-					'content' => __( 'Missing invoice ID', 'invoicing' ),
71
-				)
72
-			);
73
-		}
66
+        if ( empty( $args['id'] ) ) {
67
+            return aui()->alert(
68
+                array(
69
+                    'type'    => 'warning',
70
+                    'content' => __( 'Missing invoice ID', 'invoicing' ),
71
+                )
72
+            );
73
+        }
74 74
 
75 75
         $invoice = wpinv_get_invoice( (int) $args['id'] );
76 76
 
Please login to merge, or discard this patch.