Passed
Push — master ( 98a9e1...506bd5 )
by Brian
07:05
created
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Indentation   +2005 added lines, -2005 removed lines patch added patch discarded remove patch
@@ -1,60 +1,60 @@  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
-	define( 'SUPER_DUPER_VER', '1.1.15' );
9
-
10
-	/**
11
-	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
12
-	 *
13
-	 * Should not be called direct but extended instead.
14
-	 *
15
-	 * Class WP_Super_Duper
16
-	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17
-	 * @ver 1.1.1
18
-	 */
19
-	class WP_Super_Duper extends WP_Widget {
20
-
21
-		public $version = SUPER_DUPER_VER;
22
-		public $font_awesome_icon_version = "5.11.2";
23
-		public $block_code;
24
-		public $options;
25
-		public $base_id;
26
-		public $settings_hash;
27
-		public $arguments = array();
28
-		public $instance = array();
29
-		private $class_name;
30
-
31
-		/**
32
-		 * The relative url to the current folder.
33
-		 *
34
-		 * @var string
35
-		 */
36
-		public $url = '';
37
-
38
-		/**
39
-		 * Take the array options and use them to build.
40
-		 */
41
-		public function __construct( $options ) {
42
-			global $sd_widgets;
43
-
44
-			$sd_widgets[ $options['base_id'] ] = array(
45
-				'name'       => $options['name'],
46
-				'class_name' => $options['class_name'],
47
-				'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
-			);
49
-			$this->base_id                     = $options['base_id'];
50
-			// lets filter the options before we do anything
51
-			$options       = apply_filters( "wp_super_duper_options", $options );
52
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
-			$options       = $this->add_name_from_key( $options );
54
-			$this->options = $options;
55
-
56
-			$this->base_id   = $options['base_id'];
57
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
8
+    define( 'SUPER_DUPER_VER', '1.1.15' );
9
+
10
+    /**
11
+     * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
12
+     *
13
+     * Should not be called direct but extended instead.
14
+     *
15
+     * Class WP_Super_Duper
16
+     * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17
+     * @ver 1.1.1
18
+     */
19
+    class WP_Super_Duper extends WP_Widget {
20
+
21
+        public $version = SUPER_DUPER_VER;
22
+        public $font_awesome_icon_version = "5.11.2";
23
+        public $block_code;
24
+        public $options;
25
+        public $base_id;
26
+        public $settings_hash;
27
+        public $arguments = array();
28
+        public $instance = array();
29
+        private $class_name;
30
+
31
+        /**
32
+         * The relative url to the current folder.
33
+         *
34
+         * @var string
35
+         */
36
+        public $url = '';
37
+
38
+        /**
39
+         * Take the array options and use them to build.
40
+         */
41
+        public function __construct( $options ) {
42
+            global $sd_widgets;
43
+
44
+            $sd_widgets[ $options['base_id'] ] = array(
45
+                'name'       => $options['name'],
46
+                'class_name' => $options['class_name'],
47
+                'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
+            );
49
+            $this->base_id                     = $options['base_id'];
50
+            // lets filter the options before we do anything
51
+            $options       = apply_filters( "wp_super_duper_options", $options );
52
+            $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
+            $options       = $this->add_name_from_key( $options );
54
+            $this->options = $options;
55
+
56
+            $this->base_id   = $options['base_id'];
57
+            $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
58 58
 
59 59
             // nested blocks can't work as a widget
60 60
             if(!empty($this->options['nested-block'])){
@@ -65,234 +65,234 @@  discard block
 block discarded – undo
65 65
                 }
66 66
             }
67 67
 
68
-			// init parent
69
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
68
+            // init parent
69
+            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70 70
                 parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
-			}
71
+            }
72 72
 
73 73
 
74
-			if ( isset( $options['class_name'] ) ) {
75
-				// register widget
76
-				$this->class_name = $options['class_name'];
74
+            if ( isset( $options['class_name'] ) ) {
75
+                // register widget
76
+                $this->class_name = $options['class_name'];
77 77
 
78
-				// register shortcode, this needs to be done even for blocks and widgets
78
+                // register shortcode, this needs to be done even for blocks and widgets
79 79
                 $this->register_shortcode();
80 80
 
81 81
 
82
-				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
85
-				}
82
+                // Fusion Builder (avada) support
83
+                if ( function_exists( 'fusion_builder_map' ) ) {
84
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
85
+                }
86 86
 
87
-				// register block
88
-				if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
89
-				    add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
87
+                // register block
88
+                if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
89
+                    add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
90 90
                 }
91
-			}
91
+            }
92 92
 
93
-			// add the CSS and JS we need ONCE
94
-			global $sd_widget_scripts;
93
+            // add the CSS and JS we need ONCE
94
+            global $sd_widget_scripts;
95 95
 
96
-			if ( ! $sd_widget_scripts ) {
97
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
98
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
99
-				wp_add_inline_style( 'widgets', $this->widget_css() );
96
+            if ( ! $sd_widget_scripts ) {
97
+                wp_add_inline_script( 'admin-widgets', $this->widget_js() );
98
+                wp_add_inline_script( 'customize-controls', $this->widget_js() );
99
+                wp_add_inline_style( 'widgets', $this->widget_css() );
100 100
 
101
-				// maybe add elementor editor styles
102
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
101
+                // maybe add elementor editor styles
102
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
103 103
 
104
-				$sd_widget_scripts = true;
104
+                $sd_widget_scripts = true;
105 105
 
106
-				// add shortcode insert button once
107
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
108
-				// generatepress theme sections compatibility
109
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
110
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
111
-				}
112
-				/* Load script on Divi theme builder page */
113
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
114
-					add_thickbox();
115
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
116
-				}
106
+                // add shortcode insert button once
107
+                add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
108
+                // generatepress theme sections compatibility
109
+                if ( function_exists( 'generate_sections_sections_metabox' ) ) {
110
+                    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
111
+                }
112
+                /* Load script on Divi theme builder page */
113
+                if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
114
+                    add_thickbox();
115
+                    add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
116
+                }
117 117
 
118
-				if ( $this->is_preview() ) {
119
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
120
-					// this makes the insert button work for elementor
121
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
122
-						$this,
123
-						'shortcode_insert_button_script'
124
-					) ); // for elementor
125
-				}
126
-				// this makes the insert button work for cornerstone
127
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
118
+                if ( $this->is_preview() ) {
119
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
120
+                    // this makes the insert button work for elementor
121
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
122
+                        $this,
123
+                        'shortcode_insert_button_script'
124
+                    ) ); // for elementor
125
+                }
126
+                // this makes the insert button work for cornerstone
127
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
128 128
 
129
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
130
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
129
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
130
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
131 131
 
132
-				// add generator text to admin head
133
-				add_action( 'admin_head', array( $this, 'generator' ) );
134
-			}
132
+                // add generator text to admin head
133
+                add_action( 'admin_head', array( $this, 'generator' ) );
134
+            }
135 135
 
136
-			do_action( 'wp_super_duper_widget_init', $options, $this );
137
-		}
136
+            do_action( 'wp_super_duper_widget_init', $options, $this );
137
+        }
138 138
 
139 139
         /**
140 140
          * The register widget function
141 141
          * @return void
142 142
          */
143
-		public function _register() {
143
+        public function _register() {
144 144
             if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
145 145
                 parent::_register();
146
-			}
147
-		}
146
+            }
147
+        }
148 148
 
149
-		/**
150
-		 * Add our widget CSS to elementor editor.
151
-		 */
152
-		public function elementor_editor_styles() {
153
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
154
-		}
149
+        /**
150
+         * Add our widget CSS to elementor editor.
151
+         */
152
+        public function elementor_editor_styles() {
153
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
154
+        }
155 155
 
156
-		public function register_fusion_element() {
156
+        public function register_fusion_element() {
157 157
 
158
-			$options = $this->options;
158
+            $options = $this->options;
159 159
 
160
-			if ( $this->base_id ) {
160
+            if ( $this->base_id ) {
161 161
 
162
-				$params = $this->get_fusion_params();
162
+                $params = $this->get_fusion_params();
163 163
 
164
-				$args = array(
165
-					'name'            => $options['name'],
166
-					'shortcode'       => $this->base_id,
167
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
168
-					'allow_generator' => true,
169
-				);
164
+                $args = array(
165
+                    'name'            => $options['name'],
166
+                    'shortcode'       => $this->base_id,
167
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
168
+                    'allow_generator' => true,
169
+                );
170 170
 
171
-				if ( ! empty( $params ) ) {
172
-					$args['params'] = $params;
173
-				}
171
+                if ( ! empty( $params ) ) {
172
+                    $args['params'] = $params;
173
+                }
174 174
 
175
-				fusion_builder_map( $args );
176
-			}
175
+                fusion_builder_map( $args );
176
+            }
177 177
 
178
-		}
178
+        }
179 179
 
180
-		public function get_fusion_params() {
181
-			$params    = array();
182
-			$arguments = $this->get_arguments();
183
-
184
-			if ( ! empty( $arguments ) ) {
185
-				foreach ( $arguments as $key => $val ) {
186
-					$param = array();
187
-					// type
188
-					$param['type'] = str_replace(
189
-						array(
190
-							"text",
191
-							"number",
192
-							"email",
193
-							"color",
194
-							"checkbox"
195
-						),
196
-						array(
197
-							"textfield",
198
-							"textfield",
199
-							"textfield",
200
-							"colorpicker",
201
-							"select",
202
-
203
-						),
204
-						$val['type'] );
205
-
206
-					// multiselect
207
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
208
-						$param['type']     = 'multiple_select';
209
-						$param['multiple'] = true;
210
-					}
180
+        public function get_fusion_params() {
181
+            $params    = array();
182
+            $arguments = $this->get_arguments();
183
+
184
+            if ( ! empty( $arguments ) ) {
185
+                foreach ( $arguments as $key => $val ) {
186
+                    $param = array();
187
+                    // type
188
+                    $param['type'] = str_replace(
189
+                        array(
190
+                            "text",
191
+                            "number",
192
+                            "email",
193
+                            "color",
194
+                            "checkbox"
195
+                        ),
196
+                        array(
197
+                            "textfield",
198
+                            "textfield",
199
+                            "textfield",
200
+                            "colorpicker",
201
+                            "select",
211 202
 
212
-					// heading
213
-					$param['heading'] = $val['title'];
203
+                        ),
204
+                        $val['type'] );
214 205
 
215
-					// description
216
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
206
+                    // multiselect
207
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
208
+                        $param['type']     = 'multiple_select';
209
+                        $param['multiple'] = true;
210
+                    }
217 211
 
218
-					// param_name
219
-					$param['param_name'] = $key;
212
+                    // heading
213
+                    $param['heading'] = $val['title'];
220 214
 
221
-					// Default
222
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
215
+                    // description
216
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
223 217
 
224
-					// Group
225
-					if ( isset( $val['group'] ) ) {
226
-						$param['group'] = $val['group'];
227
-					}
218
+                    // param_name
219
+                    $param['param_name'] = $key;
228 220
 
229
-					// value
230
-					if ( $val['type'] == 'checkbox' ) {
231
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
232
-							unset( $param['default'] );
233
-						}
234
-						$param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
235
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
236
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
237
-					} else {
238
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
239
-					}
221
+                    // Default
222
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
240 223
 
241
-					// setup the param
242
-					$params[] = $param;
224
+                    // Group
225
+                    if ( isset( $val['group'] ) ) {
226
+                        $param['group'] = $val['group'];
227
+                    }
243 228
 
244
-				}
245
-			}
229
+                    // value
230
+                    if ( $val['type'] == 'checkbox' ) {
231
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
232
+                            unset( $param['default'] );
233
+                        }
234
+                        $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) );
235
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
236
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
237
+                    } else {
238
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
239
+                    }
246 240
 
241
+                    // setup the param
242
+                    $params[] = $param;
247 243
 
248
-			return $params;
249
-		}
244
+                }
245
+            }
250 246
 
251
-		/**
252
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
253
-		 */
254
-		public static function maybe_cornerstone_builder() {
255
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
256
-				self::shortcode_insert_button_script();
257
-			}
258
-		}
259 247
 
260
-		/**
261
-		 * A function to ge the shortcode builder picker html.
262
-		 *
263
-		 * @param string $editor_id
264
-		 *
265
-		 * @return string
266
-		 */
267
-		public static function get_picker( $editor_id = '' ) {
268
-
269
-			ob_start();
270
-			if ( isset( $_POST['editor_id'] ) ) {
271
-				$editor_id = esc_attr( $_POST['editor_id'] );
272
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
273
-				$editor_id = 'main_content_content_vb_tiny_mce';
274
-			}
248
+            return $params;
249
+        }
250
+
251
+        /**
252
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
253
+         */
254
+        public static function maybe_cornerstone_builder() {
255
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
256
+                self::shortcode_insert_button_script();
257
+            }
258
+        }
259
+
260
+        /**
261
+         * A function to ge the shortcode builder picker html.
262
+         *
263
+         * @param string $editor_id
264
+         *
265
+         * @return string
266
+         */
267
+        public static function get_picker( $editor_id = '' ) {
268
+
269
+            ob_start();
270
+            if ( isset( $_POST['editor_id'] ) ) {
271
+                $editor_id = esc_attr( $_POST['editor_id'] );
272
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
273
+                $editor_id = 'main_content_content_vb_tiny_mce';
274
+            }
275 275
 
276
-			global $sd_widgets;
276
+            global $sd_widgets;
277 277
 
278 278
 //			print_r($sd_widgets);exit;
279
-			?>
279
+            ?>
280 280
 
281 281
 			<div class="sd-shortcode-left-wrap">
282 282
 				<?php
283
-				ksort( $sd_widgets );
284
-				//				print_r($sd_widgets);exit;
285
-				if ( ! empty( $sd_widgets ) ) {
286
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
287
-					echo "<option>" . __( 'Select shortcode' ) . "</option>";
288
-					foreach ( $sd_widgets as $shortcode => $class ) {
289
-						if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
290
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
291
-					}
292
-					echo "</select>";
283
+                ksort( $sd_widgets );
284
+                //				print_r($sd_widgets);exit;
285
+                if ( ! empty( $sd_widgets ) ) {
286
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
287
+                    echo "<option>" . __( 'Select shortcode' ) . "</option>";
288
+                    foreach ( $sd_widgets as $shortcode => $class ) {
289
+                        if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
290
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
291
+                    }
292
+                    echo "</select>";
293 293
 
294
-				}
295
-				?>
294
+                }
295
+                ?>
296 296
 				<div class="sd-shortcode-settings"></div>
297 297
 
298 298
 			</div>
@@ -303,8 +303,8 @@  discard block
 block discarded – undo
303 303
 					<?php if ( $editor_id != '' ) { ?>
304 304
 						<button class="button sd-insert-shortcode-button"
305 305
 						        onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
306
-							        echo "'" . $editor_id . "'";
307
-						        } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
306
+                                    echo "'" . $editor_id . "'";
307
+                                } ?>)"><?php _e( 'Insert shortcode' ); ?></button>
308 308
 					<?php } ?>
309 309
 					<button class="button"
310 310
 					        onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -312,135 +312,135 @@  discard block
 block discarded – undo
312 312
 			</div>
313 313
 			<?php
314 314
 
315
-			$html = ob_get_clean();
315
+            $html = ob_get_clean();
316 316
 
317
-			if ( wp_doing_ajax() ) {
318
-				echo $html;
319
-				$should_die = true;
317
+            if ( wp_doing_ajax() ) {
318
+                echo $html;
319
+                $should_die = true;
320 320
 
321
-				// some builder get the editor via ajax so we should not die on those occasions
322
-				$dont_die = array(
323
-					'parent_tag',// WP Bakery
324
-					'avia_request' // enfold
325
-				);
321
+                // some builder get the editor via ajax so we should not die on those occasions
322
+                $dont_die = array(
323
+                    'parent_tag',// WP Bakery
324
+                    'avia_request' // enfold
325
+                );
326 326
 
327
-				foreach ( $dont_die as $request ) {
328
-					if ( isset( $_REQUEST[ $request ] ) ) {
329
-						$should_die = false;
330
-					}
331
-				}
327
+                foreach ( $dont_die as $request ) {
328
+                    if ( isset( $_REQUEST[ $request ] ) ) {
329
+                        $should_die = false;
330
+                    }
331
+                }
332 332
 
333
-				if ( $should_die ) {
334
-					wp_die();
335
-				}
333
+                if ( $should_die ) {
334
+                    wp_die();
335
+                }
336 336
 
337
-			} else {
338
-				return $html;
339
-			}
337
+            } else {
338
+                return $html;
339
+            }
340 340
 
341
-			return '';
341
+            return '';
342 342
 
343
-		}
343
+        }
344 344
 
345
-		/**
346
-		 * Output the version in the admin header.
347
-		 */
348
-		public function generator() {
349
-			echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
350
-		}
345
+        /**
346
+         * Output the version in the admin header.
347
+         */
348
+        public function generator() {
349
+            echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />';
350
+        }
351 351
 
352
-		/**
353
-		 * Get widget settings.
354
-		 *
355
-		 * @since 1.0.0
356
-		 */
357
-		public static function get_widget_settings() {
358
-			global $sd_widgets;
359
-
360
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
361
-			if ( ! $shortcode ) {
362
-				wp_die();
363
-			}
364
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
365
-			if ( ! $widget_args ) {
366
-				wp_die();
367
-			}
368
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
369
-			if ( ! $class_name ) {
370
-				wp_die();
371
-			}
352
+        /**
353
+         * Get widget settings.
354
+         *
355
+         * @since 1.0.0
356
+         */
357
+        public static function get_widget_settings() {
358
+            global $sd_widgets;
359
+
360
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
361
+            if ( ! $shortcode ) {
362
+                wp_die();
363
+            }
364
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
365
+            if ( ! $widget_args ) {
366
+                wp_die();
367
+            }
368
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
369
+            if ( ! $class_name ) {
370
+                wp_die();
371
+            }
372 372
 
373
-			// invoke an instance method
374
-			$widget = new $class_name;
373
+            // invoke an instance method
374
+            $widget = new $class_name;
375 375
 
376
-			ob_start();
377
-			$widget->form( array() );
378
-			$form = ob_get_clean();
379
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
380
-			echo "<style>" . $widget->widget_css() . "</style>";
381
-			echo "<script>" . $widget->widget_js() . "</script>";
382
-			?>
376
+            ob_start();
377
+            $widget->form( array() );
378
+            $form = ob_get_clean();
379
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
380
+            echo "<style>" . $widget->widget_css() . "</style>";
381
+            echo "<script>" . $widget->widget_js() . "</script>";
382
+            ?>
383 383
 			<?php
384
-			wp_die();
385
-		}
384
+            wp_die();
385
+        }
386 386
 
387
-		/**
388
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
389
-		 *
390
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
391
-		 * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
392
-		 *
393
-		 *@since 1.0.0
394
-		 *
395
-		 */
396
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
397
-			global $sd_widgets, $shortcode_insert_button_once;
398
-			if ( $shortcode_insert_button_once ) {
399
-				return;
400
-			}
401
-			add_thickbox();
387
+        /**
388
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
389
+         *
390
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
391
+         * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
392
+         *
393
+         *@since 1.0.0
394
+         *
395
+         */
396
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
397
+            global $sd_widgets, $shortcode_insert_button_once;
398
+            if ( $shortcode_insert_button_once ) {
399
+                return;
400
+            }
401
+            add_thickbox();
402 402
 
403 403
 
404
-			/**
405
-			 * Cornerstone makes us play dirty tricks :/
406
-			 * 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.
407
-			 */
408
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
409
-				echo '<span id="insert-media-button">';
410
-			}
404
+            /**
405
+             * Cornerstone makes us play dirty tricks :/
406
+             * 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.
407
+             */
408
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
409
+                echo '<span id="insert-media-button">';
410
+            }
411 411
 
412
-			echo self::shortcode_button( 'this', 'true' );
412
+            echo self::shortcode_button( 'this', 'true' );
413 413
 
414
-			// see opening note
415
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
416
-				echo '</span>'; // end #insert-media-button
417
-			}
414
+            // see opening note
415
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
416
+                echo '</span>'; // end #insert-media-button
417
+            }
418 418
 
419
-			// Add separate script for generatepress theme sections
420
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
421
-			} else {
422
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
423
-			}
419
+            // Add separate script for generatepress theme sections
420
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
421
+            } else {
422
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
423
+            }
424 424
 
425
-			$shortcode_insert_button_once = true;
426
-		}
425
+            $shortcode_insert_button_once = true;
426
+        }
427 427
 
428
-		/**
429
-		 * Gets the shortcode insert button html.
430
-		 *
431
-		 * @param string $id
432
-		 * @param string $search_for_id
433
-		 *
434
-		 * @return mixed
435
-		 */
436
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
437
-			ob_start();
438
-			?>
428
+        /**
429
+         * Gets the shortcode insert button html.
430
+         *
431
+         * @param string $id
432
+         * @param string $search_for_id
433
+         *
434
+         * @return mixed
435
+         */
436
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
437
+            ob_start();
438
+            ?>
439 439
 			<span class="sd-lable-shortcode-inserter">
440 440
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
441
-				if ( $search_for_id ) {
442
-					echo "," . $search_for_id;
443
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
441
+                if ( $search_for_id ) {
442
+                    echo "," . $search_for_id;
443
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
444 444
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
445 445
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
446 446
 					      class="dashicons dashicons-screenoptions"></span>
@@ -451,21 +451,21 @@  discard block
 block discarded – undo
451 451
 			</span>
452 452
 
453 453
 			<?php
454
-			$html = ob_get_clean();
454
+            $html = ob_get_clean();
455 455
 
456
-			// remove line breaks so we can use it in js
457
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
458
-		}
456
+            // remove line breaks so we can use it in js
457
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
458
+        }
459 459
 
460
-		/**
461
-		 * Makes SD work with the siteOrigin page builder.
462
-		 *
463
-		 * @return mixed
464
-		 *@since 1.0.6
465
-		 */
466
-		public static function siteorigin_js() {
467
-			ob_start();
468
-			?>
460
+        /**
461
+         * Makes SD work with the siteOrigin page builder.
462
+         *
463
+         * @return mixed
464
+         *@since 1.0.6
465
+         */
466
+        public static function siteorigin_js() {
467
+            ob_start();
468
+            ?>
469 469
 			<script>
470 470
 				/**
471 471
 				 * Check a form to see what items should be shown or hidden.
@@ -541,29 +541,29 @@  discard block
 block discarded – undo
541 541
 				});
542 542
 			</script>
543 543
 			<?php
544
-			$output = ob_get_clean();
544
+            $output = ob_get_clean();
545 545
 
546
-			/*
546
+            /*
547 547
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
548 548
 			 */
549 549
 
550
-			return str_replace( array(
551
-				'<script>',
552
-				'</script>'
553
-			), '', $output );
554
-		}
550
+            return str_replace( array(
551
+                '<script>',
552
+                '</script>'
553
+            ), '', $output );
554
+        }
555 555
 
556
-		/**
557
-		 * Output the JS and CSS for the shortcode insert button.
558
-		 *
559
-		 * @param string $editor_id
560
-		 * @param string $insert_shortcode_function
561
-		 *
562
-		 *@since 1.0.6
563
-		 *
564
-		 */
565
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
566
-			?>
556
+        /**
557
+         * Output the JS and CSS for the shortcode insert button.
558
+         *
559
+         * @param string $editor_id
560
+         * @param string $insert_shortcode_function
561
+         *
562
+         *@since 1.0.6
563
+         *
564
+         */
565
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
566
+            ?>
567 567
 			<style>
568 568
 				.sd-shortcode-left-wrap {
569 569
 					float: left;
@@ -691,35 +691,35 @@  discard block
 block discarded – undo
691 691
 				<?php } ?>
692 692
 			</style>
693 693
 			<?php
694
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
695
-				echo "<script>" . self::siteorigin_js() . "</script>";
696
-			}
697
-			?>
694
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
695
+                echo "<script>" . self::siteorigin_js() . "</script>";
696
+            }
697
+            ?>
698 698
 			<script>
699 699
 				<?php
700
-				if(! empty( $insert_shortcode_function )){
701
-					echo $insert_shortcode_function;
702
-				}else{
700
+                if(! empty( $insert_shortcode_function )){
701
+                    echo $insert_shortcode_function;
702
+                }else{
703 703
 
704
-				/**
705
-				 * Function for super duper insert shortcode.
706
-				 *
707
-				 * @since 1.0.0
708
-				 */
709
-				?>
704
+                /**
705
+                 * Function for super duper insert shortcode.
706
+                 *
707
+                 * @since 1.0.0
708
+                 */
709
+                ?>
710 710
 				function sd_insert_shortcode($editor_id) {
711 711
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
712 712
 					if ($shortcode) {
713 713
 						if (!$editor_id) {
714 714
 							<?php
715
-							if ( isset( $_REQUEST['et_fb'] ) ) {
716
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
717
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
718
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
719
-							} else {
720
-								echo '$editor_id = "#wp-content-editor-container textarea";';
721
-							}
722
-							?>
715
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
716
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
717
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
718
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
719
+                            } else {
720
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
721
+                            }
722
+                            ?>
723 723
 						} else {
724 724
 							$editor_id = '#' + $editor_id;
725 725
 						}
@@ -1046,18 +1046,18 @@  discard block
 block discarded – undo
1046 1046
 
1047 1047
 			</script>
1048 1048
 			<?php
1049
-		}
1049
+        }
1050 1050
 
1051
-		/**
1052
-		 * Gets some CSS for the widgets screen.
1053
-		 *
1054
-		 * @param bool $advanced If we should include advanced CSS.
1055
-		 *
1056
-		 * @return mixed
1057
-		 */
1058
-		public function widget_css( $advanced = true ) {
1059
-			ob_start();
1060
-			?>
1051
+        /**
1052
+         * Gets some CSS for the widgets screen.
1053
+         *
1054
+         * @param bool $advanced If we should include advanced CSS.
1055
+         *
1056
+         * @return mixed
1057
+         */
1058
+        public function widget_css( $advanced = true ) {
1059
+            ob_start();
1060
+            ?>
1061 1061
 			<style>
1062 1062
 				<?php if( $advanced ){ ?>
1063 1063
 				.sd-advanced-setting {
@@ -1095,26 +1095,26 @@  discard block
 block discarded – undo
1095 1095
 				}
1096 1096
 			</style>
1097 1097
 			<?php
1098
-			$output = ob_get_clean();
1098
+            $output = ob_get_clean();
1099 1099
 
1100
-			/*
1100
+            /*
1101 1101
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1102 1102
 			 */
1103 1103
 
1104
-			return str_replace( array(
1105
-				'<style>',
1106
-				'</style>'
1107
-			), '', $output );
1108
-		}
1104
+            return str_replace( array(
1105
+                '<style>',
1106
+                '</style>'
1107
+            ), '', $output );
1108
+        }
1109 1109
 
1110
-		/**
1111
-		 * Gets some JS for the widgets screen.
1112
-		 *
1113
-		 * @return mixed
1114
-		 */
1115
-		public function widget_js() {
1116
-			ob_start();
1117
-			?>
1110
+        /**
1111
+         * Gets some JS for the widgets screen.
1112
+         *
1113
+         * @return mixed
1114
+         */
1115
+        public function widget_js() {
1116
+            ob_start();
1117
+            ?>
1118 1118
 			<script>
1119 1119
 
1120 1120
 				/**
@@ -1265,471 +1265,471 @@  discard block
 block discarded – undo
1265 1265
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1266 1266
 			</script>
1267 1267
 			<?php
1268
-			$output = ob_get_clean();
1268
+            $output = ob_get_clean();
1269 1269
 
1270
-			/*
1270
+            /*
1271 1271
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1272 1272
 			 */
1273 1273
 
1274
-			return str_replace( array(
1275
-				'<script>',
1276
-				'</script>'
1277
-			), '', $output );
1278
-		}
1274
+            return str_replace( array(
1275
+                '<script>',
1276
+                '</script>'
1277
+            ), '', $output );
1278
+        }
1279 1279
 
1280 1280
 
1281
-		/**
1282
-		 * Set the name from the argument key.
1283
-		 *
1284
-		 * @param $options
1285
-		 *
1286
-		 * @return mixed
1287
-		 */
1288
-		private function add_name_from_key( $options, $arguments = false ) {
1289
-			if ( ! empty( $options['arguments'] ) ) {
1290
-				foreach ( $options['arguments'] as $key => $val ) {
1291
-					$options['arguments'][ $key ]['name'] = $key;
1292
-				}
1293
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1294
-				foreach ( $options as $key => $val ) {
1295
-					$options[ $key ]['name'] = $key;
1296
-				}
1297
-			}
1281
+        /**
1282
+         * Set the name from the argument key.
1283
+         *
1284
+         * @param $options
1285
+         *
1286
+         * @return mixed
1287
+         */
1288
+        private function add_name_from_key( $options, $arguments = false ) {
1289
+            if ( ! empty( $options['arguments'] ) ) {
1290
+                foreach ( $options['arguments'] as $key => $val ) {
1291
+                    $options['arguments'][ $key ]['name'] = $key;
1292
+                }
1293
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1294
+                foreach ( $options as $key => $val ) {
1295
+                    $options[ $key ]['name'] = $key;
1296
+                }
1297
+            }
1298 1298
 
1299
-			return $options;
1300
-		}
1299
+            return $options;
1300
+        }
1301 1301
 
1302
-		/**
1303
-		 * Register the parent shortcode.
1304
-		 *
1305
-		 * @since 1.0.0
1306
-		 */
1307
-		public function register_shortcode() {
1308
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1309
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1310
-		}
1302
+        /**
1303
+         * Register the parent shortcode.
1304
+         *
1305
+         * @since 1.0.0
1306
+         */
1307
+        public function register_shortcode() {
1308
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1309
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1310
+        }
1311 1311
 
1312
-		/**
1313
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1314
-		 *
1315
-		 * @since 1.0.0
1316
-		 */
1317
-		public function render_shortcode() {
1318
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1319
-			if ( ! current_user_can( 'manage_options' ) ) {
1320
-				wp_die();
1321
-			}
1312
+        /**
1313
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1314
+         *
1315
+         * @since 1.0.0
1316
+         */
1317
+        public function render_shortcode() {
1318
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1319
+            if ( ! current_user_can( 'manage_options' ) ) {
1320
+                wp_die();
1321
+            }
1322 1322
 
1323
-			// we might need the $post value here so lets set it.
1324
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1325
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1326
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1327
-					global $post;
1328
-					$post = $post_obj;
1329
-				}
1330
-			}
1323
+            // we might need the $post value here so lets set it.
1324
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1325
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1326
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1327
+                    global $post;
1328
+                    $post = $post_obj;
1329
+                }
1330
+            }
1331 1331
 
1332
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1333
-				$is_preview = $this->is_preview();
1334
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1335
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1336
-				$attributes       = '';
1337
-				if ( ! empty( $attributes_array ) ) {
1338
-					foreach ( $attributes_array as $key => $value ) {
1339
-						if ( is_array( $value ) ) {
1340
-							$value = implode( ",", $value );
1341
-						}
1332
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1333
+                $is_preview = $this->is_preview();
1334
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1335
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1336
+                $attributes       = '';
1337
+                if ( ! empty( $attributes_array ) ) {
1338
+                    foreach ( $attributes_array as $key => $value ) {
1339
+                        if ( is_array( $value ) ) {
1340
+                            $value = implode( ",", $value );
1341
+                        }
1342 1342
 
1343
-						if ( ! empty( $value ) ) {
1344
-							$value = wp_unslash( $value );
1343
+                        if ( ! empty( $value ) ) {
1344
+                            $value = wp_unslash( $value );
1345 1345
 
1346
-							// Encode [ and ].
1347
-							if ( $is_preview ) {
1348
-								$value = $this->encode_shortcodes( $value );
1349
-							}
1350
-						}
1351
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1352
-					}
1353
-				}
1346
+                            // Encode [ and ].
1347
+                            if ( $is_preview ) {
1348
+                                $value = $this->encode_shortcodes( $value );
1349
+                            }
1350
+                        }
1351
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1352
+                    }
1353
+                }
1354 1354
 
1355
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1355
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1356 1356
 
1357
-				$content = do_shortcode( $shortcode );
1357
+                $content = do_shortcode( $shortcode );
1358 1358
 
1359
-				// Decode [ and ].
1360
-				if ( ! empty( $content ) && $is_preview ) {
1361
-					$content = $this->decode_shortcodes( $content );
1362
-				}
1359
+                // Decode [ and ].
1360
+                if ( ! empty( $content ) && $is_preview ) {
1361
+                    $content = $this->decode_shortcodes( $content );
1362
+                }
1363 1363
 
1364
-				echo $content;
1365
-			}
1366
-			wp_die();
1367
-		}
1364
+                echo $content;
1365
+            }
1366
+            wp_die();
1367
+        }
1368 1368
 
1369
-		/**
1370
-		 * Output the shortcode.
1371
-		 *
1372
-		 * @param array $args
1373
-		 * @param string $content
1374
-		 *
1375
-		 * @return string
1376
-		 */
1377
-		public function shortcode_output( $args = array(), $content = '' ) {
1378
-			$_instance = $args;
1379
-
1380
-			$args = $this->argument_values( $args );
1381
-
1382
-			// add extra argument so we know its a output to gutenberg
1383
-			//$args
1384
-			$args = $this->string_to_bool( $args );
1385
-
1386
-			// if we have a enclosed shortcode we add it to the special `html` argument
1387
-			if ( ! empty( $content ) ) {
1388
-				$args['html'] = $content;
1389
-			}
1369
+        /**
1370
+         * Output the shortcode.
1371
+         *
1372
+         * @param array $args
1373
+         * @param string $content
1374
+         *
1375
+         * @return string
1376
+         */
1377
+        public function shortcode_output( $args = array(), $content = '' ) {
1378
+            $_instance = $args;
1390 1379
 
1391
-			if ( ! $this->is_preview() ) {
1392
-				/**
1393
-				 * Filters the settings for a particular widget args.
1394
-				 *
1395
-				 * @param array          $args      The current widget instance's settings.
1396
-				 * @param WP_Super_Duper $widget    The current widget settings.
1397
-				 * @param array          $_instance An array of default widget arguments.
1398
-				 *
1399
-				 *@since 1.0.28
1400
-				 *
1401
-				 */
1402
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1380
+            $args = $this->argument_values( $args );
1403 1381
 
1404
-				if ( ! is_array( $args ) ) {
1405
-					return $args;
1406
-				}
1407
-			}
1382
+            // add extra argument so we know its a output to gutenberg
1383
+            //$args
1384
+            $args = $this->string_to_bool( $args );
1408 1385
 
1409
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1410
-			$class .= " sdel-".$this->get_instance_hash();
1386
+            // if we have a enclosed shortcode we add it to the special `html` argument
1387
+            if ( ! empty( $content ) ) {
1388
+                $args['html'] = $content;
1389
+            }
1411 1390
 
1412
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1413
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1391
+            if ( ! $this->is_preview() ) {
1392
+                /**
1393
+                 * Filters the settings for a particular widget args.
1394
+                 *
1395
+                 * @param array          $args      The current widget instance's settings.
1396
+                 * @param WP_Super_Duper $widget    The current widget settings.
1397
+                 * @param array          $_instance An array of default widget arguments.
1398
+                 *
1399
+                 *@since 1.0.28
1400
+                 *
1401
+                 */
1402
+                $args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1403
+
1404
+                if ( ! is_array( $args ) ) {
1405
+                    return $args;
1406
+                }
1407
+            }
1414 1408
 
1415
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1416
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1409
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1410
+            $class .= " sdel-".$this->get_instance_hash();
1417 1411
 
1418
-			$shortcode_args = array();
1419
-			$output         = '';
1420
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1421
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1422
-				$no_wrap = true;
1423
-			}
1424
-			$main_content = $this->output( $args, $shortcode_args, $content );
1425
-			if ( $main_content && ! $no_wrap ) {
1426
-				// wrap the shortcode in a div with the same class as the widget
1427
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1428
-				if ( ! empty( $args['title'] ) ) {
1429
-					// if its a shortcode and there is a title try to grab the title wrappers
1430
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1431
-					if ( empty( $instance ) ) {
1432
-						global $wp_registered_sidebars;
1433
-						if ( ! empty( $wp_registered_sidebars ) ) {
1434
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1435
-								if ( ! empty( $sidebar['before_title'] ) ) {
1436
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1437
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1438
-									break;
1439
-								}
1440
-							}
1441
-						}
1442
-					}
1443
-					$output .= $this->output_title( $shortcode_args, $args );
1444
-				}
1445
-				$output .= $main_content;
1446
-				$output .= '</div>';
1447
-			} elseif ( $main_content && $no_wrap ) {
1448
-				$output .= $main_content;
1449
-			}
1412
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1413
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1450 1414
 
1451
-			// if preview show a placeholder if empty
1452
-			if ( $this->is_preview() && $output == '' ) {
1453
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1454
-			}
1415
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1416
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1455 1417
 
1456
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1457
-		}
1418
+            $shortcode_args = array();
1419
+            $output         = '';
1420
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1421
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1422
+                $no_wrap = true;
1423
+            }
1424
+            $main_content = $this->output( $args, $shortcode_args, $content );
1425
+            if ( $main_content && ! $no_wrap ) {
1426
+                // wrap the shortcode in a div with the same class as the widget
1427
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1428
+                if ( ! empty( $args['title'] ) ) {
1429
+                    // if its a shortcode and there is a title try to grab the title wrappers
1430
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1431
+                    if ( empty( $instance ) ) {
1432
+                        global $wp_registered_sidebars;
1433
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1434
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1435
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1436
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1437
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1438
+                                    break;
1439
+                                }
1440
+                            }
1441
+                        }
1442
+                    }
1443
+                    $output .= $this->output_title( $shortcode_args, $args );
1444
+                }
1445
+                $output .= $main_content;
1446
+                $output .= '</div>';
1447
+            } elseif ( $main_content && $no_wrap ) {
1448
+                $output .= $main_content;
1449
+            }
1458 1450
 
1459
-		/**
1460
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1461
-		 *
1462
-		 * @param string $name
1463
-		 *
1464
-		 * @return string
1465
-		 */
1466
-		public function preview_placeholder_text( $name = '' ) {
1467
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1468
-		}
1451
+            // if preview show a placeholder if empty
1452
+            if ( $this->is_preview() && $output == '' ) {
1453
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1454
+            }
1469 1455
 
1470
-		/**
1471
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1472
-		 *
1473
-		 * @param $options
1474
-		 *
1475
-		 * @return mixed
1476
-		 */
1477
-		public function string_to_bool( $options ) {
1478
-			// convert bool strings to booleans
1479
-			foreach ( $options as $key => $val ) {
1480
-				if ( $val == 'false' ) {
1481
-					$options[ $key ] = false;
1482
-				} elseif ( $val == 'true' ) {
1483
-					$options[ $key ] = true;
1484
-				}
1485
-			}
1456
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1457
+        }
1486 1458
 
1487
-			return $options;
1488
-		}
1459
+        /**
1460
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1461
+         *
1462
+         * @param string $name
1463
+         *
1464
+         * @return string
1465
+         */
1466
+        public function preview_placeholder_text( $name = '' ) {
1467
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>";
1468
+        }
1489 1469
 
1490
-		/**
1491
-		 * Get the argument values that are also filterable.
1492
-		 *
1493
-		 * @param $instance
1494
-		 *
1495
-		 * @return array
1496
-		 *@since 1.0.12 Don't set checkbox default value if the value is empty.
1497
-		 *
1498
-		 */
1499
-		public function argument_values( $instance ) {
1500
-			$argument_values = array();
1501
-
1502
-			// set widget instance
1503
-			$this->instance = $instance;
1504
-
1505
-			if ( empty( $this->arguments ) ) {
1506
-				$this->arguments = $this->get_arguments();
1507
-			}
1470
+        /**
1471
+         * Sometimes booleans values can be turned to strings, so we fix that.
1472
+         *
1473
+         * @param $options
1474
+         *
1475
+         * @return mixed
1476
+         */
1477
+        public function string_to_bool( $options ) {
1478
+            // convert bool strings to booleans
1479
+            foreach ( $options as $key => $val ) {
1480
+                if ( $val == 'false' ) {
1481
+                    $options[ $key ] = false;
1482
+                } elseif ( $val == 'true' ) {
1483
+                    $options[ $key ] = true;
1484
+                }
1485
+            }
1508 1486
 
1509
-			if ( ! empty( $this->arguments ) ) {
1510
-				foreach ( $this->arguments as $key => $args ) {
1511
-					// set the input name from the key
1512
-					$args['name'] = $key;
1513
-					//
1514
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1515
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1516
-						// don't set default for an empty checkbox
1517
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1518
-						$argument_values[ $key ] = $args['default'];
1519
-					}
1520
-				}
1521
-			}
1487
+            return $options;
1488
+        }
1522 1489
 
1523
-			return $argument_values;
1524
-		}
1490
+        /**
1491
+         * Get the argument values that are also filterable.
1492
+         *
1493
+         * @param $instance
1494
+         *
1495
+         * @return array
1496
+         *@since 1.0.12 Don't set checkbox default value if the value is empty.
1497
+         *
1498
+         */
1499
+        public function argument_values( $instance ) {
1500
+            $argument_values = array();
1525 1501
 
1526
-		/**
1527
-		 * Set arguments in super duper.
1528
-		 *
1529
-		 * @return array Set arguments.
1530
-		 *@since 1.0.0
1531
-		 *
1532
-		 */
1533
-		public function set_arguments() {
1534
-			return $this->arguments;
1535
-		}
1502
+            // set widget instance
1503
+            $this->instance = $instance;
1536 1504
 
1537
-		/**
1538
-		 * Get arguments in super duper.
1539
-		 *
1540
-		 * @return array Get arguments.
1541
-		 *@since 1.0.0
1542
-		 *
1543
-		 */
1544
-		public function get_arguments() {
1545
-			if ( empty( $this->arguments ) ) {
1546
-				$this->arguments = $this->set_arguments();
1547
-			}
1505
+            if ( empty( $this->arguments ) ) {
1506
+                $this->arguments = $this->get_arguments();
1507
+            }
1548 1508
 
1549
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1550
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1509
+            if ( ! empty( $this->arguments ) ) {
1510
+                foreach ( $this->arguments as $key => $args ) {
1511
+                    // set the input name from the key
1512
+                    $args['name'] = $key;
1513
+                    //
1514
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1515
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1516
+                        // don't set default for an empty checkbox
1517
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1518
+                        $argument_values[ $key ] = $args['default'];
1519
+                    }
1520
+                }
1521
+            }
1551 1522
 
1552
-			return $this->arguments;
1553
-		}
1523
+            return $argument_values;
1524
+        }
1554 1525
 
1555
-		/**
1556
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1557
-		 *
1558
-		 * @param array $args
1559
-		 * @param array $widget_args
1560
-		 * @param string $content
1561
-		 */
1562
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1526
+        /**
1527
+         * Set arguments in super duper.
1528
+         *
1529
+         * @return array Set arguments.
1530
+         *@since 1.0.0
1531
+         *
1532
+         */
1533
+        public function set_arguments() {
1534
+            return $this->arguments;
1535
+        }
1563 1536
 
1564
-		}
1537
+        /**
1538
+         * Get arguments in super duper.
1539
+         *
1540
+         * @return array Get arguments.
1541
+         *@since 1.0.0
1542
+         *
1543
+         */
1544
+        public function get_arguments() {
1545
+            if ( empty( $this->arguments ) ) {
1546
+                $this->arguments = $this->set_arguments();
1547
+            }
1565 1548
 
1566
-		/**
1567
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1568
-		 */
1569
-		public function register_block() {
1570
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1571
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1572
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1573
-			}
1574
-		}
1549
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1550
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1575 1551
 
1576
-		/**
1577
-		 * Check if we need to show advanced options.
1578
-		 *
1579
-		 * @return bool
1580
-		 */
1581
-		public function block_show_advanced() {
1582
-
1583
-			$show      = false;
1584
-			$arguments = $this->get_arguments();
1585
-
1586
-			if ( ! empty( $arguments ) ) {
1587
-				foreach ( $arguments as $argument ) {
1588
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1589
-						$show = true;
1590
-						break; // no need to continue if we know we have it
1591
-					}
1592
-				}
1593
-			}
1552
+            return $this->arguments;
1553
+        }
1594 1554
 
1595
-			return $show;
1596
-		}
1555
+        /**
1556
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1557
+         *
1558
+         * @param array $args
1559
+         * @param array $widget_args
1560
+         * @param string $content
1561
+         */
1562
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1597 1563
 
1598
-		/**
1599
-		 * Get the url path to the current folder.
1600
-		 *
1601
-		 * @return string
1602
-		 */
1603
-		public function get_url() {
1604
-			$url = $this->url;
1605
-
1606
-			if ( ! $url ) {
1607
-				$content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1608
-				$content_url = untrailingslashit( WP_CONTENT_URL );
1609
-
1610
-				// Replace http:// to https://.
1611
-				if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1612
-					$content_url = str_replace( 'http://', 'https://', $content_url );
1613
-				}
1564
+        }
1614 1565
 
1615
-				// Check if we are inside a plugin
1616
-				$file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1617
-				$url = str_replace( $content_dir, $content_url, $file_dir );
1618
-				$url = trailingslashit( $url );
1619
-				$this->url = $url;
1620
-			}
1566
+        /**
1567
+         * Add the dynamic block code inline when the wp-block in enqueued.
1568
+         */
1569
+        public function register_block() {
1570
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1571
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1572
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1573
+            }
1574
+        }
1621 1575
 
1622
-			return $url;
1623
-		}
1576
+        /**
1577
+         * Check if we need to show advanced options.
1578
+         *
1579
+         * @return bool
1580
+         */
1581
+        public function block_show_advanced() {
1624 1582
 
1625
-		/**
1626
-		 * Get the url path to the current folder.
1627
-		 *
1628
-		 * @return string
1629
-		 */
1630
-		public function get_url_old() {
1583
+            $show      = false;
1584
+            $arguments = $this->get_arguments();
1631 1585
 
1632
-			$url = $this->url;
1586
+            if ( ! empty( $arguments ) ) {
1587
+                foreach ( $arguments as $argument ) {
1588
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1589
+                        $show = true;
1590
+                        break; // no need to continue if we know we have it
1591
+                    }
1592
+                }
1593
+            }
1633 1594
 
1634
-			if ( ! $url ) {
1635
-				// check if we are inside a plugin
1636
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1595
+            return $show;
1596
+        }
1637 1597
 
1638
-				$dir_parts = explode( "/wp-content/", $file_dir );
1639
-				$url_parts = explode( "/wp-content/", plugins_url() );
1598
+        /**
1599
+         * Get the url path to the current folder.
1600
+         *
1601
+         * @return string
1602
+         */
1603
+        public function get_url() {
1604
+            $url = $this->url;
1640 1605
 
1641
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1642
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1643
-					$this->url = $url;
1644
-				}
1645
-			}
1606
+            if ( ! $url ) {
1607
+                $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1608
+                $content_url = untrailingslashit( WP_CONTENT_URL );
1646 1609
 
1610
+                // Replace http:// to https://.
1611
+                if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1612
+                    $content_url = str_replace( 'http://', 'https://', $content_url );
1613
+                }
1647 1614
 
1648
-			return $url;
1649
-		}
1615
+                // Check if we are inside a plugin
1616
+                $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1617
+                $url = str_replace( $content_dir, $content_url, $file_dir );
1618
+                $url = trailingslashit( $url );
1619
+                $this->url = $url;
1620
+            }
1650 1621
 
1651
-		/**
1652
-		 * Generate the block icon.
1653
-		 *
1654
-		 * Enables the use of Font Awesome icons.
1655
-		 *
1656
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1657
-		 *
1658
-		 * @param $icon
1659
-		 *
1660
-		 * @return string
1661
-		 *@since 1.1.0
1662
-		 */
1663
-		public function get_block_icon( $icon ) {
1664
-
1665
-			// check if we have a Font Awesome icon
1666
-			$fa_type = '';
1667
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1668
-				$fa_type = 'solid';
1669
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1670
-				$fa_type = 'regular';
1671
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1672
-				$fa_type = 'brands';
1673
-			} else {
1674
-				$icon = "'" . $icon . "'";
1675
-			}
1622
+            return $url;
1623
+        }
1676 1624
 
1677
-			// set the icon if we found one
1678
-			if ( $fa_type ) {
1679
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1680
-				$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 . "'}))";
1681
-			}
1625
+        /**
1626
+         * Get the url path to the current folder.
1627
+         *
1628
+         * @return string
1629
+         */
1630
+        public function get_url_old() {
1682 1631
 
1683
-			return $icon;
1684
-		}
1632
+            $url = $this->url;
1633
+
1634
+            if ( ! $url ) {
1635
+                // check if we are inside a plugin
1636
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1637
+
1638
+                $dir_parts = explode( "/wp-content/", $file_dir );
1639
+                $url_parts = explode( "/wp-content/", plugins_url() );
1640
+
1641
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1642
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1643
+                    $this->url = $url;
1644
+                }
1645
+            }
1646
+
1647
+
1648
+            return $url;
1649
+        }
1685 1650
 
1686
-		public function group_arguments( $arguments ) {
1651
+        /**
1652
+         * Generate the block icon.
1653
+         *
1654
+         * Enables the use of Font Awesome icons.
1655
+         *
1656
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1657
+         *
1658
+         * @param $icon
1659
+         *
1660
+         * @return string
1661
+         *@since 1.1.0
1662
+         */
1663
+        public function get_block_icon( $icon ) {
1664
+
1665
+            // check if we have a Font Awesome icon
1666
+            $fa_type = '';
1667
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1668
+                $fa_type = 'solid';
1669
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1670
+                $fa_type = 'regular';
1671
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1672
+                $fa_type = 'brands';
1673
+            } else {
1674
+                $icon = "'" . $icon . "'";
1675
+            }
1676
+
1677
+            // set the icon if we found one
1678
+            if ( $fa_type ) {
1679
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1680
+                $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 . "'}))";
1681
+            }
1682
+
1683
+            return $icon;
1684
+        }
1685
+
1686
+        public function group_arguments( $arguments ) {
1687 1687
 //			echo '###';print_r($arguments);
1688
-			if ( ! empty( $arguments ) ) {
1689
-				$temp_arguments = array();
1690
-				$general        = __( "General" );
1691
-				$add_sections   = false;
1692
-				foreach ( $arguments as $key => $args ) {
1693
-					if ( isset( $args['group'] ) ) {
1694
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1695
-						$add_sections                             = true;
1696
-					} else {
1697
-						$temp_arguments[ $general ][ $key ] = $args;
1698
-					}
1699
-				}
1688
+            if ( ! empty( $arguments ) ) {
1689
+                $temp_arguments = array();
1690
+                $general        = __( "General" );
1691
+                $add_sections   = false;
1692
+                foreach ( $arguments as $key => $args ) {
1693
+                    if ( isset( $args['group'] ) ) {
1694
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1695
+                        $add_sections                             = true;
1696
+                    } else {
1697
+                        $temp_arguments[ $general ][ $key ] = $args;
1698
+                    }
1699
+                }
1700 1700
 
1701
-				// only add sections if more than one
1702
-				if ( $add_sections ) {
1703
-					$arguments = $temp_arguments;
1704
-				}
1705
-			}
1701
+                // only add sections if more than one
1702
+                if ( $add_sections ) {
1703
+                    $arguments = $temp_arguments;
1704
+                }
1705
+            }
1706 1706
 
1707 1707
 //			echo '###';print_r($arguments);
1708
-			return $arguments;
1709
-		}
1708
+            return $arguments;
1709
+        }
1710 1710
 
1711 1711
 
1712
-		/**
1713
-		 * Output the JS for building the dynamic Guntenberg block.
1714
-		 *
1715
-		 * @return mixed
1716
-		 *@since 1.0.9 Save numbers as numbers and not strings.
1717
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1718
-		 * @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.
1719
-		 */
1720
-		public function block() {
1712
+        /**
1713
+         * Output the JS for building the dynamic Guntenberg block.
1714
+         *
1715
+         * @return mixed
1716
+         *@since 1.0.9 Save numbers as numbers and not strings.
1717
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1718
+         * @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.
1719
+         */
1720
+        public function block() {
1721 1721
             global $sd_is_js_functions_loaded, $aui_bs5;
1722 1722
 
1723
-			ob_start();
1723
+            ob_start();
1724 1724
 
1725
-			$show_advanced = $this->block_show_advanced();
1725
+            $show_advanced = $this->block_show_advanced();
1726 1726
 
1727 1727
 
1728
-			?>
1728
+            ?>
1729 1729
 			<script>
1730 1730
 
1731 1731
 			<?php
1732
-			if(!$sd_is_js_functions_loaded){
1732
+            if(!$sd_is_js_functions_loaded){
1733 1733
                 $sd_is_js_functions_loaded = true;
1734 1734
             ?>
1735 1735
 
@@ -1963,8 +1963,8 @@  discard block
 block discarded – undo
1963 1963
                 $classes = [];
1964 1964
 
1965 1965
 				<?php
1966
-				if($aui_bs5){
1967
-					?>
1966
+                if($aui_bs5){
1967
+                    ?>
1968 1968
 				$aui_bs5 = true;
1969 1969
 				$p_ml = 'ms-';
1970 1970
 				$p_mr = 'me-';
@@ -1972,8 +1972,8 @@  discard block
 block discarded – undo
1972 1972
 				$p_pl = 'ps-';
1973 1973
 				$p_pr = 'pe-';
1974 1974
 					<?php
1975
-				}else{
1976
-						?>
1975
+                }else{
1976
+                        ?>
1977 1977
 				$aui_bs5 = false;
1978 1978
 				$p_ml = 'ml-';
1979 1979
 				$p_mr = 'mr-';
@@ -1981,8 +1981,8 @@  discard block
 block discarded – undo
1981 1981
 				$p_pl = 'pl-';
1982 1982
 				$p_pr = 'pr-';
1983 1983
 					<?php
1984
-				}
1985
-				?>
1984
+                }
1985
+                ?>
1986 1986
 
1987 1987
                 // margins
1988 1988
 	            if ( $args['mt'] !== undefined && $args['mt'] !== '' ) { $classes.push( "mt-" + $args['mt'] );  $mt = $args['mt']; }else{$mt = null;}
@@ -2165,10 +2165,10 @@  discard block
 block discarded – undo
2165 2165
 
2166 2166
             }
2167 2167
 
2168
-			if(method_exists($this,'block_global_js')){
2169
-					echo $this->block_global_js();
2170
-			}
2171
-			?>
2168
+            if(method_exists($this,'block_global_js')){
2169
+                    echo $this->block_global_js();
2170
+            }
2171
+            ?>
2172 2172
 
2173 2173
 jQuery(function() {
2174 2174
 
@@ -2218,14 +2218,14 @@  discard block
 block discarded – undo
2218 2218
 						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/.
2219 2219
 						supports: {
2220 2220
 							<?php
2221
-							if ( isset( $this->options['block-supports'] ) ) {
2222
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2223
-							}
2224
-							?>
2221
+                            if ( isset( $this->options['block-supports'] ) ) {
2222
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
2223
+                            }
2224
+                            ?>
2225 2225
 						},
2226 2226
 						<?php
2227
-						if ( isset( $this->options['block-label'] ) ) {
2228
-						?>
2227
+                        if ( isset( $this->options['block-label'] ) ) {
2228
+                        ?>
2229 2229
 						__experimentalLabel( attributes, { context } ) {
2230 2230
                             return <?php echo $this->options['block-label']; ?>;
2231 2231
                         },
@@ -2234,7 +2234,7 @@  discard block
 block discarded – undo
2234 2234
                         ?>
2235 2235
 						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.
2236 2236
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
2237
-						echo "keywords : " . $this->options['block-keywords'] . ",";
2237
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
2238 2238
 
2239 2239
 //						// block hover preview.
2240 2240
 //						$example_args = array();
@@ -2259,86 +2259,86 @@  discard block
 block discarded – undo
2259 2259
 
2260 2260
                         }
2261 2261
 
2262
-						// maybe set no_wrap
2263
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2264
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2265
-							$no_wrap = true;
2266
-						}
2267
-						if ( $no_wrap ) {
2268
-							$this->options['block-wrap'] = '';
2269
-						}
2262
+                        // maybe set no_wrap
2263
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2264
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2265
+                            $no_wrap = true;
2266
+                        }
2267
+                        if ( $no_wrap ) {
2268
+                            $this->options['block-wrap'] = '';
2269
+                        }
2270 2270
 
2271
-						// maybe load the drag/drop functions.
2272
-						$img_drag_drop = false;
2271
+                        // maybe load the drag/drop functions.
2272
+                        $img_drag_drop = false;
2273 2273
 
2274
-						$show_alignment = false;
2275
-						// align feature
2276
-						/*echo "supports: {";
2274
+                        $show_alignment = false;
2275
+                        // align feature
2276
+                        /*echo "supports: {";
2277 2277
 						echo "	align: true,";
2278 2278
 						echo "  html: false";
2279 2279
 						echo "},";*/
2280 2280
 
2281
-						if ( ! empty( $this->arguments ) ) {
2282
-							echo "attributes : {";
2281
+                        if ( ! empty( $this->arguments ) ) {
2282
+                            echo "attributes : {";
2283 2283
 
2284
-							if ( $show_advanced ) {
2285
-								echo "show_advanced: {";
2286
-								echo "	type: 'boolean',";
2287
-								echo "  default: false,";
2288
-								echo "},";
2289
-							}
2284
+                            if ( $show_advanced ) {
2285
+                                echo "show_advanced: {";
2286
+                                echo "	type: 'boolean',";
2287
+                                echo "  default: false,";
2288
+                                echo "},";
2289
+                            }
2290 2290
 
2291
-							// block wrap element
2292
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2293
-								echo "block_wrap: {";
2294
-								echo "	type: 'string',";
2295
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2296
-								echo "},";
2297
-							}
2291
+                            // block wrap element
2292
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2293
+                                echo "block_wrap: {";
2294
+                                echo "	type: 'string',";
2295
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2296
+                                echo "},";
2297
+                            }
2298 2298
 
2299 2299
 
2300 2300
 
2301
-							foreach ( $this->arguments as $key => $args ) {
2301
+                            foreach ( $this->arguments as $key => $args ) {
2302 2302
 
2303
-								if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2304
-									$img_drag_drop = true;
2305
-								}
2303
+                                if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2304
+                                    $img_drag_drop = true;
2305
+                                }
2306 2306
 
2307
-								// set if we should show alignment
2308
-								if ( $key == 'alignment' ) {
2309
-									$show_alignment = true;
2310
-								}
2307
+                                // set if we should show alignment
2308
+                                if ( $key == 'alignment' ) {
2309
+                                    $show_alignment = true;
2310
+                                }
2311 2311
 
2312
-								$extra = '';
2312
+                                $extra = '';
2313 2313
 
2314
-								if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2315
-									continue;
2316
-								}
2317
-								elseif ( $args['type'] == 'checkbox' ) {
2318
-									$type    = 'boolean';
2319
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2320
-								} elseif ( $args['type'] == 'number' ) {
2321
-									$type    = 'number';
2322
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2323
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2324
-									$type = 'array';
2325
-									if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2326
-										$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2327
-									} else {
2328
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2329
-									}
2330
-								} elseif ( $args['type'] == 'tagselect' ) {
2331
-									$type    = 'array';
2332
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2333
-								} elseif ( $args['type'] == 'multiselect' ) {
2334
-									$type    = 'array';
2335
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2336
-								} elseif ( $args['type'] == 'image_xy' ) {
2337
-									$type    = 'object';
2338
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2339
-								} elseif ( $args['type'] == 'image' ) {
2340
-									$type    = 'string';
2341
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2314
+                                if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2315
+                                    continue;
2316
+                                }
2317
+                                elseif ( $args['type'] == 'checkbox' ) {
2318
+                                    $type    = 'boolean';
2319
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2320
+                                } elseif ( $args['type'] == 'number' ) {
2321
+                                    $type    = 'number';
2322
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2323
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2324
+                                    $type = 'array';
2325
+                                    if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2326
+                                        $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2327
+                                    } else {
2328
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2329
+                                    }
2330
+                                } elseif ( $args['type'] == 'tagselect' ) {
2331
+                                    $type    = 'array';
2332
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2333
+                                } elseif ( $args['type'] == 'multiselect' ) {
2334
+                                    $type    = 'array';
2335
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2336
+                                } elseif ( $args['type'] == 'image_xy' ) {
2337
+                                    $type    = 'object';
2338
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2339
+                                } elseif ( $args['type'] == 'image' ) {
2340
+                                    $type    = 'string';
2341
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2342 2342
 
2343 2343
                                     // add a field for ID
2344 2344
 //                                    echo $key . "_id : {";
@@ -2348,25 +2348,25 @@  discard block
 block discarded – undo
2348 2348
 //                                    echo "type : 'object',";
2349 2349
 //                                    echo "},";
2350 2350
 
2351
-								} else {
2352
-									$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2353
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2351
+                                } else {
2352
+                                    $type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2353
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2354 2354
 
2355
-								}
2356
-								echo $key . " : {";
2357
-								echo "type : '$type',";
2358
-								echo "default : $default,";
2359
-								echo "},";
2360
-							}
2355
+                                }
2356
+                                echo $key . " : {";
2357
+                                echo "type : '$type',";
2358
+                                echo "default : $default,";
2359
+                                echo "},";
2360
+                            }
2361 2361
 
2362
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2363
-							echo "className: { type: 'string', default: '' },";
2362
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2363
+                            echo "className: { type: 'string', default: '' },";
2364 2364
 
2365
-							echo "},";
2365
+                            echo "},";
2366 2366
 
2367
-						}
2367
+                        }
2368 2368
 
2369
-						?>
2369
+                        ?>
2370 2370
 
2371 2371
 						// The "edit" property must be a valid function.
2372 2372
 						edit: function (props) {
@@ -2465,9 +2465,9 @@  discard block
 block discarded – undo
2465 2465
 
2466 2466
 	var $value = '';
2467 2467
 	<?php
2468
-	// if we have a post_type and a category then link them
2469
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2470
-	?>
2468
+    // if we have a post_type and a category then link them
2469
+    if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2470
+    ?>
2471 2471
 	if(typeof(prev_attributes[props.clientId]) != 'undefined'){
2472 2472
 		$pt = props.attributes.post_type;
2473 2473
 		if(post_type_rest_slugs.length){
@@ -2480,11 +2480,11 @@  discard block
 block discarded – undo
2480 2480
 			term_query_type = $pt;
2481 2481
 		}
2482 2482
 <?php
2483
-	$cat_path = '';
2484
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2485
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2486
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2487
-	}
2483
+    $cat_path = '';
2484
+    if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2485
+        $cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2486
+        $cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2487
+    }
2488 2488
 ?>
2489 2489
 		/* taxonomies */
2490 2490
 		if($value && 'post_type' in prev_attributes[props.clientId] && 'category' in prev_attributes[props.clientId] && run){
@@ -2576,7 +2576,7 @@  discard block
 block discarded – undo
2576 2576
 <?php
2577 2577
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2578 2578
 if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2579
-	echo 'const { deviceType } = "";';
2579
+    echo 'const { deviceType } = "";';
2580 2580
 }else{
2581 2581
 ?>
2582 2582
 /** Get device type const. */
@@ -2610,8 +2610,8 @@  discard block
 block discarded – undo
2610 2610
 										'attributes': props.attributes,
2611 2611
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
2612 2612
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
2613
-										echo $post->ID;
2614
-									}else{echo '0';}?>,
2613
+                                        echo $post->ID;
2614
+                                    }else{echo '0';}?>,
2615 2615
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
2616 2616
 									};
2617 2617
 
@@ -2688,10 +2688,10 @@  discard block
 block discarded – undo
2688 2688
 
2689 2689
 									<?php
2690 2690
 
2691
-									if(! empty( $this->arguments )){
2691
+                                    if(! empty( $this->arguments )){
2692 2692
 
2693
-									if ( $show_advanced ) {
2694
-									?>
2693
+                                    if ( $show_advanced ) {
2694
+                                    ?>
2695 2695
 									el('div', {
2696 2696
 											style: {'padding-left': '16px','padding-right': '16px'}
2697 2697
 										},
@@ -2709,147 +2709,147 @@  discard block
 block discarded – undo
2709 2709
 									,
2710 2710
 									<?php
2711 2711
 
2712
-									}
2712
+                                    }
2713 2713
 
2714
-								//	print_r( $this->arguments);
2714
+                                //	print_r( $this->arguments);
2715 2715
 
2716
-									//echo '####';
2716
+                                    //echo '####';
2717 2717
 
2718
-									$arguments = $this->group_arguments( $this->arguments );
2718
+                                    $arguments = $this->group_arguments( $this->arguments );
2719 2719
 //print_r($arguments ); exit;
2720
-									// Do we have sections?
2721
-									$has_sections = $arguments == $this->arguments ? false : true;
2720
+                                    // Do we have sections?
2721
+                                    $has_sections = $arguments == $this->arguments ? false : true;
2722 2722
 
2723 2723
 
2724
-									if($has_sections){
2725
-									$panel_count = 0;
2726
-									$open_tab = '';
2724
+                                    if($has_sections){
2725
+                                    $panel_count = 0;
2726
+                                    $open_tab = '';
2727 2727
 
2728
-									$open_tab_groups = array();
2729
-									$used_tabs = array();
2730
-									foreach($arguments as $key => $args){
2728
+                                    $open_tab_groups = array();
2729
+                                    $used_tabs = array();
2730
+                                    foreach($arguments as $key => $args){
2731 2731
 
2732
-										$close_tab = false;
2733
-										$close_tabs = false;
2732
+                                        $close_tab = false;
2733
+                                        $close_tabs = false;
2734 2734
 
2735
-										 if(!empty($this->options['block_group_tabs'])) {
2736
-											foreach($this->options['block_group_tabs'] as $tab_name => $tab_args){
2737
-												if(in_array($key,$tab_args['groups'])){
2735
+                                            if(!empty($this->options['block_group_tabs'])) {
2736
+                                            foreach($this->options['block_group_tabs'] as $tab_name => $tab_args){
2737
+                                                if(in_array($key,$tab_args['groups'])){
2738 2738
 
2739
-													$open_tab_groups[] = $key;
2739
+                                                    $open_tab_groups[] = $key;
2740 2740
 
2741
-													if($open_tab != $tab_name){
2742
-														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
2743
-														$tab_args['tab']['open'] = true;
2741
+                                                    if($open_tab != $tab_name){
2742
+                                                        $tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
2743
+                                                        $tab_args['tab']['open'] = true;
2744 2744
 
2745
-														$this->block_tab_start( '', $tab_args );
2745
+                                                        $this->block_tab_start( '', $tab_args );
2746 2746
 //														echo '###open'.$tab_name;print_r($tab_args);
2747
-														$open_tab = $tab_name;
2748
-														$used_tabs[] = $tab_name;
2749
-													}
2747
+                                                        $open_tab = $tab_name;
2748
+                                                        $used_tabs[] = $tab_name;
2749
+                                                    }
2750 2750
 
2751
-													if($open_tab_groups == $tab_args['groups']){
2752
-														//$open_tab = '';
2753
-														$close_tab = true;
2754
-														$open_tab_groups = array();
2751
+                                                    if($open_tab_groups == $tab_args['groups']){
2752
+                                                        //$open_tab = '';
2753
+                                                        $close_tab = true;
2754
+                                                        $open_tab_groups = array();
2755 2755
 
2756 2756
 //													print_r(array_keys($this->options['block_group_tabs']));echo '####';print_r($used_tabs);
2757
-													if($used_tabs == array_keys($this->options['block_group_tabs'])){
2757
+                                                    if($used_tabs == array_keys($this->options['block_group_tabs'])){
2758 2758
 //														echo '@@@';
2759
-															$close_tabs = true;
2760
-														}
2761
-													}
2759
+                                                            $close_tabs = true;
2760
+                                                        }
2761
+                                                    }
2762 2762
 
2763
-												}
2764
-											}
2765
-										}
2763
+                                                }
2764
+                                            }
2765
+                                        }
2766 2766
 
2767 2767
 //
2768 2768
 
2769
-									//	print_r($arguments);exit;
2769
+                                    //	print_r($arguments);exit;
2770 2770
 
2771
-										?>
2771
+                                        ?>
2772 2772
 										el(wp.components.PanelBody, {
2773 2773
 												title: '<?php esc_attr_e( $key ); ?>',
2774 2774
 												initialOpen: <?php if ( $panel_count ) {
2775
-												echo "false";
2776
-											} else {
2777
-												echo "true";
2778
-											}?>
2775
+                                                echo "false";
2776
+                                            } else {
2777
+                                                echo "true";
2778
+                                            }?>
2779 2779
 											},
2780 2780
 											<?php
2781 2781
 
2782 2782
 
2783 2783
 
2784
-											foreach ( $args as $k => $a ) {
2784
+                                            foreach ( $args as $k => $a ) {
2785 2785
 
2786
-												$this->block_tab_start( $k, $a );
2787
-												$this->block_row_start( $k, $a );
2788
-												$this->build_block_arguments( $k, $a );
2789
-												$this->block_row_end( $k, $a );
2790
-												$this->block_tab_end( $k, $a );
2791
-											}
2792
-											?>
2786
+                                                $this->block_tab_start( $k, $a );
2787
+                                                $this->block_row_start( $k, $a );
2788
+                                                $this->build_block_arguments( $k, $a );
2789
+                                                $this->block_row_end( $k, $a );
2790
+                                                $this->block_tab_end( $k, $a );
2791
+                                            }
2792
+                                            ?>
2793 2793
 										),
2794 2794
 										<?php
2795
-										$panel_count ++;
2795
+                                        $panel_count ++;
2796 2796
 
2797 2797
 
2798
-										if($close_tab || $close_tabs){
2799
-											$tab_args = array(
2800
-												'tab'	=> array(
2801
-													'tabs_close' => $close_tabs,
2802
-												'close' => true,
2803
-												)
2798
+                                        if($close_tab || $close_tabs){
2799
+                                            $tab_args = array(
2800
+                                                'tab'	=> array(
2801
+                                                    'tabs_close' => $close_tabs,
2802
+                                                'close' => true,
2803
+                                                )
2804 2804
 
2805
-											);
2806
-											$this->block_tab_end( '', $tab_args );
2805
+                                            );
2806
+                                            $this->block_tab_end( '', $tab_args );
2807 2807
 //											echo '###close'; print_r($tab_args);
2808
-											$panel_count = 0;
2809
-										}
2808
+                                            $panel_count = 0;
2809
+                                        }
2810 2810
 //
2811 2811
 
2812
-									}
2813
-									}else {
2814
-									?>
2812
+                                    }
2813
+                                    }else {
2814
+                                    ?>
2815 2815
 									el(wp.components.PanelBody, {
2816 2816
 											title: '<?php esc_attr_e( "Settings" ); ?>',
2817 2817
 											initialOpen: true
2818 2818
 										},
2819 2819
 										<?php
2820
-										foreach ( $this->arguments as $key => $args ) {
2821
-											$this->block_row_start( $key, $args );
2822
-											$this->build_block_arguments( $key, $args );
2823
-											$this->block_row_end( $key, $args );
2824
-										}
2825
-										?>
2820
+                                        foreach ( $this->arguments as $key => $args ) {
2821
+                                            $this->block_row_start( $key, $args );
2822
+                                            $this->build_block_arguments( $key, $args );
2823
+                                            $this->block_row_end( $key, $args );
2824
+                                        }
2825
+                                        ?>
2826 2826
 									),
2827 2827
 									<?php
2828
-									}
2828
+                                    }
2829 2829
 
2830
-									}
2831
-									?>
2830
+                                    }
2831
+                                    ?>
2832 2832
 
2833 2833
 								),
2834 2834
 
2835 2835
 								<?php
2836
-								// If the user sets block-output array then build it
2837
-								if ( ! empty( $this->options['block-output'] ) ) {
2838
-								$this->block_element( $this->options['block-output'] );
2839
-							}elseif(!empty($this->options['block-edit-return'])){
2840
-                                   echo $this->options['block-edit-return'];
2841
-							}else{
2842
-								// if no block-output is set then we try and get the shortcode html output via ajax.
2843
-								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
2844
-								?>
2836
+                                // If the user sets block-output array then build it
2837
+                                if ( ! empty( $this->options['block-output'] ) ) {
2838
+                                $this->block_element( $this->options['block-output'] );
2839
+                            }elseif(!empty($this->options['block-edit-return'])){
2840
+                                    echo $this->options['block-edit-return'];
2841
+                            }else{
2842
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
2843
+                                $block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
2844
+                                ?>
2845 2845
 								el('<?php echo esc_attr($block_edit_wrap_tag); ?>', wp.blockEditor.useBlockProps({
2846 2846
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
2847 2847
 									className: props.className,
2848 2848
 									style: {'minHeight': '30px'}
2849 2849
 								}))
2850 2850
 								<?php
2851
-								}
2852
-								?>
2851
+                                }
2852
+                                ?>
2853 2853
 							]; // end return
2854 2854
 
2855 2855
 							<?php
@@ -2868,11 +2868,11 @@  discard block
 block discarded – undo
2868 2868
 							$html = '';
2869 2869
 							<?php
2870 2870
 
2871
-							if(! empty( $this->arguments )){
2871
+                            if(! empty( $this->arguments )){
2872 2872
 
2873
-							foreach($this->arguments as $key => $args){
2874
-                               // if($args['type']=='tabs'){continue;}
2875
-							?>
2873
+                            foreach($this->arguments as $key => $args){
2874
+                                // if($args['type']=='tabs'){continue;}
2875
+                            ?>
2876 2876
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2877 2877
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
2878 2878
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -2883,10 +2883,10 @@  discard block
 block discarded – undo
2883 2883
 								}
2884 2884
 							}
2885 2885
 							<?php
2886
-							}
2887
-							}
2886
+                            }
2887
+                            }
2888 2888
 
2889
-							?>
2889
+                            ?>
2890 2890
 							content += "]";
2891 2891
 
2892 2892
                             <?php
@@ -2933,7 +2933,7 @@  discard block
 block discarded – undo
2933 2933
 //                               $this->block_element( $this->options['block-output'], true );
2934 2934
 //                               echo ";";
2935 2935
 
2936
-                               ?>
2936
+                                ?>
2937 2937
                               return el(
2938 2938
                                    '',
2939 2939
                                    {},
@@ -2943,9 +2943,9 @@  discard block
 block discarded – undo
2943 2943
                                );
2944 2944
                                 <?php
2945 2945
 
2946
-							}elseif(!empty($this->options['block-save-return'])){
2947
-                                   echo 'return ' . $this->options['block-save-return'];
2948
-							}elseif(!empty($this->options['nested-block'])){
2946
+                            }elseif(!empty($this->options['block-save-return'])){
2947
+                                    echo 'return ' . $this->options['block-save-return'];
2948
+                            }elseif(!empty($this->options['nested-block'])){
2949 2949
                                 ?>
2950 2950
                               return el(
2951 2951
                                    '',
@@ -2955,22 +2955,22 @@  discard block
 block discarded – undo
2955 2955
                                    el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
2956 2956
                                );
2957 2957
                                 <?php
2958
-							}elseif(!empty( $this->options['block-save-return'] ) ){
2958
+                            }elseif(!empty( $this->options['block-save-return'] ) ){
2959 2959
                                 echo "return ". $this->options['block-edit-return'].";";
2960
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2961
-							?>
2960
+                            }elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
2961
+                            ?>
2962 2962
 							return content;
2963 2963
 							<?php
2964
-							}else{
2965
-							?>
2964
+                            }else{
2965
+                            ?>
2966 2966
 							var block_wrap = 'div';
2967 2967
 							if (attr.hasOwnProperty("block_wrap")) {
2968 2968
 								block_wrap = attr.block_wrap;
2969 2969
 							}
2970 2970
 							return el(block_wrap, wp.blockEditor.useBlockProps.save( {dangerouslySetInnerHTML: {__html: content}, className: align} ));
2971 2971
 							<?php
2972
-							}
2973
-							?>
2972
+                            }
2973
+                            ?>
2974 2974
 
2975 2975
 
2976 2976
 						}
@@ -2984,29 +2984,29 @@  discard block
 block discarded – undo
2984 2984
                 });
2985 2985
 			</script>
2986 2986
 			<?php
2987
-			$output = ob_get_clean();
2987
+            $output = ob_get_clean();
2988 2988
 
2989
-			/*
2989
+            /*
2990 2990
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
2991 2991
 			 */
2992 2992
 
2993
-			return str_replace( array(
2994
-				'<script>',
2995
-				'</script>'
2996
-			), '', $output );
2997
-		}
2993
+            return str_replace( array(
2994
+                '<script>',
2995
+                '</script>'
2996
+            ), '', $output );
2997
+        }
2998 2998
 
2999 2999
 
3000 3000
 
3001
-		public function block_row_start($key, $args){
3001
+        public function block_row_start($key, $args){
3002 3002
 
3003
-			// check for row
3004
-			if(!empty($args['row'])){
3003
+            // check for row
3004
+            if(!empty($args['row'])){
3005 3005
 
3006
-				if(!empty($args['row']['open'])){
3006
+                if(!empty($args['row']['open'])){
3007 3007
 
3008
-				// element require
3009
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3008
+                // element require
3009
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3010 3010
                 $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3011 3011
                 $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3012 3012
                 $device_type_icon = '';
@@ -3017,10 +3017,10 @@  discard block
 block discarded – undo
3017 3017
                 }elseif($device_type=='Mobile'){
3018 3018
                     $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3019 3019
                 }
3020
-				echo $element_require;
3020
+                echo $element_require;
3021 3021
                 echo $device_type_require;
3022 3022
 
3023
-					if(false){?><script><?php }?>
3023
+                    if(false){?><script><?php }?>
3024 3024
 						el('div', {
3025 3025
 								className: 'bsui components-base-control',
3026 3026
 							},
@@ -3058,51 +3058,51 @@  discard block
 block discarded – undo
3058 3058
 									},
3059 3059
 
3060 3060
 					<?php
3061
-					if(false){?></script><?php }
3062
-				}elseif(!empty($args['row']['close'])){
3063
-					if(false){?><script><?php }?>
3061
+                    if(false){?></script><?php }
3062
+                }elseif(!empty($args['row']['close'])){
3063
+                    if(false){?><script><?php }?>
3064 3064
 						el(
3065 3065
 							'div',
3066 3066
 							{
3067 3067
 								className: 'col pl-0 ps-0',
3068 3068
 							},
3069 3069
 					<?php
3070
-					if(false){?></script><?php }
3071
-				}else{
3072
-					if(false){?><script><?php }?>
3070
+                    if(false){?></script><?php }
3071
+                }else{
3072
+                    if(false){?><script><?php }?>
3073 3073
 						el(
3074 3074
 							'div',
3075 3075
 							{
3076 3076
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3077 3077
 							},
3078 3078
 					<?php
3079
-					if(false){?></script><?php }
3080
-				}
3079
+                    if(false){?></script><?php }
3080
+                }
3081 3081
 
3082
-			}
3082
+            }
3083 3083
 
3084
-		}
3084
+        }
3085 3085
 
3086
-		public function block_row_end($key, $args){
3086
+        public function block_row_end($key, $args){
3087 3087
 
3088
-			if(!empty($args['row'])){
3089
-				// maybe close
3090
-				if(!empty($args['row']['close'])){
3091
-					echo "))";
3092
-				}
3088
+            if(!empty($args['row'])){
3089
+                // maybe close
3090
+                if(!empty($args['row']['close'])){
3091
+                    echo "))";
3092
+                }
3093 3093
 
3094
-				echo "),";
3095
-			}
3096
-		}
3094
+                echo "),";
3095
+            }
3096
+        }
3097 3097
 
3098
-		public function block_tab_start($key, $args){
3098
+        public function block_tab_start($key, $args){
3099 3099
 
3100
-			// check for row
3101
-			if(!empty($args['tab'])){
3100
+            // check for row
3101
+            if(!empty($args['tab'])){
3102 3102
 
3103
-				if(!empty($args['tab']['tabs_open'])){
3103
+                if(!empty($args['tab']['tabs_open'])){
3104 3104
 
3105
-					if(false){?><script><?php }?>
3105
+                    if(false){?><script><?php }?>
3106 3106
 
3107 3107
 el('div',{className: 'bsui'},
3108 3108
 
@@ -3115,12 +3115,12 @@  discard block
 block discarded – undo
3115 3115
 										tabs: [
3116 3116
 
3117 3117
 					<?php
3118
-					if(false){?></script><?php }
3119
-				}
3118
+                    if(false){?></script><?php }
3119
+                }
3120 3120
 
3121
-				if(!empty($args['tab']['open'])){
3121
+                if(!empty($args['tab']['open'])){
3122 3122
 
3123
-					if(false){?><script><?php }?>
3123
+                    if(false){?><script><?php }?>
3124 3124
 							{
3125 3125
 												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3126 3126
 												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
@@ -3129,23 +3129,23 @@  discard block
 block discarded – undo
3129 3129
 									className: 'components-base-control__help mb-0',
3130 3130
 									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3131 3131
 								}),<?php }
3132
-					if(false){?></script><?php }
3133
-				}
3132
+                    if(false){?></script><?php }
3133
+                }
3134 3134
 
3135
-			}
3135
+            }
3136 3136
 
3137
-		}
3137
+        }
3138 3138
 
3139
-		public function block_tab_end($key, $args){
3139
+        public function block_tab_end($key, $args){
3140 3140
 
3141
-			if(!empty($args['tab'])){
3142
-				// maybe close
3143
-				if(!empty($args['tab']['close'])){
3144
-					echo ")}, /* tab close */";
3145
-				}
3141
+            if(!empty($args['tab'])){
3142
+                // maybe close
3143
+                if(!empty($args['tab']['close'])){
3144
+                    echo ")}, /* tab close */";
3145
+                }
3146 3146
 
3147
-				if(!empty($args['tab']['tabs_close'])){
3148
-					if(false){?><script><?php }?>
3147
+                if(!empty($args['tab']['tabs_close'])){
3148
+                    if(false){?><script><?php }?>
3149 3149
 							],
3150 3150
 									},
3151 3151
 									( tab ) => {
@@ -3155,22 +3155,22 @@  discard block
 block discarded – undo
3155 3155
 								}
3156 3156
 								)), /* tabs close */
3157 3157
 					<?php if(false){ ?></script><?php }
3158
-				}
3159
-			}
3160
-		}
3158
+                }
3159
+            }
3160
+        }
3161 3161
 
3162
-		public function build_block_arguments( $key, $args ) {
3163
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3164
-			$options           = '';
3165
-			$extra             = '';
3166
-			$require           = '';
3162
+        public function build_block_arguments( $key, $args ) {
3163
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3164
+            $options           = '';
3165
+            $extra             = '';
3166
+            $require           = '';
3167 3167
             $inside_elements   = '';
3168
-			$after_elements	   = '';
3168
+            $after_elements	   = '';
3169 3169
 
3170
-			// `content` is a protected and special argument
3171
-			if ( $key == 'content' ) {
3172
-				return;
3173
-			}
3170
+            // `content` is a protected and special argument
3171
+            if ( $key == 'content' ) {
3172
+                return;
3173
+            }
3174 3174
 
3175 3175
             $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3176 3176
             $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
@@ -3183,51 +3183,51 @@  discard block
 block discarded – undo
3183 3183
                 $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3184 3184
             }
3185 3185
 
3186
-			// icon
3187
-			$icon = '';
3188
-			if( !empty( $args['icon'] ) ){
3189
-				$icon .= "el('div', {";
3190
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3191
-									$icon .= "className: 'text-center',";
3192
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3193
-								$icon .= "}),";
3194
-
3195
-				// blank title as its added to the icon.
3196
-				$args['title'] = '';
3197
-			}
3186
+            // icon
3187
+            $icon = '';
3188
+            if( !empty( $args['icon'] ) ){
3189
+                $icon .= "el('div', {";
3190
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3191
+                                    $icon .= "className: 'text-center',";
3192
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
3193
+                                $icon .= "}),";
3194
+
3195
+                // blank title as its added to the icon.
3196
+                $args['title'] = '';
3197
+            }
3198 3198
 
3199
-			// require advanced
3200
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3199
+            // require advanced
3200
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3201 3201
 
3202
-			// element require
3203
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3202
+            // element require
3203
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3204 3204
 
3205 3205
 
3206
-			$onchange  = "props.setAttributes({ $key: $key } )";
3207
-			$onchangecomplete  = "";
3208
-			$value     = "props.attributes.$key";
3209
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3210
-			if ( in_array( $args['type'], $text_type ) ) {
3211
-				$type = 'TextControl';
3212
-				// Save numbers as numbers and not strings
3213
-				if ( $args['type'] == 'number' ) {
3214
-					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3215
-				}
3216
-			}else if ( $args['type'] == 'styleid' ) {
3217
-				$type = 'TextControl';
3218
-				$args['type'] == 'text';
3219
-				// Save numbers as numbers and not strings
3220
-				$value     = "props.attributes.$key ? props.attributes.$key : 'aaabbbccc'";
3221
-			}else if ( $args['type'] == 'notice' ) {
3222
-
3223
-				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3224
-				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3225
-
3226
-				$notice = "el('div',{className:'bsui'},el(wp.components.Notice, {status: '$notice_status',isDismissible: false,className: 'm-0 pr-0 pe-0 mb-3'},el('div',{dangerouslySetInnerHTML: {__html: '$notice_message'}}))),";
3227
-				echo $notice_message ? $element_require . $notice : '';
3228
-				return;
3229
-			}
3230
-			/*
3206
+            $onchange  = "props.setAttributes({ $key: $key } )";
3207
+            $onchangecomplete  = "";
3208
+            $value     = "props.attributes.$key";
3209
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3210
+            if ( in_array( $args['type'], $text_type ) ) {
3211
+                $type = 'TextControl';
3212
+                // Save numbers as numbers and not strings
3213
+                if ( $args['type'] == 'number' ) {
3214
+                    $onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3215
+                }
3216
+            }else if ( $args['type'] == 'styleid' ) {
3217
+                $type = 'TextControl';
3218
+                $args['type'] == 'text';
3219
+                // Save numbers as numbers and not strings
3220
+                $value     = "props.attributes.$key ? props.attributes.$key : 'aaabbbccc'";
3221
+            }else if ( $args['type'] == 'notice' ) {
3222
+
3223
+                $notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3224
+                $notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3225
+
3226
+                $notice = "el('div',{className:'bsui'},el(wp.components.Notice, {status: '$notice_status',isDismissible: false,className: 'm-0 pr-0 pe-0 mb-3'},el('div',{dangerouslySetInnerHTML: {__html: '$notice_message'}}))),";
3227
+                echo $notice_message ? $element_require . $notice : '';
3228
+                return;
3229
+            }
3230
+            /*
3231 3231
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
3232 3232
 						elseif($args['type']=='tabs'){
3233 3233
 							?>
@@ -3280,23 +3280,23 @@  discard block
 block discarded – undo
3280 3280
 							return;
3281 3281
 						}
3282 3282
 */
3283
-			elseif ( $args['type'] == 'color' ) {
3284
-				$type = 'ColorPicker';
3285
-				$onchange = "";
3286
-				$extra = "color: $value,";
3287
-				if(!empty($args['disable_alpha'])){
3288
-					$extra .= "disableAlpha: true,";
3289
-				}
3290
-				$onchangecomplete = "onChangeComplete: function($key) {
3283
+            elseif ( $args['type'] == 'color' ) {
3284
+                $type = 'ColorPicker';
3285
+                $onchange = "";
3286
+                $extra = "color: $value,";
3287
+                if(!empty($args['disable_alpha'])){
3288
+                    $extra .= "disableAlpha: true,";
3289
+                }
3290
+                $onchangecomplete = "onChangeComplete: function($key) {
3291 3291
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
3292 3292
                         props.setAttributes({
3293 3293
                             $key: value
3294 3294
                         });
3295 3295
                     },";
3296
-			}elseif ( $args['type'] == 'gradient' ) {
3297
-				$type = 'GradientPicker';
3296
+            }elseif ( $args['type'] == 'gradient' ) {
3297
+                $type = 'GradientPicker';
3298 3298
 
3299
-			}elseif ( $args['type'] == 'image' ) {
3299
+            }elseif ( $args['type'] == 'image' ) {
3300 3300
 //                print_r($args);
3301 3301
 
3302 3302
                 $img_preview = isset($args['focalpoint']) && !$args['focalpoint'] ? " props.attributes.$key && el('img', { src: props.attributes.$key,style: {maxWidth:'100%',background: '#ccc'}})," : " ( props.attributes.$key ||  props.attributes.{$key}_use_featured ) && el(wp.components.FocalPointPicker,{
@@ -3321,15 +3321,15 @@  discard block
 block discarded – undo
3321 3321
 
3322 3322
 
3323 3323
                 $value = '""';
3324
-				$type = 'MediaUpload';
3324
+                $type = 'MediaUpload';
3325 3325
                 $extra .= "onSelect: function(media){
3326 3326
                       return props.setAttributes({
3327 3327
                           $key: media.url,
3328 3328
                           {$key}_id: media.id
3329 3329
                         });
3330 3330
                       },";
3331
-                   $extra .= "type: 'image',";
3332
-                   $extra .= "render: function (obj) {
3331
+                    $extra .= "type: 'image',";
3332
+                    $extra .= "render: function (obj) {
3333 3333
                         return el( 'div',{},
3334 3334
                         ( !props.attributes.$key && !props.attributes.{$key}_use_featured ) && el( wp.components.Button, {
3335 3335
                           className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
@@ -3358,8 +3358,8 @@  discard block
 block discarded – undo
3358 3358
                 $onchange = "";
3359 3359
 
3360 3360
                 //$inside_elements = ",el('div',{},'file upload')";
3361
-			}elseif ( $args['type'] == 'images' ) {
3362
-				//                print_r($args);
3361
+            }elseif ( $args['type'] == 'images' ) {
3362
+                //                print_r($args);
3363 3363
 
3364 3364
                 $img_preview = "props.attributes.$key && (function() {
3365 3365
 
@@ -3388,7 +3388,7 @@  discard block
 block discarded – undo
3388 3388
 
3389 3389
 
3390 3390
                 $value = '""';
3391
-				$type = 'MediaUpload';
3391
+                $type = 'MediaUpload';
3392 3392
                 $extra .= "onSelect: function(media){
3393 3393
 
3394 3394
                 let slim_images = props.attributes.$key ? JSON.parse('['+props.attributes.$key+']') : [];
@@ -3402,9 +3402,9 @@  discard block
 block discarded – undo
3402 3402
                           $key: JSON.stringify(slim_images).replace('[','').replace(']',''),
3403 3403
                         });
3404 3404
                       },";
3405
-                   $extra .= "type: 'image',";
3406
-                   $extra .= "multiple: true,";
3407
-                   $extra .= "render: function (obj) {
3405
+                    $extra .= "type: 'image',";
3406
+                    $extra .= "multiple: true,";
3407
+                    $extra .= "render: function (obj) {
3408 3408
 
3409 3409
                    // init the sort
3410 3410
 				enableDragSort('sd-sortable');
@@ -3443,37 +3443,37 @@  discard block
 block discarded – undo
3443 3443
                 $onchange = "";
3444 3444
 
3445 3445
                 //$inside_elements = ",el('div',{},'file upload')";
3446
-			}
3447
-			elseif ( $args['type'] == 'checkbox' ) {
3448
-				$type = 'CheckboxControl';
3449
-				$extra .= "checked: props.attributes.$key,";
3450
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3451
-			} elseif ( $args['type'] == 'textarea' ) {
3452
-				$type = 'TextareaControl';
3453
-
3454
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3455
-				$type = 'SelectControl';
3456
-
3457
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3458
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3459
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3460
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3461
-				}else {
3462
-
3463
-					if ( ! empty( $args['options'] ) ) {
3464
-						$options .= "options: [";
3465
-						foreach ( $args['options'] as $option_val => $option_label ) {
3466
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
3467
-						}
3468
-						$options .= "],";
3469
-					}
3470
-				}
3471
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3472
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3473
-				}
3446
+            }
3447
+            elseif ( $args['type'] == 'checkbox' ) {
3448
+                $type = 'CheckboxControl';
3449
+                $extra .= "checked: props.attributes.$key,";
3450
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3451
+            } elseif ( $args['type'] == 'textarea' ) {
3452
+                $type = 'TextareaControl';
3453
+
3454
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3455
+                $type = 'SelectControl';
3456
+
3457
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3458
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3459
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3460
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3461
+                }else {
3462
+
3463
+                    if ( ! empty( $args['options'] ) ) {
3464
+                        $options .= "options: [";
3465
+                        foreach ( $args['options'] as $option_val => $option_label ) {
3466
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },";
3467
+                        }
3468
+                        $options .= "],";
3469
+                    }
3470
+                }
3471
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3472
+                    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3473
+                }
3474 3474
 
3475
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3476
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3475
+                if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3476
+                    $after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3477 3477
                                       className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3478 3478
                                       style: {margin:'-8px 0 8px 0',display: 'block'},
3479 3479
                                       onClick: function(){
@@ -3484,8 +3484,8 @@  discard block
 block discarded – undo
3484 3484
                                     },
3485 3485
                                     'Clear'
3486 3486
                             ),";
3487
-				}
3488
-			} elseif ( $args['type'] == 'tagselect' ) {
3487
+                }
3488
+            } elseif ( $args['type'] == 'tagselect' ) {
3489 3489
 //				$type = 'FormTokenField';
3490 3490
 //
3491 3491
 //				if ( ! empty( $args['options'] ) ) {
@@ -3520,39 +3520,39 @@  discard block
 block discarded – undo
3520 3520
 //				$value     = "[]";
3521 3521
 //				$extra .= ' __experimentalExpandOnFocus: true,';
3522 3522
 
3523
-			} elseif ( $args['type'] == 'alignment' ) {
3524
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3525
-			}elseif ( $args['type'] == 'margins' ) {
3523
+            } elseif ( $args['type'] == 'alignment' ) {
3524
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3525
+            }elseif ( $args['type'] == 'margins' ) {
3526 3526
 
3527
-			} else {
3528
-				return;// if we have not implemented the control then don't break the JS.
3529
-			}
3527
+            } else {
3528
+                return;// if we have not implemented the control then don't break the JS.
3529
+            }
3530 3530
 
3531 3531
 
3532 3532
 
3533
-			// color input does not show the labels so we add them
3534
-			if($args['type']=='color'){
3535
-				// add show only if advanced
3536
-				echo $require_advanced;
3537
-				// add setting require if defined
3538
-				echo $element_require;
3539
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3540
-			}
3533
+            // color input does not show the labels so we add them
3534
+            if($args['type']=='color'){
3535
+                // add show only if advanced
3536
+                echo $require_advanced;
3537
+                // add setting require if defined
3538
+                echo $element_require;
3539
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3540
+            }
3541 3541
 
3542
-			// add show only if advanced
3543
-			echo $require_advanced;
3544
-			// add setting require if defined
3545
-			echo $element_require;
3542
+            // add show only if advanced
3543
+            echo $require_advanced;
3544
+            // add setting require if defined
3545
+            echo $element_require;
3546 3546
             echo $device_type_require;
3547 3547
 
3548
-			// icon
3549
-			echo $icon;
3550
-			?>
3548
+            // icon
3549
+            echo $icon;
3550
+            ?>
3551 3551
 			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
3552 3552
 			label: <?php
3553
-			if(empty($args['title'])){
3553
+            if(empty($args['title'])){
3554 3554
                 echo "''";
3555
-			}elseif(empty($args['row']) && !empty($args['device_type'])){
3555
+            }elseif(empty($args['row']) && !empty($args['device_type'])){
3556 3556
                 ?>el('label', {
3557 3557
 									className: 'components-base-control__label',
3558 3558
 									style: {width:"100%"}
@@ -3567,22 +3567,22 @@  discard block
 block discarded – undo
3567 3567
 
3568 3568
 							)<?php
3569 3569
 
3570
-			}else{
3571
-                 ?>'<?php echo addslashes( $args['title'] ); ?>'<?php
3570
+            }else{
3571
+                    ?>'<?php echo addslashes( $args['title'] ); ?>'<?php
3572 3572
 
3573
-			}
3573
+            }
3574 3574
 
3575
-			?>,
3575
+            ?>,
3576 3576
 			help: <?php if ( isset( $args['desc'] ) ) {
3577
-				echo "el('span',{dangerouslySetInnerHTML: {__html: '".wp_kses_post( addslashes($args['desc']) )."'}})";
3578
-			}else{ echo "''"; } ?>,
3577
+                echo "el('span',{dangerouslySetInnerHTML: {__html: '".wp_kses_post( addslashes($args['desc']) )."'}})";
3578
+            }else{ echo "''"; } ?>,
3579 3579
 			value: <?php echo $value; ?>,
3580 3580
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
3581
-				echo "type: '" . addslashes( $args['type'] ) . "',";
3582
-			} ?>
3581
+                echo "type: '" . addslashes( $args['type'] ) . "',";
3582
+            } ?>
3583 3583
 			<?php if ( ! empty( $args['placeholder'] ) ) {
3584
-				echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
3585
-			} ?>
3584
+                echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',";
3585
+            } ?>
3586 3586
 			<?php echo $options; ?>
3587 3587
 			<?php echo $extra; ?>
3588 3588
 			<?php echo $custom_attributes; ?>
@@ -3595,69 +3595,69 @@  discard block
 block discarded – undo
3595 3595
 			<?php }?>
3596 3596
 			} <?php echo $inside_elements; ?> ),
3597 3597
 			<?php
3598
-			echo $after_elements;
3598
+            echo $after_elements;
3599 3599
 
3600
-		}
3600
+        }
3601 3601
 
3602
-		/**
3603
-		 * Convert an array of attributes to block string.
3604
-		 *
3605
-		 * @param $custom_attributes
3606
-		 *
3607
-		 * @return string
3608
-		 *@todo there is prob a faster way to do this, also we could add some validation here.
3609
-		 *
3610
-		 */
3611
-		public function array_to_attributes( $custom_attributes, $html = false ) {
3612
-			$attributes = '';
3613
-			if ( ! empty( $custom_attributes ) ) {
3614
-
3615
-				foreach ( $custom_attributes as $key => $val ) {
3616
-					if(is_array($val)){
3617
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
3618
-					}else{
3619
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
3620
-					}
3621
-				}
3602
+        /**
3603
+         * Convert an array of attributes to block string.
3604
+         *
3605
+         * @param $custom_attributes
3606
+         *
3607
+         * @return string
3608
+         *@todo there is prob a faster way to do this, also we could add some validation here.
3609
+         *
3610
+         */
3611
+        public function array_to_attributes( $custom_attributes, $html = false ) {
3612
+            $attributes = '';
3613
+            if ( ! empty( $custom_attributes ) ) {
3622 3614
 
3623
-			}
3615
+                foreach ( $custom_attributes as $key => $val ) {
3616
+                    if(is_array($val)){
3617
+                        $attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
3618
+                    }else{
3619
+                        $attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
3620
+                    }
3621
+                }
3624 3622
 
3625
-			return $attributes;
3626
-		}
3623
+            }
3627 3624
 
3625
+            return $attributes;
3626
+        }
3628 3627
 
3629 3628
 
3630
-		/**
3631
-		 * A self looping function to create the output for JS block elements.
3632
-		 *
3633
-		 * This is what is output in the WP Editor visual view.
3634
-		 *
3635
-		 * @param $args
3636
-		 */
3637
-		public function block_element( $args, $save = false ) {
3638 3629
 
3630
+        /**
3631
+         * A self looping function to create the output for JS block elements.
3632
+         *
3633
+         * This is what is output in the WP Editor visual view.
3634
+         *
3635
+         * @param $args
3636
+         */
3637
+        public function block_element( $args, $save = false ) {
3639 3638
 
3640
-			if ( ! empty( $args ) ) {
3641
-				foreach ( $args as $element => $new_args ) {
3642 3639
 
3643
-					if ( is_array( $new_args ) ) { // its an element
3640
+            if ( ! empty( $args ) ) {
3641
+                foreach ( $args as $element => $new_args ) {
3644 3642
 
3643
+                    if ( is_array( $new_args ) ) { // its an element
3645 3644
 
3646
-						if ( isset( $new_args['element'] ) ) {
3647 3645
 
3648
-							if ( isset( $new_args['element_require'] ) ) {
3649
-								echo str_replace( array(
3650
-										"'+",
3651
-										"+'"
3652
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
3653
-								unset( $new_args['element_require'] );
3654
-							}
3646
+                        if ( isset( $new_args['element'] ) ) {
3647
+
3648
+                            if ( isset( $new_args['element_require'] ) ) {
3649
+                                echo str_replace( array(
3650
+                                        "'+",
3651
+                                        "+'"
3652
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
3653
+                                unset( $new_args['element_require'] );
3654
+                            }
3655 3655
 
3656 3656
                             if($new_args['element']=='InnerBlocks'){
3657 3657
                                 echo "\n el( InnerBlocks, {";
3658 3658
                             }elseif($new_args['element']=='innerBlocksProps'){
3659 3659
                                 $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
3660
-                              //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
3660
+                                //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
3661 3661
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
3662 3662
                                 echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
3663 3663
                                 echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
@@ -3667,74 +3667,74 @@  discard block
 block discarded – undo
3667 3667
                                 echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
3668 3668
                             //    echo '###';
3669 3669
 
3670
-                              //  echo '###';
3670
+                                //  echo '###';
3671 3671
                             }elseif($new_args['element']=='BlocksProps'){
3672 3672
 
3673
-								if ( isset($new_args['if_inner_element']) ) {
3674
-									$element = $new_args['if_inner_element'];
3675
-								}else {
3676
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
3677
-								}
3673
+                                if ( isset($new_args['if_inner_element']) ) {
3674
+                                    $element = $new_args['if_inner_element'];
3675
+                                }else {
3676
+                                    $element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
3677
+                                }
3678 3678
 
3679
-								unset($new_args['inner_element']);
3679
+                                unset($new_args['inner_element']);
3680 3680
                                 echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
3681 3681
                                 echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
3682 3682
 
3683 3683
 
3684
-                               // echo "} ),";
3684
+                                // echo "} ),";
3685 3685
 
3686 3686
                             }else{
3687 3687
                                 echo "\n el( '" . $new_args['element'] . "', {";
3688 3688
                             }
3689 3689
 
3690 3690
 
3691
-							// get the attributes
3692
-							foreach ( $new_args as $new_key => $new_value ) {
3691
+                            // get the attributes
3692
+                            foreach ( $new_args as $new_key => $new_value ) {
3693 3693
 
3694 3694
 
3695
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
3696
-									// do nothing
3697
-								} else {
3698
-									echo $this->block_element( array( $new_key => $new_value ),$save );
3699
-								}
3700
-							}
3695
+                                if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
3696
+                                    // do nothing
3697
+                                } else {
3698
+                                    echo $this->block_element( array( $new_key => $new_value ),$save );
3699
+                                }
3700
+                            }
3701 3701
 
3702
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
3702
+                            echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
3703 3703
 
3704
-							// get the content
3705
-							$first_item = 0;
3706
-							foreach ( $new_args as $new_key => $new_value ) {
3707
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
3704
+                            // get the content
3705
+                            $first_item = 0;
3706
+                            foreach ( $new_args as $new_key => $new_value ) {
3707
+                                if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
3708 3708
 
3709
-									if ( $new_key === 'content' ) {
3710
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
3711
-									}else if ( $new_key === 'if_content' ) {
3712
-										echo  $this->block_props_replace(  $new_value  );
3713
-									}
3709
+                                    if ( $new_key === 'content' ) {
3710
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
3711
+                                    }else if ( $new_key === 'if_content' ) {
3712
+                                        echo  $this->block_props_replace(  $new_value  );
3713
+                                    }
3714 3714
 
3715
-									if ( is_array( $new_value ) ) {
3715
+                                    if ( is_array( $new_value ) ) {
3716 3716
 
3717
-										if ( isset( $new_value['element_require'] ) ) {
3718
-											echo str_replace( array(
3719
-													"'+",
3720
-													"+'"
3721
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
3722
-											unset( $new_value['element_require'] );
3723
-										}
3717
+                                        if ( isset( $new_value['element_require'] ) ) {
3718
+                                            echo str_replace( array(
3719
+                                                    "'+",
3720
+                                                    "+'"
3721
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
3722
+                                            unset( $new_value['element_require'] );
3723
+                                        }
3724 3724
 
3725
-										if ( isset( $new_value['element_repeat'] ) ) {
3726
-											$x = 1;
3727
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
3728
-												$this->block_element( array( '' => $new_value ),$save );
3729
-												$x ++;
3730
-											}
3731
-										} else {
3732
-											$this->block_element( array( '' => $new_value ),$save );
3733
-										}
3734
-									}
3735
-									$first_item ++;
3736
-								}
3737
-							}
3725
+                                        if ( isset( $new_value['element_repeat'] ) ) {
3726
+                                            $x = 1;
3727
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
3728
+                                                $this->block_element( array( '' => $new_value ),$save );
3729
+                                                $x ++;
3730
+                                            }
3731
+                                        } else {
3732
+                                            $this->block_element( array( '' => $new_value ),$save );
3733
+                                        }
3734
+                                    }
3735
+                                    $first_item ++;
3736
+                                }
3737
+                            }
3738 3738
 
3739 3739
                             if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
3740 3740
                                 echo "))";// end content
@@ -3743,517 +3743,517 @@  discard block
 block discarded – undo
3743 3743
                             }
3744 3744
 
3745 3745
 
3746
-							echo ", \n";
3746
+                            echo ", \n";
3747 3747
 
3748
-						}
3749
-					} else {
3748
+                        }
3749
+                    } else {
3750 3750
 
3751
-						if ( substr( $element, 0, 3 ) === "if_" ) {
3752
-							$extra = '';
3753
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
3754
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
3755
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
3756
-							}
3757
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
3758
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
3751
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
3752
+                            $extra = '';
3753
+                            if( strpos($new_args, '[%WrapClass%]') !== false ){
3754
+                                $new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
3755
+                                $new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
3756
+                            }
3757
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
3758
+                        } elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
3759 3759
                             $new_args = str_replace('[%WrapStyle%]','',$new_args);
3760 3760
                             echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
3761 3761
 //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
3762
-						} elseif ( $element == 'style' ) {
3763
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
3764
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
3762
+                        } elseif ( $element == 'style' ) {
3763
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
3764
+                        } elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
3765 3765
                             $new_args = str_replace('[%WrapClass%]','',$new_args);
3766 3766
                             echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
3767
-						} elseif ( $element == 'template' && $new_args ) {
3768
-							echo $element . ": $new_args,";
3769
-						} else {
3770
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
3771
-						}
3767
+                        } elseif ( $element == 'template' && $new_args ) {
3768
+                            echo $element . ": $new_args,";
3769
+                        } else {
3770
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
3771
+                        }
3772 3772
 
3773
-					}
3774
-				}
3775
-			}
3776
-		}
3773
+                    }
3774
+                }
3775
+            }
3776
+        }
3777 3777
 
3778
-		/**
3779
-		 * Replace block attributes placeholders with the proper naming.
3780
-		 *
3781
-		 * @param $string
3782
-		 *
3783
-		 * @return mixed
3784
-		 */
3785
-		public function block_props_replace( $string, $no_wrap = false ) {
3786
-
3787
-			if ( $no_wrap ) {
3788
-				$string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
3789
-			} else {
3790
-				$string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
3791
-			}
3778
+        /**
3779
+         * Replace block attributes placeholders with the proper naming.
3780
+         *
3781
+         * @param $string
3782
+         *
3783
+         * @return mixed
3784
+         */
3785
+        public function block_props_replace( $string, $no_wrap = false ) {
3792 3786
 
3793
-			return $string;
3794
-		}
3787
+            if ( $no_wrap ) {
3788
+                $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string );
3789
+            } else {
3790
+                $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string );
3791
+            }
3795 3792
 
3796
-		/**
3797
-		 * Outputs the content of the widget
3798
-		 *
3799
-		 * @param array $args
3800
-		 * @param array $instance
3801
-		 */
3802
-		public function widget( $args, $instance ) {
3803
-
3804
-			// get the filtered values
3805
-			$argument_values = $this->argument_values( $instance );
3806
-			$argument_values = $this->string_to_bool( $argument_values );
3807
-			$output          = $this->output( $argument_values, $args );
3808
-
3809
-			$no_wrap = false;
3810
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
3811
-				$no_wrap = true;
3812
-			}
3793
+            return $string;
3794
+        }
3813 3795
 
3814
-			ob_start();
3815
-			if ( $output && ! $no_wrap ) {
3796
+        /**
3797
+         * Outputs the content of the widget
3798
+         *
3799
+         * @param array $args
3800
+         * @param array $instance
3801
+         */
3802
+        public function widget( $args, $instance ) {
3816 3803
 
3817
-				$class_original = $this->options['widget_ops']['classname'];
3818
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
3804
+            // get the filtered values
3805
+            $argument_values = $this->argument_values( $instance );
3806
+            $argument_values = $this->string_to_bool( $argument_values );
3807
+            $output          = $this->output( $argument_values, $args );
3819 3808
 
3820
-				// Before widget
3821
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
3822
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
3823
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
3824
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
3809
+            $no_wrap = false;
3810
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
3811
+                $no_wrap = true;
3812
+            }
3825 3813
 
3826
-				// After widget
3827
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
3828
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
3829
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
3814
+            ob_start();
3815
+            if ( $output && ! $no_wrap ) {
3830 3816
 
3831
-				echo $before_widget;
3832
-				// elementor strips the widget wrapping div so we check for and add it back if needed
3833
-				if ( $this->is_elementor_widget_output() ) {
3834
-					// Filter class & attrs for elementor widget output.
3835
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
3836
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
3817
+                $class_original = $this->options['widget_ops']['classname'];
3818
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
3837 3819
 
3838
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
3839
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
3820
+                // Before widget
3821
+                $before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
3822
+                $before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
3823
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
3824
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
3840 3825
 
3841
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
3842
-				}
3843
-				echo $this->output_title( $args, $instance );
3844
-				echo $output;
3845
-				if ( $this->is_elementor_widget_output() ) {
3846
-					echo "</span>";
3847
-				}
3848
-				echo $after_widget;
3849
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
3850
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
3851
-				echo $output;
3852
-			} elseif ( $output && $no_wrap ) {
3853
-				echo $output;
3854
-			}
3855
-			$output = ob_get_clean();
3826
+                // After widget
3827
+                $after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
3828
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
3829
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
3856 3830
 
3857
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
3831
+                echo $before_widget;
3832
+                // elementor strips the widget wrapping div so we check for and add it back if needed
3833
+                if ( $this->is_elementor_widget_output() ) {
3834
+                    // Filter class & attrs for elementor widget output.
3835
+                    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
3836
+                    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
3858 3837
 
3859
-			echo $output;
3860
-		}
3838
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
3839
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
3861 3840
 
3862
-		/**
3863
-		 * Tests if the current output is inside a elementor container.
3864
-		 *
3865
-		 * @return bool
3866
-		 *@since 1.0.4
3867
-		 */
3868
-		public function is_elementor_widget_output() {
3869
-			$result = false;
3870
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
3871
-				$result = true;
3872
-			}
3841
+                    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
3842
+                }
3843
+                echo $this->output_title( $args, $instance );
3844
+                echo $output;
3845
+                if ( $this->is_elementor_widget_output() ) {
3846
+                    echo "</span>";
3847
+                }
3848
+                echo $after_widget;
3849
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
3850
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
3851
+                echo $output;
3852
+            } elseif ( $output && $no_wrap ) {
3853
+                echo $output;
3854
+            }
3855
+            $output = ob_get_clean();
3873 3856
 
3874
-			return $result;
3875
-		}
3857
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
3876 3858
 
3877
-		/**
3878
-		 * Tests if the current output is inside a elementor preview.
3879
-		 *
3880
-		 * @return bool
3881
-		 *@since 1.0.4
3882
-		 */
3883
-		public function is_elementor_preview() {
3884
-			$result = false;
3885
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3886
-				$result = true;
3887
-			}
3859
+            echo $output;
3860
+        }
3888 3861
 
3889
-			return $result;
3890
-		}
3862
+        /**
3863
+         * Tests if the current output is inside a elementor container.
3864
+         *
3865
+         * @return bool
3866
+         *@since 1.0.4
3867
+         */
3868
+        public function is_elementor_widget_output() {
3869
+            $result = false;
3870
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
3871
+                $result = true;
3872
+            }
3891 3873
 
3892
-		/**
3893
-		 * Tests if the current output is inside a Divi preview.
3894
-		 *
3895
-		 * @return bool
3896
-		 *@since 1.0.6
3897
-		 */
3898
-		public function is_divi_preview() {
3899
-			$result = false;
3900
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3901
-				$result = true;
3902
-			}
3874
+            return $result;
3875
+        }
3903 3876
 
3904
-			return $result;
3905
-		}
3877
+        /**
3878
+         * Tests if the current output is inside a elementor preview.
3879
+         *
3880
+         * @return bool
3881
+         *@since 1.0.4
3882
+         */
3883
+        public function is_elementor_preview() {
3884
+            $result = false;
3885
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3886
+                $result = true;
3887
+            }
3906 3888
 
3907
-		/**
3908
-		 * Tests if the current output is inside a Beaver builder preview.
3909
-		 *
3910
-		 * @return bool
3911
-		 *@since 1.0.6
3912
-		 */
3913
-		public function is_beaver_preview() {
3914
-			$result = false;
3915
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
3916
-				$result = true;
3917
-			}
3889
+            return $result;
3890
+        }
3918 3891
 
3919
-			return $result;
3920
-		}
3892
+        /**
3893
+         * Tests if the current output is inside a Divi preview.
3894
+         *
3895
+         * @return bool
3896
+         *@since 1.0.6
3897
+         */
3898
+        public function is_divi_preview() {
3899
+            $result = false;
3900
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3901
+                $result = true;
3902
+            }
3921 3903
 
3922
-		/**
3923
-		 * Tests if the current output is inside a siteorigin builder preview.
3924
-		 *
3925
-		 * @return bool
3926
-		 *@since 1.0.6
3927
-		 */
3928
-		public function is_siteorigin_preview() {
3929
-			$result = false;
3930
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3931
-				$result = true;
3932
-			}
3904
+            return $result;
3905
+        }
3933 3906
 
3934
-			return $result;
3935
-		}
3907
+        /**
3908
+         * Tests if the current output is inside a Beaver builder preview.
3909
+         *
3910
+         * @return bool
3911
+         *@since 1.0.6
3912
+         */
3913
+        public function is_beaver_preview() {
3914
+            $result = false;
3915
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
3916
+                $result = true;
3917
+            }
3936 3918
 
3937
-		/**
3938
-		 * Tests if the current output is inside a cornerstone builder preview.
3939
-		 *
3940
-		 * @return bool
3941
-		 *@since 1.0.8
3942
-		 */
3943
-		public function is_cornerstone_preview() {
3944
-			$result = false;
3945
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3946
-				$result = true;
3947
-			}
3919
+            return $result;
3920
+        }
3948 3921
 
3949
-			return $result;
3950
-		}
3922
+        /**
3923
+         * Tests if the current output is inside a siteorigin builder preview.
3924
+         *
3925
+         * @return bool
3926
+         *@since 1.0.6
3927
+         */
3928
+        public function is_siteorigin_preview() {
3929
+            $result = false;
3930
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3931
+                $result = true;
3932
+            }
3951 3933
 
3952
-		/**
3953
-		 * Tests if the current output is inside a fusion builder preview.
3954
-		 *
3955
-		 * @return bool
3956
-		 *@since 1.1.0
3957
-		 */
3958
-		public function is_fusion_preview() {
3959
-			$result = false;
3960
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3961
-				$result = true;
3962
-			}
3934
+            return $result;
3935
+        }
3963 3936
 
3964
-			return $result;
3965
-		}
3937
+        /**
3938
+         * Tests if the current output is inside a cornerstone builder preview.
3939
+         *
3940
+         * @return bool
3941
+         *@since 1.0.8
3942
+         */
3943
+        public function is_cornerstone_preview() {
3944
+            $result = false;
3945
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3946
+                $result = true;
3947
+            }
3966 3948
 
3967
-		/**
3968
-		 * Tests if the current output is inside a Oxygen builder preview.
3969
-		 *
3970
-		 * @return bool
3971
-		 *@since 1.0.18
3972
-		 */
3973
-		public function is_oxygen_preview() {
3974
-			$result = false;
3975
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3976
-				$result = true;
3977
-			}
3949
+            return $result;
3950
+        }
3978 3951
 
3979
-			return $result;
3980
-		}
3952
+        /**
3953
+         * Tests if the current output is inside a fusion builder preview.
3954
+         *
3955
+         * @return bool
3956
+         *@since 1.1.0
3957
+         */
3958
+        public function is_fusion_preview() {
3959
+            $result = false;
3960
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3961
+                $result = true;
3962
+            }
3981 3963
 
3982
-		/**
3983
-		 * General function to check if we are in a preview situation.
3984
-		 *
3985
-		 * @return bool
3986
-		 *@since 1.0.6
3987
-		 */
3988
-		public function is_preview() {
3989
-			$preview = false;
3990
-			if ( $this->is_divi_preview() ) {
3991
-				$preview = true;
3992
-			} elseif ( $this->is_elementor_preview() ) {
3993
-				$preview = true;
3994
-			} elseif ( $this->is_beaver_preview() ) {
3995
-				$preview = true;
3996
-			} elseif ( $this->is_siteorigin_preview() ) {
3997
-				$preview = true;
3998
-			} elseif ( $this->is_cornerstone_preview() ) {
3999
-				$preview = true;
4000
-			} elseif ( $this->is_fusion_preview() ) {
4001
-				$preview = true;
4002
-			} elseif ( $this->is_oxygen_preview() ) {
4003
-				$preview = true;
4004
-			} elseif( $this->is_block_content_call() ) {
4005
-				$preview = true;
4006
-			}
3964
+            return $result;
3965
+        }
4007 3966
 
4008
-			return $preview;
4009
-		}
3967
+        /**
3968
+         * Tests if the current output is inside a Oxygen builder preview.
3969
+         *
3970
+         * @return bool
3971
+         *@since 1.0.18
3972
+         */
3973
+        public function is_oxygen_preview() {
3974
+            $result = false;
3975
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3976
+                $result = true;
3977
+            }
4010 3978
 
4011
-		/**
4012
-		 * Output the super title.
4013
-		 *
4014
-		 * @param $args
4015
-		 * @param array $instance
4016
-		 *
4017
-		 * @return string
4018
-		 */
4019
-		public function output_title( $args, $instance = array() ) {
4020
-			$output = '';
4021
-			if ( ! empty( $instance['title'] ) ) {
4022
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4023
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4024
-
4025
-				if(empty($instance['widget_title_tag'])){
4026
-					$output = $args['before_title'] . $title . $args['after_title'];
4027
-				}else{
4028
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
4029
-
4030
-					// classes
4031
-					$title_classes = array();
4032
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4033
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4034
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4035
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4036
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4037
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4038
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4039
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4040
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4041
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4042
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4043
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4044
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4045
-
4046
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4047
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
4048
-				}
3979
+            return $result;
3980
+        }
4049 3981
 
4050
-			}
3982
+        /**
3983
+         * General function to check if we are in a preview situation.
3984
+         *
3985
+         * @return bool
3986
+         *@since 1.0.6
3987
+         */
3988
+        public function is_preview() {
3989
+            $preview = false;
3990
+            if ( $this->is_divi_preview() ) {
3991
+                $preview = true;
3992
+            } elseif ( $this->is_elementor_preview() ) {
3993
+                $preview = true;
3994
+            } elseif ( $this->is_beaver_preview() ) {
3995
+                $preview = true;
3996
+            } elseif ( $this->is_siteorigin_preview() ) {
3997
+                $preview = true;
3998
+            } elseif ( $this->is_cornerstone_preview() ) {
3999
+                $preview = true;
4000
+            } elseif ( $this->is_fusion_preview() ) {
4001
+                $preview = true;
4002
+            } elseif ( $this->is_oxygen_preview() ) {
4003
+                $preview = true;
4004
+            } elseif( $this->is_block_content_call() ) {
4005
+                $preview = true;
4006
+            }
4051 4007
 
4052
-			return $output;
4053
-		}
4008
+            return $preview;
4009
+        }
4010
+
4011
+        /**
4012
+         * Output the super title.
4013
+         *
4014
+         * @param $args
4015
+         * @param array $instance
4016
+         *
4017
+         * @return string
4018
+         */
4019
+        public function output_title( $args, $instance = array() ) {
4020
+            $output = '';
4021
+            if ( ! empty( $instance['title'] ) ) {
4022
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4023
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4024
+
4025
+                if(empty($instance['widget_title_tag'])){
4026
+                    $output = $args['before_title'] . $title . $args['after_title'];
4027
+                }else{
4028
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
4029
+
4030
+                    // classes
4031
+                    $title_classes = array();
4032
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4033
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4034
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4035
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4036
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4037
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4038
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4039
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4040
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4041
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4042
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4043
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4044
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4045
+
4046
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4047
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
4048
+                }
4049
+
4050
+            }
4054 4051
 
4055
-		/**
4056
-		 * Outputs the options form inputs for the widget.
4057
-		 *
4058
-		 * @param array $instance The widget options.
4059
-		 */
4060
-		public function form( $instance ) {
4052
+            return $output;
4053
+        }
4054
+
4055
+        /**
4056
+         * Outputs the options form inputs for the widget.
4057
+         *
4058
+         * @param array $instance The widget options.
4059
+         */
4060
+        public function form( $instance ) {
4061 4061
 
4062
-			// set widget instance
4063
-			$this->instance = $instance;
4062
+            // set widget instance
4063
+            $this->instance = $instance;
4064 4064
 
4065
-			// set it as a SD widget
4066
-			echo $this->widget_advanced_toggle();
4065
+            // set it as a SD widget
4066
+            echo $this->widget_advanced_toggle();
4067 4067
 
4068
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4069
-			$arguments_raw = $this->get_arguments();
4068
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4069
+            $arguments_raw = $this->get_arguments();
4070 4070
 
4071
-			if ( is_array( $arguments_raw ) ) {
4071
+            if ( is_array( $arguments_raw ) ) {
4072 4072
 
4073
-				$arguments = $this->group_arguments( $arguments_raw );
4073
+                $arguments = $this->group_arguments( $arguments_raw );
4074 4074
 
4075
-				// Do we have sections?
4076
-				$has_sections = $arguments == $arguments_raw ? false : true;
4075
+                // Do we have sections?
4076
+                $has_sections = $arguments == $arguments_raw ? false : true;
4077 4077
 
4078 4078
 
4079
-				if ( $has_sections ) {
4080
-					$panel_count = 0;
4081
-					foreach ( $arguments as $key => $args ) {
4079
+                if ( $has_sections ) {
4080
+                    $panel_count = 0;
4081
+                    foreach ( $arguments as $key => $args ) {
4082 4082
 
4083
-						?>
4083
+                        ?>
4084 4084
 						<script>
4085 4085
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
4086 4086
 						</script>
4087 4087
 						<?php
4088 4088
 
4089
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
4090
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4091
-						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>";
4092
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4089
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
4090
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4091
+                        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>";
4092
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4093 4093
 
4094
-						foreach ( $args as $k => $a ) {
4094
+                        foreach ( $args as $k => $a ) {
4095 4095
 
4096
-							$this->widget_inputs_row_start($k, $a);
4097
-							$this->widget_inputs( $a, $instance );
4098
-							$this->widget_inputs_row_end($k, $a);
4096
+                            $this->widget_inputs_row_start($k, $a);
4097
+                            $this->widget_inputs( $a, $instance );
4098
+                            $this->widget_inputs_row_end($k, $a);
4099 4099
 
4100
-						}
4100
+                        }
4101 4101
 
4102
-						echo "</div>";
4102
+                        echo "</div>";
4103 4103
 
4104
-						$panel_count ++;
4104
+                        $panel_count ++;
4105 4105
 
4106
-					}
4107
-				} else {
4108
-					foreach ( $arguments as $key => $args ) {
4109
-						$this->widget_inputs_row_start($key, $args);
4110
-						$this->widget_inputs( $args, $instance );
4111
-						$this->widget_inputs_row_end($key, $args);
4112
-					}
4113
-				}
4106
+                    }
4107
+                } else {
4108
+                    foreach ( $arguments as $key => $args ) {
4109
+                        $this->widget_inputs_row_start($key, $args);
4110
+                        $this->widget_inputs( $args, $instance );
4111
+                        $this->widget_inputs_row_end($key, $args);
4112
+                    }
4113
+                }
4114 4114
 
4115
-			}
4116
-		}
4115
+            }
4116
+        }
4117 4117
 
4118
-		public function widget_inputs_row_start($key, $args){
4119
-			if(!empty($args['row'])){
4120
-				// maybe open
4121
-				if(!empty($args['row']['open'])){
4122
-					?>
4118
+        public function widget_inputs_row_start($key, $args){
4119
+            if(!empty($args['row'])){
4120
+                // maybe open
4121
+                if(!empty($args['row']['open'])){
4122
+                    ?>
4123 4123
 					<div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) {
4124
-						echo $this->convert_element_require( $args['row']['element_require'] );
4125
-					} ?>'>
4124
+                        echo $this->convert_element_require( $args['row']['element_require'] );
4125
+                    } ?>'>
4126 4126
 					<?php if(!empty($args['row']['title'])){ ?>
4127 4127
 					<label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4128 4128
 					<?php }?>
4129 4129
 					<div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'>
4130 4130
 					<div class='col pr-2'>
4131 4131
 					<?php
4132
-				}elseif(!empty($args['row']['close'])){
4133
-					echo "<div class='col pl-0 ps-0'>";
4134
-				}else{
4135
-					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4136
-				}
4137
-			}
4138
-		}
4132
+                }elseif(!empty($args['row']['close'])){
4133
+                    echo "<div class='col pl-0 ps-0'>";
4134
+                }else{
4135
+                    echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4136
+                }
4137
+            }
4138
+        }
4139 4139
 
4140
-		public function widget_inputs_row_end($key, $args){
4140
+        public function widget_inputs_row_end($key, $args){
4141 4141
 
4142
-			if(!empty($args['row'])){
4143
-				// maybe close
4144
-				if(!empty($args['row']['close'])){
4145
-					echo "</div></div>";
4146
-				}
4142
+            if(!empty($args['row'])){
4143
+                // maybe close
4144
+                if(!empty($args['row']['close'])){
4145
+                    echo "</div></div>";
4146
+                }
4147 4147
 
4148
-				echo "</div>";
4149
-			}
4150
-		}
4148
+                echo "</div>";
4149
+            }
4150
+        }
4151 4151
 
4152
-		/**
4153
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
4154
-		 *
4155
-		 * @return string
4156
-		 */
4157
-		public function widget_advanced_toggle() {
4152
+        /**
4153
+         * Get the hidden input that when added makes the advanced button show on widget settings.
4154
+         *
4155
+         * @return string
4156
+         */
4157
+        public function widget_advanced_toggle() {
4158 4158
 
4159
-			$output = '';
4160
-			if ( $this->block_show_advanced() ) {
4161
-				$val = 1;
4162
-			} else {
4163
-				$val = 0;
4164
-			}
4159
+            $output = '';
4160
+            if ( $this->block_show_advanced() ) {
4161
+                $val = 1;
4162
+            } else {
4163
+                $val = 0;
4164
+            }
4165 4165
 
4166
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4166
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4167 4167
 
4168
-			return $output;
4169
-		}
4168
+            return $output;
4169
+        }
4170 4170
 
4171
-		/**
4172
-		 * Convert require element.
4173
-		 *
4174
-		 * @param string $input Input element.
4175
-		 *
4176
-		 * @return string $output
4177
-		 *@since 1.0.0
4178
-		 *
4179
-		 */
4180
-		public function convert_element_require( $input ) {
4181
-
4182
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4183
-
4184
-			$output = esc_attr( str_replace( array( "[%", "%]" ), array(
4185
-				"jQuery(form).find('[data-argument=\"",
4186
-				"\"]').find('input,select,textarea').val()"
4187
-			), $input ) );
4188
-
4189
-			return $output;
4190
-		}
4171
+        /**
4172
+         * Convert require element.
4173
+         *
4174
+         * @param string $input Input element.
4175
+         *
4176
+         * @return string $output
4177
+         *@since 1.0.0
4178
+         *
4179
+         */
4180
+        public function convert_element_require( $input ) {
4191 4181
 
4192
-		/**
4193
-		 * Builds the inputs for the widget options.
4194
-		 *
4195
-		 * @param $args
4196
-		 * @param $instance
4197
-		 */
4198
-		public function widget_inputs( $args, $instance ) {
4199
-
4200
-			$class             = "";
4201
-			$element_require   = "";
4202
-			$custom_attributes = "";
4203
-
4204
-			// get value
4205
-			if ( isset( $instance[ $args['name'] ] ) ) {
4206
-				$value = $instance[ $args['name'] ];
4207
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4208
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4209
-			} else {
4210
-				$value = '';
4211
-			}
4182
+            $input = str_replace( "'", '"', $input );// we only want double quotes
4212 4183
 
4213
-			// get placeholder
4214
-			if ( ! empty( $args['placeholder'] ) ) {
4215
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4216
-			} else {
4217
-				$placeholder = '';
4218
-			}
4184
+            $output = esc_attr( str_replace( array( "[%", "%]" ), array(
4185
+                "jQuery(form).find('[data-argument=\"",
4186
+                "\"]').find('input,select,textarea').val()"
4187
+            ), $input ) );
4219 4188
 
4220
-			// get if advanced
4221
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4222
-				$class .= " sd-advanced-setting ";
4223
-			}
4189
+            return $output;
4190
+        }
4224 4191
 
4225
-			// element_require
4226
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4227
-				$element_require = $args['element_require'];
4228
-			}
4192
+        /**
4193
+         * Builds the inputs for the widget options.
4194
+         *
4195
+         * @param $args
4196
+         * @param $instance
4197
+         */
4198
+        public function widget_inputs( $args, $instance ) {
4199
+
4200
+            $class             = "";
4201
+            $element_require   = "";
4202
+            $custom_attributes = "";
4203
+
4204
+            // get value
4205
+            if ( isset( $instance[ $args['name'] ] ) ) {
4206
+                $value = $instance[ $args['name'] ];
4207
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4208
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4209
+            } else {
4210
+                $value = '';
4211
+            }
4229 4212
 
4230
-			// custom_attributes
4231
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4232
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4233
-			}
4213
+            // get placeholder
4214
+            if ( ! empty( $args['placeholder'] ) ) {
4215
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4216
+            } else {
4217
+                $placeholder = '';
4218
+            }
4219
+
4220
+            // get if advanced
4221
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4222
+                $class .= " sd-advanced-setting ";
4223
+            }
4224
+
4225
+            // element_require
4226
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4227
+                $element_require = $args['element_require'];
4228
+            }
4229
+
4230
+            // custom_attributes
4231
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4232
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4233
+            }
4234 4234
 
4235 4235
 
4236
-			// before wrapper
4237
-			?>
4236
+            // before wrapper
4237
+            ?>
4238 4238
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>"
4239 4239
 			data-argument='<?php echo esc_attr( $args['name'] ); ?>'
4240 4240
 			data-element_require='<?php if ( $element_require ) {
4241
-				echo $this->convert_element_require( $element_require );
4242
-			} ?>'
4241
+                echo $this->convert_element_require( $element_require );
4242
+            } ?>'
4243 4243
 			>
4244 4244
 			<?php
4245 4245
 
4246 4246
 
4247
-			switch ( $args['type'] ) {
4248
-				//array('text','password','number','email','tel','url','color')
4249
-				case "text":
4250
-				case "password":
4251
-				case "number":
4252
-				case "email":
4253
-				case "tel":
4254
-				case "url":
4255
-				case "color":
4256
-					?>
4247
+            switch ( $args['type'] ) {
4248
+                //array('text','password','number','email','tel','url','color')
4249
+                case "text":
4250
+                case "password":
4251
+                case "number":
4252
+                case "email":
4253
+                case "tel":
4254
+                case "url":
4255
+                case "color":
4256
+                    ?>
4257 4257
 					<label
4258 4258
 						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>
4259 4259
 					<input <?php echo $placeholder; ?> class="widefat"
@@ -4264,47 +4264,47 @@  discard block
 block discarded – undo
4264 4264
 						                               value="<?php echo esc_attr( $value ); ?>">
4265 4265
 					<?php
4266 4266
 
4267
-					break;
4268
-				case "select":
4269
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4270
-					if ( $multiple ) {
4271
-						if ( empty( $value ) ) {
4272
-							$value = array();
4273
-						}
4274
-					}
4275
-					?>
4267
+                    break;
4268
+                case "select":
4269
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4270
+                    if ( $multiple ) {
4271
+                        if ( empty( $value ) ) {
4272
+                            $value = array();
4273
+                        }
4274
+                    }
4275
+                    ?>
4276 4276
 					<label
4277 4277
 						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>
4278 4278
 					<select <?php echo $placeholder; ?> class="widefat"
4279 4279
 						<?php echo $custom_attributes; ?>
4280 4280
 						                                id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
4281 4281
 						                                name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) );
4282
-						                                if ( $multiple ) {
4283
-							                                echo "[]";
4284
-						                                } ?>"
4282
+                                                        if ( $multiple ) {
4283
+                                                            echo "[]";
4284
+                                                        } ?>"
4285 4285
 						<?php if ( $multiple ) {
4286
-							echo "multiple";
4287
-						} //@todo not implemented yet due to gutenberg not supporting it
4288
-						?>
4286
+                            echo "multiple";
4287
+                        } //@todo not implemented yet due to gutenberg not supporting it
4288
+                        ?>
4289 4289
 					>
4290 4290
 						<?php
4291 4291
 
4292
-						if ( ! empty( $args['options'] ) ) {
4293
-							foreach ( $args['options'] as $val => $label ) {
4294
-								if ( $multiple ) {
4295
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4296
-								} else {
4297
-									$selected = selected( $value, $val, false );
4298
-								}
4299
-								echo "<option value='$val' " . $selected . ">$label</option>";
4300
-							}
4301
-						}
4302
-						?>
4292
+                        if ( ! empty( $args['options'] ) ) {
4293
+                            foreach ( $args['options'] as $val => $label ) {
4294
+                                if ( $multiple ) {
4295
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4296
+                                } else {
4297
+                                    $selected = selected( $value, $val, false );
4298
+                                }
4299
+                                echo "<option value='$val' " . $selected . ">$label</option>";
4300
+                            }
4301
+                        }
4302
+                        ?>
4303 4303
 					</select>
4304 4304
 					<?php
4305
-					break;
4306
-				case "checkbox":
4307
-					?>
4305
+                    break;
4306
+                case "checkbox":
4307
+                    ?>
4308 4308
 					<input <?php echo $placeholder; ?>
4309 4309
 						<?php checked( 1, $value, true ) ?>
4310 4310
 						<?php echo $custom_attributes; ?>
@@ -4314,9 +4314,9 @@  discard block
 block discarded – undo
4314 4314
 					<label
4315 4315
 						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>
4316 4316
 					<?php
4317
-					break;
4318
-				case "textarea":
4319
-					?>
4317
+                    break;
4318
+                case "textarea":
4319
+                    ?>
4320 4320
 					<label
4321 4321
 						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>
4322 4322
 					<textarea <?php echo $placeholder; ?> class="widefat"
@@ -4326,282 +4326,282 @@  discard block
 block discarded – undo
4326 4326
 					><?php echo esc_attr( $value ); ?></textarea>
4327 4327
 					<?php
4328 4328
 
4329
-					break;
4330
-				case "hidden":
4331
-					?>
4329
+                    break;
4330
+                case "hidden":
4331
+                    ?>
4332 4332
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"
4333 4333
 					       name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden"
4334 4334
 					       value="<?php echo esc_attr( $value ); ?>">
4335 4335
 					<?php
4336
-					break;
4337
-				default:
4338
-					echo "No input type found!"; // @todo we need to add more input types.
4339
-			}
4336
+                    break;
4337
+                default:
4338
+                    echo "No input type found!"; // @todo we need to add more input types.
4339
+            }
4340 4340
 
4341
-			// after wrapper
4342
-			?>
4341
+            // after wrapper
4342
+            ?>
4343 4343
 			</p>
4344 4344
 			<?php
4345 4345
 
4346 4346
 
4347
-		}
4347
+        }
4348 4348
 
4349
-		public function get_widget_icon($icon = 'box-top', $title = ''){
4350
-			if($icon=='box-top'){
4351
-				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>';
4352
-			}elseif($icon=='box-right'){
4353
-				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>';
4354
-			}elseif($icon=='box-bottom'){
4355
-				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>';
4356
-			}elseif($icon=='box-left'){
4357
-				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>';
4358
-			}
4359
-		}
4349
+        public function get_widget_icon($icon = 'box-top', $title = ''){
4350
+            if($icon=='box-top'){
4351
+                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>';
4352
+            }elseif($icon=='box-right'){
4353
+                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>';
4354
+            }elseif($icon=='box-bottom'){
4355
+                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>';
4356
+            }elseif($icon=='box-left'){
4357
+                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>';
4358
+            }
4359
+        }
4360 4360
 
4361
-		/**
4362
-		 * Get the widget input description html.
4363
-		 *
4364
-		 * @param $args
4365
-		 *
4366
-		 * @return string
4367
-		 * @todo, need to make its own tooltip script
4368
-		 */
4369
-		public function widget_field_desc( $args ) {
4370
-
4371
-			$description = '';
4372
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
4373
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4374
-					$description = $this->desc_tip( $args['desc'] );
4375
-				} else {
4376
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4377
-				}
4378
-			}
4361
+        /**
4362
+         * Get the widget input description html.
4363
+         *
4364
+         * @param $args
4365
+         *
4366
+         * @return string
4367
+         * @todo, need to make its own tooltip script
4368
+         */
4369
+        public function widget_field_desc( $args ) {
4370
+
4371
+            $description = '';
4372
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
4373
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4374
+                    $description = $this->desc_tip( $args['desc'] );
4375
+                } else {
4376
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4377
+                }
4378
+            }
4379 4379
 
4380
-			return $description;
4381
-		}
4380
+            return $description;
4381
+        }
4382 4382
 
4383
-		/**
4384
-		 * Get the widget input title html.
4385
-		 *
4386
-		 * @param $args
4387
-		 *
4388
-		 * @return string
4389
-		 */
4390
-		public function widget_field_title( $args ) {
4391
-
4392
-			$title = '';
4393
-			if ( isset( $args['title'] ) && $args['title'] ) {
4394
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
4395
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
4396
-				} else {
4397
-					$title = esc_attr($args['title']);
4398
-				}
4399
-			}
4383
+        /**
4384
+         * Get the widget input title html.
4385
+         *
4386
+         * @param $args
4387
+         *
4388
+         * @return string
4389
+         */
4390
+        public function widget_field_title( $args ) {
4391
+
4392
+            $title = '';
4393
+            if ( isset( $args['title'] ) && $args['title'] ) {
4394
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
4395
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
4396
+                } else {
4397
+                    $title = esc_attr($args['title']);
4398
+                }
4399
+            }
4400 4400
 
4401
-			return $title;
4402
-		}
4401
+            return $title;
4402
+        }
4403 4403
 
4404
-		/**
4405
-		 * Get the tool tip html.
4406
-		 *
4407
-		 * @param $tip
4408
-		 * @param bool $allow_html
4409
-		 *
4410
-		 * @return string
4411
-		 */
4412
-		function desc_tip( $tip, $allow_html = false ) {
4413
-			if ( $allow_html ) {
4414
-				$tip = $this->sanitize_tooltip( $tip );
4415
-			} else {
4416
-				$tip = esc_attr( $tip );
4417
-			}
4404
+        /**
4405
+         * Get the tool tip html.
4406
+         *
4407
+         * @param $tip
4408
+         * @param bool $allow_html
4409
+         *
4410
+         * @return string
4411
+         */
4412
+        function desc_tip( $tip, $allow_html = false ) {
4413
+            if ( $allow_html ) {
4414
+                $tip = $this->sanitize_tooltip( $tip );
4415
+            } else {
4416
+                $tip = esc_attr( $tip );
4417
+            }
4418 4418
 
4419
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4420
-		}
4419
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4420
+        }
4421 4421
 
4422
-		/**
4423
-		 * Sanitize a string destined to be a tooltip.
4424
-		 *
4425
-		 * @param string $var
4426
-		 *
4427
-		 * @return string
4428
-		 */
4429
-		public function sanitize_tooltip( $var ) {
4430
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4431
-				'br'     => array(),
4432
-				'em'     => array(),
4433
-				'strong' => array(),
4434
-				'small'  => array(),
4435
-				'span'   => array(),
4436
-				'ul'     => array(),
4437
-				'li'     => array(),
4438
-				'ol'     => array(),
4439
-				'p'      => array(),
4440
-			) ) );
4441
-		}
4422
+        /**
4423
+         * Sanitize a string destined to be a tooltip.
4424
+         *
4425
+         * @param string $var
4426
+         *
4427
+         * @return string
4428
+         */
4429
+        public function sanitize_tooltip( $var ) {
4430
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4431
+                'br'     => array(),
4432
+                'em'     => array(),
4433
+                'strong' => array(),
4434
+                'small'  => array(),
4435
+                'span'   => array(),
4436
+                'ul'     => array(),
4437
+                'li'     => array(),
4438
+                'ol'     => array(),
4439
+                'p'      => array(),
4440
+            ) ) );
4441
+        }
4442 4442
 
4443
-		/**
4444
-		 * Processing widget options on save
4445
-		 *
4446
-		 * @param array $new_instance The new options
4447
-		 * @param array $old_instance The previous options
4448
-		 *
4449
-		 * @return array
4450
-		 * @todo we should add some sanitation here.
4451
-		 */
4452
-		public function update( $new_instance, $old_instance ) {
4453
-
4454
-			//save the widget
4455
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
4456
-
4457
-			// set widget instance
4458
-			$this->instance = $instance;
4459
-
4460
-			if ( empty( $this->arguments ) ) {
4461
-				$this->get_arguments();
4462
-			}
4443
+        /**
4444
+         * Processing widget options on save
4445
+         *
4446
+         * @param array $new_instance The new options
4447
+         * @param array $old_instance The previous options
4448
+         *
4449
+         * @return array
4450
+         * @todo we should add some sanitation here.
4451
+         */
4452
+        public function update( $new_instance, $old_instance ) {
4463 4453
 
4464
-			// check for checkboxes
4465
-			if ( ! empty( $this->arguments ) ) {
4466
-				foreach ( $this->arguments as $argument ) {
4467
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4468
-						$instance[ $argument['name'] ] = '0';
4469
-					}
4470
-				}
4471
-			}
4454
+            //save the widget
4455
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
4472 4456
 
4473
-			return $instance;
4474
-		}
4457
+            // set widget instance
4458
+            $this->instance = $instance;
4475 4459
 
4476
-		/**
4477
-		 * Checks if the current call is a ajax call to get the block content.
4478
-		 *
4479
-		 * This can be used in your widget to return different content as the block content.
4480
-		 *
4481
-		 * @return bool
4482
-		 *@since 1.0.3
4483
-		 */
4484
-		public function is_block_content_call() {
4485
-			$result = false;
4486
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4487
-				$result = true;
4488
-			}
4460
+            if ( empty( $this->arguments ) ) {
4461
+                $this->get_arguments();
4462
+            }
4489 4463
 
4490
-			return $result;
4491
-		}
4464
+            // check for checkboxes
4465
+            if ( ! empty( $this->arguments ) ) {
4466
+                foreach ( $this->arguments as $argument ) {
4467
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4468
+                        $instance[ $argument['name'] ] = '0';
4469
+                    }
4470
+                }
4471
+            }
4492 4472
 
4493
-		/**
4494
-		 * Get an instance hash that will be unique to the type and settings.
4495
-		 *
4496
-		 * @return string
4497
-		 *@since 1.0.20
4498
-		 */
4499
-		public function get_instance_hash(){
4500
-			$instance_string = $this->base_id.serialize($this->instance);
4501
-			return hash('crc32b',$instance_string);
4502
-		}
4473
+            return $instance;
4474
+        }
4503 4475
 
4504
-		/**
4505
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
4506
-		 *
4507
-		 * @param array $rules
4508
-		 *
4509
-		 * @return string
4510
-		 *@since 1.0.20
4511
-		 */
4512
-		public function get_instance_style($rules = array()){
4513
-			$css = '';
4514
-
4515
-			if(!empty($rules)){
4516
-				$rules = array_unique($rules);
4517
-				$instance_hash = $this->get_instance_hash();
4518
-				$css .= "<style>";
4519
-				foreach($rules as $rule){
4520
-					$css .= ".sdel-$instance_hash $rule";
4521
-				}
4522
-				$css .= "</style>";
4523
-			}
4476
+        /**
4477
+         * Checks if the current call is a ajax call to get the block content.
4478
+         *
4479
+         * This can be used in your widget to return different content as the block content.
4480
+         *
4481
+         * @return bool
4482
+         *@since 1.0.3
4483
+         */
4484
+        public function is_block_content_call() {
4485
+            $result = false;
4486
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4487
+                $result = true;
4488
+            }
4524 4489
 
4525
-			return $css;
4526
-		}
4490
+            return $result;
4491
+        }
4492
+
4493
+        /**
4494
+         * Get an instance hash that will be unique to the type and settings.
4495
+         *
4496
+         * @return string
4497
+         *@since 1.0.20
4498
+         */
4499
+        public function get_instance_hash(){
4500
+            $instance_string = $this->base_id.serialize($this->instance);
4501
+            return hash('crc32b',$instance_string);
4502
+        }
4527 4503
 
4528
-		/**
4529
-		 * Encode shortcodes tags.
4530
-		 *
4531
-		 * @param string $content Content to search for shortcode tags.
4532
-		 *
4504
+        /**
4505
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
4506
+         *
4507
+         * @param array $rules
4508
+         *
4509
+         * @return string
4510
+         *@since 1.0.20
4511
+         */
4512
+        public function get_instance_style($rules = array()){
4513
+            $css = '';
4514
+
4515
+            if(!empty($rules)){
4516
+                $rules = array_unique($rules);
4517
+                $instance_hash = $this->get_instance_hash();
4518
+                $css .= "<style>";
4519
+                foreach($rules as $rule){
4520
+                    $css .= ".sdel-$instance_hash $rule";
4521
+                }
4522
+                $css .= "</style>";
4523
+            }
4524
+
4525
+            return $css;
4526
+        }
4527
+
4528
+        /**
4529
+         * Encode shortcodes tags.
4530
+         *
4531
+         * @param string $content Content to search for shortcode tags.
4532
+         *
4533 4533
 *@return string Content with shortcode tags removed.
4534
-		 *@since 1.0.28
4535
-		 *
4536
-		 */
4537
-		public function encode_shortcodes( $content ) {
4538
-			// Avoids existing encoded tags.
4539
-			$trans   = array(
4540
-				'&#91;' => '&#091;',
4541
-				'&#93;' => '&#093;',
4542
-				'&amp;#91;' => '&#091;',
4543
-				'&amp;#93;' => '&#093;',
4544
-				'&lt;' => '&0lt;',
4545
-				'&gt;' => '&0gt;',
4546
-				'&amp;lt;' => '&0lt;',
4547
-				'&amp;gt;' => '&0gt;',
4548
-			);
4549
-
4550
-			$content = strtr( $content, $trans );
4551
-
4552
-			$trans   = array(
4553
-				'[' => '&#91;',
4554
-				']' => '&#93;',
4555
-				'<' => '&lt;',
4556
-				'>' => '&gt;',
4557
-				'"' => '&quot;',
4558
-				"'" => '&#39;',
4559
-			);
4560
-
4561
-			$content = strtr( $content, $trans );
4562
-
4563
-			return $content;
4564
-		}
4534
+         *@since 1.0.28
4535
+         *
4536
+         */
4537
+        public function encode_shortcodes( $content ) {
4538
+            // Avoids existing encoded tags.
4539
+            $trans   = array(
4540
+                '&#91;' => '&#091;',
4541
+                '&#93;' => '&#093;',
4542
+                '&amp;#91;' => '&#091;',
4543
+                '&amp;#93;' => '&#093;',
4544
+                '&lt;' => '&0lt;',
4545
+                '&gt;' => '&0gt;',
4546
+                '&amp;lt;' => '&0lt;',
4547
+                '&amp;gt;' => '&0gt;',
4548
+            );
4549
+
4550
+            $content = strtr( $content, $trans );
4551
+
4552
+            $trans   = array(
4553
+                '[' => '&#91;',
4554
+                ']' => '&#93;',
4555
+                '<' => '&lt;',
4556
+                '>' => '&gt;',
4557
+                '"' => '&quot;',
4558
+                "'" => '&#39;',
4559
+            );
4560
+
4561
+            $content = strtr( $content, $trans );
4562
+
4563
+            return $content;
4564
+        }
4565 4565
 
4566
-		/**
4567
-		 * Remove encoded shortcod tags.
4568
-		 *
4569
-		 * @param string $content Content to search for shortcode tags.
4570
-		 *
4566
+        /**
4567
+         * Remove encoded shortcod tags.
4568
+         *
4569
+         * @param string $content Content to search for shortcode tags.
4570
+         *
4571 4571
 *@return string Content with decoded shortcode tags.
4572
-		 *@since 1.0.28
4573
-		 *
4574
-		 */
4575
-		public function decode_shortcodes( $content ) {
4576
-			$trans   = array(
4577
-				'&#91;' => '[',
4578
-				'&#93;' => ']',
4579
-				'&amp;#91;' => '[',
4580
-				'&amp;#93;' => ']',
4581
-				'&lt;' => '<',
4582
-				'&gt;' => '>',
4583
-				'&amp;lt;' => '<',
4584
-				'&amp;gt;' => '>',
4585
-				'&quot;' => '"',
4586
-				'&apos;' => "'",
4587
-			);
4588
-
4589
-			$content = strtr( $content, $trans );
4590
-
4591
-			$trans   = array(
4592
-				'&#091;' => '&#91;',
4593
-				'&#093;' => '&#93;',
4594
-				'&amp;#091;' => '&#91;',
4595
-				'&amp;#093;' => '&#93;',
4596
-				'&0lt;' => '&lt;',
4597
-				'&0gt;' => '&gt;',
4598
-				'&amp;0lt;' => '&lt;',
4599
-				'&amp;0gt;' => '&gt;',
4600
-			);
4601
-
4602
-			$content = strtr( $content, $trans );
4603
-
4604
-			return $content;
4605
-		}
4606
-	}
4572
+         *@since 1.0.28
4573
+         *
4574
+         */
4575
+        public function decode_shortcodes( $content ) {
4576
+            $trans   = array(
4577
+                '&#91;' => '[',
4578
+                '&#93;' => ']',
4579
+                '&amp;#91;' => '[',
4580
+                '&amp;#93;' => ']',
4581
+                '&lt;' => '<',
4582
+                '&gt;' => '>',
4583
+                '&amp;lt;' => '<',
4584
+                '&amp;gt;' => '>',
4585
+                '&quot;' => '"',
4586
+                '&apos;' => "'",
4587
+            );
4588
+
4589
+            $content = strtr( $content, $trans );
4590
+
4591
+            $trans   = array(
4592
+                '&#091;' => '&#91;',
4593
+                '&#093;' => '&#93;',
4594
+                '&amp;#091;' => '&#91;',
4595
+                '&amp;#093;' => '&#93;',
4596
+                '&0lt;' => '&lt;',
4597
+                '&0gt;' => '&gt;',
4598
+                '&amp;0lt;' => '&lt;',
4599
+                '&amp;0gt;' => '&gt;',
4600
+            );
4601
+
4602
+            $content = strtr( $content, $trans );
4603
+
4604
+            return $content;
4605
+        }
4606
+    }
4607 4607
 }
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/sd-functions.php 1 patch
Indentation   +2054 added lines, -2054 removed lines patch added patch discarded remove patch
@@ -11,21 +11,21 @@  discard block
 block discarded – undo
11 11
  * @return mixed|void
12 12
  */
13 13
 function sd_pagenow_exclude() {
14
-	return apply_filters(
15
-		'sd_pagenow_exclude',
16
-		array(
17
-			'upload.php',
18
-			'edit-comments.php',
19
-			'edit-tags.php',
20
-			'index.php',
21
-			'media-new.php',
22
-			'options-discussion.php',
23
-			'options-writing.php',
24
-			'edit.php',
25
-			'themes.php',
26
-			'users.php',
27
-		)
28
-	);
14
+    return apply_filters(
15
+        'sd_pagenow_exclude',
16
+        array(
17
+            'upload.php',
18
+            'edit-comments.php',
19
+            'edit-tags.php',
20
+            'index.php',
21
+            'media-new.php',
22
+            'options-discussion.php',
23
+            'options-writing.php',
24
+            'edit.php',
25
+            'themes.php',
26
+            'users.php',
27
+        )
28
+    );
29 29
 }
30 30
 
31 31
 
@@ -37,7 +37,7 @@  discard block
 block discarded – undo
37 37
  * @return mixed|void
38 38
  */
39 39
 function sd_widget_exclude() {
40
-	return apply_filters( 'sd_widget_exclude', array() );
40
+    return apply_filters( 'sd_widget_exclude', array() );
41 41
 }
42 42
 
43 43
 
@@ -50,83 +50,83 @@  discard block
 block discarded – undo
50 50
  * @return array
51 51
  */
52 52
 function sd_get_margin_input( $type = 'mt', $overwrite = array(), $include_negatives = true ) {
53
-	global $aui_bs5;
54
-	$options = array(
55
-		''     => __( 'None', 'super-duper' ),
56
-		'auto' => __( 'auto', 'super-duper' ),
57
-		'0'    => '0',
58
-		'1'    => '1',
59
-		'2'    => '2',
60
-		'3'    => '3',
61
-		'4'    => '4',
62
-		'5'    => '5',
63
-		'6'    => '6',
64
-		'7'    => '7',
65
-		'8'    => '8',
66
-		'9'    => '9',
67
-		'10'   => '10',
68
-		'11'   => '11',
69
-		'12'   => '12',
70
-	);
71
-
72
-	if ( $include_negatives ) {
73
-		$options['n1']  = '-1';
74
-		$options['n2']  = '-2';
75
-		$options['n3']  = '-3';
76
-		$options['n4']  = '-4';
77
-		$options['n5']  = '-5';
78
-		$options['n6']  = '-6';
79
-		$options['n7']  = '-7';
80
-		$options['n8']  = '-8';
81
-		$options['n9']  = '-9';
82
-		$options['n10'] = '-10';
83
-		$options['n11'] = '-11';
84
-		$options['n12'] = '-12';
85
-	}
86
-
87
-	$defaults = array(
88
-		'type'     => 'select',
89
-		'title'    => __( 'Margin top', 'super-duper' ),
90
-		'options'  => $options,
91
-		'default'  => '',
92
-		'desc_tip' => true,
93
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
94
-	);
95
-
96
-	// title
97
-	if ( $type == 'mt' ) {
98
-		$defaults['title'] = __( 'Margin top', 'super-duper' );
99
-		$defaults['icon']  = 'box-top';
100
-		$defaults['row']   = array(
101
-			'title' => __( 'Margins', 'super-duper' ),
102
-			'key'   => 'wrapper-margins',
103
-			'open'  => true,
104
-			'class' => 'text-center',
105
-		);
106
-	} elseif ( $type == 'mr' ) {
107
-		$defaults['title'] = __( 'Margin right', 'super-duper' );
108
-		$defaults['icon']  = 'box-right';
109
-		$defaults['row']   = array(
110
-			'key' => 'wrapper-margins',
111
-		);
112
-	} elseif ( $type == 'mb' ) {
113
-		$defaults['title'] = __( 'Margin bottom', 'super-duper' );
114
-		$defaults['icon']  = 'box-bottom';
115
-		$defaults['row']   = array(
116
-			'key' => 'wrapper-margins',
117
-		);
118
-	} elseif ( $type == 'ml' ) {
119
-		$defaults['title'] = __( 'Margin left', 'super-duper' );
120
-		$defaults['icon']  = 'box-left';
121
-		$defaults['row']   = array(
122
-			'key'   => 'wrapper-margins',
123
-			'close' => true,
124
-		);
125
-	}
126
-
127
-	$input = wp_parse_args( $overwrite, $defaults );
128
-
129
-	return $input;
53
+    global $aui_bs5;
54
+    $options = array(
55
+        ''     => __( 'None', 'super-duper' ),
56
+        'auto' => __( 'auto', 'super-duper' ),
57
+        '0'    => '0',
58
+        '1'    => '1',
59
+        '2'    => '2',
60
+        '3'    => '3',
61
+        '4'    => '4',
62
+        '5'    => '5',
63
+        '6'    => '6',
64
+        '7'    => '7',
65
+        '8'    => '8',
66
+        '9'    => '9',
67
+        '10'   => '10',
68
+        '11'   => '11',
69
+        '12'   => '12',
70
+    );
71
+
72
+    if ( $include_negatives ) {
73
+        $options['n1']  = '-1';
74
+        $options['n2']  = '-2';
75
+        $options['n3']  = '-3';
76
+        $options['n4']  = '-4';
77
+        $options['n5']  = '-5';
78
+        $options['n6']  = '-6';
79
+        $options['n7']  = '-7';
80
+        $options['n8']  = '-8';
81
+        $options['n9']  = '-9';
82
+        $options['n10'] = '-10';
83
+        $options['n11'] = '-11';
84
+        $options['n12'] = '-12';
85
+    }
86
+
87
+    $defaults = array(
88
+        'type'     => 'select',
89
+        'title'    => __( 'Margin top', 'super-duper' ),
90
+        'options'  => $options,
91
+        'default'  => '',
92
+        'desc_tip' => true,
93
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
94
+    );
95
+
96
+    // title
97
+    if ( $type == 'mt' ) {
98
+        $defaults['title'] = __( 'Margin top', 'super-duper' );
99
+        $defaults['icon']  = 'box-top';
100
+        $defaults['row']   = array(
101
+            'title' => __( 'Margins', 'super-duper' ),
102
+            'key'   => 'wrapper-margins',
103
+            'open'  => true,
104
+            'class' => 'text-center',
105
+        );
106
+    } elseif ( $type == 'mr' ) {
107
+        $defaults['title'] = __( 'Margin right', 'super-duper' );
108
+        $defaults['icon']  = 'box-right';
109
+        $defaults['row']   = array(
110
+            'key' => 'wrapper-margins',
111
+        );
112
+    } elseif ( $type == 'mb' ) {
113
+        $defaults['title'] = __( 'Margin bottom', 'super-duper' );
114
+        $defaults['icon']  = 'box-bottom';
115
+        $defaults['row']   = array(
116
+            'key' => 'wrapper-margins',
117
+        );
118
+    } elseif ( $type == 'ml' ) {
119
+        $defaults['title'] = __( 'Margin left', 'super-duper' );
120
+        $defaults['icon']  = 'box-left';
121
+        $defaults['row']   = array(
122
+            'key'   => 'wrapper-margins',
123
+            'close' => true,
124
+        );
125
+    }
126
+
127
+    $input = wp_parse_args( $overwrite, $defaults );
128
+
129
+    return $input;
130 130
 }
131 131
 
132 132
 /**
@@ -138,67 +138,67 @@  discard block
 block discarded – undo
138 138
  * @return array
139 139
  */
140 140
 function sd_get_padding_input( $type = 'pt', $overwrite = array() ) {
141
-	$options = array(
142
-		''   => __( 'None', 'super-duper' ),
143
-		'0'  => '0',
144
-		'1'  => '1',
145
-		'2'  => '2',
146
-		'3'  => '3',
147
-		'4'  => '4',
148
-		'5'  => '5',
149
-		'6'  => '6',
150
-		'7'  => '7',
151
-		'8'  => '8',
152
-		'9'  => '9',
153
-		'10' => '10',
154
-		'11' => '11',
155
-		'12' => '12',
156
-	);
157
-
158
-	$defaults = array(
159
-		'type'     => 'select',
160
-		'title'    => __( 'Padding top', 'super-duper' ),
161
-		'options'  => $options,
162
-		'default'  => '',
163
-		'desc_tip' => true,
164
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
165
-	);
166
-
167
-	// title
168
-	if ( $type == 'pt' ) {
169
-		$defaults['title'] = __( 'Padding top', 'super-duper' );
170
-		$defaults['icon']  = 'box-top';
171
-		$defaults['row']   = array(
172
-			'title' => __( 'Padding', 'super-duper' ),
173
-			'key'   => 'wrapper-padding',
174
-			'open'  => true,
175
-			'class' => 'text-center',
176
-		);
177
-	} elseif ( $type == 'pr' ) {
178
-		$defaults['title'] = __( 'Padding right', 'super-duper' );
179
-		$defaults['icon']  = 'box-right';
180
-		$defaults['row']   = array(
181
-			'key' => 'wrapper-padding',
182
-		);
183
-	} elseif ( $type == 'pb' ) {
184
-		$defaults['title'] = __( 'Padding bottom', 'super-duper' );
185
-		$defaults['icon']  = 'box-bottom';
186
-		$defaults['row']   = array(
187
-			'key' => 'wrapper-padding',
188
-		);
189
-	} elseif ( $type == 'pl' ) {
190
-		$defaults['title'] = __( 'Padding left', 'super-duper' );
191
-		$defaults['icon']  = 'box-left';
192
-		$defaults['row']   = array(
193
-			'key'   => 'wrapper-padding',
194
-			'close' => true,
195
-
196
-		);
197
-	}
198
-
199
-	$input = wp_parse_args( $overwrite, $defaults );
200
-
201
-	return $input;
141
+    $options = array(
142
+        ''   => __( 'None', 'super-duper' ),
143
+        '0'  => '0',
144
+        '1'  => '1',
145
+        '2'  => '2',
146
+        '3'  => '3',
147
+        '4'  => '4',
148
+        '5'  => '5',
149
+        '6'  => '6',
150
+        '7'  => '7',
151
+        '8'  => '8',
152
+        '9'  => '9',
153
+        '10' => '10',
154
+        '11' => '11',
155
+        '12' => '12',
156
+    );
157
+
158
+    $defaults = array(
159
+        'type'     => 'select',
160
+        'title'    => __( 'Padding top', 'super-duper' ),
161
+        'options'  => $options,
162
+        'default'  => '',
163
+        'desc_tip' => true,
164
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
165
+    );
166
+
167
+    // title
168
+    if ( $type == 'pt' ) {
169
+        $defaults['title'] = __( 'Padding top', 'super-duper' );
170
+        $defaults['icon']  = 'box-top';
171
+        $defaults['row']   = array(
172
+            'title' => __( 'Padding', 'super-duper' ),
173
+            'key'   => 'wrapper-padding',
174
+            'open'  => true,
175
+            'class' => 'text-center',
176
+        );
177
+    } elseif ( $type == 'pr' ) {
178
+        $defaults['title'] = __( 'Padding right', 'super-duper' );
179
+        $defaults['icon']  = 'box-right';
180
+        $defaults['row']   = array(
181
+            'key' => 'wrapper-padding',
182
+        );
183
+    } elseif ( $type == 'pb' ) {
184
+        $defaults['title'] = __( 'Padding bottom', 'super-duper' );
185
+        $defaults['icon']  = 'box-bottom';
186
+        $defaults['row']   = array(
187
+            'key' => 'wrapper-padding',
188
+        );
189
+    } elseif ( $type == 'pl' ) {
190
+        $defaults['title'] = __( 'Padding left', 'super-duper' );
191
+        $defaults['icon']  = 'box-left';
192
+        $defaults['row']   = array(
193
+            'key'   => 'wrapper-padding',
194
+            'close' => true,
195
+
196
+        );
197
+    }
198
+
199
+    $input = wp_parse_args( $overwrite, $defaults );
200
+
201
+    return $input;
202 202
 }
203 203
 
204 204
 /**
@@ -210,97 +210,97 @@  discard block
 block discarded – undo
210 210
  * @return array
211 211
  */
212 212
 function sd_get_border_input( $type = 'border', $overwrite = array() ) {
213
-	global $aui_bs5;
214
-
215
-	$defaults = array(
216
-		'type'     => 'select',
217
-		'title'    => __( 'Border' ),
218
-		'options'  => array(),
219
-		'default'  => '',
220
-		'desc_tip' => true,
221
-		'group'    => __( 'Wrapper Styles', 'geodirectory' ),
222
-	);
223
-
224
-	// title
225
-	if ( 'rounded' === $type ) {
226
-		$defaults['title']           = __( 'Border radius type', 'super-duper' );
227
-		$defaults['options']         = array(
228
-			''               => __( 'Default', 'super-duper' ),
229
-			'rounded'        => 'rounded',
230
-			'rounded-top'    => 'rounded-top',
231
-			'rounded-right'  => 'rounded-right',
232
-			'rounded-bottom' => 'rounded-bottom',
233
-			'rounded-left'   => 'rounded-left',
234
-		);
235
-		$defaults['element_require'] = '[%border%]';
236
-	} elseif ( 'rounded_size' === $type ) {
237
-		$defaults['title'] = __( 'Border radius size', 'super-duper' );
238
-
239
-		if ( $aui_bs5 ) {
240
-			$defaults['options'] = array(
241
-				''       => __( 'Default', 'super-duper' ),
242
-				'0'      => '0',
243
-				'1'      => '1',
244
-				'2'      => '2',
245
-				'3'      => '3',
246
-				'4'      => '4',
247
-				'circle' => 'circle',
248
-				'pill'   => 'pill',
249
-			);
250
-		} else {
251
-			$defaults['options'] = array(
252
-				''   => __( 'Default', 'super-duper' ),
253
-				'sm' => __( 'Small', 'super-duper' ),
254
-				'lg' => __( 'Large', 'super-duper' ),
255
-			);
256
-		}
257
-		$defaults['element_require'] = '[%border%]';
258
-	} elseif ( 'width' === $type ) { // BS%
259
-		$defaults['title']           = __( 'Border width', 'super-duper' );
260
-		$defaults['options']         = array(
261
-			''         => __( 'Default', 'super-duper' ),
262
-			'border-2' => '2',
263
-			'border-3' => '3',
264
-			'border-4' => '4',
265
-			'border-5' => '5',
266
-		);
267
-		$defaults['element_require'] = $aui_bs5 ? '[%border%]' : '1==2';
268
-	} elseif ( 'opacity' === $type ) { // BS%
269
-		$defaults['title']           = __( 'Border opacity', 'super-duper' );
270
-		$defaults['options']         = array(
271
-			''                  => __( 'Default', 'super-duper' ),
272
-			'border-opacity-75' => '75%',
273
-			'border-opacity-50' => '50%',
274
-			'border-opacity-25' => '25%',
275
-			'border-opacity-10' => '10%',
276
-		);
277
-		$defaults['element_require'] = $aui_bs5 ? '[%border%]' : '1==2';
278
-	} elseif ( 'type' === $type ) {
279
-		$defaults['title']           = __( 'Border show', 'super-duper' );
280
-		$defaults['options']         = array(
281
-			'border'          => __( 'Full (set color to show)', 'super-duper' ),
282
-			'border-top'      => __( 'Top', 'super-duper' ),
283
-			'border-bottom'   => __( 'Bottom', 'super-duper' ),
284
-			'border-left'     => __( 'Left', 'super-duper' ),
285
-			'border-right'    => __( 'Right', 'super-duper' ),
286
-			'border-top-0'    => __( '-Top', 'super-duper' ),
287
-			'border-bottom-0' => __( '-Bottom', 'super-duper' ),
288
-			'border-left-0'   => __( '-Left', 'super-duper' ),
289
-			'border-right-0'  => __( '-Right', 'super-duper' ),
290
-		);
291
-		$defaults['element_require'] = '[%border%]';
292
-
293
-	} else {
294
-		$defaults['title']   = __( 'Border color' );
295
-		$defaults['options'] = array(
296
-			                       ''  => __( 'Default', 'super-duper' ),
297
-			                       '0' => __( 'None', 'super-duper' ),
298
-		                       ) + sd_aui_colors();
299
-	}
300
-
301
-	$input = wp_parse_args( $overwrite, $defaults );
302
-
303
-	return $input;
213
+    global $aui_bs5;
214
+
215
+    $defaults = array(
216
+        'type'     => 'select',
217
+        'title'    => __( 'Border' ),
218
+        'options'  => array(),
219
+        'default'  => '',
220
+        'desc_tip' => true,
221
+        'group'    => __( 'Wrapper Styles', 'geodirectory' ),
222
+    );
223
+
224
+    // title
225
+    if ( 'rounded' === $type ) {
226
+        $defaults['title']           = __( 'Border radius type', 'super-duper' );
227
+        $defaults['options']         = array(
228
+            ''               => __( 'Default', 'super-duper' ),
229
+            'rounded'        => 'rounded',
230
+            'rounded-top'    => 'rounded-top',
231
+            'rounded-right'  => 'rounded-right',
232
+            'rounded-bottom' => 'rounded-bottom',
233
+            'rounded-left'   => 'rounded-left',
234
+        );
235
+        $defaults['element_require'] = '[%border%]';
236
+    } elseif ( 'rounded_size' === $type ) {
237
+        $defaults['title'] = __( 'Border radius size', 'super-duper' );
238
+
239
+        if ( $aui_bs5 ) {
240
+            $defaults['options'] = array(
241
+                ''       => __( 'Default', 'super-duper' ),
242
+                '0'      => '0',
243
+                '1'      => '1',
244
+                '2'      => '2',
245
+                '3'      => '3',
246
+                '4'      => '4',
247
+                'circle' => 'circle',
248
+                'pill'   => 'pill',
249
+            );
250
+        } else {
251
+            $defaults['options'] = array(
252
+                ''   => __( 'Default', 'super-duper' ),
253
+                'sm' => __( 'Small', 'super-duper' ),
254
+                'lg' => __( 'Large', 'super-duper' ),
255
+            );
256
+        }
257
+        $defaults['element_require'] = '[%border%]';
258
+    } elseif ( 'width' === $type ) { // BS%
259
+        $defaults['title']           = __( 'Border width', 'super-duper' );
260
+        $defaults['options']         = array(
261
+            ''         => __( 'Default', 'super-duper' ),
262
+            'border-2' => '2',
263
+            'border-3' => '3',
264
+            'border-4' => '4',
265
+            'border-5' => '5',
266
+        );
267
+        $defaults['element_require'] = $aui_bs5 ? '[%border%]' : '1==2';
268
+    } elseif ( 'opacity' === $type ) { // BS%
269
+        $defaults['title']           = __( 'Border opacity', 'super-duper' );
270
+        $defaults['options']         = array(
271
+            ''                  => __( 'Default', 'super-duper' ),
272
+            'border-opacity-75' => '75%',
273
+            'border-opacity-50' => '50%',
274
+            'border-opacity-25' => '25%',
275
+            'border-opacity-10' => '10%',
276
+        );
277
+        $defaults['element_require'] = $aui_bs5 ? '[%border%]' : '1==2';
278
+    } elseif ( 'type' === $type ) {
279
+        $defaults['title']           = __( 'Border show', 'super-duper' );
280
+        $defaults['options']         = array(
281
+            'border'          => __( 'Full (set color to show)', 'super-duper' ),
282
+            'border-top'      => __( 'Top', 'super-duper' ),
283
+            'border-bottom'   => __( 'Bottom', 'super-duper' ),
284
+            'border-left'     => __( 'Left', 'super-duper' ),
285
+            'border-right'    => __( 'Right', 'super-duper' ),
286
+            'border-top-0'    => __( '-Top', 'super-duper' ),
287
+            'border-bottom-0' => __( '-Bottom', 'super-duper' ),
288
+            'border-left-0'   => __( '-Left', 'super-duper' ),
289
+            'border-right-0'  => __( '-Right', 'super-duper' ),
290
+        );
291
+        $defaults['element_require'] = '[%border%]';
292
+
293
+    } else {
294
+        $defaults['title']   = __( 'Border color' );
295
+        $defaults['options'] = array(
296
+                                    ''  => __( 'Default', 'super-duper' ),
297
+                                    '0' => __( 'None', 'super-duper' ),
298
+                                ) + sd_aui_colors();
299
+    }
300
+
301
+    $input = wp_parse_args( $overwrite, $defaults );
302
+
303
+    return $input;
304 304
 }
305 305
 
306 306
 /**
@@ -312,25 +312,25 @@  discard block
 block discarded – undo
312 312
  * @return array
313 313
  */
314 314
 function sd_get_shadow_input( $type = 'shadow', $overwrite = array() ) {
315
-	$options = array(
316
-		''          => __( 'None', 'super-duper' ),
317
-		'shadow-sm' => __( 'Small', 'super-duper' ),
318
-		'shadow'    => __( 'Regular', 'super-duper' ),
319
-		'shadow-lg' => __( 'Large', 'super-duper' ),
320
-	);
321
-
322
-	$defaults = array(
323
-		'type'     => 'select',
324
-		'title'    => __( 'Shadow', 'super-duper' ),
325
-		'options'  => $options,
326
-		'default'  => '',
327
-		'desc_tip' => true,
328
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
329
-	);
330
-
331
-	$input = wp_parse_args( $overwrite, $defaults );
332
-
333
-	return $input;
315
+    $options = array(
316
+        ''          => __( 'None', 'super-duper' ),
317
+        'shadow-sm' => __( 'Small', 'super-duper' ),
318
+        'shadow'    => __( 'Regular', 'super-duper' ),
319
+        'shadow-lg' => __( 'Large', 'super-duper' ),
320
+    );
321
+
322
+    $defaults = array(
323
+        'type'     => 'select',
324
+        'title'    => __( 'Shadow', 'super-duper' ),
325
+        'options'  => $options,
326
+        'default'  => '',
327
+        'desc_tip' => true,
328
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
329
+    );
330
+
331
+    $input = wp_parse_args( $overwrite, $defaults );
332
+
333
+    return $input;
334 334
 }
335 335
 
336 336
 /**
@@ -342,23 +342,23 @@  discard block
 block discarded – undo
342 342
  * @return array
343 343
  */
344 344
 function sd_get_background_input( $type = 'bg', $overwrite = array() ) {
345
-	$options = array(
346
-		           ''            => __( 'None', 'super-duper' ),
347
-		           'transparent' => __( 'Transparent', 'super-duper' ),
348
-	           ) + sd_aui_colors();
349
-
350
-	$defaults = array(
351
-		'type'     => 'select',
352
-		'title'    => __( 'Background color', 'super-duper' ),
353
-		'options'  => $options,
354
-		'default'  => '',
355
-		'desc_tip' => true,
356
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
357
-	);
358
-
359
-	$input = wp_parse_args( $overwrite, $defaults );
360
-
361
-	return $input;
345
+    $options = array(
346
+                    ''            => __( 'None', 'super-duper' ),
347
+                    'transparent' => __( 'Transparent', 'super-duper' ),
348
+                ) + sd_aui_colors();
349
+
350
+    $defaults = array(
351
+        'type'     => 'select',
352
+        'title'    => __( 'Background color', 'super-duper' ),
353
+        'options'  => $options,
354
+        'default'  => '',
355
+        'desc_tip' => true,
356
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
357
+    );
358
+
359
+    $input = wp_parse_args( $overwrite, $defaults );
360
+
361
+    return $input;
362 362
 }
363 363
 
364 364
 /**
@@ -370,35 +370,35 @@  discard block
 block discarded – undo
370 370
  * @return array
371 371
  */
372 372
 function sd_get_opacity_input( $type = 'opacity', $overwrite = array() ) {
373
-	$options = array(
374
-		''            => __( 'Default', 'super-duper' ),
375
-		'opacity-10'  => '10%',
376
-		'opacity-15'  => '15%',
377
-		'opacity-25'  => '25%',
378
-		'opacity-35'  => '35%',
379
-		'opacity-40'  => '40%',
380
-		'opacity-50'  => '50%',
381
-		'opacity-60'  => '60%',
382
-		'opacity-65'  => '65%',
383
-		'opacity-70'  => '70%',
384
-		'opacity-75'  => '75%',
385
-		'opacity-80'  => '80%',
386
-		'opacity-90'  => '90%',
387
-		'opacity-100' => '100%',
388
-	);
389
-
390
-	$defaults = array(
391
-		'type'     => 'select',
392
-		'title'    => __( 'Opacity', 'super-duper' ),
393
-		'options'  => $options,
394
-		'default'  => '',
395
-		'desc_tip' => true,
396
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
397
-	);
398
-
399
-	$input = wp_parse_args( $overwrite, $defaults );
400
-
401
-	return $input;
373
+    $options = array(
374
+        ''            => __( 'Default', 'super-duper' ),
375
+        'opacity-10'  => '10%',
376
+        'opacity-15'  => '15%',
377
+        'opacity-25'  => '25%',
378
+        'opacity-35'  => '35%',
379
+        'opacity-40'  => '40%',
380
+        'opacity-50'  => '50%',
381
+        'opacity-60'  => '60%',
382
+        'opacity-65'  => '65%',
383
+        'opacity-70'  => '70%',
384
+        'opacity-75'  => '75%',
385
+        'opacity-80'  => '80%',
386
+        'opacity-90'  => '90%',
387
+        'opacity-100' => '100%',
388
+    );
389
+
390
+    $defaults = array(
391
+        'type'     => 'select',
392
+        'title'    => __( 'Opacity', 'super-duper' ),
393
+        'options'  => $options,
394
+        'default'  => '',
395
+        'desc_tip' => true,
396
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
397
+    );
398
+
399
+    $input = wp_parse_args( $overwrite, $defaults );
400
+
401
+    return $input;
402 402
 }
403 403
 
404 404
 /**
@@ -411,124 +411,124 @@  discard block
 block discarded – undo
411 411
  */
412 412
 function sd_get_background_inputs( $type = 'bg', $overwrite = array(), $overwrite_color = array(), $overwrite_gradient = array(), $overwrite_image = array(), $include_button_colors = false ) {
413 413
 
414
-	$color_options = $include_button_colors ? sd_aui_colors( false, true, true, true ) : sd_aui_colors();
415
-
416
-	$options = array(
417
-		           ''            => __( 'None', 'super-duper' ),
418
-		           'transparent' => __( 'Transparent', 'super-duper' ),
419
-	           ) + $color_options;
420
-
421
-	if ( false !== $overwrite_color ) {
422
-		$options['custom-color'] = __( 'Custom Color', 'super-duper' );
423
-	}
424
-
425
-	if ( false !== $overwrite_gradient ) {
426
-		$options['custom-gradient'] = __( 'Custom Gradient', 'super-duper' );
427
-	}
428
-
429
-	$defaults = array(
430
-		'type'     => 'select',
431
-		'title'    => __( 'Background Color', 'super-duper' ),
432
-		'options'  => $options,
433
-		'default'  => '',
434
-		'desc_tip' => true,
435
-		'group'    => __( 'Background', 'super-duper' ),
436
-	);
437
-
438
-	if ( $overwrite !== false ) {
439
-		$input[ $type ] = wp_parse_args( $overwrite, $defaults );
440
-	}
441
-
442
-	if ( $overwrite_color !== false ) {
443
-		$input[ $type . '_color' ] = wp_parse_args(
444
-			$overwrite_color,
445
-			array(
446
-				'type'            => 'color',
447
-				'title'           => __( 'Custom color', 'super-duper' ),
448
-				'placeholder'     => '',
449
-				'default'         => '#0073aa',
450
-				'desc_tip'        => true,
451
-				'group'           => __( 'Background', 'super-duper' ),
452
-				'element_require' => '[%' . $type . '%]=="custom-color"',
453
-			)
454
-		);
455
-	}
456
-
457
-	if ( $overwrite_gradient !== false ) {
458
-		$input[ $type . '_gradient' ] = wp_parse_args(
459
-			$overwrite_gradient,
460
-			array(
461
-				'type'            => 'gradient',
462
-				'title'           => __( 'Custom gradient', 'super-duper' ),
463
-				'placeholder'     => '',
464
-				'default'         => 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
465
-				'desc_tip'        => true,
466
-				'group'           => __( 'Background', 'super-duper' ),
467
-				'element_require' => '[%' . $type . '%]=="custom-gradient"',
468
-			)
469
-		);
470
-	}
471
-
472
-	if ( $overwrite_image !== false ) {
473
-
474
-		$input[ $type . '_image_fixed' ] = array(
475
-			'type'            => 'checkbox',
476
-			'title'           => __( 'Fixed background', 'super-duper' ),
477
-			'default'         => '',
478
-			'desc_tip'        => true,
479
-			'group'           => ! empty( $overwrite_image['group'] ) ? $overwrite_image['group'] : __( 'Background' ),
480
-			'element_require' => '( [%' . $type . '%]=="" || [%' . $type . '%]=="custom-color" || [%' . $type . '%]=="custom-gradient" || [%' . $type . '%]=="transparent" )',
481
-
482
-		);
483
-
484
-		$input[ $type . '_image_use_featured' ] = array(
485
-			'type'            => 'checkbox',
486
-			'title'           => __( 'Use featured image', 'super-duper' ),
487
-			'default'         => '',
488
-			'desc_tip'        => true,
489
-			'group'           => ! empty( $overwrite_image['group'] ) ? $overwrite_image['group'] : __( 'Background', 'super-duper' ),
490
-			'element_require' => '( [%' . $type . '%]=="" || [%' . $type . '%]=="custom-color" || [%' . $type . '%]=="custom-gradient" || [%' . $type . '%]=="transparent" )',
491
-
492
-		);
493
-
494
-		$input[ $type . '_image' ] = wp_parse_args(
495
-			$overwrite_image,
496
-			array(
497
-				'type'        => 'image',
498
-				'title'       => __( 'Custom image', 'super-duper' ),
499
-				'placeholder' => '',
500
-				'default'     => '',
501
-				'desc_tip'    => true,
502
-				'group'       => __( 'Background', 'super-duper' ),
503
-				//          'element_require' => ' ![%' . $type . '_image_use_featured%] '
504
-			)
505
-		);
506
-
507
-		$input[ $type . '_image_id' ] = wp_parse_args(
508
-			$overwrite_image,
509
-			array(
510
-				'type'        => 'hidden',
511
-				'hidden_type' => 'number',
512
-				'title'       => '',
513
-				'placeholder' => '',
514
-				'default'     => '',
515
-				'group'       => __( 'Background', 'super-duper' ),
516
-			)
517
-		);
518
-
519
-		$input[ $type . '_image_xy' ] = wp_parse_args(
520
-			$overwrite_image,
521
-			array(
522
-				'type'        => 'image_xy',
523
-				'title'       => '',
524
-				'placeholder' => '',
525
-				'default'     => '',
526
-				'group'       => __( 'Background', 'super-duper' ),
527
-			)
528
-		);
529
-	}
530
-
531
-	return $input;
414
+    $color_options = $include_button_colors ? sd_aui_colors( false, true, true, true ) : sd_aui_colors();
415
+
416
+    $options = array(
417
+                    ''            => __( 'None', 'super-duper' ),
418
+                    'transparent' => __( 'Transparent', 'super-duper' ),
419
+                ) + $color_options;
420
+
421
+    if ( false !== $overwrite_color ) {
422
+        $options['custom-color'] = __( 'Custom Color', 'super-duper' );
423
+    }
424
+
425
+    if ( false !== $overwrite_gradient ) {
426
+        $options['custom-gradient'] = __( 'Custom Gradient', 'super-duper' );
427
+    }
428
+
429
+    $defaults = array(
430
+        'type'     => 'select',
431
+        'title'    => __( 'Background Color', 'super-duper' ),
432
+        'options'  => $options,
433
+        'default'  => '',
434
+        'desc_tip' => true,
435
+        'group'    => __( 'Background', 'super-duper' ),
436
+    );
437
+
438
+    if ( $overwrite !== false ) {
439
+        $input[ $type ] = wp_parse_args( $overwrite, $defaults );
440
+    }
441
+
442
+    if ( $overwrite_color !== false ) {
443
+        $input[ $type . '_color' ] = wp_parse_args(
444
+            $overwrite_color,
445
+            array(
446
+                'type'            => 'color',
447
+                'title'           => __( 'Custom color', 'super-duper' ),
448
+                'placeholder'     => '',
449
+                'default'         => '#0073aa',
450
+                'desc_tip'        => true,
451
+                'group'           => __( 'Background', 'super-duper' ),
452
+                'element_require' => '[%' . $type . '%]=="custom-color"',
453
+            )
454
+        );
455
+    }
456
+
457
+    if ( $overwrite_gradient !== false ) {
458
+        $input[ $type . '_gradient' ] = wp_parse_args(
459
+            $overwrite_gradient,
460
+            array(
461
+                'type'            => 'gradient',
462
+                'title'           => __( 'Custom gradient', 'super-duper' ),
463
+                'placeholder'     => '',
464
+                'default'         => 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
465
+                'desc_tip'        => true,
466
+                'group'           => __( 'Background', 'super-duper' ),
467
+                'element_require' => '[%' . $type . '%]=="custom-gradient"',
468
+            )
469
+        );
470
+    }
471
+
472
+    if ( $overwrite_image !== false ) {
473
+
474
+        $input[ $type . '_image_fixed' ] = array(
475
+            'type'            => 'checkbox',
476
+            'title'           => __( 'Fixed background', 'super-duper' ),
477
+            'default'         => '',
478
+            'desc_tip'        => true,
479
+            'group'           => ! empty( $overwrite_image['group'] ) ? $overwrite_image['group'] : __( 'Background' ),
480
+            'element_require' => '( [%' . $type . '%]=="" || [%' . $type . '%]=="custom-color" || [%' . $type . '%]=="custom-gradient" || [%' . $type . '%]=="transparent" )',
481
+
482
+        );
483
+
484
+        $input[ $type . '_image_use_featured' ] = array(
485
+            'type'            => 'checkbox',
486
+            'title'           => __( 'Use featured image', 'super-duper' ),
487
+            'default'         => '',
488
+            'desc_tip'        => true,
489
+            'group'           => ! empty( $overwrite_image['group'] ) ? $overwrite_image['group'] : __( 'Background', 'super-duper' ),
490
+            'element_require' => '( [%' . $type . '%]=="" || [%' . $type . '%]=="custom-color" || [%' . $type . '%]=="custom-gradient" || [%' . $type . '%]=="transparent" )',
491
+
492
+        );
493
+
494
+        $input[ $type . '_image' ] = wp_parse_args(
495
+            $overwrite_image,
496
+            array(
497
+                'type'        => 'image',
498
+                'title'       => __( 'Custom image', 'super-duper' ),
499
+                'placeholder' => '',
500
+                'default'     => '',
501
+                'desc_tip'    => true,
502
+                'group'       => __( 'Background', 'super-duper' ),
503
+                //          'element_require' => ' ![%' . $type . '_image_use_featured%] '
504
+            )
505
+        );
506
+
507
+        $input[ $type . '_image_id' ] = wp_parse_args(
508
+            $overwrite_image,
509
+            array(
510
+                'type'        => 'hidden',
511
+                'hidden_type' => 'number',
512
+                'title'       => '',
513
+                'placeholder' => '',
514
+                'default'     => '',
515
+                'group'       => __( 'Background', 'super-duper' ),
516
+            )
517
+        );
518
+
519
+        $input[ $type . '_image_xy' ] = wp_parse_args(
520
+            $overwrite_image,
521
+            array(
522
+                'type'        => 'image_xy',
523
+                'title'       => '',
524
+                'placeholder' => '',
525
+                'default'     => '',
526
+                'group'       => __( 'Background', 'super-duper' ),
527
+            )
528
+        );
529
+    }
530
+
531
+    return $input;
532 532
 }
533 533
 
534 534
 /**
@@ -541,175 +541,175 @@  discard block
 block discarded – undo
541 541
  */
542 542
 function sd_get_shape_divider_inputs( $type = 'sd', $overwrite = array(), $overwrite_color = array(), $overwrite_gradient = array(), $overwrite_image = array() ) {
543 543
 
544
-	$options = array(
545
-		''                      => __( 'None', 'super-duper' ),
546
-		'mountains'             => __( 'Mountains', 'super-duper' ),
547
-		'drops'                 => __( 'Drops', 'super-duper' ),
548
-		'clouds'                => __( 'Clouds', 'super-duper' ),
549
-		'zigzag'                => __( 'Zigzag', 'super-duper' ),
550
-		'pyramids'              => __( 'Pyramids', 'super-duper' ),
551
-		'triangle'              => __( 'Triangle', 'super-duper' ),
552
-		'triangle-asymmetrical' => __( 'Triangle Asymmetrical', 'super-duper' ),
553
-		'tilt'                  => __( 'Tilt', 'super-duper' ),
554
-		'opacity-tilt'          => __( 'Opacity Tilt', 'super-duper' ),
555
-		'opacity-fan'           => __( 'Opacity Fan', 'super-duper' ),
556
-		'curve'                 => __( 'Curve', 'super-duper' ),
557
-		'curve-asymmetrical'    => __( 'Curve Asymmetrical', 'super-duper' ),
558
-		'waves'                 => __( 'Waves', 'super-duper' ),
559
-		'wave-brush'            => __( 'Wave Brush', 'super-duper' ),
560
-		'waves-pattern'         => __( 'Waves Pattern', 'super-duper' ),
561
-		'arrow'                 => __( 'Arrow', 'super-duper' ),
562
-		'split'                 => __( 'Split', 'super-duper' ),
563
-		'book'                  => __( 'Book', 'super-duper' ),
564
-	);
565
-
566
-	$defaults = array(
567
-		'type'     => 'select',
568
-		'title'    => __( 'Type', 'super-duper' ),
569
-		'options'  => $options,
570
-		'default'  => '',
571
-		'desc_tip' => true,
572
-		'group'    => __( 'Shape Divider', 'super-duper' ),
573
-	);
574
-
575
-	$input[ $type ] = wp_parse_args( $overwrite, $defaults );
576
-
577
-	$input[ $type . '_notice' ] = array(
578
-		'type'            => 'notice',
579
-		'desc'            => __( 'Parent element must be position `relative`', 'super-duper' ),
580
-		'status'          => 'warning',
581
-		'group'           => __( 'Shape Divider', 'super-duper' ),
582
-		'element_require' => '[%' . $type . '%]!=""',
583
-	);
584
-
585
-	$input[ $type . '_position' ] = wp_parse_args(
586
-		$overwrite_color,
587
-		array(
588
-			'type'            => 'select',
589
-			'title'           => __( 'Position', 'super-duper' ),
590
-			'options'         => array(
591
-				'top'    => __( 'Top', 'super-duper' ),
592
-				'bottom' => __( 'Bottom', 'super-duper' ),
593
-			),
594
-			'desc_tip'        => true,
595
-			'group'           => __( 'Shape Divider', 'super-duper' ),
596
-			'element_require' => '[%' . $type . '%]!=""',
597
-		)
598
-	);
599
-
600
-	$options = array(
601
-		           ''            => __( 'None', 'super-duper' ),
602
-		           'transparent' => __( 'Transparent', 'super-duper' ),
603
-	           ) + sd_aui_colors()
604
-	           + array(
605
-		           'custom-color' => __( 'Custom Color', 'super-duper' ),
606
-	           );
607
-
608
-	$input[ $type . '_color' ] = wp_parse_args(
609
-		$overwrite_color,
610
-		array(
611
-			'type'            => 'select',
612
-			'title'           => __( 'Color', 'super-duper' ),
613
-			'options'         => $options,
614
-			'desc_tip'        => true,
615
-			'group'           => __( 'Shape Divider', 'super-duper' ),
616
-			'element_require' => '[%' . $type . '%]!=""',
617
-		)
618
-	);
619
-
620
-	$input[ $type . '_custom_color' ] = wp_parse_args(
621
-		$overwrite_color,
622
-		array(
623
-			'type'            => 'color',
624
-			'title'           => __( 'Custom color', 'super-duper' ),
625
-			'placeholder'     => '',
626
-			'default'         => '#0073aa',
627
-			'desc_tip'        => true,
628
-			'group'           => __( 'Shape Divider', 'super-duper' ),
629
-			'element_require' => '[%' . $type . '_color%]=="custom-color" && [%' . $type . '%]!=""',
630
-		)
631
-	);
632
-
633
-	$input[ $type . '_width' ] = wp_parse_args(
634
-		$overwrite_gradient,
635
-		array(
636
-			'type'              => 'range',
637
-			'title'             => __( 'Width', 'super-duper' ),
638
-			'placeholder'       => '',
639
-			'default'           => '200',
640
-			'desc_tip'          => true,
641
-			'custom_attributes' => array(
642
-				'min' => 100,
643
-				'max' => 300,
644
-			),
645
-			'group'             => __( 'Shape Divider', 'super-duper' ),
646
-			'element_require'   => '[%' . $type . '%]!=""',
647
-		)
648
-	);
649
-
650
-	$input[ $type . '_height' ] = array(
651
-		'type'              => 'range',
652
-		'title'             => __( 'Height', 'super-duper' ),
653
-		'default'           => '100',
654
-		'desc_tip'          => true,
655
-		'custom_attributes' => array(
656
-			'min' => 0,
657
-			'max' => 500,
658
-		),
659
-		'group'             => __( 'Shape Divider', 'super-duper' ),
660
-		'element_require'   => '[%' . $type . '%]!=""',
661
-	);
662
-
663
-	$requires = array(
664
-		'mountains'             => array( 'flip' ),
665
-		'drops'                 => array( 'flip', 'invert' ),
666
-		'clouds'                => array( 'flip', 'invert' ),
667
-		'zigzag'                => array(),
668
-		'pyramids'              => array( 'flip', 'invert' ),
669
-		'triangle'              => array( 'invert' ),
670
-		'triangle-asymmetrical' => array( 'flip', 'invert' ),
671
-		'tilt'                  => array( 'flip' ),
672
-		'opacity-tilt'          => array( 'flip' ),
673
-		'opacity-fan'           => array(),
674
-		'curve'                 => array( 'invert' ),
675
-		'curve-asymmetrical'    => array( 'flip', 'invert' ),
676
-		'waves'                 => array( 'flip', 'invert' ),
677
-		'wave-brush'            => array( 'flip' ),
678
-		'waves-pattern'         => array( 'flip' ),
679
-		'arrow'                 => array( 'invert' ),
680
-		'split'                 => array( 'invert' ),
681
-		'book'                  => array( 'invert' ),
682
-	);
683
-
684
-	$input[ $type . '_flip' ] = array(
685
-		'type'            => 'checkbox',
686
-		'title'           => __( 'Flip', 'super-duper' ),
687
-		'default'         => '',
688
-		'desc_tip'        => true,
689
-		'group'           => __( 'Shape Divider', 'super-duper' ),
690
-		'element_require' => sd_get_element_require_string( $requires, 'flip', 'sd' ),
691
-	);
692
-
693
-	$input[ $type . '_invert' ] = array(
694
-		'type'            => 'checkbox',
695
-		'title'           => __( 'Invert', 'super-duper' ),
696
-		'default'         => '',
697
-		'desc_tip'        => true,
698
-		'group'           => __( 'Shape Divider', 'super-duper' ),
699
-		'element_require' => sd_get_element_require_string( $requires, 'invert', 'sd' ),
700
-	);
701
-
702
-	$input[ $type . '_btf' ] = array(
703
-		'type'            => 'checkbox',
704
-		'title'           => __( 'Bring to front', 'super-duper' ),
705
-		'default'         => '',
706
-		'desc_tip'        => true,
707
-		'group'           => __( 'Shape Divider', 'super-duper' ),
708
-		'element_require' => '[%' . $type . '%]!=""',
709
-
710
-	);
711
-
712
-	return $input;
544
+    $options = array(
545
+        ''                      => __( 'None', 'super-duper' ),
546
+        'mountains'             => __( 'Mountains', 'super-duper' ),
547
+        'drops'                 => __( 'Drops', 'super-duper' ),
548
+        'clouds'                => __( 'Clouds', 'super-duper' ),
549
+        'zigzag'                => __( 'Zigzag', 'super-duper' ),
550
+        'pyramids'              => __( 'Pyramids', 'super-duper' ),
551
+        'triangle'              => __( 'Triangle', 'super-duper' ),
552
+        'triangle-asymmetrical' => __( 'Triangle Asymmetrical', 'super-duper' ),
553
+        'tilt'                  => __( 'Tilt', 'super-duper' ),
554
+        'opacity-tilt'          => __( 'Opacity Tilt', 'super-duper' ),
555
+        'opacity-fan'           => __( 'Opacity Fan', 'super-duper' ),
556
+        'curve'                 => __( 'Curve', 'super-duper' ),
557
+        'curve-asymmetrical'    => __( 'Curve Asymmetrical', 'super-duper' ),
558
+        'waves'                 => __( 'Waves', 'super-duper' ),
559
+        'wave-brush'            => __( 'Wave Brush', 'super-duper' ),
560
+        'waves-pattern'         => __( 'Waves Pattern', 'super-duper' ),
561
+        'arrow'                 => __( 'Arrow', 'super-duper' ),
562
+        'split'                 => __( 'Split', 'super-duper' ),
563
+        'book'                  => __( 'Book', 'super-duper' ),
564
+    );
565
+
566
+    $defaults = array(
567
+        'type'     => 'select',
568
+        'title'    => __( 'Type', 'super-duper' ),
569
+        'options'  => $options,
570
+        'default'  => '',
571
+        'desc_tip' => true,
572
+        'group'    => __( 'Shape Divider', 'super-duper' ),
573
+    );
574
+
575
+    $input[ $type ] = wp_parse_args( $overwrite, $defaults );
576
+
577
+    $input[ $type . '_notice' ] = array(
578
+        'type'            => 'notice',
579
+        'desc'            => __( 'Parent element must be position `relative`', 'super-duper' ),
580
+        'status'          => 'warning',
581
+        'group'           => __( 'Shape Divider', 'super-duper' ),
582
+        'element_require' => '[%' . $type . '%]!=""',
583
+    );
584
+
585
+    $input[ $type . '_position' ] = wp_parse_args(
586
+        $overwrite_color,
587
+        array(
588
+            'type'            => 'select',
589
+            'title'           => __( 'Position', 'super-duper' ),
590
+            'options'         => array(
591
+                'top'    => __( 'Top', 'super-duper' ),
592
+                'bottom' => __( 'Bottom', 'super-duper' ),
593
+            ),
594
+            'desc_tip'        => true,
595
+            'group'           => __( 'Shape Divider', 'super-duper' ),
596
+            'element_require' => '[%' . $type . '%]!=""',
597
+        )
598
+    );
599
+
600
+    $options = array(
601
+                    ''            => __( 'None', 'super-duper' ),
602
+                    'transparent' => __( 'Transparent', 'super-duper' ),
603
+                ) + sd_aui_colors()
604
+               + array(
605
+                    'custom-color' => __( 'Custom Color', 'super-duper' ),
606
+                );
607
+
608
+    $input[ $type . '_color' ] = wp_parse_args(
609
+        $overwrite_color,
610
+        array(
611
+            'type'            => 'select',
612
+            'title'           => __( 'Color', 'super-duper' ),
613
+            'options'         => $options,
614
+            'desc_tip'        => true,
615
+            'group'           => __( 'Shape Divider', 'super-duper' ),
616
+            'element_require' => '[%' . $type . '%]!=""',
617
+        )
618
+    );
619
+
620
+    $input[ $type . '_custom_color' ] = wp_parse_args(
621
+        $overwrite_color,
622
+        array(
623
+            'type'            => 'color',
624
+            'title'           => __( 'Custom color', 'super-duper' ),
625
+            'placeholder'     => '',
626
+            'default'         => '#0073aa',
627
+            'desc_tip'        => true,
628
+            'group'           => __( 'Shape Divider', 'super-duper' ),
629
+            'element_require' => '[%' . $type . '_color%]=="custom-color" && [%' . $type . '%]!=""',
630
+        )
631
+    );
632
+
633
+    $input[ $type . '_width' ] = wp_parse_args(
634
+        $overwrite_gradient,
635
+        array(
636
+            'type'              => 'range',
637
+            'title'             => __( 'Width', 'super-duper' ),
638
+            'placeholder'       => '',
639
+            'default'           => '200',
640
+            'desc_tip'          => true,
641
+            'custom_attributes' => array(
642
+                'min' => 100,
643
+                'max' => 300,
644
+            ),
645
+            'group'             => __( 'Shape Divider', 'super-duper' ),
646
+            'element_require'   => '[%' . $type . '%]!=""',
647
+        )
648
+    );
649
+
650
+    $input[ $type . '_height' ] = array(
651
+        'type'              => 'range',
652
+        'title'             => __( 'Height', 'super-duper' ),
653
+        'default'           => '100',
654
+        'desc_tip'          => true,
655
+        'custom_attributes' => array(
656
+            'min' => 0,
657
+            'max' => 500,
658
+        ),
659
+        'group'             => __( 'Shape Divider', 'super-duper' ),
660
+        'element_require'   => '[%' . $type . '%]!=""',
661
+    );
662
+
663
+    $requires = array(
664
+        'mountains'             => array( 'flip' ),
665
+        'drops'                 => array( 'flip', 'invert' ),
666
+        'clouds'                => array( 'flip', 'invert' ),
667
+        'zigzag'                => array(),
668
+        'pyramids'              => array( 'flip', 'invert' ),
669
+        'triangle'              => array( 'invert' ),
670
+        'triangle-asymmetrical' => array( 'flip', 'invert' ),
671
+        'tilt'                  => array( 'flip' ),
672
+        'opacity-tilt'          => array( 'flip' ),
673
+        'opacity-fan'           => array(),
674
+        'curve'                 => array( 'invert' ),
675
+        'curve-asymmetrical'    => array( 'flip', 'invert' ),
676
+        'waves'                 => array( 'flip', 'invert' ),
677
+        'wave-brush'            => array( 'flip' ),
678
+        'waves-pattern'         => array( 'flip' ),
679
+        'arrow'                 => array( 'invert' ),
680
+        'split'                 => array( 'invert' ),
681
+        'book'                  => array( 'invert' ),
682
+    );
683
+
684
+    $input[ $type . '_flip' ] = array(
685
+        'type'            => 'checkbox',
686
+        'title'           => __( 'Flip', 'super-duper' ),
687
+        'default'         => '',
688
+        'desc_tip'        => true,
689
+        'group'           => __( 'Shape Divider', 'super-duper' ),
690
+        'element_require' => sd_get_element_require_string( $requires, 'flip', 'sd' ),
691
+    );
692
+
693
+    $input[ $type . '_invert' ] = array(
694
+        'type'            => 'checkbox',
695
+        'title'           => __( 'Invert', 'super-duper' ),
696
+        'default'         => '',
697
+        'desc_tip'        => true,
698
+        'group'           => __( 'Shape Divider', 'super-duper' ),
699
+        'element_require' => sd_get_element_require_string( $requires, 'invert', 'sd' ),
700
+    );
701
+
702
+    $input[ $type . '_btf' ] = array(
703
+        'type'            => 'checkbox',
704
+        'title'           => __( 'Bring to front', 'super-duper' ),
705
+        'default'         => '',
706
+        'desc_tip'        => true,
707
+        'group'           => __( 'Shape Divider', 'super-duper' ),
708
+        'element_require' => '[%' . $type . '%]!=""',
709
+
710
+    );
711
+
712
+    return $input;
713 713
 }
714 714
 
715 715
 /**
@@ -722,22 +722,22 @@  discard block
 block discarded – undo
722 722
  * @return string
723 723
  */
724 724
 function sd_get_element_require_string( $args, $key, $type ) {
725
-	$output   = '';
726
-	$requires = array();
727
-
728
-	if ( ! empty( $args ) ) {
729
-		foreach ( $args as $t => $k ) {
730
-			if ( in_array( $key, $k ) ) {
731
-				$requires[] = '[%' . $type . '%]=="' . $t . '"';
732
-			}
733
-		}
734
-
735
-		if ( ! empty( $requires ) ) {
736
-			$output = '(' . implode( ' || ', $requires ) . ')';
737
-		}
738
-	}
739
-
740
-	return $output;
725
+    $output   = '';
726
+    $requires = array();
727
+
728
+    if ( ! empty( $args ) ) {
729
+        foreach ( $args as $t => $k ) {
730
+            if ( in_array( $key, $k ) ) {
731
+                $requires[] = '[%' . $type . '%]=="' . $t . '"';
732
+            }
733
+        }
734
+
735
+        if ( ! empty( $requires ) ) {
736
+            $output = '(' . implode( ' || ', $requires ) . ')';
737
+        }
738
+    }
739
+
740
+    return $output;
741 741
 }
742 742
 
743 743
 /**
@@ -749,41 +749,41 @@  discard block
 block discarded – undo
749 749
  * @return array
750 750
  */
751 751
 function sd_get_text_color_input( $type = 'text_color', $overwrite = array(), $has_custom = false ) {
752
-	$options = array(
753
-		           '' => __( 'None', 'super-duper' ),
754
-	           ) + sd_aui_colors();
755
-
756
-	if ( $has_custom ) {
757
-		$options['custom'] = __( 'Custom color', 'super-duper' );
758
-	}
759
-
760
-	$defaults = array(
761
-		'type'     => 'select',
762
-		'title'    => __( 'Text color', 'super-duper' ),
763
-		'options'  => $options,
764
-		'default'  => '',
765
-		'desc_tip' => true,
766
-		'group'    => __( 'Typography', 'super-duper' ),
767
-	);
768
-
769
-	$input = wp_parse_args( $overwrite, $defaults );
770
-
771
-	return $input;
752
+    $options = array(
753
+                    '' => __( 'None', 'super-duper' ),
754
+                ) + sd_aui_colors();
755
+
756
+    if ( $has_custom ) {
757
+        $options['custom'] = __( 'Custom color', 'super-duper' );
758
+    }
759
+
760
+    $defaults = array(
761
+        'type'     => 'select',
762
+        'title'    => __( 'Text color', 'super-duper' ),
763
+        'options'  => $options,
764
+        'default'  => '',
765
+        'desc_tip' => true,
766
+        'group'    => __( 'Typography', 'super-duper' ),
767
+    );
768
+
769
+    $input = wp_parse_args( $overwrite, $defaults );
770
+
771
+    return $input;
772 772
 }
773 773
 
774 774
 function sd_get_text_color_input_group( $type = 'text_color', $overwrite = array(), $overwrite_custom = array() ) {
775
-	$inputs = array();
775
+    $inputs = array();
776 776
 
777
-	if ( $overwrite !== false ) {
778
-		$inputs[ $type ] = sd_get_text_color_input( $type, $overwrite, true );
779
-	}
777
+    if ( $overwrite !== false ) {
778
+        $inputs[ $type ] = sd_get_text_color_input( $type, $overwrite, true );
779
+    }
780 780
 
781
-	if ( $overwrite_custom !== false ) {
782
-		$custom            = $type . '_custom';
783
-		$inputs[ $custom ] = sd_get_custom_color_input( $custom, $overwrite_custom, $type );
784
-	}
781
+    if ( $overwrite_custom !== false ) {
782
+        $custom            = $type . '_custom';
783
+        $inputs[ $custom ] = sd_get_custom_color_input( $custom, $overwrite_custom, $type );
784
+    }
785 785
 
786
-	return $inputs;
786
+    return $inputs;
787 787
 }
788 788
 
789 789
 /**
@@ -796,22 +796,22 @@  discard block
 block discarded – undo
796 796
  */
797 797
 function sd_get_custom_color_input( $type = 'color_custom', $overwrite = array(), $parent_type = '' ) {
798 798
 
799
-	$defaults = array(
800
-		'type'        => 'color',
801
-		'title'       => __( 'Custom color', 'super-duper' ),
802
-		'default'     => '',
803
-		'placeholder' => '',
804
-		'desc_tip'    => true,
805
-		'group'       => __( 'Typography', 'super-duper' ),
806
-	);
799
+    $defaults = array(
800
+        'type'        => 'color',
801
+        'title'       => __( 'Custom color', 'super-duper' ),
802
+        'default'     => '',
803
+        'placeholder' => '',
804
+        'desc_tip'    => true,
805
+        'group'       => __( 'Typography', 'super-duper' ),
806
+    );
807 807
 
808
-	if ( $parent_type ) {
809
-		$defaults['element_require'] = '[%' . $parent_type . '%]=="custom"';
810
-	}
808
+    if ( $parent_type ) {
809
+        $defaults['element_require'] = '[%' . $parent_type . '%]=="custom"';
810
+    }
811 811
 
812
-	$input = wp_parse_args( $overwrite, $defaults );
812
+    $input = wp_parse_args( $overwrite, $defaults );
813 813
 
814
-	return $input;
814
+    return $input;
815 815
 }
816 816
 
817 817
 /**
@@ -824,44 +824,44 @@  discard block
 block discarded – undo
824 824
  */
825 825
 function sd_get_col_input( $type = 'col', $overwrite = array() ) {
826 826
 
827
-	$device_size = '';
828
-	if ( ! empty( $overwrite['device_type'] ) ) {
829
-		if ( $overwrite['device_type'] == 'Tablet' ) {
830
-			$device_size = '-md';
831
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
832
-			$device_size = '-lg';
833
-		}
834
-	}
835
-	$options = array(
836
-		''     => __( 'Default', 'super-duper' ),
837
-		'auto' => __( 'auto', 'super-duper' ),
838
-		'1'    => '1/12',
839
-		'2'    => '2/12',
840
-		'3'    => '3/12',
841
-		'4'    => '4/12',
842
-		'5'    => '5/12',
843
-		'6'    => '6/12',
844
-		'7'    => '7/12',
845
-		'8'    => '8/12',
846
-		'9'    => '9/12',
847
-		'10'   => '10/12',
848
-		'11'   => '11/12',
849
-		'12'   => '12/12',
850
-	);
851
-
852
-	$defaults = array(
853
-		'type'            => 'select',
854
-		'title'           => __( 'Column width', 'super-duper' ),
855
-		'options'         => $options,
856
-		'default'         => '',
857
-		'desc_tip'        => true,
858
-		'group'           => __( 'Container', 'super-duper' ),
859
-		'element_require' => '[%container%]=="col"',
860
-	);
861
-
862
-	$input = wp_parse_args( $overwrite, $defaults );
863
-
864
-	return $input;
827
+    $device_size = '';
828
+    if ( ! empty( $overwrite['device_type'] ) ) {
829
+        if ( $overwrite['device_type'] == 'Tablet' ) {
830
+            $device_size = '-md';
831
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
832
+            $device_size = '-lg';
833
+        }
834
+    }
835
+    $options = array(
836
+        ''     => __( 'Default', 'super-duper' ),
837
+        'auto' => __( 'auto', 'super-duper' ),
838
+        '1'    => '1/12',
839
+        '2'    => '2/12',
840
+        '3'    => '3/12',
841
+        '4'    => '4/12',
842
+        '5'    => '5/12',
843
+        '6'    => '6/12',
844
+        '7'    => '7/12',
845
+        '8'    => '8/12',
846
+        '9'    => '9/12',
847
+        '10'   => '10/12',
848
+        '11'   => '11/12',
849
+        '12'   => '12/12',
850
+    );
851
+
852
+    $defaults = array(
853
+        'type'            => 'select',
854
+        'title'           => __( 'Column width', 'super-duper' ),
855
+        'options'         => $options,
856
+        'default'         => '',
857
+        'desc_tip'        => true,
858
+        'group'           => __( 'Container', 'super-duper' ),
859
+        'element_require' => '[%container%]=="col"',
860
+    );
861
+
862
+    $input = wp_parse_args( $overwrite, $defaults );
863
+
864
+    return $input;
865 865
 }
866 866
 
867 867
 /**
@@ -874,37 +874,37 @@  discard block
 block discarded – undo
874 874
  */
875 875
 function sd_get_row_cols_input( $type = 'row_cols', $overwrite = array() ) {
876 876
 
877
-	$device_size = '';
878
-	if ( ! empty( $overwrite['device_type'] ) ) {
879
-		if ( $overwrite['device_type'] == 'Tablet' ) {
880
-			$device_size = '-md';
881
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
882
-			$device_size = '-lg';
883
-		}
884
-	}
885
-	$options = array(
886
-		''  => __( 'auto', 'super-duper' ),
887
-		'1' => '1',
888
-		'2' => '2',
889
-		'3' => '3',
890
-		'4' => '4',
891
-		'5' => '5',
892
-		'6' => '6',
893
-	);
894
-
895
-	$defaults = array(
896
-		'type'            => 'select',
897
-		'title'           => __( 'Row columns', 'super-duper' ),
898
-		'options'         => $options,
899
-		'default'         => '',
900
-		'desc_tip'        => true,
901
-		'group'           => __( 'Container', 'super-duper' ),
902
-		'element_require' => '[%container%]=="row"',
903
-	);
904
-
905
-	$input = wp_parse_args( $overwrite, $defaults );
906
-
907
-	return $input;
877
+    $device_size = '';
878
+    if ( ! empty( $overwrite['device_type'] ) ) {
879
+        if ( $overwrite['device_type'] == 'Tablet' ) {
880
+            $device_size = '-md';
881
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
882
+            $device_size = '-lg';
883
+        }
884
+    }
885
+    $options = array(
886
+        ''  => __( 'auto', 'super-duper' ),
887
+        '1' => '1',
888
+        '2' => '2',
889
+        '3' => '3',
890
+        '4' => '4',
891
+        '5' => '5',
892
+        '6' => '6',
893
+    );
894
+
895
+    $defaults = array(
896
+        'type'            => 'select',
897
+        'title'           => __( 'Row columns', 'super-duper' ),
898
+        'options'         => $options,
899
+        'default'         => '',
900
+        'desc_tip'        => true,
901
+        'group'           => __( 'Container', 'super-duper' ),
902
+        'element_require' => '[%container%]=="row"',
903
+    );
904
+
905
+    $input = wp_parse_args( $overwrite, $defaults );
906
+
907
+    return $input;
908 908
 }
909 909
 
910 910
 /**
@@ -917,33 +917,33 @@  discard block
 block discarded – undo
917 917
  */
918 918
 function sd_get_text_align_input( $type = 'text_align', $overwrite = array() ) {
919 919
 
920
-	$device_size = '';
921
-	if ( ! empty( $overwrite['device_type'] ) ) {
922
-		if ( $overwrite['device_type'] == 'Tablet' ) {
923
-			$device_size = '-md';
924
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
925
-			$device_size = '-lg';
926
-		}
927
-	}
928
-	$options = array(
929
-		''                                => __( 'Default', 'super-duper' ),
930
-		'text' . $device_size . '-left'   => __( 'Left', 'super-duper' ),
931
-		'text' . $device_size . '-right'  => __( 'Right', 'super-duper' ),
932
-		'text' . $device_size . '-center' => __( 'Center', 'super-duper' ),
933
-	);
934
-
935
-	$defaults = array(
936
-		'type'     => 'select',
937
-		'title'    => __( 'Text align', 'super-duper' ),
938
-		'options'  => $options,
939
-		'default'  => '',
940
-		'desc_tip' => true,
941
-		'group'    => __( 'Typography', 'super-duper' ),
942
-	);
943
-
944
-	$input = wp_parse_args( $overwrite, $defaults );
945
-
946
-	return $input;
920
+    $device_size = '';
921
+    if ( ! empty( $overwrite['device_type'] ) ) {
922
+        if ( $overwrite['device_type'] == 'Tablet' ) {
923
+            $device_size = '-md';
924
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
925
+            $device_size = '-lg';
926
+        }
927
+    }
928
+    $options = array(
929
+        ''                                => __( 'Default', 'super-duper' ),
930
+        'text' . $device_size . '-left'   => __( 'Left', 'super-duper' ),
931
+        'text' . $device_size . '-right'  => __( 'Right', 'super-duper' ),
932
+        'text' . $device_size . '-center' => __( 'Center', 'super-duper' ),
933
+    );
934
+
935
+    $defaults = array(
936
+        'type'     => 'select',
937
+        'title'    => __( 'Text align', 'super-duper' ),
938
+        'options'  => $options,
939
+        'default'  => '',
940
+        'desc_tip' => true,
941
+        'group'    => __( 'Typography', 'super-duper' ),
942
+    );
943
+
944
+    $input = wp_parse_args( $overwrite, $defaults );
945
+
946
+    return $input;
947 947
 }
948 948
 
949 949
 /**
@@ -956,39 +956,39 @@  discard block
 block discarded – undo
956 956
  */
957 957
 function sd_get_display_input( $type = 'display', $overwrite = array() ) {
958 958
 
959
-	$device_size = '';
960
-	if ( ! empty( $overwrite['device_type'] ) ) {
961
-		if ( $overwrite['device_type'] == 'Tablet' ) {
962
-			$device_size = '-md';
963
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
964
-			$device_size = '-lg';
965
-		}
966
-	}
967
-	$options = array(
968
-		''                                   => __( 'Default', 'super-duper' ),
969
-		'd' . $device_size . '-none'         => 'none',
970
-		'd' . $device_size . '-inline'       => 'inline',
971
-		'd' . $device_size . '-inline-block' => 'inline-block',
972
-		'd' . $device_size . '-block'        => 'block',
973
-		'd' . $device_size . '-table'        => 'table',
974
-		'd' . $device_size . '-table-cell'   => 'table-cell',
975
-		'd' . $device_size . '-table-row'    => 'table-row',
976
-		'd' . $device_size . '-flex'         => 'flex',
977
-		'd' . $device_size . '-inline-flex'  => 'inline-flex',
978
-	);
979
-
980
-	$defaults = array(
981
-		'type'     => 'select',
982
-		'title'    => __( 'Display', 'super-duper' ),
983
-		'options'  => $options,
984
-		'default'  => '',
985
-		'desc_tip' => true,
986
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
987
-	);
988
-
989
-	$input = wp_parse_args( $overwrite, $defaults );
990
-
991
-	return $input;
959
+    $device_size = '';
960
+    if ( ! empty( $overwrite['device_type'] ) ) {
961
+        if ( $overwrite['device_type'] == 'Tablet' ) {
962
+            $device_size = '-md';
963
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
964
+            $device_size = '-lg';
965
+        }
966
+    }
967
+    $options = array(
968
+        ''                                   => __( 'Default', 'super-duper' ),
969
+        'd' . $device_size . '-none'         => 'none',
970
+        'd' . $device_size . '-inline'       => 'inline',
971
+        'd' . $device_size . '-inline-block' => 'inline-block',
972
+        'd' . $device_size . '-block'        => 'block',
973
+        'd' . $device_size . '-table'        => 'table',
974
+        'd' . $device_size . '-table-cell'   => 'table-cell',
975
+        'd' . $device_size . '-table-row'    => 'table-row',
976
+        'd' . $device_size . '-flex'         => 'flex',
977
+        'd' . $device_size . '-inline-flex'  => 'inline-flex',
978
+    );
979
+
980
+    $defaults = array(
981
+        'type'     => 'select',
982
+        'title'    => __( 'Display', 'super-duper' ),
983
+        'options'  => $options,
984
+        'default'  => '',
985
+        'desc_tip' => true,
986
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
987
+    );
988
+
989
+    $input = wp_parse_args( $overwrite, $defaults );
990
+
991
+    return $input;
992 992
 }
993 993
 
994 994
 /**
@@ -1001,17 +1001,17 @@  discard block
 block discarded – undo
1001 1001
  */
1002 1002
 function sd_get_text_justify_input( $type = 'text_justify', $overwrite = array() ) {
1003 1003
 
1004
-	$defaults = array(
1005
-		'type'     => 'checkbox',
1006
-		'title'    => __( 'Text justify', 'super-duper' ),
1007
-		'default'  => '',
1008
-		'desc_tip' => true,
1009
-		'group'    => __( 'Typography', 'super-duper' ),
1010
-	);
1004
+    $defaults = array(
1005
+        'type'     => 'checkbox',
1006
+        'title'    => __( 'Text justify', 'super-duper' ),
1007
+        'default'  => '',
1008
+        'desc_tip' => true,
1009
+        'group'    => __( 'Typography', 'super-duper' ),
1010
+    );
1011 1011
 
1012
-	$input = wp_parse_args( $overwrite, $defaults );
1012
+    $input = wp_parse_args( $overwrite, $defaults );
1013 1013
 
1014
-	return $input;
1014
+    return $input;
1015 1015
 }
1016 1016
 
1017 1017
 /**
@@ -1024,71 +1024,71 @@  discard block
 block discarded – undo
1024 1024
  * @return array
1025 1025
  */
1026 1026
 function sd_aui_colors( $include_branding = false, $include_outlines = false, $outline_button_only_text = false, $include_translucent = false ) {
1027
-	$theme_colors = array();
1028
-
1029
-	$theme_colors['primary']   = __( 'Primary', 'super-duper' );
1030
-	$theme_colors['secondary'] = __( 'Secondary', 'super-duper' );
1031
-	$theme_colors['success']   = __( 'Success', 'super-duper' );
1032
-	$theme_colors['danger']    = __( 'Danger', 'super-duper' );
1033
-	$theme_colors['warning']   = __( 'Warning', 'super-duper' );
1034
-	$theme_colors['info']      = __( 'Info', 'super-duper' );
1035
-	$theme_colors['light']     = __( 'Light', 'super-duper' );
1036
-	$theme_colors['dark']      = __( 'Dark', 'super-duper' );
1037
-	$theme_colors['white']     = __( 'White', 'super-duper' );
1038
-	$theme_colors['purple']    = __( 'Purple', 'super-duper' );
1039
-	$theme_colors['salmon']    = __( 'Salmon', 'super-duper' );
1040
-	$theme_colors['cyan']      = __( 'Cyan', 'super-duper' );
1041
-	$theme_colors['gray']      = __( 'Gray', 'super-duper' );
1042
-	$theme_colors['muted']     = __( 'Muted', 'super-duper' );
1043
-	$theme_colors['gray-dark'] = __( 'Gray dark', 'super-duper' );
1044
-	$theme_colors['indigo']    = __( 'Indigo', 'super-duper' );
1045
-	$theme_colors['orange']    = __( 'Orange', 'super-duper' );
1046
-
1047
-	if ( $include_outlines ) {
1048
-		$button_only                       = $outline_button_only_text ? ' ' . __( '(button only)', 'super-duper' ) : '';
1049
-		$theme_colors['outline-primary']   = __( 'Primary outline', 'super-duper' ) . $button_only;
1050
-		$theme_colors['outline-secondary'] = __( 'Secondary outline', 'super-duper' ) . $button_only;
1051
-		$theme_colors['outline-success']   = __( 'Success outline', 'super-duper' ) . $button_only;
1052
-		$theme_colors['outline-danger']    = __( 'Danger outline', 'super-duper' ) . $button_only;
1053
-		$theme_colors['outline-warning']   = __( 'Warning outline', 'super-duper' ) . $button_only;
1054
-		$theme_colors['outline-info']      = __( 'Info outline', 'super-duper' ) . $button_only;
1055
-		$theme_colors['outline-light']     = __( 'Light outline', 'super-duper' ) . $button_only;
1056
-		$theme_colors['outline-dark']      = __( 'Dark outline', 'super-duper' ) . $button_only;
1057
-		$theme_colors['outline-white']     = __( 'White outline', 'super-duper' ) . $button_only;
1058
-		$theme_colors['outline-purple']    = __( 'Purple outline', 'super-duper' ) . $button_only;
1059
-		$theme_colors['outline-salmon']    = __( 'Salmon outline', 'super-duper' ) . $button_only;
1060
-		$theme_colors['outline-cyan']      = __( 'Cyan outline', 'super-duper' ) . $button_only;
1061
-		$theme_colors['outline-gray']      = __( 'Gray outline', 'super-duper' ) . $button_only;
1062
-		$theme_colors['outline-gray-dark'] = __( 'Gray dark outline', 'super-duper' ) . $button_only;
1063
-		$theme_colors['outline-indigo']    = __( 'Indigo outline', 'super-duper' ) . $button_only;
1064
-		$theme_colors['outline-orange']    = __( 'Orange outline', 'super-duper' ) . $button_only;
1065
-	}
1066
-
1067
-	if ( $include_branding ) {
1068
-		$theme_colors = $theme_colors + sd_aui_branding_colors();
1069
-	}
1070
-
1071
-	if ( $include_translucent ) {
1072
-		$button_only                           = $outline_button_only_text ? ' ' . __( '(button only)', 'super-duper' ) : '';
1073
-		$theme_colors['translucent-primary']   = __( 'Primary translucent', 'super-duper' ) . $button_only;
1074
-		$theme_colors['translucent-secondary'] = __( 'Secondary translucent', 'super-duper' ) . $button_only;
1075
-		$theme_colors['translucent-success']   = __( 'Success translucent', 'super-duper' ) . $button_only;
1076
-		$theme_colors['translucent-danger']    = __( 'Danger translucent', 'super-duper' ) . $button_only;
1077
-		$theme_colors['translucent-warning']   = __( 'Warning translucent', 'super-duper' ) . $button_only;
1078
-		$theme_colors['translucent-info']      = __( 'Info translucent', 'super-duper' ) . $button_only;
1079
-		$theme_colors['translucent-light']     = __( 'Light translucent', 'super-duper' ) . $button_only;
1080
-		$theme_colors['translucent-dark']      = __( 'Dark translucent', 'super-duper' ) . $button_only;
1081
-		$theme_colors['translucent-white']     = __( 'White translucent', 'super-duper' ) . $button_only;
1082
-		$theme_colors['translucent-purple']    = __( 'Purple translucent', 'super-duper' ) . $button_only;
1083
-		$theme_colors['translucent-salmon']    = __( 'Salmon translucent', 'super-duper' ) . $button_only;
1084
-		$theme_colors['translucent-cyan']      = __( 'Cyan translucent', 'super-duper' ) . $button_only;
1085
-		$theme_colors['translucent-gray']      = __( 'Gray translucent', 'super-duper' ) . $button_only;
1086
-		$theme_colors['translucent-gray-dark'] = __( 'Gray dark translucent', 'super-duper' ) . $button_only;
1087
-		$theme_colors['translucent-indigo']    = __( 'Indigo translucent', 'super-duper' ) . $button_only;
1088
-		$theme_colors['translucent-orange']    = __( 'Orange translucent', 'super-duper' ) . $button_only;
1089
-	}
1090
-
1091
-	return apply_filters( 'sd_aui_colors', $theme_colors, $include_outlines, $include_branding );
1027
+    $theme_colors = array();
1028
+
1029
+    $theme_colors['primary']   = __( 'Primary', 'super-duper' );
1030
+    $theme_colors['secondary'] = __( 'Secondary', 'super-duper' );
1031
+    $theme_colors['success']   = __( 'Success', 'super-duper' );
1032
+    $theme_colors['danger']    = __( 'Danger', 'super-duper' );
1033
+    $theme_colors['warning']   = __( 'Warning', 'super-duper' );
1034
+    $theme_colors['info']      = __( 'Info', 'super-duper' );
1035
+    $theme_colors['light']     = __( 'Light', 'super-duper' );
1036
+    $theme_colors['dark']      = __( 'Dark', 'super-duper' );
1037
+    $theme_colors['white']     = __( 'White', 'super-duper' );
1038
+    $theme_colors['purple']    = __( 'Purple', 'super-duper' );
1039
+    $theme_colors['salmon']    = __( 'Salmon', 'super-duper' );
1040
+    $theme_colors['cyan']      = __( 'Cyan', 'super-duper' );
1041
+    $theme_colors['gray']      = __( 'Gray', 'super-duper' );
1042
+    $theme_colors['muted']     = __( 'Muted', 'super-duper' );
1043
+    $theme_colors['gray-dark'] = __( 'Gray dark', 'super-duper' );
1044
+    $theme_colors['indigo']    = __( 'Indigo', 'super-duper' );
1045
+    $theme_colors['orange']    = __( 'Orange', 'super-duper' );
1046
+
1047
+    if ( $include_outlines ) {
1048
+        $button_only                       = $outline_button_only_text ? ' ' . __( '(button only)', 'super-duper' ) : '';
1049
+        $theme_colors['outline-primary']   = __( 'Primary outline', 'super-duper' ) . $button_only;
1050
+        $theme_colors['outline-secondary'] = __( 'Secondary outline', 'super-duper' ) . $button_only;
1051
+        $theme_colors['outline-success']   = __( 'Success outline', 'super-duper' ) . $button_only;
1052
+        $theme_colors['outline-danger']    = __( 'Danger outline', 'super-duper' ) . $button_only;
1053
+        $theme_colors['outline-warning']   = __( 'Warning outline', 'super-duper' ) . $button_only;
1054
+        $theme_colors['outline-info']      = __( 'Info outline', 'super-duper' ) . $button_only;
1055
+        $theme_colors['outline-light']     = __( 'Light outline', 'super-duper' ) . $button_only;
1056
+        $theme_colors['outline-dark']      = __( 'Dark outline', 'super-duper' ) . $button_only;
1057
+        $theme_colors['outline-white']     = __( 'White outline', 'super-duper' ) . $button_only;
1058
+        $theme_colors['outline-purple']    = __( 'Purple outline', 'super-duper' ) . $button_only;
1059
+        $theme_colors['outline-salmon']    = __( 'Salmon outline', 'super-duper' ) . $button_only;
1060
+        $theme_colors['outline-cyan']      = __( 'Cyan outline', 'super-duper' ) . $button_only;
1061
+        $theme_colors['outline-gray']      = __( 'Gray outline', 'super-duper' ) . $button_only;
1062
+        $theme_colors['outline-gray-dark'] = __( 'Gray dark outline', 'super-duper' ) . $button_only;
1063
+        $theme_colors['outline-indigo']    = __( 'Indigo outline', 'super-duper' ) . $button_only;
1064
+        $theme_colors['outline-orange']    = __( 'Orange outline', 'super-duper' ) . $button_only;
1065
+    }
1066
+
1067
+    if ( $include_branding ) {
1068
+        $theme_colors = $theme_colors + sd_aui_branding_colors();
1069
+    }
1070
+
1071
+    if ( $include_translucent ) {
1072
+        $button_only                           = $outline_button_only_text ? ' ' . __( '(button only)', 'super-duper' ) : '';
1073
+        $theme_colors['translucent-primary']   = __( 'Primary translucent', 'super-duper' ) . $button_only;
1074
+        $theme_colors['translucent-secondary'] = __( 'Secondary translucent', 'super-duper' ) . $button_only;
1075
+        $theme_colors['translucent-success']   = __( 'Success translucent', 'super-duper' ) . $button_only;
1076
+        $theme_colors['translucent-danger']    = __( 'Danger translucent', 'super-duper' ) . $button_only;
1077
+        $theme_colors['translucent-warning']   = __( 'Warning translucent', 'super-duper' ) . $button_only;
1078
+        $theme_colors['translucent-info']      = __( 'Info translucent', 'super-duper' ) . $button_only;
1079
+        $theme_colors['translucent-light']     = __( 'Light translucent', 'super-duper' ) . $button_only;
1080
+        $theme_colors['translucent-dark']      = __( 'Dark translucent', 'super-duper' ) . $button_only;
1081
+        $theme_colors['translucent-white']     = __( 'White translucent', 'super-duper' ) . $button_only;
1082
+        $theme_colors['translucent-purple']    = __( 'Purple translucent', 'super-duper' ) . $button_only;
1083
+        $theme_colors['translucent-salmon']    = __( 'Salmon translucent', 'super-duper' ) . $button_only;
1084
+        $theme_colors['translucent-cyan']      = __( 'Cyan translucent', 'super-duper' ) . $button_only;
1085
+        $theme_colors['translucent-gray']      = __( 'Gray translucent', 'super-duper' ) . $button_only;
1086
+        $theme_colors['translucent-gray-dark'] = __( 'Gray dark translucent', 'super-duper' ) . $button_only;
1087
+        $theme_colors['translucent-indigo']    = __( 'Indigo translucent', 'super-duper' ) . $button_only;
1088
+        $theme_colors['translucent-orange']    = __( 'Orange translucent', 'super-duper' ) . $button_only;
1089
+    }
1090
+
1091
+    return apply_filters( 'sd_aui_colors', $theme_colors, $include_outlines, $include_branding );
1092 1092
 }
1093 1093
 
1094 1094
 /**
@@ -1097,19 +1097,19 @@  discard block
 block discarded – undo
1097 1097
  * @return array
1098 1098
  */
1099 1099
 function sd_aui_branding_colors() {
1100
-	return array(
1101
-		'facebook'  => __( 'Facebook', 'super-duper' ),
1102
-		'twitter'   => __( 'Twitter', 'super-duper' ),
1103
-		'instagram' => __( 'Instagram', 'super-duper' ),
1104
-		'linkedin'  => __( 'Linkedin', 'super-duper' ),
1105
-		'flickr'    => __( 'Flickr', 'super-duper' ),
1106
-		'github'    => __( 'GitHub', 'super-duper' ),
1107
-		'youtube'   => __( 'YouTube', 'super-duper' ),
1108
-		'wordpress' => __( 'WordPress', 'super-duper' ),
1109
-		'google'    => __( 'Google', 'super-duper' ),
1110
-		'yahoo'     => __( 'Yahoo', 'super-duper' ),
1111
-		'vkontakte' => __( 'Vkontakte', 'super-duper' ),
1112
-	);
1100
+    return array(
1101
+        'facebook'  => __( 'Facebook', 'super-duper' ),
1102
+        'twitter'   => __( 'Twitter', 'super-duper' ),
1103
+        'instagram' => __( 'Instagram', 'super-duper' ),
1104
+        'linkedin'  => __( 'Linkedin', 'super-duper' ),
1105
+        'flickr'    => __( 'Flickr', 'super-duper' ),
1106
+        'github'    => __( 'GitHub', 'super-duper' ),
1107
+        'youtube'   => __( 'YouTube', 'super-duper' ),
1108
+        'wordpress' => __( 'WordPress', 'super-duper' ),
1109
+        'google'    => __( 'Google', 'super-duper' ),
1110
+        'yahoo'     => __( 'Yahoo', 'super-duper' ),
1111
+        'vkontakte' => __( 'Vkontakte', 'super-duper' ),
1112
+    );
1113 1113
 }
1114 1114
 
1115 1115
 
@@ -1123,38 +1123,38 @@  discard block
 block discarded – undo
1123 1123
  */
1124 1124
 function sd_get_container_class_input( $type = 'container', $overwrite = array() ) {
1125 1125
 
1126
-	$options = array(
1127
-		'container'       => __( 'container (default)', 'super-duper' ),
1128
-		'container-sm'    => 'container-sm',
1129
-		'container-md'    => 'container-md',
1130
-		'container-lg'    => 'container-lg',
1131
-		'container-xl'    => 'container-xl',
1132
-		'container-xxl'   => 'container-xxl',
1133
-		'container-fluid' => 'container-fluid',
1134
-		'row'             => 'row',
1135
-		'col'             => 'col',
1136
-		'card'            => 'card',
1137
-		'card-header'     => 'card-header',
1138
-		'card-img-top'    => 'card-img-top',
1139
-		'card-body'       => 'card-body',
1140
-		'card-footer'     => 'card-footer',
1141
-		'list-group'      => 'list-group',
1142
-		'list-group-item' => 'list-group-item',
1143
-		''                => __( 'no container class', 'super-duper' ),
1144
-	);
1145
-
1146
-	$defaults = array(
1147
-		'type'     => 'select',
1148
-		'title'    => __( 'Type', 'super-duper' ),
1149
-		'options'  => $options,
1150
-		'default'  => '',
1151
-		'desc_tip' => true,
1152
-		'group'    => __( 'Container', 'super-duper' ),
1153
-	);
1154
-
1155
-	$input = wp_parse_args( $overwrite, $defaults );
1156
-
1157
-	return $input;
1126
+    $options = array(
1127
+        'container'       => __( 'container (default)', 'super-duper' ),
1128
+        'container-sm'    => 'container-sm',
1129
+        'container-md'    => 'container-md',
1130
+        'container-lg'    => 'container-lg',
1131
+        'container-xl'    => 'container-xl',
1132
+        'container-xxl'   => 'container-xxl',
1133
+        'container-fluid' => 'container-fluid',
1134
+        'row'             => 'row',
1135
+        'col'             => 'col',
1136
+        'card'            => 'card',
1137
+        'card-header'     => 'card-header',
1138
+        'card-img-top'    => 'card-img-top',
1139
+        'card-body'       => 'card-body',
1140
+        'card-footer'     => 'card-footer',
1141
+        'list-group'      => 'list-group',
1142
+        'list-group-item' => 'list-group-item',
1143
+        ''                => __( 'no container class', 'super-duper' ),
1144
+    );
1145
+
1146
+    $defaults = array(
1147
+        'type'     => 'select',
1148
+        'title'    => __( 'Type', 'super-duper' ),
1149
+        'options'  => $options,
1150
+        'default'  => '',
1151
+        'desc_tip' => true,
1152
+        'group'    => __( 'Container', 'super-duper' ),
1153
+    );
1154
+
1155
+    $input = wp_parse_args( $overwrite, $defaults );
1156
+
1157
+    return $input;
1158 1158
 }
1159 1159
 
1160 1160
 /**
@@ -1167,30 +1167,30 @@  discard block
 block discarded – undo
1167 1167
  */
1168 1168
 function sd_get_position_class_input( $type = 'position', $overwrite = array() ) {
1169 1169
 
1170
-	$options = array(
1171
-		''                  => __( 'Default', 'super-duper' ),
1172
-		'position-static'   => 'static',
1173
-		'position-relative' => 'relative',
1174
-		'position-absolute' => 'absolute',
1175
-		'position-fixed'    => 'fixed',
1176
-		'position-sticky'   => 'sticky',
1177
-		'fixed-top'         => 'fixed-top',
1178
-		'fixed-bottom'      => 'fixed-bottom',
1179
-		'sticky-top'        => 'sticky-top',
1180
-	);
1181
-
1182
-	$defaults = array(
1183
-		'type'     => 'select',
1184
-		'title'    => __( 'Position', 'super-duper' ),
1185
-		'options'  => $options,
1186
-		'default'  => '',
1187
-		'desc_tip' => true,
1188
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
1189
-	);
1190
-
1191
-	$input = wp_parse_args( $overwrite, $defaults );
1192
-
1193
-	return $input;
1170
+    $options = array(
1171
+        ''                  => __( 'Default', 'super-duper' ),
1172
+        'position-static'   => 'static',
1173
+        'position-relative' => 'relative',
1174
+        'position-absolute' => 'absolute',
1175
+        'position-fixed'    => 'fixed',
1176
+        'position-sticky'   => 'sticky',
1177
+        'fixed-top'         => 'fixed-top',
1178
+        'fixed-bottom'      => 'fixed-bottom',
1179
+        'sticky-top'        => 'sticky-top',
1180
+    );
1181
+
1182
+    $defaults = array(
1183
+        'type'     => 'select',
1184
+        'title'    => __( 'Position', 'super-duper' ),
1185
+        'options'  => $options,
1186
+        'default'  => '',
1187
+        'desc_tip' => true,
1188
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
1189
+    );
1190
+
1191
+    $input = wp_parse_args( $overwrite, $defaults );
1192
+
1193
+    return $input;
1194 1194
 }
1195 1195
 
1196 1196
 /**
@@ -1201,32 +1201,32 @@  discard block
 block discarded – undo
1201 1201
  */
1202 1202
 function sd_get_absolute_position_input( $type = 'absolute_position', $overwrite = array() ) {
1203 1203
 
1204
-	$options = array(
1205
-		''              => __( 'Default', 'super-duper' ),
1206
-		'top-left'      => 'top-left',
1207
-		'top-center'    => 'top-center',
1208
-		'top-right'     => 'top-right',
1209
-		'center-left'   => 'middle-left',
1210
-		'center'        => 'center',
1211
-		'center-right'  => 'middle-right',
1212
-		'bottom-left'   => 'bottom-left',
1213
-		'bottom-center' => 'bottom-center',
1214
-		'bottom-right'  => 'bottom-right',
1215
-	);
1216
-
1217
-	$defaults = array(
1218
-		'type'            => 'select',
1219
-		'title'           => __( 'Absolute Position', 'super-duper' ),
1220
-		'options'         => $options,
1221
-		'default'         => '',
1222
-		'desc_tip'        => true,
1223
-		'group'           => __( 'Wrapper Styles', 'super-duper' ),
1224
-		'element_require' => '[%position%]=="position-absolute"',
1225
-	);
1226
-
1227
-	$input = wp_parse_args( $overwrite, $defaults );
1228
-
1229
-	return $input;
1204
+    $options = array(
1205
+        ''              => __( 'Default', 'super-duper' ),
1206
+        'top-left'      => 'top-left',
1207
+        'top-center'    => 'top-center',
1208
+        'top-right'     => 'top-right',
1209
+        'center-left'   => 'middle-left',
1210
+        'center'        => 'center',
1211
+        'center-right'  => 'middle-right',
1212
+        'bottom-left'   => 'bottom-left',
1213
+        'bottom-center' => 'bottom-center',
1214
+        'bottom-right'  => 'bottom-right',
1215
+    );
1216
+
1217
+    $defaults = array(
1218
+        'type'            => 'select',
1219
+        'title'           => __( 'Absolute Position', 'super-duper' ),
1220
+        'options'         => $options,
1221
+        'default'         => '',
1222
+        'desc_tip'        => true,
1223
+        'group'           => __( 'Wrapper Styles', 'super-duper' ),
1224
+        'element_require' => '[%position%]=="position-absolute"',
1225
+    );
1226
+
1227
+    $input = wp_parse_args( $overwrite, $defaults );
1228
+
1229
+    return $input;
1230 1230
 }
1231 1231
 
1232 1232
 /**
@@ -1239,38 +1239,38 @@  discard block
 block discarded – undo
1239 1239
  */
1240 1240
 function sd_get_sticky_offset_input( $type = 'top', $overwrite = array() ) {
1241 1241
 
1242
-	$defaults = array(
1243
-		'type'            => 'number',
1244
-		'title'           => __( 'Sticky offset', 'super-duper' ),
1245
-		//'desc' =>  __('Sticky offset'),
1246
-		'default'         => '',
1247
-		'desc_tip'        => true,
1248
-		'group'           => __( 'Wrapper Styles', 'super-duper' ),
1249
-		'element_require' => '[%position%]=="sticky" || [%position%]=="sticky-top"',
1250
-	);
1251
-
1252
-	// title
1253
-	if ( $type == 'top' ) {
1254
-		$defaults['title'] = __( 'Top offset', 'super-duper' );
1255
-		$defaults['icon']  = 'box-top';
1256
-		$defaults['row']   = array(
1257
-			'title' => __( 'Sticky offset', 'super-duper' ),
1258
-			'key'   => 'sticky-offset',
1259
-			'open'  => true,
1260
-			'class' => 'text-center',
1261
-		);
1262
-	} elseif ( $type == 'bottom' ) {
1263
-		$defaults['title'] = __( 'Bottom offset', 'super-duper' );
1264
-		$defaults['icon']  = 'box-bottom';
1265
-		$defaults['row']   = array(
1266
-			'key'   => 'sticky-offset',
1267
-			'close' => true,
1268
-		);
1269
-	}
1270
-
1271
-	$input = wp_parse_args( $overwrite, $defaults );
1272
-
1273
-	return $input;
1242
+    $defaults = array(
1243
+        'type'            => 'number',
1244
+        'title'           => __( 'Sticky offset', 'super-duper' ),
1245
+        //'desc' =>  __('Sticky offset'),
1246
+        'default'         => '',
1247
+        'desc_tip'        => true,
1248
+        'group'           => __( 'Wrapper Styles', 'super-duper' ),
1249
+        'element_require' => '[%position%]=="sticky" || [%position%]=="sticky-top"',
1250
+    );
1251
+
1252
+    // title
1253
+    if ( $type == 'top' ) {
1254
+        $defaults['title'] = __( 'Top offset', 'super-duper' );
1255
+        $defaults['icon']  = 'box-top';
1256
+        $defaults['row']   = array(
1257
+            'title' => __( 'Sticky offset', 'super-duper' ),
1258
+            'key'   => 'sticky-offset',
1259
+            'open'  => true,
1260
+            'class' => 'text-center',
1261
+        );
1262
+    } elseif ( $type == 'bottom' ) {
1263
+        $defaults['title'] = __( 'Bottom offset', 'super-duper' );
1264
+        $defaults['icon']  = 'box-bottom';
1265
+        $defaults['row']   = array(
1266
+            'key'   => 'sticky-offset',
1267
+            'close' => true,
1268
+        );
1269
+    }
1270
+
1271
+    $input = wp_parse_args( $overwrite, $defaults );
1272
+
1273
+    return $input;
1274 1274
 }
1275 1275
 
1276 1276
 /**
@@ -1282,61 +1282,61 @@  discard block
 block discarded – undo
1282 1282
  * @return array
1283 1283
  */
1284 1284
 function sd_get_font_size_input( $type = 'font_size', $overwrite = array(), $has_custom = false ) {
1285
-	global $aui_bs5;
1286
-
1287
-	$options[] = __( 'Inherit from parent', 'super-duper' );
1288
-	if ( $aui_bs5 ) {
1289
-		// responsive font sizes
1290
-		$options['fs-base'] = 'fs-base (body default)';
1291
-		$options['fs-6']    = 'fs-6';
1292
-		$options['fs-5']    = 'fs-5';
1293
-		$options['fs-4']    = 'fs-4';
1294
-		$options['fs-3']    = 'fs-3';
1295
-		$options['fs-2']    = 'fs-2';
1296
-		$options['fs-1']    = 'fs-1';
1297
-
1298
-		// custom
1299
-		$options['fs-lg']  = 'fs-lg';
1300
-		$options['fs-sm']  = 'fs-sm';
1301
-		$options['fs-xs']  = 'fs-xs';
1302
-		$options['fs-xxs'] = 'fs-xxs';
1303
-
1304
-	}
1305
-
1306
-	$options = $options + array(
1307
-			'h6'        => 'h6',
1308
-			'h5'        => 'h5',
1309
-			'h4'        => 'h4',
1310
-			'h3'        => 'h3',
1311
-			'h2'        => 'h2',
1312
-			'h1'        => 'h1',
1313
-			'display-1' => 'display-1',
1314
-			'display-2' => 'display-2',
1315
-			'display-3' => 'display-3',
1316
-			'display-4' => 'display-4',
1317
-		);
1318
-
1319
-	if ( $aui_bs5 ) {
1320
-		$options['display-5'] = 'display-5';
1321
-		$options['display-6'] = 'display-6';
1322
-	}
1323
-
1324
-	if ( $has_custom ) {
1325
-		$options['custom'] = __( 'Custom size', 'super-duper' );
1326
-	}
1327
-
1328
-	$defaults = array(
1329
-		'type'     => 'select',
1330
-		'title'    => __( 'Font size', 'super-duper' ),
1331
-		'options'  => $options,
1332
-		'default'  => '',
1333
-		'desc_tip' => true,
1334
-		'group'    => __( 'Typography', 'super-duper' ),
1335
-	);
1336
-
1337
-	$input = wp_parse_args( $overwrite, $defaults );
1338
-
1339
-	return $input;
1285
+    global $aui_bs5;
1286
+
1287
+    $options[] = __( 'Inherit from parent', 'super-duper' );
1288
+    if ( $aui_bs5 ) {
1289
+        // responsive font sizes
1290
+        $options['fs-base'] = 'fs-base (body default)';
1291
+        $options['fs-6']    = 'fs-6';
1292
+        $options['fs-5']    = 'fs-5';
1293
+        $options['fs-4']    = 'fs-4';
1294
+        $options['fs-3']    = 'fs-3';
1295
+        $options['fs-2']    = 'fs-2';
1296
+        $options['fs-1']    = 'fs-1';
1297
+
1298
+        // custom
1299
+        $options['fs-lg']  = 'fs-lg';
1300
+        $options['fs-sm']  = 'fs-sm';
1301
+        $options['fs-xs']  = 'fs-xs';
1302
+        $options['fs-xxs'] = 'fs-xxs';
1303
+
1304
+    }
1305
+
1306
+    $options = $options + array(
1307
+            'h6'        => 'h6',
1308
+            'h5'        => 'h5',
1309
+            'h4'        => 'h4',
1310
+            'h3'        => 'h3',
1311
+            'h2'        => 'h2',
1312
+            'h1'        => 'h1',
1313
+            'display-1' => 'display-1',
1314
+            'display-2' => 'display-2',
1315
+            'display-3' => 'display-3',
1316
+            'display-4' => 'display-4',
1317
+        );
1318
+
1319
+    if ( $aui_bs5 ) {
1320
+        $options['display-5'] = 'display-5';
1321
+        $options['display-6'] = 'display-6';
1322
+    }
1323
+
1324
+    if ( $has_custom ) {
1325
+        $options['custom'] = __( 'Custom size', 'super-duper' );
1326
+    }
1327
+
1328
+    $defaults = array(
1329
+        'type'     => 'select',
1330
+        'title'    => __( 'Font size', 'super-duper' ),
1331
+        'options'  => $options,
1332
+        'default'  => '',
1333
+        'desc_tip' => true,
1334
+        'group'    => __( 'Typography', 'super-duper' ),
1335
+    );
1336
+
1337
+    $input = wp_parse_args( $overwrite, $defaults );
1338
+
1339
+    return $input;
1340 1340
 }
1341 1341
 
1342 1342
 /**
@@ -1349,27 +1349,27 @@  discard block
 block discarded – undo
1349 1349
  */
1350 1350
 function sd_get_font_custom_size_input( $type = 'font_size_custom', $overwrite = array(), $parent_type = '' ) {
1351 1351
 
1352
-	$defaults = array(
1353
-		'type'              => 'number',
1354
-		'title'             => __( 'Font size (rem)', 'super-duper' ),
1355
-		'default'           => '',
1356
-		'placeholder'       => '1.25',
1357
-		'custom_attributes' => array(
1358
-			'step' => '0.1',
1359
-			'min'  => '0',
1360
-			'max'  => '100',
1361
-		),
1362
-		'desc_tip'          => true,
1363
-		'group'             => __( 'Typography', 'super-duper' ),
1364
-	);
1365
-
1366
-	if ( $parent_type ) {
1367
-		$defaults['element_require'] = '[%' . $parent_type . '%]=="custom"';
1368
-	}
1369
-
1370
-	$input = wp_parse_args( $overwrite, $defaults );
1371
-
1372
-	return $input;
1352
+    $defaults = array(
1353
+        'type'              => 'number',
1354
+        'title'             => __( 'Font size (rem)', 'super-duper' ),
1355
+        'default'           => '',
1356
+        'placeholder'       => '1.25',
1357
+        'custom_attributes' => array(
1358
+            'step' => '0.1',
1359
+            'min'  => '0',
1360
+            'max'  => '100',
1361
+        ),
1362
+        'desc_tip'          => true,
1363
+        'group'             => __( 'Typography', 'super-duper' ),
1364
+    );
1365
+
1366
+    if ( $parent_type ) {
1367
+        $defaults['element_require'] = '[%' . $parent_type . '%]=="custom"';
1368
+    }
1369
+
1370
+    $input = wp_parse_args( $overwrite, $defaults );
1371
+
1372
+    return $input;
1373 1373
 }
1374 1374
 
1375 1375
 /**
@@ -1382,23 +1382,23 @@  discard block
 block discarded – undo
1382 1382
  */
1383 1383
 function sd_get_font_line_height_input( $type = 'font_line_height', $overwrite = array() ) {
1384 1384
 
1385
-	$defaults = array(
1386
-		'type'              => 'number',
1387
-		'title'             => __( 'Font Line Height', 'super-duper' ),
1388
-		'default'           => '',
1389
-		'placeholder'       => '1.75',
1390
-		'custom_attributes' => array(
1391
-			'step' => '0.1',
1392
-			'min'  => '0',
1393
-			'max'  => '100',
1394
-		),
1395
-		'desc_tip'          => true,
1396
-		'group'             => __( 'Typography', 'super-duper' ),
1397
-	);
1398
-
1399
-	$input = wp_parse_args( $overwrite, $defaults );
1400
-
1401
-	return $input;
1385
+    $defaults = array(
1386
+        'type'              => 'number',
1387
+        'title'             => __( 'Font Line Height', 'super-duper' ),
1388
+        'default'           => '',
1389
+        'placeholder'       => '1.75',
1390
+        'custom_attributes' => array(
1391
+            'step' => '0.1',
1392
+            'min'  => '0',
1393
+            'max'  => '100',
1394
+        ),
1395
+        'desc_tip'          => true,
1396
+        'group'             => __( 'Typography', 'super-duper' ),
1397
+    );
1398
+
1399
+    $input = wp_parse_args( $overwrite, $defaults );
1400
+
1401
+    return $input;
1402 1402
 }
1403 1403
 
1404 1404
 /**
@@ -1411,18 +1411,18 @@  discard block
 block discarded – undo
1411 1411
  */
1412 1412
 function sd_get_font_size_input_group( $type = 'font_size', $overwrite = array(), $overwrite_custom = array() ) {
1413 1413
 
1414
-	$inputs = array();
1414
+    $inputs = array();
1415 1415
 
1416
-	if ( $overwrite !== false ) {
1417
-		$inputs[ $type ] = sd_get_font_size_input( $type, $overwrite, true );
1418
-	}
1416
+    if ( $overwrite !== false ) {
1417
+        $inputs[ $type ] = sd_get_font_size_input( $type, $overwrite, true );
1418
+    }
1419 1419
 
1420
-	if ( $overwrite_custom !== false ) {
1421
-		$custom            = $type . '_custom';
1422
-		$inputs[ $custom ] = sd_get_font_custom_size_input( $custom, $overwrite_custom, $type );
1423
-	}
1420
+    if ( $overwrite_custom !== false ) {
1421
+        $custom            = $type . '_custom';
1422
+        $inputs[ $custom ] = sd_get_font_custom_size_input( $custom, $overwrite_custom, $type );
1423
+    }
1424 1424
 
1425
-	return $inputs;
1425
+    return $inputs;
1426 1426
 }
1427 1427
 
1428 1428
 /**
@@ -1435,33 +1435,33 @@  discard block
 block discarded – undo
1435 1435
  */
1436 1436
 function sd_get_font_weight_input( $type = 'font_weight', $overwrite = array() ) {
1437 1437
 
1438
-	$options = array(
1439
-		''                                => __( 'Inherit', 'super-duper' ),
1440
-		'font-weight-bold'                => 'bold',
1441
-		'font-weight-bolder'              => 'bolder',
1442
-		'font-weight-normal'              => 'normal',
1443
-		'font-weight-light'               => 'light',
1444
-		'font-weight-lighter'             => 'lighter',
1445
-		'font-italic'                     => 'italic',
1446
-		'font-weight-bold font-italic'    => 'bold italic',
1447
-		'font-weight-bolder font-italic'  => 'bolder italic',
1448
-		'font-weight-normal font-italic'  => 'normal italic',
1449
-		'font-weight-light font-italic'   => 'light italic',
1450
-		'font-weight-lighter font-italic' => 'lighter italic',
1451
-	);
1452
-
1453
-	$defaults = array(
1454
-		'type'     => 'select',
1455
-		'title'    => __( 'Appearance', 'super-duper' ),
1456
-		'options'  => $options,
1457
-		'default'  => '',
1458
-		'desc_tip' => true,
1459
-		'group'    => __( 'Typography', 'super-duper' ),
1460
-	);
1461
-
1462
-	$input = wp_parse_args( $overwrite, $defaults );
1463
-
1464
-	return $input;
1438
+    $options = array(
1439
+        ''                                => __( 'Inherit', 'super-duper' ),
1440
+        'font-weight-bold'                => 'bold',
1441
+        'font-weight-bolder'              => 'bolder',
1442
+        'font-weight-normal'              => 'normal',
1443
+        'font-weight-light'               => 'light',
1444
+        'font-weight-lighter'             => 'lighter',
1445
+        'font-italic'                     => 'italic',
1446
+        'font-weight-bold font-italic'    => 'bold italic',
1447
+        'font-weight-bolder font-italic'  => 'bolder italic',
1448
+        'font-weight-normal font-italic'  => 'normal italic',
1449
+        'font-weight-light font-italic'   => 'light italic',
1450
+        'font-weight-lighter font-italic' => 'lighter italic',
1451
+    );
1452
+
1453
+    $defaults = array(
1454
+        'type'     => 'select',
1455
+        'title'    => __( 'Appearance', 'super-duper' ),
1456
+        'options'  => $options,
1457
+        'default'  => '',
1458
+        'desc_tip' => true,
1459
+        'group'    => __( 'Typography', 'super-duper' ),
1460
+    );
1461
+
1462
+    $input = wp_parse_args( $overwrite, $defaults );
1463
+
1464
+    return $input;
1465 1465
 }
1466 1466
 
1467 1467
 /**
@@ -1474,25 +1474,25 @@  discard block
 block discarded – undo
1474 1474
  */
1475 1475
 function sd_get_font_case_input( $type = 'font_weight', $overwrite = array() ) {
1476 1476
 
1477
-	$options = array(
1478
-		''                => __( 'Default', 'super-duper' ),
1479
-		'text-lowercase'  => __( 'lowercase', 'super-duper' ),
1480
-		'text-uppercase'  => __( 'UPPERCASE', 'super-duper' ),
1481
-		'text-capitalize' => __( 'Capitalize', 'super-duper' ),
1482
-	);
1483
-
1484
-	$defaults = array(
1485
-		'type'     => 'select',
1486
-		'title'    => __( 'Letter case', 'super-duper' ),
1487
-		'options'  => $options,
1488
-		'default'  => '',
1489
-		'desc_tip' => true,
1490
-		'group'    => __( 'Typography', 'super-duper' ),
1491
-	);
1492
-
1493
-	$input = wp_parse_args( $overwrite, $defaults );
1494
-
1495
-	return $input;
1477
+    $options = array(
1478
+        ''                => __( 'Default', 'super-duper' ),
1479
+        'text-lowercase'  => __( 'lowercase', 'super-duper' ),
1480
+        'text-uppercase'  => __( 'UPPERCASE', 'super-duper' ),
1481
+        'text-capitalize' => __( 'Capitalize', 'super-duper' ),
1482
+    );
1483
+
1484
+    $defaults = array(
1485
+        'type'     => 'select',
1486
+        'title'    => __( 'Letter case', 'super-duper' ),
1487
+        'options'  => $options,
1488
+        'default'  => '',
1489
+        'desc_tip' => true,
1490
+        'group'    => __( 'Typography', 'super-duper' ),
1491
+    );
1492
+
1493
+    $input = wp_parse_args( $overwrite, $defaults );
1494
+
1495
+    return $input;
1496 1496
 }
1497 1497
 
1498 1498
 /**
@@ -1506,23 +1506,23 @@  discard block
 block discarded – undo
1506 1506
  */
1507 1507
 function sd_get_font_italic_input( $type = 'font_italic', $overwrite = array() ) {
1508 1508
 
1509
-	$options = array(
1510
-		''            => __( 'No', 'super-duper' ),
1511
-		'font-italic' => __( 'Yes', 'super-duper' ),
1512
-	);
1509
+    $options = array(
1510
+        ''            => __( 'No', 'super-duper' ),
1511
+        'font-italic' => __( 'Yes', 'super-duper' ),
1512
+    );
1513 1513
 
1514
-	$defaults = array(
1515
-		'type'     => 'select',
1516
-		'title'    => __( 'Font italic', 'super-duper' ),
1517
-		'options'  => $options,
1518
-		'default'  => '',
1519
-		'desc_tip' => true,
1520
-		'group'    => __( 'Typography', 'super-duper' ),
1521
-	);
1514
+    $defaults = array(
1515
+        'type'     => 'select',
1516
+        'title'    => __( 'Font italic', 'super-duper' ),
1517
+        'options'  => $options,
1518
+        'default'  => '',
1519
+        'desc_tip' => true,
1520
+        'group'    => __( 'Typography', 'super-duper' ),
1521
+    );
1522 1522
 
1523
-	$input = wp_parse_args( $overwrite, $defaults );
1523
+    $input = wp_parse_args( $overwrite, $defaults );
1524 1524
 
1525
-	return $input;
1525
+    return $input;
1526 1526
 }
1527 1527
 
1528 1528
 /**
@@ -1535,18 +1535,18 @@  discard block
 block discarded – undo
1535 1535
  */
1536 1536
 function sd_get_anchor_input( $type = 'anchor', $overwrite = array() ) {
1537 1537
 
1538
-	$defaults = array(
1539
-		'type'     => 'text',
1540
-		'title'    => __( 'HTML anchor', 'super-duper' ),
1541
-		'desc'     => __( 'Enter a word or two — without spaces — to make a unique web address just for this block, called an “anchor.” Then, you’ll be able to link directly to this section of your page.' ),
1542
-		'default'  => '',
1543
-		'desc_tip' => true,
1544
-		'group'    => __( 'Advanced', 'super-duper' ),
1545
-	);
1538
+    $defaults = array(
1539
+        'type'     => 'text',
1540
+        'title'    => __( 'HTML anchor', 'super-duper' ),
1541
+        'desc'     => __( 'Enter a word or two — without spaces — to make a unique web address just for this block, called an “anchor.” Then, you’ll be able to link directly to this section of your page.' ),
1542
+        'default'  => '',
1543
+        'desc_tip' => true,
1544
+        'group'    => __( 'Advanced', 'super-duper' ),
1545
+    );
1546 1546
 
1547
-	$input = wp_parse_args( $overwrite, $defaults );
1547
+    $input = wp_parse_args( $overwrite, $defaults );
1548 1548
 
1549
-	return $input;
1549
+    return $input;
1550 1550
 }
1551 1551
 
1552 1552
 /**
@@ -1559,18 +1559,18 @@  discard block
 block discarded – undo
1559 1559
  */
1560 1560
 function sd_get_class_input( $type = 'css_class', $overwrite = array() ) {
1561 1561
 
1562
-	$defaults = array(
1563
-		'type'     => 'text',
1564
-		'title'    => __( 'Additional CSS class(es)', 'super-duper' ),
1565
-		'desc'     => __( 'Separate multiple classes with spaces.', 'super-duper' ),
1566
-		'default'  => '',
1567
-		'desc_tip' => true,
1568
-		'group'    => __( 'Advanced', 'super-duper' ),
1569
-	);
1562
+    $defaults = array(
1563
+        'type'     => 'text',
1564
+        'title'    => __( 'Additional CSS class(es)', 'super-duper' ),
1565
+        'desc'     => __( 'Separate multiple classes with spaces.', 'super-duper' ),
1566
+        'default'  => '',
1567
+        'desc_tip' => true,
1568
+        'group'    => __( 'Advanced', 'super-duper' ),
1569
+    );
1570 1570
 
1571
-	$input = wp_parse_args( $overwrite, $defaults );
1571
+    $input = wp_parse_args( $overwrite, $defaults );
1572 1572
 
1573
-	return $input;
1573
+    return $input;
1574 1574
 }
1575 1575
 
1576 1576
 /**
@@ -1583,293 +1583,293 @@  discard block
 block discarded – undo
1583 1583
  */
1584 1584
 function sd_get_hover_animations_input( $type = 'hover_animations', $overwrite = array() ) {
1585 1585
 
1586
-	$options = array(
1587
-		''                 => __( 'none', 'super-duper' ),
1588
-		'hover-zoom'       => __( 'Zoom', 'super-duper' ),
1589
-		'hover-shadow'     => __( 'Shadow', 'super-duper' ),
1590
-		'hover-move-up'    => __( 'Move up', 'super-duper' ),
1591
-		'hover-move-down'  => __( 'Move down', 'super-duper' ),
1592
-		'hover-move-left'  => __( 'Move left', 'super-duper' ),
1593
-		'hover-move-right' => __( 'Move right', 'super-duper' ),
1594
-	);
1595
-
1596
-	$defaults = array(
1597
-		'type'     => 'select',
1598
-		'multiple' => true,
1599
-		'title'    => __( 'Hover Animations', 'super-duper' ),
1600
-		'options'  => $options,
1601
-		'default'  => '',
1602
-		'desc_tip' => true,
1603
-		'group'    => __( 'Hover Animations', 'super-duper' ),
1604
-	);
1605
-
1606
-	$input = wp_parse_args( $overwrite, $defaults );
1607
-
1608
-	return $input;
1586
+    $options = array(
1587
+        ''                 => __( 'none', 'super-duper' ),
1588
+        'hover-zoom'       => __( 'Zoom', 'super-duper' ),
1589
+        'hover-shadow'     => __( 'Shadow', 'super-duper' ),
1590
+        'hover-move-up'    => __( 'Move up', 'super-duper' ),
1591
+        'hover-move-down'  => __( 'Move down', 'super-duper' ),
1592
+        'hover-move-left'  => __( 'Move left', 'super-duper' ),
1593
+        'hover-move-right' => __( 'Move right', 'super-duper' ),
1594
+    );
1595
+
1596
+    $defaults = array(
1597
+        'type'     => 'select',
1598
+        'multiple' => true,
1599
+        'title'    => __( 'Hover Animations', 'super-duper' ),
1600
+        'options'  => $options,
1601
+        'default'  => '',
1602
+        'desc_tip' => true,
1603
+        'group'    => __( 'Hover Animations', 'super-duper' ),
1604
+    );
1605
+
1606
+    $input = wp_parse_args( $overwrite, $defaults );
1607
+
1608
+    return $input;
1609 1609
 }
1610 1610
 
1611 1611
 
1612 1612
 function sd_get_flex_align_items_input( $type = 'align-items', $overwrite = array() ) {
1613
-	$device_size = '';
1614
-	if ( ! empty( $overwrite['device_type'] ) ) {
1615
-		if ( $overwrite['device_type'] == 'Tablet' ) {
1616
-			$device_size = '-md';
1617
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
1618
-			$device_size = '-lg';
1619
-		}
1620
-	}
1621
-	$options = array(
1622
-		''                                         => __( 'Default', 'super-duper' ),
1623
-		'align-items' . $device_size . '-start'    => 'align-items-start',
1624
-		'align-items' . $device_size . '-end'      => 'align-items-end',
1625
-		'align-items' . $device_size . '-center'   => 'align-items-center',
1626
-		'align-items' . $device_size . '-baseline' => 'align-items-baseline',
1627
-		'align-items' . $device_size . '-stretch'  => 'align-items-stretch',
1628
-	);
1629
-
1630
-	$defaults = array(
1631
-		'type'            => 'select',
1632
-		'title'           => __( 'Vertical Align Items', 'super-duper' ),
1633
-		'options'         => $options,
1634
-		'default'         => '',
1635
-		'desc_tip'        => true,
1636
-		'group'           => __( 'Wrapper Styles', 'super-duper' ),
1637
-		'element_require' => ' ( ( [%container%]=="row" ) || ( [%display%]=="d-flex" || [%display_md%]=="d-md-flex" || [%display_lg%]=="d-lg-flex" ) ) ',
1638
-
1639
-	);
1640
-
1641
-	$input = wp_parse_args( $overwrite, $defaults );
1642
-
1643
-	return $input;
1613
+    $device_size = '';
1614
+    if ( ! empty( $overwrite['device_type'] ) ) {
1615
+        if ( $overwrite['device_type'] == 'Tablet' ) {
1616
+            $device_size = '-md';
1617
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
1618
+            $device_size = '-lg';
1619
+        }
1620
+    }
1621
+    $options = array(
1622
+        ''                                         => __( 'Default', 'super-duper' ),
1623
+        'align-items' . $device_size . '-start'    => 'align-items-start',
1624
+        'align-items' . $device_size . '-end'      => 'align-items-end',
1625
+        'align-items' . $device_size . '-center'   => 'align-items-center',
1626
+        'align-items' . $device_size . '-baseline' => 'align-items-baseline',
1627
+        'align-items' . $device_size . '-stretch'  => 'align-items-stretch',
1628
+    );
1629
+
1630
+    $defaults = array(
1631
+        'type'            => 'select',
1632
+        'title'           => __( 'Vertical Align Items', 'super-duper' ),
1633
+        'options'         => $options,
1634
+        'default'         => '',
1635
+        'desc_tip'        => true,
1636
+        'group'           => __( 'Wrapper Styles', 'super-duper' ),
1637
+        'element_require' => ' ( ( [%container%]=="row" ) || ( [%display%]=="d-flex" || [%display_md%]=="d-md-flex" || [%display_lg%]=="d-lg-flex" ) ) ',
1638
+
1639
+    );
1640
+
1641
+    $input = wp_parse_args( $overwrite, $defaults );
1642
+
1643
+    return $input;
1644 1644
 }
1645 1645
 
1646 1646
 function sd_get_flex_align_items_input_group( $type = 'flex_align_items', $overwrite = array() ) {
1647
-	$inputs = array();
1648
-	$sizes  = array(
1649
-		''    => 'Mobile',
1650
-		'_md' => 'Tablet',
1651
-		'_lg' => 'Desktop',
1652
-	);
1653
-
1654
-	if ( $overwrite !== false ) {
1655
-
1656
-		foreach ( $sizes as $ds => $dt ) {
1657
-			$overwrite['device_type'] = $dt;
1658
-			$inputs[ $type . $ds ]    = sd_get_flex_align_items_input( $type, $overwrite );
1659
-		}
1660
-	}
1661
-
1662
-	return $inputs;
1647
+    $inputs = array();
1648
+    $sizes  = array(
1649
+        ''    => 'Mobile',
1650
+        '_md' => 'Tablet',
1651
+        '_lg' => 'Desktop',
1652
+    );
1653
+
1654
+    if ( $overwrite !== false ) {
1655
+
1656
+        foreach ( $sizes as $ds => $dt ) {
1657
+            $overwrite['device_type'] = $dt;
1658
+            $inputs[ $type . $ds ]    = sd_get_flex_align_items_input( $type, $overwrite );
1659
+        }
1660
+    }
1661
+
1662
+    return $inputs;
1663 1663
 }
1664 1664
 
1665 1665
 function sd_get_flex_justify_content_input( $type = 'flex_justify_content', $overwrite = array() ) {
1666
-	$device_size = '';
1667
-	if ( ! empty( $overwrite['device_type'] ) ) {
1668
-		if ( $overwrite['device_type'] == 'Tablet' ) {
1669
-			$device_size = '-md';
1670
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
1671
-			$device_size = '-lg';
1672
-		}
1673
-	}
1674
-	$options = array(
1675
-		''                                            => __( 'Default', 'super-duper' ),
1676
-		'justify-content' . $device_size . '-start'   => 'justify-content-start',
1677
-		'justify-content' . $device_size . '-end'     => 'justify-content-end',
1678
-		'justify-content' . $device_size . '-center'  => 'justify-content-center',
1679
-		'justify-content' . $device_size . '-between' => 'justify-content-between',
1680
-		'justify-content' . $device_size . '-stretch' => 'justify-content-around',
1681
-	);
1682
-
1683
-	$defaults = array(
1684
-		'type'            => 'select',
1685
-		'title'           => __( 'Justify content' ),
1686
-		'options'         => $options,
1687
-		'default'         => '',
1688
-		'desc_tip'        => true,
1689
-		'group'           => __( 'Wrapper Styles', 'super-duper' ),
1690
-		'element_require' => '( ( [%container%]=="row" ) || ( [%display%]=="d-flex" || [%display_md%]=="d-md-flex" || [%display_lg%]=="d-lg-flex" ) ) ',
1691
-
1692
-	);
1693
-
1694
-	$input = wp_parse_args( $overwrite, $defaults );
1695
-
1696
-	return $input;
1666
+    $device_size = '';
1667
+    if ( ! empty( $overwrite['device_type'] ) ) {
1668
+        if ( $overwrite['device_type'] == 'Tablet' ) {
1669
+            $device_size = '-md';
1670
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
1671
+            $device_size = '-lg';
1672
+        }
1673
+    }
1674
+    $options = array(
1675
+        ''                                            => __( 'Default', 'super-duper' ),
1676
+        'justify-content' . $device_size . '-start'   => 'justify-content-start',
1677
+        'justify-content' . $device_size . '-end'     => 'justify-content-end',
1678
+        'justify-content' . $device_size . '-center'  => 'justify-content-center',
1679
+        'justify-content' . $device_size . '-between' => 'justify-content-between',
1680
+        'justify-content' . $device_size . '-stretch' => 'justify-content-around',
1681
+    );
1682
+
1683
+    $defaults = array(
1684
+        'type'            => 'select',
1685
+        'title'           => __( 'Justify content' ),
1686
+        'options'         => $options,
1687
+        'default'         => '',
1688
+        'desc_tip'        => true,
1689
+        'group'           => __( 'Wrapper Styles', 'super-duper' ),
1690
+        'element_require' => '( ( [%container%]=="row" ) || ( [%display%]=="d-flex" || [%display_md%]=="d-md-flex" || [%display_lg%]=="d-lg-flex" ) ) ',
1691
+
1692
+    );
1693
+
1694
+    $input = wp_parse_args( $overwrite, $defaults );
1695
+
1696
+    return $input;
1697 1697
 }
1698 1698
 
1699 1699
 function sd_get_flex_justify_content_input_group( $type = 'flex_justify_content', $overwrite = array() ) {
1700
-	$inputs = array();
1701
-	$sizes  = array(
1702
-		''    => 'Mobile',
1703
-		'_md' => 'Tablet',
1704
-		'_lg' => 'Desktop',
1705
-	);
1706
-
1707
-	if ( $overwrite !== false ) {
1708
-
1709
-		foreach ( $sizes as $ds => $dt ) {
1710
-			$overwrite['device_type'] = $dt;
1711
-			$inputs[ $type . $ds ]    = sd_get_flex_justify_content_input( $type, $overwrite );
1712
-		}
1713
-	}
1714
-
1715
-	return $inputs;
1700
+    $inputs = array();
1701
+    $sizes  = array(
1702
+        ''    => 'Mobile',
1703
+        '_md' => 'Tablet',
1704
+        '_lg' => 'Desktop',
1705
+    );
1706
+
1707
+    if ( $overwrite !== false ) {
1708
+
1709
+        foreach ( $sizes as $ds => $dt ) {
1710
+            $overwrite['device_type'] = $dt;
1711
+            $inputs[ $type . $ds ]    = sd_get_flex_justify_content_input( $type, $overwrite );
1712
+        }
1713
+    }
1714
+
1715
+    return $inputs;
1716 1716
 }
1717 1717
 
1718 1718
 
1719 1719
 function sd_get_flex_align_self_input( $type = 'flex_align_self', $overwrite = array() ) {
1720
-	$device_size = '';
1721
-	if ( ! empty( $overwrite['device_type'] ) ) {
1722
-		if ( $overwrite['device_type'] == 'Tablet' ) {
1723
-			$device_size = '-md';
1724
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
1725
-			$device_size = '-lg';
1726
-		}
1727
-	}
1728
-	$options = array(
1729
-		''                                         => __( 'Default', 'super-duper' ),
1730
-		'align-items' . $device_size . '-start'    => 'align-items-start',
1731
-		'align-items' . $device_size . '-end'      => 'align-items-end',
1732
-		'align-items' . $device_size . '-center'   => 'align-items-center',
1733
-		'align-items' . $device_size . '-baseline' => 'align-items-baseline',
1734
-		'align-items' . $device_size . '-stretch'  => 'align-items-stretch',
1735
-	);
1736
-
1737
-	$defaults = array(
1738
-		'type'            => 'select',
1739
-		'title'           => __( 'Align Self', 'super-duper' ),
1740
-		'options'         => $options,
1741
-		'default'         => '',
1742
-		'desc_tip'        => true,
1743
-		'group'           => __( 'Wrapper Styles', 'super-duper' ),
1744
-		'element_require' => ' [%container%]=="col" ',
1745
-
1746
-	);
1747
-
1748
-	$input = wp_parse_args( $overwrite, $defaults );
1749
-
1750
-	return $input;
1720
+    $device_size = '';
1721
+    if ( ! empty( $overwrite['device_type'] ) ) {
1722
+        if ( $overwrite['device_type'] == 'Tablet' ) {
1723
+            $device_size = '-md';
1724
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
1725
+            $device_size = '-lg';
1726
+        }
1727
+    }
1728
+    $options = array(
1729
+        ''                                         => __( 'Default', 'super-duper' ),
1730
+        'align-items' . $device_size . '-start'    => 'align-items-start',
1731
+        'align-items' . $device_size . '-end'      => 'align-items-end',
1732
+        'align-items' . $device_size . '-center'   => 'align-items-center',
1733
+        'align-items' . $device_size . '-baseline' => 'align-items-baseline',
1734
+        'align-items' . $device_size . '-stretch'  => 'align-items-stretch',
1735
+    );
1736
+
1737
+    $defaults = array(
1738
+        'type'            => 'select',
1739
+        'title'           => __( 'Align Self', 'super-duper' ),
1740
+        'options'         => $options,
1741
+        'default'         => '',
1742
+        'desc_tip'        => true,
1743
+        'group'           => __( 'Wrapper Styles', 'super-duper' ),
1744
+        'element_require' => ' [%container%]=="col" ',
1745
+
1746
+    );
1747
+
1748
+    $input = wp_parse_args( $overwrite, $defaults );
1749
+
1750
+    return $input;
1751 1751
 }
1752 1752
 
1753 1753
 function sd_get_flex_align_self_input_group( $type = 'flex_align_self', $overwrite = array() ) {
1754
-	$inputs = array();
1755
-	$sizes  = array(
1756
-		''    => 'Mobile',
1757
-		'_md' => 'Tablet',
1758
-		'_lg' => 'Desktop',
1759
-	);
1760
-
1761
-	if ( $overwrite !== false ) {
1762
-
1763
-		foreach ( $sizes as $ds => $dt ) {
1764
-			$overwrite['device_type'] = $dt;
1765
-			$inputs[ $type . $ds ]    = sd_get_flex_align_self_input( $type, $overwrite );
1766
-		}
1767
-	}
1768
-
1769
-	return $inputs;
1754
+    $inputs = array();
1755
+    $sizes  = array(
1756
+        ''    => 'Mobile',
1757
+        '_md' => 'Tablet',
1758
+        '_lg' => 'Desktop',
1759
+    );
1760
+
1761
+    if ( $overwrite !== false ) {
1762
+
1763
+        foreach ( $sizes as $ds => $dt ) {
1764
+            $overwrite['device_type'] = $dt;
1765
+            $inputs[ $type . $ds ]    = sd_get_flex_align_self_input( $type, $overwrite );
1766
+        }
1767
+    }
1768
+
1769
+    return $inputs;
1770 1770
 }
1771 1771
 
1772 1772
 function sd_get_flex_order_input( $type = 'flex_order', $overwrite = array() ) {
1773
-	$device_size = '';
1774
-	if ( ! empty( $overwrite['device_type'] ) ) {
1775
-		if ( $overwrite['device_type'] == 'Tablet' ) {
1776
-			$device_size = '-md';
1777
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
1778
-			$device_size = '-lg';
1779
-		}
1780
-	}
1781
-	$options = array(
1782
-		'' => __( 'Default', 'super-duper' ),
1783
-	);
1784
-
1785
-	$i = 0;
1786
-	while ( $i <= 5 ) {
1787
-		$options[ 'order' . $device_size . '-' . $i ] = $i;
1788
-		$i++;
1789
-	}
1790
-
1791
-	$defaults = array(
1792
-		'type'            => 'select',
1793
-		'title'           => __( 'Flex Order', 'super-duper' ),
1794
-		'options'         => $options,
1795
-		'default'         => '',
1796
-		'desc_tip'        => true,
1797
-		'group'           => __( 'Wrapper Styles', 'super-duper' ),
1798
-		'element_require' => ' [%container%]=="col" ',
1799
-
1800
-	);
1801
-
1802
-	$input = wp_parse_args( $overwrite, $defaults );
1803
-
1804
-	return $input;
1773
+    $device_size = '';
1774
+    if ( ! empty( $overwrite['device_type'] ) ) {
1775
+        if ( $overwrite['device_type'] == 'Tablet' ) {
1776
+            $device_size = '-md';
1777
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
1778
+            $device_size = '-lg';
1779
+        }
1780
+    }
1781
+    $options = array(
1782
+        '' => __( 'Default', 'super-duper' ),
1783
+    );
1784
+
1785
+    $i = 0;
1786
+    while ( $i <= 5 ) {
1787
+        $options[ 'order' . $device_size . '-' . $i ] = $i;
1788
+        $i++;
1789
+    }
1790
+
1791
+    $defaults = array(
1792
+        'type'            => 'select',
1793
+        'title'           => __( 'Flex Order', 'super-duper' ),
1794
+        'options'         => $options,
1795
+        'default'         => '',
1796
+        'desc_tip'        => true,
1797
+        'group'           => __( 'Wrapper Styles', 'super-duper' ),
1798
+        'element_require' => ' [%container%]=="col" ',
1799
+
1800
+    );
1801
+
1802
+    $input = wp_parse_args( $overwrite, $defaults );
1803
+
1804
+    return $input;
1805 1805
 }
1806 1806
 
1807 1807
 function sd_get_flex_order_input_group( $type = 'flex_order', $overwrite = array() ) {
1808
-	$inputs = array();
1809
-	$sizes  = array(
1810
-		''    => 'Mobile',
1811
-		'_md' => 'Tablet',
1812
-		'_lg' => 'Desktop',
1813
-	);
1814
-
1815
-	if ( $overwrite !== false ) {
1816
-
1817
-		foreach ( $sizes as $ds => $dt ) {
1818
-			$overwrite['device_type'] = $dt;
1819
-			$inputs[ $type . $ds ]    = sd_get_flex_order_input( $type, $overwrite );
1820
-		}
1821
-	}
1822
-
1823
-	return $inputs;
1808
+    $inputs = array();
1809
+    $sizes  = array(
1810
+        ''    => 'Mobile',
1811
+        '_md' => 'Tablet',
1812
+        '_lg' => 'Desktop',
1813
+    );
1814
+
1815
+    if ( $overwrite !== false ) {
1816
+
1817
+        foreach ( $sizes as $ds => $dt ) {
1818
+            $overwrite['device_type'] = $dt;
1819
+            $inputs[ $type . $ds ]    = sd_get_flex_order_input( $type, $overwrite );
1820
+        }
1821
+    }
1822
+
1823
+    return $inputs;
1824 1824
 }
1825 1825
 
1826 1826
 function sd_get_flex_wrap_group( $type = 'flex_wrap', $overwrite = array() ) {
1827
-	$inputs = array();
1828
-	$sizes  = array(
1829
-		''    => 'Mobile',
1830
-		'_md' => 'Tablet',
1831
-		'_lg' => 'Desktop',
1832
-	);
1833
-
1834
-	if ( $overwrite !== false ) {
1835
-
1836
-		foreach ( $sizes as $ds => $dt ) {
1837
-			$overwrite['device_type'] = $dt;
1838
-			$inputs[ $type . $ds ]    = sd_get_flex_wrap_input( $type, $overwrite );
1839
-		}
1840
-	}
1841
-
1842
-	return $inputs;
1827
+    $inputs = array();
1828
+    $sizes  = array(
1829
+        ''    => 'Mobile',
1830
+        '_md' => 'Tablet',
1831
+        '_lg' => 'Desktop',
1832
+    );
1833
+
1834
+    if ( $overwrite !== false ) {
1835
+
1836
+        foreach ( $sizes as $ds => $dt ) {
1837
+            $overwrite['device_type'] = $dt;
1838
+            $inputs[ $type . $ds ]    = sd_get_flex_wrap_input( $type, $overwrite );
1839
+        }
1840
+    }
1841
+
1842
+    return $inputs;
1843 1843
 }
1844 1844
 
1845 1845
 function sd_get_flex_wrap_input( $type = 'flex_wrap', $overwrite = array() ) {
1846
-	$device_size = '';
1847
-	if ( ! empty( $overwrite['device_type'] ) ) {
1848
-		if ( $overwrite['device_type'] == 'Tablet' ) {
1849
-			$device_size = '-md';
1850
-		} elseif ( $overwrite['device_type'] == 'Desktop' ) {
1851
-			$device_size = '-lg';
1852
-		}
1853
-	}
1854
-	$options = array(
1855
-		''                                      => __( 'Default', 'super-duper' ),
1856
-		'flex' . $device_size . '-nowrap'       => 'nowrap',
1857
-		'flex' . $device_size . '-wrap'         => 'wrap',
1858
-		'flex' . $device_size . '-wrap-reverse' => 'wrap-reverse',
1859
-	);
1860
-
1861
-	$defaults = array(
1862
-		'type'     => 'select',
1863
-		'title'    => __( 'Flex wrap', 'super-duper' ),
1864
-		'options'  => $options,
1865
-		'default'  => '',
1866
-		'desc_tip' => true,
1867
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
1868
-	);
1869
-
1870
-	$input = wp_parse_args( $overwrite, $defaults );
1871
-
1872
-	return $input;
1846
+    $device_size = '';
1847
+    if ( ! empty( $overwrite['device_type'] ) ) {
1848
+        if ( $overwrite['device_type'] == 'Tablet' ) {
1849
+            $device_size = '-md';
1850
+        } elseif ( $overwrite['device_type'] == 'Desktop' ) {
1851
+            $device_size = '-lg';
1852
+        }
1853
+    }
1854
+    $options = array(
1855
+        ''                                      => __( 'Default', 'super-duper' ),
1856
+        'flex' . $device_size . '-nowrap'       => 'nowrap',
1857
+        'flex' . $device_size . '-wrap'         => 'wrap',
1858
+        'flex' . $device_size . '-wrap-reverse' => 'wrap-reverse',
1859
+    );
1860
+
1861
+    $defaults = array(
1862
+        'type'     => 'select',
1863
+        'title'    => __( 'Flex wrap', 'super-duper' ),
1864
+        'options'  => $options,
1865
+        'default'  => '',
1866
+        'desc_tip' => true,
1867
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
1868
+    );
1869
+
1870
+    $input = wp_parse_args( $overwrite, $defaults );
1871
+
1872
+    return $input;
1873 1873
 }
1874 1874
 
1875 1875
 /**
@@ -1880,26 +1880,26 @@  discard block
 block discarded – undo
1880 1880
  */
1881 1881
 function sd_get_zindex_input( $type = 'zindex', $overwrite = array() ) {
1882 1882
 
1883
-	$options = array(
1884
-		''          => __( 'Default', 'super-duper' ),
1885
-		'zindex-0'  => '0',
1886
-		'zindex-1'  => '1',
1887
-		'zindex-5'  => '5',
1888
-		'zindex-10' => '10',
1889
-	);
1890
-
1891
-	$defaults = array(
1892
-		'type'     => 'select',
1893
-		'title'    => __( 'Z-index', 'super-duper' ),
1894
-		'options'  => $options,
1895
-		'default'  => '',
1896
-		'desc_tip' => true,
1897
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
1898
-	);
1899
-
1900
-	$input = wp_parse_args( $overwrite, $defaults );
1901
-
1902
-	return $input;
1883
+    $options = array(
1884
+        ''          => __( 'Default', 'super-duper' ),
1885
+        'zindex-0'  => '0',
1886
+        'zindex-1'  => '1',
1887
+        'zindex-5'  => '5',
1888
+        'zindex-10' => '10',
1889
+    );
1890
+
1891
+    $defaults = array(
1892
+        'type'     => 'select',
1893
+        'title'    => __( 'Z-index', 'super-duper' ),
1894
+        'options'  => $options,
1895
+        'default'  => '',
1896
+        'desc_tip' => true,
1897
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
1898
+    );
1899
+
1900
+    $input = wp_parse_args( $overwrite, $defaults );
1901
+
1902
+    return $input;
1903 1903
 }
1904 1904
 
1905 1905
 /**
@@ -1910,26 +1910,26 @@  discard block
 block discarded – undo
1910 1910
  */
1911 1911
 function sd_get_overflow_input( $type = 'overflow', $overwrite = array() ) {
1912 1912
 
1913
-	$options = array(
1914
-		''                 => __( 'Default', 'super-duper' ),
1915
-		'overflow-auto'    => __( 'Auto', 'super-duper' ),
1916
-		'overflow-hidden'  => __( 'Hidden', 'super-duper' ),
1917
-		'overflow-visible' => __( 'Visible', 'super-duper' ),
1918
-		'overflow-scroll'  => __( 'Scroll', 'super-duper' ),
1919
-	);
1920
-
1921
-	$defaults = array(
1922
-		'type'     => 'select',
1923
-		'title'    => __( 'Overflow', 'super-duper' ),
1924
-		'options'  => $options,
1925
-		'default'  => '',
1926
-		'desc_tip' => true,
1927
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
1928
-	);
1929
-
1930
-	$input = wp_parse_args( $overwrite, $defaults );
1931
-
1932
-	return $input;
1913
+    $options = array(
1914
+        ''                 => __( 'Default', 'super-duper' ),
1915
+        'overflow-auto'    => __( 'Auto', 'super-duper' ),
1916
+        'overflow-hidden'  => __( 'Hidden', 'super-duper' ),
1917
+        'overflow-visible' => __( 'Visible', 'super-duper' ),
1918
+        'overflow-scroll'  => __( 'Scroll', 'super-duper' ),
1919
+    );
1920
+
1921
+    $defaults = array(
1922
+        'type'     => 'select',
1923
+        'title'    => __( 'Overflow', 'super-duper' ),
1924
+        'options'  => $options,
1925
+        'default'  => '',
1926
+        'desc_tip' => true,
1927
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
1928
+    );
1929
+
1930
+    $input = wp_parse_args( $overwrite, $defaults );
1931
+
1932
+    return $input;
1933 1933
 }
1934 1934
 
1935 1935
 /**
@@ -1940,40 +1940,40 @@  discard block
 block discarded – undo
1940 1940
  */
1941 1941
 function sd_get_max_height_input( $type = 'max_height', $overwrite = array() ) {
1942 1942
 
1943
-	$defaults = array(
1944
-		'type'        => 'text',
1945
-		'title'       => __( 'Max height', 'super-duper' ),
1946
-		'value'       => '',
1947
-		'default'     => '',
1948
-		'placeholder' => '',
1949
-		'desc_tip'    => true,
1950
-		'group'       => __( 'Wrapper Styles', 'super-duper' ),
1951
-	);
1943
+    $defaults = array(
1944
+        'type'        => 'text',
1945
+        'title'       => __( 'Max height', 'super-duper' ),
1946
+        'value'       => '',
1947
+        'default'     => '',
1948
+        'placeholder' => '',
1949
+        'desc_tip'    => true,
1950
+        'group'       => __( 'Wrapper Styles', 'super-duper' ),
1951
+    );
1952 1952
 
1953
-	$input = wp_parse_args( $overwrite, $defaults );
1953
+    $input = wp_parse_args( $overwrite, $defaults );
1954 1954
 
1955
-	return $input;
1955
+    return $input;
1956 1956
 }
1957 1957
 
1958 1958
 function sd_get_scrollbars_input( $type = 'scrollbars', $overwrite = array() ) {
1959 1959
 
1960
-	$options = array(
1961
-		''               => __( 'Default', 'super-duper' ),
1962
-		'scrollbars-ios' => __( 'IOS Style', 'super-duper' ),
1963
-	);
1960
+    $options = array(
1961
+        ''               => __( 'Default', 'super-duper' ),
1962
+        'scrollbars-ios' => __( 'IOS Style', 'super-duper' ),
1963
+    );
1964 1964
 
1965
-	$defaults = array(
1966
-		'type'     => 'select',
1967
-		'title'    => __( 'Scrollbars', 'super-duper' ),
1968
-		'options'  => $options,
1969
-		'default'  => '',
1970
-		'desc_tip' => true,
1971
-		'group'    => __( 'Wrapper Styles', 'super-duper' ),
1972
-	);
1965
+    $defaults = array(
1966
+        'type'     => 'select',
1967
+        'title'    => __( 'Scrollbars', 'super-duper' ),
1968
+        'options'  => $options,
1969
+        'default'  => '',
1970
+        'desc_tip' => true,
1971
+        'group'    => __( 'Wrapper Styles', 'super-duper' ),
1972
+    );
1973 1973
 
1974
-	$input = wp_parse_args( $overwrite, $defaults );
1974
+    $input = wp_parse_args( $overwrite, $defaults );
1975 1975
 
1976
-	return $input;
1976
+    return $input;
1977 1977
 }
1978 1978
 
1979 1979
 /**
@@ -1985,415 +1985,415 @@  discard block
 block discarded – undo
1985 1985
  * @todo find best way to use px- py- or general p-
1986 1986
  */
1987 1987
 function sd_build_aui_class( $args ) {
1988
-	global $aui_bs5;
1989
-
1990
-	$classes = array();
1991
-
1992
-	if ( $aui_bs5 ) {
1993
-		$p_ml = 'ms-';
1994
-		$p_mr = 'me-';
1995
-
1996
-		$p_pl = 'ps-';
1997
-		$p_pr = 'pe-';
1998
-	} else {
1999
-		$p_ml = 'ml-';
2000
-		$p_mr = 'mr-';
2001
-
2002
-		$p_pl = 'pl-';
2003
-		$p_pr = 'pr-';
2004
-	}
2005
-
2006
-	// margins.
2007
-	if ( isset( $args['mt'] ) && $args['mt'] !== '' ) {
2008
-		$classes[] = 'mt-' . sanitize_html_class( $args['mt'] );
2009
-		$mt        = $args['mt'];
2010
-	} else {
2011
-		$mt = null;
2012
-	}
2013
-	if ( isset( $args['mr'] ) && $args['mr'] !== '' ) {
2014
-		$classes[] = $p_mr . sanitize_html_class( $args['mr'] );
2015
-		$mr        = $args['mr'];
2016
-	} else {
2017
-		$mr = null;
2018
-	}
2019
-	if ( isset( $args['mb'] ) && $args['mb'] !== '' ) {
2020
-		$classes[] = 'mb-' . sanitize_html_class( $args['mb'] );
2021
-		$mb        = $args['mb'];
2022
-	} else {
2023
-		$mb = null;
2024
-	}
2025
-	if ( isset( $args['ml'] ) && $args['ml'] !== '' ) {
2026
-		$classes[] = $p_ml . sanitize_html_class( $args['ml'] );
2027
-		$ml        = $args['ml'];
2028
-	} else {
2029
-		$ml = null;
2030
-	}
2031
-
2032
-	// margins tablet.
2033
-	if ( isset( $args['mt_md'] ) && $args['mt_md'] !== '' ) {
2034
-		$classes[] = 'mt-md-' . sanitize_html_class( $args['mt_md'] );
2035
-		$mt_md     = $args['mt_md'];
2036
-	} else {
2037
-		$mt_md = null;
2038
-	}
2039
-	if ( isset( $args['mr_md'] ) && $args['mr_md'] !== '' ) {
2040
-		$classes[] = $p_mr . 'md-' . sanitize_html_class( $args['mr_md'] );
2041
-		$mt_md     = $args['mr_md'];
2042
-	} else {
2043
-		$mr_md = null;
2044
-	}
2045
-	if ( isset( $args['mb_md'] ) && $args['mb_md'] !== '' ) {
2046
-		$classes[] = 'mb-md-' . sanitize_html_class( $args['mb_md'] );
2047
-		$mt_md     = $args['mb_md'];
2048
-	} else {
2049
-		$mb_md = null;
2050
-	}
2051
-	if ( isset( $args['ml_md'] ) && $args['ml_md'] !== '' ) {
2052
-		$classes[] = $p_ml . 'md-' . sanitize_html_class( $args['ml_md'] );
2053
-		$mt_md     = $args['ml_md'];
2054
-	} else {
2055
-		$ml_md = null;
2056
-	}
2057
-
2058
-	// margins desktop.
2059
-	if ( isset( $args['mt_lg'] ) && $args['mt_lg'] !== '' ) {
2060
-		if ( $mt == null && $mt_md == null ) {
2061
-			$classes[] = 'mt-' . sanitize_html_class( $args['mt_lg'] );
2062
-		} else {
2063
-			$classes[] = 'mt-lg-' . sanitize_html_class( $args['mt_lg'] );
2064
-		}
2065
-	}
2066
-	if ( isset( $args['mr_lg'] ) && $args['mr_lg'] !== '' ) {
2067
-		if ( $mr == null && $mr_md == null ) {
2068
-			$classes[] = $p_mr . sanitize_html_class( $args['mr_lg'] );
2069
-		} else {
2070
-			$classes[] = $p_mr . 'lg-' . sanitize_html_class( $args['mr_lg'] );
2071
-		}
2072
-	}
2073
-	if ( isset( $args['mb_lg'] ) && $args['mb_lg'] !== '' ) {
2074
-		if ( $mb == null && $mb_md == null ) {
2075
-			$classes[] = 'mb-' . sanitize_html_class( $args['mb_lg'] );
2076
-		} else {
2077
-			$classes[] = 'mb-lg-' . sanitize_html_class( $args['mb_lg'] );
2078
-		}
2079
-	}
2080
-	if ( isset( $args['ml_lg'] ) && $args['ml_lg'] !== '' ) {
2081
-		if ( $ml == null && $ml_md == null ) {
2082
-			$classes[] = $p_ml . sanitize_html_class( $args['ml_lg'] );
2083
-		} else {
2084
-			$classes[] = $p_ml . 'lg-' . sanitize_html_class( $args['ml_lg'] );
2085
-		}
2086
-	}
2087
-
2088
-	// padding.
2089
-	if ( isset( $args['pt'] ) && $args['pt'] !== '' ) {
2090
-		$classes[] = 'pt-' . sanitize_html_class( $args['pt'] );
2091
-		$pt        = $args['pt'];
2092
-	} else {
2093
-		$pt = null;
2094
-	}
2095
-	if ( isset( $args['pr'] ) && $args['pr'] !== '' ) {
2096
-		$classes[] = $p_pr . sanitize_html_class( $args['pr'] );
2097
-		$pr        = $args['pr'];
2098
-	} else {
2099
-		$pr = null;
2100
-	}
2101
-	if ( isset( $args['pb'] ) && $args['pb'] !== '' ) {
2102
-		$classes[] = 'pb-' . sanitize_html_class( $args['pb'] );
2103
-		$pb        = $args['pb'];
2104
-	} else {
2105
-		$pb = null;
2106
-	}
2107
-	if ( isset( $args['pl'] ) && $args['pl'] !== '' ) {
2108
-		$classes[] = $p_pl . sanitize_html_class( $args['pl'] );
2109
-		$pl        = $args['pl'];
2110
-	} else {
2111
-		$pl = null;
2112
-	}
2113
-
2114
-	// padding tablet.
2115
-	if ( isset( $args['pt_md'] ) && $args['pt_md'] !== '' ) {
2116
-		$classes[] = 'pt-md-' . sanitize_html_class( $args['pt_md'] );
2117
-		$pt_md     = $args['pt_md'];
2118
-	} else {
2119
-		$pt_md = null;
2120
-	}
2121
-	if ( isset( $args['pr_md'] ) && $args['pr_md'] !== '' ) {
2122
-		$classes[] = $p_pr . 'md-' . sanitize_html_class( $args['pr_md'] );
2123
-		$pt_md     = $args['pr_md'];
2124
-	} else {
2125
-		$pr_md = null;
2126
-	}
2127
-	if ( isset( $args['pb_md'] ) && $args['pb_md'] !== '' ) {
2128
-		$classes[] = 'pb-md-' . sanitize_html_class( $args['pb_md'] );
2129
-		$pt_md     = $args['pb_md'];
2130
-	} else {
2131
-		$pb_md = null;
2132
-	}
2133
-	if ( isset( $args['pl_md'] ) && $args['pl_md'] !== '' ) {
2134
-		$classes[] = $p_pl . 'md-' . sanitize_html_class( $args['pl_md'] );
2135
-		$pt_md     = $args['pl_md'];
2136
-	} else {
2137
-		$pl_md = null;
2138
-	}
2139
-
2140
-	// padding desktop.
2141
-	if ( isset( $args['pt_lg'] ) && $args['pt_lg'] !== '' ) {
2142
-		if ( $pt == null && $pt_md == null ) {
2143
-			$classes[] = 'pt-' . sanitize_html_class( $args['pt_lg'] );
2144
-		} else {
2145
-			$classes[] = 'pt-lg-' . sanitize_html_class( $args['pt_lg'] );
2146
-		}
2147
-	}
2148
-	if ( isset( $args['pr_lg'] ) && $args['pr_lg'] !== '' ) {
2149
-		if ( $pr == null && $pr_md == null ) {
2150
-			$classes[] = $p_pr . sanitize_html_class( $args['pr_lg'] );
2151
-		} else {
2152
-			$classes[] = $p_pr . 'lg-' . sanitize_html_class( $args['pr_lg'] );
2153
-		}
2154
-	}
2155
-	if ( isset( $args['pb_lg'] ) && $args['pb_lg'] !== '' ) {
2156
-		if ( $pb == null && $pb_md == null ) {
2157
-			$classes[] = 'pb-' . sanitize_html_class( $args['pb_lg'] );
2158
-		} else {
2159
-			$classes[] = 'pb-lg-' . sanitize_html_class( $args['pb_lg'] );
2160
-		}
2161
-	}
2162
-	if ( isset( $args['pl_lg'] ) && $args['pl_lg'] !== '' ) {
2163
-		if ( $pl == null && $pl_md == null ) {
2164
-			$classes[] = $p_pl . sanitize_html_class( $args['pl_lg'] );
2165
-		} else {
2166
-			$classes[] = $p_pl . 'lg-' . sanitize_html_class( $args['pl_lg'] );
2167
-		}
2168
-	}
2169
-
2170
-	// row cols, mobile, tablet, desktop
2171
-	if ( ! empty( $args['row_cols'] ) && $args['row_cols'] !== '' ) {
2172
-		$classes[] = sanitize_html_class( 'row-cols-' . $args['row_cols'] );
2173
-		$row_cols  = $args['row_cols'];
2174
-	} else {
2175
-		$row_cols = null;
2176
-	}
2177
-	if ( ! empty( $args['row_cols_md'] ) && $args['row_cols_md'] !== '' ) {
2178
-		$classes[]   = sanitize_html_class( 'row-cols-md-' . $args['row_cols_md'] );
2179
-		$row_cols_md = $args['row_cols_md'];
2180
-	} else {
2181
-		$row_cols_md = null;
2182
-	}
2183
-	if ( ! empty( $args['row_cols_lg'] ) && $args['row_cols_lg'] !== '' ) {
2184
-		if ( $row_cols == null && $row_cols_md == null ) {
2185
-			$classes[] = sanitize_html_class( 'row-cols-' . $args['row_cols_lg'] );
2186
-		} else {
2187
-			$classes[] = sanitize_html_class( 'row-cols-lg-' . $args['row_cols_lg'] );
2188
-		}
2189
-	}
2190
-
2191
-	// columns , mobile, tablet, desktop
2192
-	if ( ! empty( $args['col'] ) && $args['col'] !== '' ) {
2193
-		$classes[] = sanitize_html_class( 'col-' . $args['col'] );
2194
-		$col       = $args['col'];
2195
-	} else {
2196
-		$col = null;
2197
-	}
2198
-	if ( ! empty( $args['col_md'] ) && $args['col_md'] !== '' ) {
2199
-		$classes[] = sanitize_html_class( 'col-md-' . $args['col_md'] );
2200
-		$col_md    = $args['col_md'];
2201
-	} else {
2202
-		$col_md = null;
2203
-	}
2204
-	if ( ! empty( $args['col_lg'] ) && $args['col_lg'] !== '' ) {
2205
-		if ( $col == null && $col_md == null ) {
2206
-			$classes[] = sanitize_html_class( 'col-' . $args['col_lg'] );
2207
-		} else {
2208
-			$classes[] = sanitize_html_class( 'col-lg-' . $args['col_lg'] );
2209
-		}
2210
-	}
2211
-
2212
-	// border
2213
-	if ( isset( $args['border'] ) && ( $args['border'] == 'none' || $args['border'] === '0' || $args['border'] === 0 ) ) {
2214
-		$classes[] = 'border-0';
2215
-	} elseif ( ! empty( $args['border'] ) ) {
2216
-		$border_class = 'border';
2217
-		if ( ! empty( $args['border_type'] ) && strpos( $args['border_type'], '-0' ) === false ) {
2218
-			$border_class = '';
2219
-		}
2220
-		$classes[] = $border_class . ' border-' . sanitize_html_class( $args['border'] );
2221
-	}
2222
-
2223
-	// border radius type
2224
-	if ( ! empty( $args['rounded'] ) ) {
2225
-		$classes[] = sanitize_html_class( $args['rounded'] );
2226
-	}
2227
-
2228
-	// border radius size BS4
2229
-	if ( isset( $args['rounded_size'] ) && in_array( $args['rounded_size'], array( 'sm', 'lg' ) ) ) {
2230
-		$classes[] = 'rounded-' . sanitize_html_class( $args['rounded_size'] );
2231
-		// if we set a size then we need to remove "rounded" if set
2232
-		if ( ( $key = array_search( 'rounded', $classes ) ) !== false ) {
2233
-			unset( $classes[ $key ] );
2234
-		}
2235
-	} else {
2236
-
2237
-		// border radius size , mobile, tablet, desktop
2238
-		if ( isset( $args['rounded_size'] ) && $args['rounded_size'] !== '' ) {
2239
-			$classes[]    = sanitize_html_class( 'rounded-' . $args['rounded_size'] );
2240
-			$rounded_size = $args['rounded_size'];
2241
-		} else {
2242
-			$rounded_size = null;
2243
-		}
2244
-		if ( isset( $args['rounded_size_md'] ) && $args['rounded_size_md'] !== '' ) {
2245
-			$classes[]       = sanitize_html_class( 'rounded-md-' . $args['rounded_size_md'] );
2246
-			$rounded_size_md = $args['rounded_size_md'];
2247
-		} else {
2248
-			$rounded_size_md = null;
2249
-		}
2250
-		if ( isset( $args['rounded_size_lg'] ) && $args['rounded_size_lg'] !== '' ) {
2251
-			if ( $rounded_size == null && $rounded_size_md == null ) {
2252
-				$classes[] = sanitize_html_class( 'rounded-' . $args['rounded_size_lg'] );
2253
-			} else {
2254
-				$classes[] = sanitize_html_class( 'rounded-lg-' . $args['rounded_size_lg'] );
2255
-			}
2256
-		}
2257
-	}
2258
-
2259
-	// shadow
2260
-	//if ( !empty( $args['shadow'] ) ) { $classes[] = sanitize_html_class($args['shadow']); }
2261
-
2262
-	// background
2263
-	if ( ! empty( $args['bg'] ) ) {
2264
-		$classes[] = 'bg-' . sanitize_html_class( $args['bg'] );
2265
-	}
2266
-
2267
-	// text_color
2268
-	if ( ! empty( $args['text_color'] ) ) {
2269
-		$classes[] = 'text-' . sanitize_html_class( $args['text_color'] );
2270
-	}
2271
-
2272
-	// text_align
2273
-	if ( ! empty( $args['text_justify'] ) ) {
2274
-		$classes[] = 'text-justify';
2275
-	} else {
2276
-		if ( ! empty( $args['text_align'] ) ) {
2277
-			$classes[]  = sanitize_html_class( $args['text_align'] );
2278
-			$text_align = $args['text_align'];
2279
-		} else {
2280
-			$text_align = null;
2281
-		}
2282
-		if ( ! empty( $args['text_align_md'] ) && $args['text_align_md'] !== '' ) {
2283
-			$classes[]     = sanitize_html_class( $args['text_align_md'] );
2284
-			$text_align_md = $args['text_align_md'];
2285
-		} else {
2286
-			$text_align_md = null;
2287
-		}
2288
-		if ( ! empty( $args['text_align_lg'] ) && $args['text_align_lg'] !== '' ) {
2289
-			if ( $text_align == null && $text_align_md == null ) {
2290
-				$classes[] = sanitize_html_class( str_replace( '-lg', '', $args['text_align_lg'] ) );
2291
-			} else {
2292
-				$classes[] = sanitize_html_class( $args['text_align_lg'] );
2293
-			}
2294
-		}
2295
-	}
2296
-
2297
-	// display
2298
-	if ( ! empty( $args['display'] ) ) {
2299
-		$classes[] = sanitize_html_class( $args['display'] );
2300
-		$display   = $args['display'];
2301
-	} else {
2302
-		$display = null;
2303
-	}
2304
-	if ( ! empty( $args['display_md'] ) && $args['display_md'] !== '' ) {
2305
-		$classes[]  = sanitize_html_class( $args['display_md'] );
2306
-		$display_md = $args['display_md'];
2307
-	} else {
2308
-		$display_md = null;
2309
-	}
2310
-	if ( ! empty( $args['display_lg'] ) && $args['display_lg'] !== '' ) {
2311
-		if ( $display == null && $display_md == null ) {
2312
-			$classes[] = sanitize_html_class( str_replace( '-lg', '', $args['display_lg'] ) );
2313
-		} else {
2314
-			$classes[] = sanitize_html_class( $args['display_lg'] );
2315
-		}
2316
-	}
2317
-
2318
-	// bgtus - background transparent until scroll
2319
-	if ( ! empty( $args['bgtus'] ) ) {
2320
-		$classes[] = sanitize_html_class( 'bg-transparent-until-scroll' );
2321
-	}
2322
-
2323
-	// cscos - change color scheme on scroll
2324
-	if ( ! empty( $args['bgtus'] ) && ! empty( $args['cscos'] ) ) {
2325
-		$classes[] = sanitize_html_class( 'color-scheme-flip-on-scroll' );
2326
-	}
2327
-
2328
-	// hover animations
2329
-	if ( ! empty( $args['hover_animations'] ) ) {
2330
-		$classes[] = sd_sanitize_html_classes( str_replace( ',', ' ', $args['hover_animations'] ) );
2331
-	}
2332
-
2333
-	// absolute_position
2334
-	if ( ! empty( $args['absolute_position'] ) ) {
2335
-		if ( 'top-left' === $args['absolute_position'] ) {
2336
-			$classes[] = 'start-0 top-0';
2337
-		} elseif ( 'top-center' === $args['absolute_position'] ) {
2338
-			$classes[] = 'start-50 top-0 translate-middle';
2339
-		} elseif ( 'top-right' === $args['absolute_position'] ) {
2340
-			$classes[] = 'end-0 top-0';
2341
-		} elseif ( 'center-left' === $args['absolute_position'] ) {
2342
-			$classes[] = 'start-0 top-50';
2343
-		} elseif ( 'center' === $args['absolute_position'] ) {
2344
-			$classes[] = 'start-50 top-50 translate-middle';
2345
-		} elseif ( 'center-right' === $args['absolute_position'] ) {
2346
-			$classes[] = 'end-0 top-50';
2347
-		} elseif ( 'bottom-left' === $args['absolute_position'] ) {
2348
-			$classes[] = 'start-0 bottom-0';
2349
-		} elseif ( 'bottom-center' === $args['absolute_position'] ) {
2350
-			$classes[] = 'start-50 bottom-0 translate-middle';
2351
-		} elseif ( 'bottom-right' === $args['absolute_position'] ) {
2352
-			$classes[] = 'end-0 bottom-0';
2353
-		}
2354
-	}
2355
-
2356
-	// build classes from build keys
2357
-	$build_keys = sd_get_class_build_keys();
2358
-	if ( ! empty( $build_keys ) ) {
2359
-		foreach ( $build_keys as $key ) {
2360
-
2361
-			if ( substr( $key, -4 ) == '-MTD' ) {
2362
-
2363
-				$k = str_replace( '-MTD', '', $key );
2364
-
2365
-				// Mobile, Tablet, Desktop
2366
-				if ( ! empty( $args[ $k ] ) && $args[ $k ] !== '' ) {
2367
-					$classes[] = sanitize_html_class( $args[ $k ] );
2368
-					$v         = $args[ $k ];
2369
-				} else {
2370
-					$v = null;
2371
-				}
2372
-				if ( ! empty( $args[ $k . '_md' ] ) && $args[ $k . '_md' ] !== '' ) {
2373
-					$classes[] = sanitize_html_class( $args[ $k . '_md' ] );
2374
-					$v_md      = $args[ $k . '_md' ];
2375
-				} else {
2376
-					$v_md = null;
2377
-				}
2378
-				if ( ! empty( $args[ $k . '_lg' ] ) && $args[ $k . '_lg' ] !== '' ) {
2379
-					if ( $v == null && $v_md == null ) {
2380
-						$classes[] = sanitize_html_class( str_replace( '-lg', '', $args[ $k . '_lg' ] ) );
2381
-					} else {
2382
-						$classes[] = sanitize_html_class( $args[ $k . '_lg' ] );
2383
-					}
2384
-				}
2385
-			} else {
2386
-				if ( $key == 'font_size' && ! empty( $args[ $key ] ) && $args[ $key ] == 'custom' ) {
2387
-					continue;
2388
-				}
2389
-				if ( ! empty( $args[ $key ] ) ) {
2390
-					$classes[] = sd_sanitize_html_classes( $args[ $key ] );
2391
-				}
2392
-			}
2393
-		}
2394
-	}
2395
-
2396
-	return implode( ' ', $classes );
1988
+    global $aui_bs5;
1989
+
1990
+    $classes = array();
1991
+
1992
+    if ( $aui_bs5 ) {
1993
+        $p_ml = 'ms-';
1994
+        $p_mr = 'me-';
1995
+
1996
+        $p_pl = 'ps-';
1997
+        $p_pr = 'pe-';
1998
+    } else {
1999
+        $p_ml = 'ml-';
2000
+        $p_mr = 'mr-';
2001
+
2002
+        $p_pl = 'pl-';
2003
+        $p_pr = 'pr-';
2004
+    }
2005
+
2006
+    // margins.
2007
+    if ( isset( $args['mt'] ) && $args['mt'] !== '' ) {
2008
+        $classes[] = 'mt-' . sanitize_html_class( $args['mt'] );
2009
+        $mt        = $args['mt'];
2010
+    } else {
2011
+        $mt = null;
2012
+    }
2013
+    if ( isset( $args['mr'] ) && $args['mr'] !== '' ) {
2014
+        $classes[] = $p_mr . sanitize_html_class( $args['mr'] );
2015
+        $mr        = $args['mr'];
2016
+    } else {
2017
+        $mr = null;
2018
+    }
2019
+    if ( isset( $args['mb'] ) && $args['mb'] !== '' ) {
2020
+        $classes[] = 'mb-' . sanitize_html_class( $args['mb'] );
2021
+        $mb        = $args['mb'];
2022
+    } else {
2023
+        $mb = null;
2024
+    }
2025
+    if ( isset( $args['ml'] ) && $args['ml'] !== '' ) {
2026
+        $classes[] = $p_ml . sanitize_html_class( $args['ml'] );
2027
+        $ml        = $args['ml'];
2028
+    } else {
2029
+        $ml = null;
2030
+    }
2031
+
2032
+    // margins tablet.
2033
+    if ( isset( $args['mt_md'] ) && $args['mt_md'] !== '' ) {
2034
+        $classes[] = 'mt-md-' . sanitize_html_class( $args['mt_md'] );
2035
+        $mt_md     = $args['mt_md'];
2036
+    } else {
2037
+        $mt_md = null;
2038
+    }
2039
+    if ( isset( $args['mr_md'] ) && $args['mr_md'] !== '' ) {
2040
+        $classes[] = $p_mr . 'md-' . sanitize_html_class( $args['mr_md'] );
2041
+        $mt_md     = $args['mr_md'];
2042
+    } else {
2043
+        $mr_md = null;
2044
+    }
2045
+    if ( isset( $args['mb_md'] ) && $args['mb_md'] !== '' ) {
2046
+        $classes[] = 'mb-md-' . sanitize_html_class( $args['mb_md'] );
2047
+        $mt_md     = $args['mb_md'];
2048
+    } else {
2049
+        $mb_md = null;
2050
+    }
2051
+    if ( isset( $args['ml_md'] ) && $args['ml_md'] !== '' ) {
2052
+        $classes[] = $p_ml . 'md-' . sanitize_html_class( $args['ml_md'] );
2053
+        $mt_md     = $args['ml_md'];
2054
+    } else {
2055
+        $ml_md = null;
2056
+    }
2057
+
2058
+    // margins desktop.
2059
+    if ( isset( $args['mt_lg'] ) && $args['mt_lg'] !== '' ) {
2060
+        if ( $mt == null && $mt_md == null ) {
2061
+            $classes[] = 'mt-' . sanitize_html_class( $args['mt_lg'] );
2062
+        } else {
2063
+            $classes[] = 'mt-lg-' . sanitize_html_class( $args['mt_lg'] );
2064
+        }
2065
+    }
2066
+    if ( isset( $args['mr_lg'] ) && $args['mr_lg'] !== '' ) {
2067
+        if ( $mr == null && $mr_md == null ) {
2068
+            $classes[] = $p_mr . sanitize_html_class( $args['mr_lg'] );
2069
+        } else {
2070
+            $classes[] = $p_mr . 'lg-' . sanitize_html_class( $args['mr_lg'] );
2071
+        }
2072
+    }
2073
+    if ( isset( $args['mb_lg'] ) && $args['mb_lg'] !== '' ) {
2074
+        if ( $mb == null && $mb_md == null ) {
2075
+            $classes[] = 'mb-' . sanitize_html_class( $args['mb_lg'] );
2076
+        } else {
2077
+            $classes[] = 'mb-lg-' . sanitize_html_class( $args['mb_lg'] );
2078
+        }
2079
+    }
2080
+    if ( isset( $args['ml_lg'] ) && $args['ml_lg'] !== '' ) {
2081
+        if ( $ml == null && $ml_md == null ) {
2082
+            $classes[] = $p_ml . sanitize_html_class( $args['ml_lg'] );
2083
+        } else {
2084
+            $classes[] = $p_ml . 'lg-' . sanitize_html_class( $args['ml_lg'] );
2085
+        }
2086
+    }
2087
+
2088
+    // padding.
2089
+    if ( isset( $args['pt'] ) && $args['pt'] !== '' ) {
2090
+        $classes[] = 'pt-' . sanitize_html_class( $args['pt'] );
2091
+        $pt        = $args['pt'];
2092
+    } else {
2093
+        $pt = null;
2094
+    }
2095
+    if ( isset( $args['pr'] ) && $args['pr'] !== '' ) {
2096
+        $classes[] = $p_pr . sanitize_html_class( $args['pr'] );
2097
+        $pr        = $args['pr'];
2098
+    } else {
2099
+        $pr = null;
2100
+    }
2101
+    if ( isset( $args['pb'] ) && $args['pb'] !== '' ) {
2102
+        $classes[] = 'pb-' . sanitize_html_class( $args['pb'] );
2103
+        $pb        = $args['pb'];
2104
+    } else {
2105
+        $pb = null;
2106
+    }
2107
+    if ( isset( $args['pl'] ) && $args['pl'] !== '' ) {
2108
+        $classes[] = $p_pl . sanitize_html_class( $args['pl'] );
2109
+        $pl        = $args['pl'];
2110
+    } else {
2111
+        $pl = null;
2112
+    }
2113
+
2114
+    // padding tablet.
2115
+    if ( isset( $args['pt_md'] ) && $args['pt_md'] !== '' ) {
2116
+        $classes[] = 'pt-md-' . sanitize_html_class( $args['pt_md'] );
2117
+        $pt_md     = $args['pt_md'];
2118
+    } else {
2119
+        $pt_md = null;
2120
+    }
2121
+    if ( isset( $args['pr_md'] ) && $args['pr_md'] !== '' ) {
2122
+        $classes[] = $p_pr . 'md-' . sanitize_html_class( $args['pr_md'] );
2123
+        $pt_md     = $args['pr_md'];
2124
+    } else {
2125
+        $pr_md = null;
2126
+    }
2127
+    if ( isset( $args['pb_md'] ) && $args['pb_md'] !== '' ) {
2128
+        $classes[] = 'pb-md-' . sanitize_html_class( $args['pb_md'] );
2129
+        $pt_md     = $args['pb_md'];
2130
+    } else {
2131
+        $pb_md = null;
2132
+    }
2133
+    if ( isset( $args['pl_md'] ) && $args['pl_md'] !== '' ) {
2134
+        $classes[] = $p_pl . 'md-' . sanitize_html_class( $args['pl_md'] );
2135
+        $pt_md     = $args['pl_md'];
2136
+    } else {
2137
+        $pl_md = null;
2138
+    }
2139
+
2140
+    // padding desktop.
2141
+    if ( isset( $args['pt_lg'] ) && $args['pt_lg'] !== '' ) {
2142
+        if ( $pt == null && $pt_md == null ) {
2143
+            $classes[] = 'pt-' . sanitize_html_class( $args['pt_lg'] );
2144
+        } else {
2145
+            $classes[] = 'pt-lg-' . sanitize_html_class( $args['pt_lg'] );
2146
+        }
2147
+    }
2148
+    if ( isset( $args['pr_lg'] ) && $args['pr_lg'] !== '' ) {
2149
+        if ( $pr == null && $pr_md == null ) {
2150
+            $classes[] = $p_pr . sanitize_html_class( $args['pr_lg'] );
2151
+        } else {
2152
+            $classes[] = $p_pr . 'lg-' . sanitize_html_class( $args['pr_lg'] );
2153
+        }
2154
+    }
2155
+    if ( isset( $args['pb_lg'] ) && $args['pb_lg'] !== '' ) {
2156
+        if ( $pb == null && $pb_md == null ) {
2157
+            $classes[] = 'pb-' . sanitize_html_class( $args['pb_lg'] );
2158
+        } else {
2159
+            $classes[] = 'pb-lg-' . sanitize_html_class( $args['pb_lg'] );
2160
+        }
2161
+    }
2162
+    if ( isset( $args['pl_lg'] ) && $args['pl_lg'] !== '' ) {
2163
+        if ( $pl == null && $pl_md == null ) {
2164
+            $classes[] = $p_pl . sanitize_html_class( $args['pl_lg'] );
2165
+        } else {
2166
+            $classes[] = $p_pl . 'lg-' . sanitize_html_class( $args['pl_lg'] );
2167
+        }
2168
+    }
2169
+
2170
+    // row cols, mobile, tablet, desktop
2171
+    if ( ! empty( $args['row_cols'] ) && $args['row_cols'] !== '' ) {
2172
+        $classes[] = sanitize_html_class( 'row-cols-' . $args['row_cols'] );
2173
+        $row_cols  = $args['row_cols'];
2174
+    } else {
2175
+        $row_cols = null;
2176
+    }
2177
+    if ( ! empty( $args['row_cols_md'] ) && $args['row_cols_md'] !== '' ) {
2178
+        $classes[]   = sanitize_html_class( 'row-cols-md-' . $args['row_cols_md'] );
2179
+        $row_cols_md = $args['row_cols_md'];
2180
+    } else {
2181
+        $row_cols_md = null;
2182
+    }
2183
+    if ( ! empty( $args['row_cols_lg'] ) && $args['row_cols_lg'] !== '' ) {
2184
+        if ( $row_cols == null && $row_cols_md == null ) {
2185
+            $classes[] = sanitize_html_class( 'row-cols-' . $args['row_cols_lg'] );
2186
+        } else {
2187
+            $classes[] = sanitize_html_class( 'row-cols-lg-' . $args['row_cols_lg'] );
2188
+        }
2189
+    }
2190
+
2191
+    // columns , mobile, tablet, desktop
2192
+    if ( ! empty( $args['col'] ) && $args['col'] !== '' ) {
2193
+        $classes[] = sanitize_html_class( 'col-' . $args['col'] );
2194
+        $col       = $args['col'];
2195
+    } else {
2196
+        $col = null;
2197
+    }
2198
+    if ( ! empty( $args['col_md'] ) && $args['col_md'] !== '' ) {
2199
+        $classes[] = sanitize_html_class( 'col-md-' . $args['col_md'] );
2200
+        $col_md    = $args['col_md'];
2201
+    } else {
2202
+        $col_md = null;
2203
+    }
2204
+    if ( ! empty( $args['col_lg'] ) && $args['col_lg'] !== '' ) {
2205
+        if ( $col == null && $col_md == null ) {
2206
+            $classes[] = sanitize_html_class( 'col-' . $args['col_lg'] );
2207
+        } else {
2208
+            $classes[] = sanitize_html_class( 'col-lg-' . $args['col_lg'] );
2209
+        }
2210
+    }
2211
+
2212
+    // border
2213
+    if ( isset( $args['border'] ) && ( $args['border'] == 'none' || $args['border'] === '0' || $args['border'] === 0 ) ) {
2214
+        $classes[] = 'border-0';
2215
+    } elseif ( ! empty( $args['border'] ) ) {
2216
+        $border_class = 'border';
2217
+        if ( ! empty( $args['border_type'] ) && strpos( $args['border_type'], '-0' ) === false ) {
2218
+            $border_class = '';
2219
+        }
2220
+        $classes[] = $border_class . ' border-' . sanitize_html_class( $args['border'] );
2221
+    }
2222
+
2223
+    // border radius type
2224
+    if ( ! empty( $args['rounded'] ) ) {
2225
+        $classes[] = sanitize_html_class( $args['rounded'] );
2226
+    }
2227
+
2228
+    // border radius size BS4
2229
+    if ( isset( $args['rounded_size'] ) && in_array( $args['rounded_size'], array( 'sm', 'lg' ) ) ) {
2230
+        $classes[] = 'rounded-' . sanitize_html_class( $args['rounded_size'] );
2231
+        // if we set a size then we need to remove "rounded" if set
2232
+        if ( ( $key = array_search( 'rounded', $classes ) ) !== false ) {
2233
+            unset( $classes[ $key ] );
2234
+        }
2235
+    } else {
2236
+
2237
+        // border radius size , mobile, tablet, desktop
2238
+        if ( isset( $args['rounded_size'] ) && $args['rounded_size'] !== '' ) {
2239
+            $classes[]    = sanitize_html_class( 'rounded-' . $args['rounded_size'] );
2240
+            $rounded_size = $args['rounded_size'];
2241
+        } else {
2242
+            $rounded_size = null;
2243
+        }
2244
+        if ( isset( $args['rounded_size_md'] ) && $args['rounded_size_md'] !== '' ) {
2245
+            $classes[]       = sanitize_html_class( 'rounded-md-' . $args['rounded_size_md'] );
2246
+            $rounded_size_md = $args['rounded_size_md'];
2247
+        } else {
2248
+            $rounded_size_md = null;
2249
+        }
2250
+        if ( isset( $args['rounded_size_lg'] ) && $args['rounded_size_lg'] !== '' ) {
2251
+            if ( $rounded_size == null && $rounded_size_md == null ) {
2252
+                $classes[] = sanitize_html_class( 'rounded-' . $args['rounded_size_lg'] );
2253
+            } else {
2254
+                $classes[] = sanitize_html_class( 'rounded-lg-' . $args['rounded_size_lg'] );
2255
+            }
2256
+        }
2257
+    }
2258
+
2259
+    // shadow
2260
+    //if ( !empty( $args['shadow'] ) ) { $classes[] = sanitize_html_class($args['shadow']); }
2261
+
2262
+    // background
2263
+    if ( ! empty( $args['bg'] ) ) {
2264
+        $classes[] = 'bg-' . sanitize_html_class( $args['bg'] );
2265
+    }
2266
+
2267
+    // text_color
2268
+    if ( ! empty( $args['text_color'] ) ) {
2269
+        $classes[] = 'text-' . sanitize_html_class( $args['text_color'] );
2270
+    }
2271
+
2272
+    // text_align
2273
+    if ( ! empty( $args['text_justify'] ) ) {
2274
+        $classes[] = 'text-justify';
2275
+    } else {
2276
+        if ( ! empty( $args['text_align'] ) ) {
2277
+            $classes[]  = sanitize_html_class( $args['text_align'] );
2278
+            $text_align = $args['text_align'];
2279
+        } else {
2280
+            $text_align = null;
2281
+        }
2282
+        if ( ! empty( $args['text_align_md'] ) && $args['text_align_md'] !== '' ) {
2283
+            $classes[]     = sanitize_html_class( $args['text_align_md'] );
2284
+            $text_align_md = $args['text_align_md'];
2285
+        } else {
2286
+            $text_align_md = null;
2287
+        }
2288
+        if ( ! empty( $args['text_align_lg'] ) && $args['text_align_lg'] !== '' ) {
2289
+            if ( $text_align == null && $text_align_md == null ) {
2290
+                $classes[] = sanitize_html_class( str_replace( '-lg', '', $args['text_align_lg'] ) );
2291
+            } else {
2292
+                $classes[] = sanitize_html_class( $args['text_align_lg'] );
2293
+            }
2294
+        }
2295
+    }
2296
+
2297
+    // display
2298
+    if ( ! empty( $args['display'] ) ) {
2299
+        $classes[] = sanitize_html_class( $args['display'] );
2300
+        $display   = $args['display'];
2301
+    } else {
2302
+        $display = null;
2303
+    }
2304
+    if ( ! empty( $args['display_md'] ) && $args['display_md'] !== '' ) {
2305
+        $classes[]  = sanitize_html_class( $args['display_md'] );
2306
+        $display_md = $args['display_md'];
2307
+    } else {
2308
+        $display_md = null;
2309
+    }
2310
+    if ( ! empty( $args['display_lg'] ) && $args['display_lg'] !== '' ) {
2311
+        if ( $display == null && $display_md == null ) {
2312
+            $classes[] = sanitize_html_class( str_replace( '-lg', '', $args['display_lg'] ) );
2313
+        } else {
2314
+            $classes[] = sanitize_html_class( $args['display_lg'] );
2315
+        }
2316
+    }
2317
+
2318
+    // bgtus - background transparent until scroll
2319
+    if ( ! empty( $args['bgtus'] ) ) {
2320
+        $classes[] = sanitize_html_class( 'bg-transparent-until-scroll' );
2321
+    }
2322
+
2323
+    // cscos - change color scheme on scroll
2324
+    if ( ! empty( $args['bgtus'] ) && ! empty( $args['cscos'] ) ) {
2325
+        $classes[] = sanitize_html_class( 'color-scheme-flip-on-scroll' );
2326
+    }
2327
+
2328
+    // hover animations
2329
+    if ( ! empty( $args['hover_animations'] ) ) {
2330
+        $classes[] = sd_sanitize_html_classes( str_replace( ',', ' ', $args['hover_animations'] ) );
2331
+    }
2332
+
2333
+    // absolute_position
2334
+    if ( ! empty( $args['absolute_position'] ) ) {
2335
+        if ( 'top-left' === $args['absolute_position'] ) {
2336
+            $classes[] = 'start-0 top-0';
2337
+        } elseif ( 'top-center' === $args['absolute_position'] ) {
2338
+            $classes[] = 'start-50 top-0 translate-middle';
2339
+        } elseif ( 'top-right' === $args['absolute_position'] ) {
2340
+            $classes[] = 'end-0 top-0';
2341
+        } elseif ( 'center-left' === $args['absolute_position'] ) {
2342
+            $classes[] = 'start-0 top-50';
2343
+        } elseif ( 'center' === $args['absolute_position'] ) {
2344
+            $classes[] = 'start-50 top-50 translate-middle';
2345
+        } elseif ( 'center-right' === $args['absolute_position'] ) {
2346
+            $classes[] = 'end-0 top-50';
2347
+        } elseif ( 'bottom-left' === $args['absolute_position'] ) {
2348
+            $classes[] = 'start-0 bottom-0';
2349
+        } elseif ( 'bottom-center' === $args['absolute_position'] ) {
2350
+            $classes[] = 'start-50 bottom-0 translate-middle';
2351
+        } elseif ( 'bottom-right' === $args['absolute_position'] ) {
2352
+            $classes[] = 'end-0 bottom-0';
2353
+        }
2354
+    }
2355
+
2356
+    // build classes from build keys
2357
+    $build_keys = sd_get_class_build_keys();
2358
+    if ( ! empty( $build_keys ) ) {
2359
+        foreach ( $build_keys as $key ) {
2360
+
2361
+            if ( substr( $key, -4 ) == '-MTD' ) {
2362
+
2363
+                $k = str_replace( '-MTD', '', $key );
2364
+
2365
+                // Mobile, Tablet, Desktop
2366
+                if ( ! empty( $args[ $k ] ) && $args[ $k ] !== '' ) {
2367
+                    $classes[] = sanitize_html_class( $args[ $k ] );
2368
+                    $v         = $args[ $k ];
2369
+                } else {
2370
+                    $v = null;
2371
+                }
2372
+                if ( ! empty( $args[ $k . '_md' ] ) && $args[ $k . '_md' ] !== '' ) {
2373
+                    $classes[] = sanitize_html_class( $args[ $k . '_md' ] );
2374
+                    $v_md      = $args[ $k . '_md' ];
2375
+                } else {
2376
+                    $v_md = null;
2377
+                }
2378
+                if ( ! empty( $args[ $k . '_lg' ] ) && $args[ $k . '_lg' ] !== '' ) {
2379
+                    if ( $v == null && $v_md == null ) {
2380
+                        $classes[] = sanitize_html_class( str_replace( '-lg', '', $args[ $k . '_lg' ] ) );
2381
+                    } else {
2382
+                        $classes[] = sanitize_html_class( $args[ $k . '_lg' ] );
2383
+                    }
2384
+                }
2385
+            } else {
2386
+                if ( $key == 'font_size' && ! empty( $args[ $key ] ) && $args[ $key ] == 'custom' ) {
2387
+                    continue;
2388
+                }
2389
+                if ( ! empty( $args[ $key ] ) ) {
2390
+                    $classes[] = sd_sanitize_html_classes( $args[ $key ] );
2391
+                }
2392
+            }
2393
+        }
2394
+    }
2395
+
2396
+    return implode( ' ', $classes );
2397 2397
 }
2398 2398
 
2399 2399
 /**
@@ -2405,90 +2405,90 @@  discard block
 block discarded – undo
2405 2405
  */
2406 2406
 function sd_build_aui_styles( $args ) {
2407 2407
 
2408
-	$styles = array();
2409
-
2410
-	// background color
2411
-	if ( ! empty( $args['bg'] ) && $args['bg'] !== '' ) {
2412
-		if ( $args['bg'] == 'custom-color' ) {
2413
-			$styles['background-color'] = $args['bg_color'];
2414
-		} elseif ( $args['bg'] == 'custom-gradient' ) {
2415
-			$styles['background-image'] = $args['bg_gradient'];
2416
-
2417
-			// use background on text.
2418
-			if ( ! empty( $args['bg_on_text'] ) && $args['bg_on_text'] ) {
2419
-				$styles['background-clip']         = 'text';
2420
-				$styles['-webkit-background-clip'] = 'text';
2421
-				$styles['text-fill-color']         = 'transparent';
2422
-				$styles['-webkit-text-fill-color'] = 'transparent';
2423
-			}
2424
-		}
2425
-	}
2426
-
2427
-	if ( ! empty( $args['bg_image'] ) && $args['bg_image'] !== '' ) {
2428
-		$hasImage = true;
2429
-		if ( ! empty( $styles['background-color'] ) && $args['bg'] == 'custom-color' ) {
2430
-			$styles['background-image']      = 'url(' . $args['bg_image'] . ')';
2431
-			$styles['background-blend-mode'] = 'overlay';
2432
-		} elseif ( ! empty( $styles['background-image'] ) && $args['bg'] == 'custom-gradient' ) {
2433
-			$styles['background-image'] .= ',url(' . $args['bg_image'] . ')';
2434
-		} elseif ( ! empty( $args['bg'] ) && $args['bg'] != '' && $args['bg'] != 'transparent' ) {
2435
-			// do nothing as we alreay have a preset
2436
-			$hasImage = false;
2437
-		} else {
2438
-			$styles['background-image'] = 'url(' . $args['bg_image'] . ')';
2439
-		}
2440
-
2441
-		if ( $hasImage ) {
2442
-			$styles['background-size'] = 'cover';
2443
-
2444
-			if ( ! empty( $args['bg_image_fixed'] ) && $args['bg_image_fixed'] ) {
2445
-				$styles['background-attachment'] = 'fixed';
2446
-			}
2447
-		}
2448
-
2449
-		if ( $hasImage && ! empty( $args['bg_image_xy'] ) && ! empty( $args['bg_image_xy']['x'] ) ) {
2450
-			$styles['background-position'] = ( $args['bg_image_xy']['x'] * 100 ) . '% ' . ( $args['bg_image_xy']['y'] * 100 ) . '%';
2451
-		}
2452
-	}
2453
-
2454
-	// sticky offset top
2455
-	if ( ! empty( $args['sticky_offset_top'] ) && $args['sticky_offset_top'] !== '' ) {
2456
-		$styles['top'] = absint( $args['sticky_offset_top'] );
2457
-	}
2458
-
2459
-	// sticky offset bottom
2460
-	if ( ! empty( $args['sticky_offset_bottom'] ) && $args['sticky_offset_bottom'] !== '' ) {
2461
-		$styles['bottom'] = absint( $args['sticky_offset_bottom'] );
2462
-	}
2463
-
2464
-	// font size
2465
-	if ( ! empty( $args['font_size_custom'] ) && $args['font_size_custom'] !== '' ) {
2466
-		$styles['font-size'] = (float) $args['font_size_custom'] . 'rem';
2467
-	}
2468
-
2469
-	// font color
2470
-	if ( ! empty( $args['text_color_custom'] ) && $args['text_color_custom'] !== '' ) {
2471
-		$styles['color'] = esc_attr( $args['text_color_custom'] );
2472
-	}
2473
-
2474
-	// font line height
2475
-	if ( ! empty( $args['font_line_height'] ) && $args['font_line_height'] !== '' ) {
2476
-		$styles['line-height'] = esc_attr( $args['font_line_height'] );
2477
-	}
2478
-
2479
-	// max height
2480
-	if ( ! empty( $args['max_height'] ) && $args['max_height'] !== '' ) {
2481
-		$styles['max-height'] = esc_attr( $args['max_height'] );
2482
-	}
2483
-
2484
-	$style_string = '';
2485
-	if ( ! empty( $styles ) ) {
2486
-		foreach ( $styles as $key => $val ) {
2487
-			$style_string .= esc_attr( $key ) . ':' . esc_attr( $val ) . ';';
2488
-		}
2489
-	}
2490
-
2491
-	return $style_string;
2408
+    $styles = array();
2409
+
2410
+    // background color
2411
+    if ( ! empty( $args['bg'] ) && $args['bg'] !== '' ) {
2412
+        if ( $args['bg'] == 'custom-color' ) {
2413
+            $styles['background-color'] = $args['bg_color'];
2414
+        } elseif ( $args['bg'] == 'custom-gradient' ) {
2415
+            $styles['background-image'] = $args['bg_gradient'];
2416
+
2417
+            // use background on text.
2418
+            if ( ! empty( $args['bg_on_text'] ) && $args['bg_on_text'] ) {
2419
+                $styles['background-clip']         = 'text';
2420
+                $styles['-webkit-background-clip'] = 'text';
2421
+                $styles['text-fill-color']         = 'transparent';
2422
+                $styles['-webkit-text-fill-color'] = 'transparent';
2423
+            }
2424
+        }
2425
+    }
2426
+
2427
+    if ( ! empty( $args['bg_image'] ) && $args['bg_image'] !== '' ) {
2428
+        $hasImage = true;
2429
+        if ( ! empty( $styles['background-color'] ) && $args['bg'] == 'custom-color' ) {
2430
+            $styles['background-image']      = 'url(' . $args['bg_image'] . ')';
2431
+            $styles['background-blend-mode'] = 'overlay';
2432
+        } elseif ( ! empty( $styles['background-image'] ) && $args['bg'] == 'custom-gradient' ) {
2433
+            $styles['background-image'] .= ',url(' . $args['bg_image'] . ')';
2434
+        } elseif ( ! empty( $args['bg'] ) && $args['bg'] != '' && $args['bg'] != 'transparent' ) {
2435
+            // do nothing as we alreay have a preset
2436
+            $hasImage = false;
2437
+        } else {
2438
+            $styles['background-image'] = 'url(' . $args['bg_image'] . ')';
2439
+        }
2440
+
2441
+        if ( $hasImage ) {
2442
+            $styles['background-size'] = 'cover';
2443
+
2444
+            if ( ! empty( $args['bg_image_fixed'] ) && $args['bg_image_fixed'] ) {
2445
+                $styles['background-attachment'] = 'fixed';
2446
+            }
2447
+        }
2448
+
2449
+        if ( $hasImage && ! empty( $args['bg_image_xy'] ) && ! empty( $args['bg_image_xy']['x'] ) ) {
2450
+            $styles['background-position'] = ( $args['bg_image_xy']['x'] * 100 ) . '% ' . ( $args['bg_image_xy']['y'] * 100 ) . '%';
2451
+        }
2452
+    }
2453
+
2454
+    // sticky offset top
2455
+    if ( ! empty( $args['sticky_offset_top'] ) && $args['sticky_offset_top'] !== '' ) {
2456
+        $styles['top'] = absint( $args['sticky_offset_top'] );
2457
+    }
2458
+
2459
+    // sticky offset bottom
2460
+    if ( ! empty( $args['sticky_offset_bottom'] ) && $args['sticky_offset_bottom'] !== '' ) {
2461
+        $styles['bottom'] = absint( $args['sticky_offset_bottom'] );
2462
+    }
2463
+
2464
+    // font size
2465
+    if ( ! empty( $args['font_size_custom'] ) && $args['font_size_custom'] !== '' ) {
2466
+        $styles['font-size'] = (float) $args['font_size_custom'] . 'rem';
2467
+    }
2468
+
2469
+    // font color
2470
+    if ( ! empty( $args['text_color_custom'] ) && $args['text_color_custom'] !== '' ) {
2471
+        $styles['color'] = esc_attr( $args['text_color_custom'] );
2472
+    }
2473
+
2474
+    // font line height
2475
+    if ( ! empty( $args['font_line_height'] ) && $args['font_line_height'] !== '' ) {
2476
+        $styles['line-height'] = esc_attr( $args['font_line_height'] );
2477
+    }
2478
+
2479
+    // max height
2480
+    if ( ! empty( $args['max_height'] ) && $args['max_height'] !== '' ) {
2481
+        $styles['max-height'] = esc_attr( $args['max_height'] );
2482
+    }
2483
+
2484
+    $style_string = '';
2485
+    if ( ! empty( $styles ) ) {
2486
+        foreach ( $styles as $key => $val ) {
2487
+            $style_string .= esc_attr( $key ) . ':' . esc_attr( $val ) . ';';
2488
+        }
2489
+    }
2490
+
2491
+    return $style_string;
2492 2492
 
2493 2493
 }
2494 2494
 
@@ -2501,34 +2501,34 @@  discard block
 block discarded – undo
2501 2501
  * @return string
2502 2502
  */
2503 2503
 function sd_build_hover_styles( $args, $is_preview = false ) {
2504
-	$rules = '';
2505
-	// text color
2506
-	if ( ! empty( $args['styleid'] ) ) {
2507
-		$styleid = $is_preview ? 'html .editor-styles-wrapper .' . esc_attr( $args['styleid'] ) : 'html .' . esc_attr( $args['styleid'] );
2508
-
2509
-		// text
2510
-		if ( ! empty( $args['text_color_hover'] ) ) {
2511
-			$key    = 'custom' === $args['text_color_hover'] && ! empty( $args['text_color_hover_custom'] ) ? 'text_color_hover_custom' : 'text_color_hover';
2512
-			$color  = sd_get_color_from_var( $args[ $key ] );
2513
-			$rules .= $styleid . ':hover {color: ' . $color . ' !important;} ';
2514
-		}
2515
-
2516
-		// bg
2517
-		if ( ! empty( $args['bg_hover'] ) ) {
2518
-			if ( 'custom-gradient' === $args['bg_hover'] ) {
2519
-				$color  = $args['bg_hover_gradient'];
2520
-				$rules .= $styleid . ':hover {background-image: ' . $color . ' !important;} ';
2521
-				$rules .= $styleid . '.btn:hover {border-color: transparent !important;} ';
2522
-			} else {
2523
-				$key    = 'custom-color' === $args['bg_hover'] ? 'bg_hover_color' : 'bg_hover';
2524
-				$color  = sd_get_color_from_var( $args[ $key ] );
2525
-				$rules .= $styleid . ':hover {background: ' . $color . ' !important;} ';
2526
-				$rules .= $styleid . '.btn:hover {border-color: ' . $color . ' !important;} ';
2527
-			}
2528
-		}
2529
-	}
2530
-
2531
-	return $rules ? '<style>' . $rules . '</style>' : '';
2504
+    $rules = '';
2505
+    // text color
2506
+    if ( ! empty( $args['styleid'] ) ) {
2507
+        $styleid = $is_preview ? 'html .editor-styles-wrapper .' . esc_attr( $args['styleid'] ) : 'html .' . esc_attr( $args['styleid'] );
2508
+
2509
+        // text
2510
+        if ( ! empty( $args['text_color_hover'] ) ) {
2511
+            $key    = 'custom' === $args['text_color_hover'] && ! empty( $args['text_color_hover_custom'] ) ? 'text_color_hover_custom' : 'text_color_hover';
2512
+            $color  = sd_get_color_from_var( $args[ $key ] );
2513
+            $rules .= $styleid . ':hover {color: ' . $color . ' !important;} ';
2514
+        }
2515
+
2516
+        // bg
2517
+        if ( ! empty( $args['bg_hover'] ) ) {
2518
+            if ( 'custom-gradient' === $args['bg_hover'] ) {
2519
+                $color  = $args['bg_hover_gradient'];
2520
+                $rules .= $styleid . ':hover {background-image: ' . $color . ' !important;} ';
2521
+                $rules .= $styleid . '.btn:hover {border-color: transparent !important;} ';
2522
+            } else {
2523
+                $key    = 'custom-color' === $args['bg_hover'] ? 'bg_hover_color' : 'bg_hover';
2524
+                $color  = sd_get_color_from_var( $args[ $key ] );
2525
+                $rules .= $styleid . ':hover {background: ' . $color . ' !important;} ';
2526
+                $rules .= $styleid . '.btn:hover {border-color: ' . $color . ' !important;} ';
2527
+            }
2528
+        }
2529
+    }
2530
+
2531
+    return $rules ? '<style>' . $rules . '</style>' : '';
2532 2532
 }
2533 2533
 
2534 2534
 /**
@@ -2540,12 +2540,12 @@  discard block
 block discarded – undo
2540 2540
  */
2541 2541
 function sd_get_color_from_var( $var ) {
2542 2542
 
2543
-	//sanitize_hex_color() @todo this does not cover transparency
2544
-	if ( strpos( $var, '#' ) === false ) {
2545
-		$var = defined( 'BLOCKSTRAP_BLOCKS_VERSION' ) ? 'var(--wp--preset--color--' . esc_attr( $var ) . ')' : 'var(--' . esc_attr( $var ) . ')';
2546
-	}
2543
+    //sanitize_hex_color() @todo this does not cover transparency
2544
+    if ( strpos( $var, '#' ) === false ) {
2545
+        $var = defined( 'BLOCKSTRAP_BLOCKS_VERSION' ) ? 'var(--wp--preset--color--' . esc_attr( $var ) . ')' : 'var(--' . esc_attr( $var ) . ')';
2546
+    }
2547 2547
 
2548
-	return $var;
2548
+    return $var;
2549 2549
 }
2550 2550
 
2551 2551
 /**
@@ -2557,19 +2557,19 @@  discard block
 block discarded – undo
2557 2557
  * @return string
2558 2558
  */
2559 2559
 function sd_sanitize_html_classes( $classes, $sep = ' ' ) {
2560
-	$return = '';
2560
+    $return = '';
2561 2561
 
2562
-	if ( ! is_array( $classes ) ) {
2563
-		$classes = explode( $sep, $classes );
2564
-	}
2562
+    if ( ! is_array( $classes ) ) {
2563
+        $classes = explode( $sep, $classes );
2564
+    }
2565 2565
 
2566
-	if ( ! empty( $classes ) ) {
2567
-		foreach ( $classes as $class ) {
2568
-			$return .= sanitize_html_class( $class ) . ' ';
2569
-		}
2570
-	}
2566
+    if ( ! empty( $classes ) ) {
2567
+        foreach ( $classes as $class ) {
2568
+            $return .= sanitize_html_class( $class ) . ' ';
2569
+        }
2570
+    }
2571 2571
 
2572
-	return $return;
2572
+    return $return;
2573 2573
 }
2574 2574
 
2575 2575
 
@@ -2579,35 +2579,35 @@  discard block
 block discarded – undo
2579 2579
  * @return void
2580 2580
  */
2581 2581
 function sd_get_class_build_keys() {
2582
-	$keys = array(
2583
-		'container',
2584
-		'position',
2585
-		'flex_direction',
2586
-		'shadow',
2587
-		'rounded',
2588
-		'nav_style',
2589
-		'horizontal_alignment',
2590
-		'nav_fill',
2591
-		'width',
2592
-		'font_weight',
2593
-		'font_size',
2594
-		'font_case',
2595
-		'css_class',
2596
-		'flex_align_items-MTD',
2597
-		'flex_justify_content-MTD',
2598
-		'flex_align_self-MTD',
2599
-		'flex_order-MTD',
2600
-		'styleid',
2601
-		'border_opacity',
2602
-		'border_width',
2603
-		'border_type',
2604
-		'opacity',
2605
-		'zindex',
2606
-		'flex_wrap-MTD',
2607
-		'h100',
2608
-		'overflow',
2609
-		'scrollbars',
2610
-	);
2611
-
2612
-	return apply_filters( 'sd_class_build_keys', $keys );
2582
+    $keys = array(
2583
+        'container',
2584
+        'position',
2585
+        'flex_direction',
2586
+        'shadow',
2587
+        'rounded',
2588
+        'nav_style',
2589
+        'horizontal_alignment',
2590
+        'nav_fill',
2591
+        'width',
2592
+        'font_weight',
2593
+        'font_size',
2594
+        'font_case',
2595
+        'css_class',
2596
+        'flex_align_items-MTD',
2597
+        'flex_justify_content-MTD',
2598
+        'flex_align_self-MTD',
2599
+        'flex_order-MTD',
2600
+        'styleid',
2601
+        'border_opacity',
2602
+        'border_width',
2603
+        'border_type',
2604
+        'opacity',
2605
+        'zindex',
2606
+        'flex_wrap-MTD',
2607
+        'h100',
2608
+        'overflow',
2609
+        'scrollbars',
2610
+    );
2611
+
2612
+    return apply_filters( 'sd_class_build_keys', $keys );
2613 2613
 }
Please login to merge, or discard this patch.