Passed
Push — master ( db8e1f...bd5de3 )
by Stiofan
06:53 queued 01:25
created
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Indentation   +2872 added lines, -2872 removed lines patch added patch discarded remove patch
@@ -1,299 +1,299 @@  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.2.4' );
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
-
59
-			// nested blocks can't work as a widget
60
-			if(!empty($this->options['nested-block'])){
61
-				if(empty($this->options['output_types'])){
62
-					$this->options['output_types'] = array('shortcode','block');
63
-				}elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64
-					unset($this->options['output_types'][$key]);
65
-				}
66
-			}
67
-
68
-			// init parent
69
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
-				parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
-			}
72
-
73
-
74
-			if ( isset( $options['class_name'] ) ) {
75
-				// register widget
76
-				$this->class_name = $options['class_name'];
77
-
78
-				// register shortcode, this needs to be done even for blocks and widgets
79
-				$this->register_shortcode();
80
-
81
-
82
-				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
85
-				}
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' ) );
90
-				}
91
-			}
92
-
93
-			// add the CSS and JS we need ONCE
94
-			global $sd_widget_scripts;
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() );
100
-
101
-				// maybe add elementor editor styles
102
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
103
-
104
-				$sd_widget_scripts = true;
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
-				}
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' ) );
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' ) );
131
-
132
-				// add generator text to head
133
-				add_action( 'admin_head', array( $this, 'generator' ), 99 );
134
-				add_action( 'wp_head', array( $this, 'generator' ), 99 );
135
-			}
136
-
137
-			do_action( 'wp_super_duper_widget_init', $options, $this );
138
-		}
139
-
140
-		/**
141
-		 * The register widget function
142
-		 * @return void
143
-		 */
144
-		public function _register() {
145
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
146
-				parent::_register();
147
-			}
148
-		}
149
-
150
-		/**
151
-		 * Add our widget CSS to elementor editor.
152
-		 */
153
-		public function elementor_editor_styles() {
154
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
155
-		}
156
-
157
-		public function register_fusion_element() {
158
-
159
-			$options = $this->options;
160
-
161
-			if ( $this->base_id ) {
162
-
163
-				$params = $this->get_fusion_params();
164
-
165
-				$args = array(
166
-					'name'            => $options['name'],
167
-					'shortcode'       => $this->base_id,
168
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
169
-					'allow_generator' => true,
170
-				);
171
-
172
-				if ( ! empty( $params ) ) {
173
-					$args['params'] = $params;
174
-				}
175
-
176
-				fusion_builder_map( $args );
177
-			}
178
-
179
-		}
180
-
181
-		public function get_fusion_params() {
182
-			$params    = array();
183
-			$arguments = $this->get_arguments();
184
-
185
-			if ( ! empty( $arguments ) ) {
186
-				foreach ( $arguments as $key => $val ) {
187
-					$param = array();
188
-					// type
189
-					$param['type'] = str_replace(
190
-						array(
191
-							"text",
192
-							"number",
193
-							"email",
194
-							"color",
195
-							"checkbox"
196
-						),
197
-						array(
198
-							"textfield",
199
-							"textfield",
200
-							"textfield",
201
-							"colorpicker",
202
-							"select",
203
-
204
-						),
205
-						$val['type'] );
206
-
207
-					// multiselect
208
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
209
-						$param['type']     = 'multiple_select';
210
-						$param['multiple'] = true;
211
-					}
212
-
213
-					// heading
214
-					$param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
215
-
216
-					// description
217
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
218
-
219
-					// param_name
220
-					$param['param_name'] = $key;
221
-
222
-					// Default
223
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
224
-
225
-					// Group
226
-					if ( isset( $val['group'] ) ) {
227
-						$param['group'] = $val['group'];
228
-					}
229
-
230
-					// value
231
-					if ( $val['type'] == 'checkbox' ) {
232
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
233
-							unset( $param['default'] );
234
-						}
235
-						$param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
236
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
237
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
238
-					} else {
239
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
240
-					}
241
-
242
-					// setup the param
243
-					$params[] = $param;
244
-
245
-				}
246
-			}
247
-
248
-
249
-			return $params;
250
-		}
251
-
252
-		/**
253
-		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
254
-		 */
255
-		public static function maybe_cornerstone_builder() {
256
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
257
-				self::shortcode_insert_button_script();
258
-			}
259
-		}
260
-
261
-		/**
262
-		 * A function to ge the shortcode builder picker html.
263
-		 *
264
-		 * @param string $editor_id
265
-		 *
266
-		 * @return string
267
-		 */
268
-		public static function get_picker( $editor_id = '' ) {
269
-
270
-			ob_start();
271
-			if ( isset( $_POST['editor_id'] ) ) {
272
-				$editor_id = esc_attr( $_POST['editor_id'] );
273
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
274
-				$editor_id = 'main_content_content_vb_tiny_mce';
275
-			}
276
-
277
-			global $sd_widgets;
8
+    define( 'SUPER_DUPER_VER', '1.2.4' );
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
+
59
+            // nested blocks can't work as a widget
60
+            if(!empty($this->options['nested-block'])){
61
+                if(empty($this->options['output_types'])){
62
+                    $this->options['output_types'] = array('shortcode','block');
63
+                }elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64
+                    unset($this->options['output_types'][$key]);
65
+                }
66
+            }
67
+
68
+            // init parent
69
+            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
+                parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
+            }
72
+
73
+
74
+            if ( isset( $options['class_name'] ) ) {
75
+                // register widget
76
+                $this->class_name = $options['class_name'];
77
+
78
+                // register shortcode, this needs to be done even for blocks and widgets
79
+                $this->register_shortcode();
80
+
81
+
82
+                // Fusion Builder (avada) support
83
+                if ( function_exists( 'fusion_builder_map' ) ) {
84
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
85
+                }
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' ) );
90
+                }
91
+            }
92
+
93
+            // add the CSS and JS we need ONCE
94
+            global $sd_widget_scripts;
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() );
100
+
101
+                // maybe add elementor editor styles
102
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
103
+
104
+                $sd_widget_scripts = true;
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
+                }
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' ) );
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' ) );
131
+
132
+                // add generator text to head
133
+                add_action( 'admin_head', array( $this, 'generator' ), 99 );
134
+                add_action( 'wp_head', array( $this, 'generator' ), 99 );
135
+            }
136
+
137
+            do_action( 'wp_super_duper_widget_init', $options, $this );
138
+        }
139
+
140
+        /**
141
+         * The register widget function
142
+         * @return void
143
+         */
144
+        public function _register() {
145
+            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
146
+                parent::_register();
147
+            }
148
+        }
149
+
150
+        /**
151
+         * Add our widget CSS to elementor editor.
152
+         */
153
+        public function elementor_editor_styles() {
154
+            wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
155
+        }
156
+
157
+        public function register_fusion_element() {
158
+
159
+            $options = $this->options;
160
+
161
+            if ( $this->base_id ) {
162
+
163
+                $params = $this->get_fusion_params();
164
+
165
+                $args = array(
166
+                    'name'            => $options['name'],
167
+                    'shortcode'       => $this->base_id,
168
+                    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
169
+                    'allow_generator' => true,
170
+                );
171
+
172
+                if ( ! empty( $params ) ) {
173
+                    $args['params'] = $params;
174
+                }
175
+
176
+                fusion_builder_map( $args );
177
+            }
178
+
179
+        }
180
+
181
+        public function get_fusion_params() {
182
+            $params    = array();
183
+            $arguments = $this->get_arguments();
184
+
185
+            if ( ! empty( $arguments ) ) {
186
+                foreach ( $arguments as $key => $val ) {
187
+                    $param = array();
188
+                    // type
189
+                    $param['type'] = str_replace(
190
+                        array(
191
+                            "text",
192
+                            "number",
193
+                            "email",
194
+                            "color",
195
+                            "checkbox"
196
+                        ),
197
+                        array(
198
+                            "textfield",
199
+                            "textfield",
200
+                            "textfield",
201
+                            "colorpicker",
202
+                            "select",
203
+
204
+                        ),
205
+                        $val['type'] );
206
+
207
+                    // multiselect
208
+                    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
209
+                        $param['type']     = 'multiple_select';
210
+                        $param['multiple'] = true;
211
+                    }
212
+
213
+                    // heading
214
+                    $param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
215
+
216
+                    // description
217
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
218
+
219
+                    // param_name
220
+                    $param['param_name'] = $key;
221
+
222
+                    // Default
223
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
224
+
225
+                    // Group
226
+                    if ( isset( $val['group'] ) ) {
227
+                        $param['group'] = $val['group'];
228
+                    }
229
+
230
+                    // value
231
+                    if ( $val['type'] == 'checkbox' ) {
232
+                        if ( isset( $val['default'] ) && $val['default'] == '0' ) {
233
+                            unset( $param['default'] );
234
+                        }
235
+                        $param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
236
+                    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
237
+                        $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
238
+                    } else {
239
+                        $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
240
+                    }
241
+
242
+                    // setup the param
243
+                    $params[] = $param;
244
+
245
+                }
246
+            }
247
+
248
+
249
+            return $params;
250
+        }
251
+
252
+        /**
253
+         * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
254
+         */
255
+        public static function maybe_cornerstone_builder() {
256
+            if ( did_action( 'cornerstone_before_boot_app' ) ) {
257
+                self::shortcode_insert_button_script();
258
+            }
259
+        }
260
+
261
+        /**
262
+         * A function to ge the shortcode builder picker html.
263
+         *
264
+         * @param string $editor_id
265
+         *
266
+         * @return string
267
+         */
268
+        public static function get_picker( $editor_id = '' ) {
269
+
270
+            ob_start();
271
+            if ( isset( $_POST['editor_id'] ) ) {
272
+                $editor_id = esc_attr( $_POST['editor_id'] );
273
+            } elseif ( isset( $_REQUEST['et_fb'] ) ) {
274
+                $editor_id = 'main_content_content_vb_tiny_mce';
275
+            }
276
+
277
+            global $sd_widgets;
278 278
 
279 279
 //			print_r($sd_widgets);exit;
280
-			?>
280
+            ?>
281 281
 
282 282
 			<div class="sd-shortcode-left-wrap">
283 283
 				<?php
284
-				ksort( $sd_widgets );
285
-				//				print_r($sd_widgets);exit;
286
-				if ( ! empty( $sd_widgets ) ) {
287
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
288
-					echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
289
-					foreach ( $sd_widgets as $shortcode => $class ) {
290
-						if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
291
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
292
-					}
293
-					echo "</select>";
294
-
295
-				}
296
-				?>
284
+                ksort( $sd_widgets );
285
+                //				print_r($sd_widgets);exit;
286
+                if ( ! empty( $sd_widgets ) ) {
287
+                    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
288
+                    echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
289
+                    foreach ( $sd_widgets as $shortcode => $class ) {
290
+                        if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
291
+                        echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
292
+                    }
293
+                    echo "</select>";
294
+
295
+                }
296
+                ?>
297 297
 				<div class="sd-shortcode-settings"></div>
298 298
 
299 299
 			</div>
@@ -304,8 +304,8 @@  discard block
 block discarded – undo
304 304
 					<?php if ( $editor_id != '' ) { ?>
305 305
 						<button class="button sd-insert-shortcode-button"
306 306
 								onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
307
-									echo "'" . $editor_id . "'";
308
-								} ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
307
+                                    echo "'" . $editor_id . "'";
308
+                                } ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
309 309
 					<?php } ?>
310 310
 					<button class="button"
311 311
 							onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -313,150 +313,150 @@  discard block
 block discarded – undo
313 313
 			</div>
314 314
 			<?php
315 315
 
316
-			$html = ob_get_clean();
317
-
318
-			if ( wp_doing_ajax() ) {
319
-				echo $html;
320
-				$should_die = true;
321
-
322
-				// some builder get the editor via ajax so we should not die on those occasions
323
-				$dont_die = array(
324
-					'parent_tag',// WP Bakery
325
-					'avia_request' // enfold
326
-				);
327
-
328
-				foreach ( $dont_die as $request ) {
329
-					if ( isset( $_REQUEST[ $request ] ) ) {
330
-						$should_die = false;
331
-					}
332
-				}
333
-
334
-				if ( $should_die ) {
335
-					wp_die();
336
-				}
337
-
338
-			} else {
339
-				return $html;
340
-			}
341
-
342
-			return '';
343
-
344
-		}
345
-
346
-		/**
347
-		 * Output the version in the header.
348
-		 */
349
-		public function generator() {
350
-			$file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
351
-			$plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
352
-
353
-			// Find source plugin/theme of SD
354
-			$source = array();
355
-			if ( strpos( $file, $plugins_dir ) !== false ) {
356
-				$source = explode( "/", plugin_basename( $file ) );
357
-			} else if ( function_exists( 'get_theme_root' ) ) {
358
-				$themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
359
-
360
-				if ( strpos( $file, $themes_dir ) !== false ) {
361
-					$source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
362
-				}
363
-			}
364
-
365
-			echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
366
-		}
367
-
368
-		/**
369
-		 * Get widget settings.
370
-		 *
371
-		 * @since 1.0.0
372
-		 */
373
-		public static function get_widget_settings() {
374
-			global $sd_widgets;
375
-
376
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
377
-			if ( ! $shortcode ) {
378
-				wp_die();
379
-			}
380
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
381
-			if ( ! $widget_args ) {
382
-				wp_die();
383
-			}
384
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
385
-			if ( ! $class_name ) {
386
-				wp_die();
387
-			}
388
-
389
-			// invoke an instance method
390
-			$widget = new $class_name;
391
-
392
-			ob_start();
393
-			$widget->form( array() );
394
-			$form = ob_get_clean();
395
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
396
-			echo "<style>" . $widget->widget_css() . "</style>";
397
-			echo "<script>" . $widget->widget_js() . "</script>";
398
-			?>
316
+            $html = ob_get_clean();
317
+
318
+            if ( wp_doing_ajax() ) {
319
+                echo $html;
320
+                $should_die = true;
321
+
322
+                // some builder get the editor via ajax so we should not die on those occasions
323
+                $dont_die = array(
324
+                    'parent_tag',// WP Bakery
325
+                    'avia_request' // enfold
326
+                );
327
+
328
+                foreach ( $dont_die as $request ) {
329
+                    if ( isset( $_REQUEST[ $request ] ) ) {
330
+                        $should_die = false;
331
+                    }
332
+                }
333
+
334
+                if ( $should_die ) {
335
+                    wp_die();
336
+                }
337
+
338
+            } else {
339
+                return $html;
340
+            }
341
+
342
+            return '';
343
+
344
+        }
345
+
346
+        /**
347
+         * Output the version in the header.
348
+         */
349
+        public function generator() {
350
+            $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
351
+            $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
352
+
353
+            // Find source plugin/theme of SD
354
+            $source = array();
355
+            if ( strpos( $file, $plugins_dir ) !== false ) {
356
+                $source = explode( "/", plugin_basename( $file ) );
357
+            } else if ( function_exists( 'get_theme_root' ) ) {
358
+                $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
359
+
360
+                if ( strpos( $file, $themes_dir ) !== false ) {
361
+                    $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
362
+                }
363
+            }
364
+
365
+            echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
366
+        }
367
+
368
+        /**
369
+         * Get widget settings.
370
+         *
371
+         * @since 1.0.0
372
+         */
373
+        public static function get_widget_settings() {
374
+            global $sd_widgets;
375
+
376
+            $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
377
+            if ( ! $shortcode ) {
378
+                wp_die();
379
+            }
380
+            $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
381
+            if ( ! $widget_args ) {
382
+                wp_die();
383
+            }
384
+            $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
385
+            if ( ! $class_name ) {
386
+                wp_die();
387
+            }
388
+
389
+            // invoke an instance method
390
+            $widget = new $class_name;
391
+
392
+            ob_start();
393
+            $widget->form( array() );
394
+            $form = ob_get_clean();
395
+            echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
396
+            echo "<style>" . $widget->widget_css() . "</style>";
397
+            echo "<script>" . $widget->widget_js() . "</script>";
398
+            ?>
399 399
 			<?php
400
-			wp_die();
401
-		}
402
-
403
-		/**
404
-		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
405
-		 *
406
-		 * @param string $editor_id Optional. Shortcode editor id. Default null.
407
-		 * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
408
-		 *
409
-		 *@since 1.0.0
410
-		 *
411
-		 */
412
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
413
-			global $sd_widgets, $shortcode_insert_button_once;
414
-			if ( $shortcode_insert_button_once ) {
415
-				return;
416
-			}
417
-			add_thickbox();
418
-
419
-
420
-			/**
421
-			 * Cornerstone makes us play dirty tricks :/
422
-			 * 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.
423
-			 */
424
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
425
-				echo '<span id="insert-media-button">';
426
-			}
427
-
428
-			echo self::shortcode_button( 'this', 'true' );
429
-
430
-			// see opening note
431
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
432
-				echo '</span>'; // end #insert-media-button
433
-			}
434
-
435
-			// Add separate script for generatepress theme sections
436
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
437
-			} else {
438
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
439
-			}
440
-
441
-			$shortcode_insert_button_once = true;
442
-		}
443
-
444
-		/**
445
-		 * Gets the shortcode insert button html.
446
-		 *
447
-		 * @param string $id
448
-		 * @param string $search_for_id
449
-		 *
450
-		 * @return mixed
451
-		 */
452
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
453
-			ob_start();
454
-			?>
400
+            wp_die();
401
+        }
402
+
403
+        /**
404
+         * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
405
+         *
406
+         * @param string $editor_id Optional. Shortcode editor id. Default null.
407
+         * @param string $insert_shortcode_function Optional. Insert shortcode function. Default null.
408
+         *
409
+         *@since 1.0.0
410
+         *
411
+         */
412
+        public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
413
+            global $sd_widgets, $shortcode_insert_button_once;
414
+            if ( $shortcode_insert_button_once ) {
415
+                return;
416
+            }
417
+            add_thickbox();
418
+
419
+
420
+            /**
421
+             * Cornerstone makes us play dirty tricks :/
422
+             * 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.
423
+             */
424
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
425
+                echo '<span id="insert-media-button">';
426
+            }
427
+
428
+            echo self::shortcode_button( 'this', 'true' );
429
+
430
+            // see opening note
431
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
432
+                echo '</span>'; // end #insert-media-button
433
+            }
434
+
435
+            // Add separate script for generatepress theme sections
436
+            if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
437
+            } else {
438
+                self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
439
+            }
440
+
441
+            $shortcode_insert_button_once = true;
442
+        }
443
+
444
+        /**
445
+         * Gets the shortcode insert button html.
446
+         *
447
+         * @param string $id
448
+         * @param string $search_for_id
449
+         *
450
+         * @return mixed
451
+         */
452
+        public static function shortcode_button( $id = '', $search_for_id = '' ) {
453
+            ob_start();
454
+            ?>
455 455
 			<span class="sd-lable-shortcode-inserter">
456 456
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
457
-				if ( $search_for_id ) {
458
-					echo "," . $search_for_id;
459
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
457
+                if ( $search_for_id ) {
458
+                    echo "," . $search_for_id;
459
+                } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
460 460
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
461 461
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
462 462
 						  class="dashicons dashicons-screenoptions"></span>
@@ -467,21 +467,21 @@  discard block
 block discarded – undo
467 467
 			</span>
468 468
 
469 469
 			<?php
470
-			$html = ob_get_clean();
471
-
472
-			// remove line breaks so we can use it in js
473
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
474
-		}
475
-
476
-		/**
477
-		 * Makes SD work with the siteOrigin page builder.
478
-		 *
479
-		 * @return mixed
480
-		 *@since 1.0.6
481
-		 */
482
-		public static function siteorigin_js() {
483
-			ob_start();
484
-			?>
470
+            $html = ob_get_clean();
471
+
472
+            // remove line breaks so we can use it in js
473
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
474
+        }
475
+
476
+        /**
477
+         * Makes SD work with the siteOrigin page builder.
478
+         *
479
+         * @return mixed
480
+         *@since 1.0.6
481
+         */
482
+        public static function siteorigin_js() {
483
+            ob_start();
484
+            ?>
485 485
 			<script>
486 486
 				/**
487 487
 				 * Check a form to see what items should be shown or hidden.
@@ -557,29 +557,29 @@  discard block
 block discarded – undo
557 557
 				});
558 558
 			</script>
559 559
 			<?php
560
-			$output = ob_get_clean();
560
+            $output = ob_get_clean();
561 561
 
562
-			/*
562
+            /*
563 563
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
564 564
 			 */
565 565
 
566
-			return str_replace( array(
567
-				'<script>',
568
-				'</script>'
569
-			), '', $output );
570
-		}
571
-
572
-		/**
573
-		 * Output the JS and CSS for the shortcode insert button.
574
-		 *
575
-		 * @param string $editor_id
576
-		 * @param string $insert_shortcode_function
577
-		 *
578
-		 *@since 1.0.6
579
-		 *
580
-		 */
581
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
582
-			?>
566
+            return str_replace( array(
567
+                '<script>',
568
+                '</script>'
569
+            ), '', $output );
570
+        }
571
+
572
+        /**
573
+         * Output the JS and CSS for the shortcode insert button.
574
+         *
575
+         * @param string $editor_id
576
+         * @param string $insert_shortcode_function
577
+         *
578
+         *@since 1.0.6
579
+         *
580
+         */
581
+        public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
582
+            ?>
583 583
 			<style>
584 584
 				.sd-shortcode-left-wrap {
585 585
 					float: left;
@@ -707,35 +707,35 @@  discard block
 block discarded – undo
707 707
 				<?php } ?>
708 708
 			</style>
709 709
 			<?php
710
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
711
-				echo "<script>" . self::siteorigin_js() . "</script>";
712
-			}
713
-			?>
710
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
711
+                echo "<script>" . self::siteorigin_js() . "</script>";
712
+            }
713
+            ?>
714 714
 			<script>
715 715
 				<?php
716
-				if(! empty( $insert_shortcode_function )){
717
-					echo $insert_shortcode_function;
718
-				}else{
719
-
720
-				/**
721
-				 * Function for super duper insert shortcode.
722
-				 *
723
-				 * @since 1.0.0
724
-				 */
725
-				?>
716
+                if(! empty( $insert_shortcode_function )){
717
+                    echo $insert_shortcode_function;
718
+                }else{
719
+
720
+                /**
721
+                 * Function for super duper insert shortcode.
722
+                 *
723
+                 * @since 1.0.0
724
+                 */
725
+                ?>
726 726
 				function sd_insert_shortcode($editor_id) {
727 727
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
728 728
 					if ($shortcode) {
729 729
 						if (!$editor_id) {
730 730
 							<?php
731
-							if ( isset( $_REQUEST['et_fb'] ) ) {
732
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
733
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
734
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
735
-							} else {
736
-								echo '$editor_id = "#wp-content-editor-container textarea";';
737
-							}
738
-							?>
731
+                            if ( isset( $_REQUEST['et_fb'] ) ) {
732
+                                echo '$editor_id = "#main_content_content_vb_tiny_mce";';
733
+                            } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
734
+                                echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
735
+                            } else {
736
+                                echo '$editor_id = "#wp-content-editor-container textarea";';
737
+                            }
738
+                            ?>
739 739
 						} else {
740 740
 							$editor_id = '#' + $editor_id;
741 741
 						}
@@ -1049,18 +1049,18 @@  discard block
 block discarded – undo
1049 1049
 				}
1050 1050
 			</script>
1051 1051
 			<?php
1052
-		}
1053
-
1054
-		/**
1055
-		 * Gets some CSS for the widgets screen.
1056
-		 *
1057
-		 * @param bool $advanced If we should include advanced CSS.
1058
-		 *
1059
-		 * @return mixed
1060
-		 */
1061
-		public function widget_css( $advanced = true ) {
1062
-			ob_start();
1063
-			?>
1052
+        }
1053
+
1054
+        /**
1055
+         * Gets some CSS for the widgets screen.
1056
+         *
1057
+         * @param bool $advanced If we should include advanced CSS.
1058
+         *
1059
+         * @return mixed
1060
+         */
1061
+        public function widget_css( $advanced = true ) {
1062
+            ob_start();
1063
+            ?>
1064 1064
 			<style>
1065 1065
 				<?php if( $advanced ){ ?>
1066 1066
 				.sd-advanced-setting {
@@ -1100,26 +1100,26 @@  discard block
 block discarded – undo
1100 1100
 				.elementor-control .sd-argument select[multiple] option{padding:3px}
1101 1101
 			</style>
1102 1102
 			<?php
1103
-			$output = ob_get_clean();
1103
+            $output = ob_get_clean();
1104 1104
 
1105
-			/*
1105
+            /*
1106 1106
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1107 1107
 			 */
1108 1108
 
1109
-			return str_replace( array(
1110
-				'<style>',
1111
-				'</style>'
1112
-			), '', $output );
1113
-		}
1114
-
1115
-		/**
1116
-		 * Gets some JS for the widgets screen.
1117
-		 *
1118
-		 * @return mixed
1119
-		 */
1120
-		public function widget_js() {
1121
-			ob_start();
1122
-			?>
1109
+            return str_replace( array(
1110
+                '<style>',
1111
+                '</style>'
1112
+            ), '', $output );
1113
+        }
1114
+
1115
+        /**
1116
+         * Gets some JS for the widgets screen.
1117
+         *
1118
+         * @return mixed
1119
+         */
1120
+        public function widget_js() {
1121
+            ob_start();
1122
+            ?>
1123 1123
 			<script>
1124 1124
 
1125 1125
 				/**
@@ -1270,595 +1270,595 @@  discard block
 block discarded – undo
1270 1270
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1271 1271
 			</script>
1272 1272
 			<?php
1273
-			$output = ob_get_clean();
1273
+            $output = ob_get_clean();
1274 1274
 
1275
-			/*
1275
+            /*
1276 1276
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1277 1277
 			 */
1278 1278
 
1279
-			return str_replace( array(
1280
-				'<script>',
1281
-				'</script>'
1282
-			), '', $output );
1283
-		}
1284
-
1285
-
1286
-		/**
1287
-		 * Set the name from the argument key.
1288
-		 *
1289
-		 * @param $options
1290
-		 *
1291
-		 * @return mixed
1292
-		 */
1293
-		private function add_name_from_key( $options, $arguments = false ) {
1294
-			if ( ! empty( $options['arguments'] ) ) {
1295
-				foreach ( $options['arguments'] as $key => $val ) {
1296
-					$options['arguments'][ $key ]['name'] = $key;
1297
-				}
1298
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1299
-				foreach ( $options as $key => $val ) {
1300
-					$options[ $key ]['name'] = $key;
1301
-				}
1302
-			}
1279
+            return str_replace( array(
1280
+                '<script>',
1281
+                '</script>'
1282
+            ), '', $output );
1283
+        }
1284
+
1285
+
1286
+        /**
1287
+         * Set the name from the argument key.
1288
+         *
1289
+         * @param $options
1290
+         *
1291
+         * @return mixed
1292
+         */
1293
+        private function add_name_from_key( $options, $arguments = false ) {
1294
+            if ( ! empty( $options['arguments'] ) ) {
1295
+                foreach ( $options['arguments'] as $key => $val ) {
1296
+                    $options['arguments'][ $key ]['name'] = $key;
1297
+                }
1298
+            } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1299
+                foreach ( $options as $key => $val ) {
1300
+                    $options[ $key ]['name'] = $key;
1301
+                }
1302
+            }
1303
+
1304
+            return $options;
1305
+        }
1306
+
1307
+        /**
1308
+         * Register the parent shortcode.
1309
+         *
1310
+         * @since 1.0.0
1311
+         */
1312
+        public function register_shortcode() {
1313
+            add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1314
+            add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1315
+        }
1316
+
1317
+        /**
1318
+         * Render the shortcode via ajax so we can return it to Gutenberg.
1319
+         *
1320
+         * @since 1.0.0
1321
+         */
1322
+        public function render_shortcode() {
1323
+            check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1324
+            if ( ! current_user_can( 'manage_options' ) ) {
1325
+                wp_die();
1326
+            }
1327
+
1328
+            // we might need the $post value here so lets set it.
1329
+            if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1330
+                $post_obj = get_post( absint( $_POST['post_id'] ) );
1331
+                if ( ! empty( $post_obj ) && empty( $post ) ) {
1332
+                    global $post;
1333
+                    $post = $post_obj;
1334
+                }
1335
+            }
1336
+
1337
+            if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1338
+                $is_preview = $this->is_preview();
1339
+                $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1340
+                $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1341
+                $attributes       = '';
1342
+                if ( ! empty( $attributes_array ) ) {
1343
+                    foreach ( $attributes_array as $key => $value ) {
1344
+                        if ( is_array( $value ) ) {
1345
+                            $value = implode( ",", $value );
1346
+                        }
1347
+
1348
+                        if ( ! empty( $value ) ) {
1349
+                            $value = wp_unslash( $value );
1350
+
1351
+                            // Encode [ and ].
1352
+                            if ( $is_preview ) {
1353
+                                $value = $this->encode_shortcodes( $value );
1354
+                            }
1355
+                        }
1356
+                        $attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1357
+                    }
1358
+                }
1359
+
1360
+                $shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1361
+
1362
+                $content = do_shortcode( $shortcode );
1363
+
1364
+                // Decode [ and ].
1365
+                if ( ! empty( $content ) && $is_preview ) {
1366
+                    $content = $this->decode_shortcodes( $content );
1367
+                }
1368
+
1369
+                echo $content;
1370
+            }
1371
+            wp_die();
1372
+        }
1373
+
1374
+        /**
1375
+         * Output the shortcode.
1376
+         *
1377
+         * @param array $args
1378
+         * @param string $content
1379
+         *
1380
+         * @return string
1381
+         */
1382
+        public function shortcode_output( $args = array(), $content = '' ) {
1383
+            $_instance = $args;
1384
+
1385
+            $args = $this->argument_values( $args );
1386
+
1387
+            // add extra argument so we know its a output to gutenberg
1388
+            //$args
1389
+            $args = $this->string_to_bool( $args );
1390
+
1391
+            // if we have a enclosed shortcode we add it to the special `html` argument
1392
+            if ( ! empty( $content ) ) {
1393
+                $args['html'] = $content;
1394
+            }
1395
+
1396
+            if ( ! $this->is_preview() ) {
1397
+                /**
1398
+                 * Filters the settings for a particular widget args.
1399
+                 *
1400
+                 * @param array          $args      The current widget instance's settings.
1401
+                 * @param WP_Super_Duper $widget    The current widget settings.
1402
+                 * @param array          $_instance An array of default widget arguments.
1403
+                 *
1404
+                 *@since 1.0.28
1405
+                 *
1406
+                 */
1407
+                $args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1408
+
1409
+                if ( ! is_array( $args ) ) {
1410
+                    return $args;
1411
+                }
1412
+            }
1413
+
1414
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1415
+            $class .= " sdel-".$this->get_instance_hash();
1416
+
1417
+            $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1418
+            $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1419
+
1420
+            $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1421
+            $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1422
+
1423
+            $shortcode_args = array();
1424
+            $output         = '';
1425
+            $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1426
+            if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1427
+                $no_wrap = true;
1428
+            }
1429
+            $main_content = $this->output( $args, $shortcode_args, $content );
1430
+            if ( $main_content && ! $no_wrap ) {
1431
+                // wrap the shortcode in a div with the same class as the widget
1432
+                $output .= '<div class="' . $class . '" ' . $attrs . '>';
1433
+                if ( ! empty( $args['title'] ) ) {
1434
+                    // if its a shortcode and there is a title try to grab the title wrappers
1435
+                    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1436
+                    if ( empty( $instance ) ) {
1437
+                        global $wp_registered_sidebars;
1438
+                        if ( ! empty( $wp_registered_sidebars ) ) {
1439
+                            foreach ( $wp_registered_sidebars as $sidebar ) {
1440
+                                if ( ! empty( $sidebar['before_title'] ) ) {
1441
+                                    $shortcode_args['before_title'] = $sidebar['before_title'];
1442
+                                    $shortcode_args['after_title']  = $sidebar['after_title'];
1443
+                                    break;
1444
+                                }
1445
+                            }
1446
+                        }
1447
+                    }
1448
+                    $output .= $this->output_title( $shortcode_args, $args );
1449
+                }
1450
+                $output .= $main_content;
1451
+                $output .= '</div>';
1452
+            } elseif ( $main_content && $no_wrap ) {
1453
+                $output .= $main_content;
1454
+            }
1455
+
1456
+            // if preview show a placeholder if empty
1457
+            if ( $this->is_preview() && $output == '' ) {
1458
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1459
+            }
1460
+
1461
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1462
+        }
1463
+
1464
+        /**
1465
+         * Placeholder text to show if output is empty and we are on a preview/builder page.
1466
+         *
1467
+         * @param string $name
1468
+         *
1469
+         * @return string
1470
+         */
1471
+        public function preview_placeholder_text( $name = '' ) {
1472
+            return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1473
+        }
1474
+
1475
+        /**
1476
+         * Sometimes booleans values can be turned to strings, so we fix that.
1477
+         *
1478
+         * @param $options
1479
+         *
1480
+         * @return mixed
1481
+         */
1482
+        public function string_to_bool( $options ) {
1483
+            // convert bool strings to booleans
1484
+            foreach ( $options as $key => $val ) {
1485
+                if ( $val == 'false' ) {
1486
+                    $options[ $key ] = false;
1487
+                } elseif ( $val == 'true' ) {
1488
+                    $options[ $key ] = true;
1489
+                }
1490
+            }
1491
+
1492
+            return $options;
1493
+        }
1494
+
1495
+        /**
1496
+         * Get the argument values that are also filterable.
1497
+         *
1498
+         * @param $instance
1499
+         *
1500
+         * @return array
1501
+         *@since 1.0.12 Don't set checkbox default value if the value is empty.
1502
+         *
1503
+         */
1504
+        public function argument_values( $instance ) {
1505
+            $argument_values = array();
1506
+
1507
+            // set widget instance
1508
+            $this->instance = $instance;
1509
+
1510
+            if ( empty( $this->arguments ) ) {
1511
+                $this->arguments = $this->get_arguments();
1512
+            }
1513
+
1514
+            if ( ! empty( $this->arguments ) ) {
1515
+                foreach ( $this->arguments as $key => $args ) {
1516
+                    // set the input name from the key
1517
+                    $args['name'] = $key;
1518
+                    //
1519
+                    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1520
+                    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1521
+                        // don't set default for an empty checkbox
1522
+                    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1523
+                        $argument_values[ $key ] = $args['default'];
1524
+                    }
1525
+                }
1526
+            }
1527
+
1528
+            return $argument_values;
1529
+        }
1530
+
1531
+        /**
1532
+         * Set arguments in super duper.
1533
+         *
1534
+         * @return array Set arguments.
1535
+         *@since 1.0.0
1536
+         *
1537
+         */
1538
+        public function set_arguments() {
1539
+            return $this->arguments;
1540
+        }
1541
+
1542
+        /**
1543
+         * Get arguments in super duper.
1544
+         *
1545
+         * @return array Get arguments.
1546
+         *@since 1.0.0
1547
+         *
1548
+         */
1549
+        public function get_arguments() {
1550
+            if ( empty( $this->arguments ) ) {
1551
+                $this->arguments = $this->set_arguments();
1552
+            }
1553
+
1554
+            $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1555
+            $this->arguments = $this->add_name_from_key( $this->arguments, true );
1556
+
1557
+            return $this->arguments;
1558
+        }
1559
+
1560
+        /**
1561
+         * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1562
+         *
1563
+         * @param array $args
1564
+         * @param array $widget_args
1565
+         * @param string $content
1566
+         */
1567
+        public function output( $args = array(), $widget_args = array(), $content = '' ) {
1568
+
1569
+        }
1570
+
1571
+        /**
1572
+         * Add the dynamic block code inline when the wp-block in enqueued.
1573
+         */
1574
+        public function register_block() {
1575
+            wp_add_inline_script( 'wp-blocks', $this->block() );
1576
+            if ( class_exists( 'SiteOrigin_Panels' ) ) {
1577
+                wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1578
+            }
1579
+        }
1580
+
1581
+        /**
1582
+         * Check if we need to show advanced options.
1583
+         *
1584
+         * @return bool
1585
+         */
1586
+        public function block_show_advanced() {
1587
+
1588
+            $show      = false;
1589
+            $arguments = $this->get_arguments();
1590
+
1591
+            if ( ! empty( $arguments ) ) {
1592
+                foreach ( $arguments as $argument ) {
1593
+                    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1594
+                        $show = true;
1595
+                        break; // no need to continue if we know we have it
1596
+                    }
1597
+                }
1598
+            }
1599
+
1600
+            return $show;
1601
+        }
1602
+
1603
+        /**
1604
+         * Get the url path to the current folder.
1605
+         *
1606
+         * @return string
1607
+         */
1608
+        public function get_url() {
1609
+            $url = $this->url;
1610
+
1611
+            if ( ! $url ) {
1612
+                $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1613
+                $content_url = untrailingslashit( WP_CONTENT_URL );
1614
+
1615
+                // Replace http:// to https://.
1616
+                if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1617
+                    $content_url = str_replace( 'http://', 'https://', $content_url );
1618
+                }
1619
+
1620
+                // Check if we are inside a plugin
1621
+                $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1622
+                $url = str_replace( $content_dir, $content_url, $file_dir );
1623
+                $url = trailingslashit( $url );
1624
+                $this->url = $url;
1625
+            }
1626
+
1627
+            return $url;
1628
+        }
1629
+
1630
+        /**
1631
+         * Get the url path to the current folder.
1632
+         *
1633
+         * @return string
1634
+         */
1635
+        public function get_url_old() {
1636
+
1637
+            $url = $this->url;
1638
+
1639
+            if ( ! $url ) {
1640
+                // check if we are inside a plugin
1641
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1642
+
1643
+                $dir_parts = explode( "/wp-content/", $file_dir );
1644
+                $url_parts = explode( "/wp-content/", plugins_url() );
1645
+
1646
+                if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1647
+                    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1648
+                    $this->url = $url;
1649
+                }
1650
+            }
1651
+
1652
+
1653
+            return $url;
1654
+        }
1655
+
1656
+        /**
1657
+         * Generate the block icon.
1658
+         *
1659
+         * Enables the use of Font Awesome icons.
1660
+         *
1661
+         * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1662
+         *
1663
+         * @param $icon
1664
+         *
1665
+         * @return string
1666
+         *@since 1.1.0
1667
+         */
1668
+        public function get_block_icon( $icon ) {
1669
+
1670
+            // check if we have a Font Awesome icon
1671
+            $fa_type = '';
1672
+            if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1673
+                $fa_type = 'solid';
1674
+            } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1675
+                $fa_type = 'regular';
1676
+            } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1677
+                $fa_type = 'brands';
1678
+            } else {
1679
+                $icon = "'" . $icon . "'";
1680
+            }
1681
+
1682
+            // set the icon if we found one
1683
+            if ( $fa_type ) {
1684
+                $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1685
+                $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 . "'}))";
1686
+            }
1687
+
1688
+            return $icon;
1689
+        }
1690
+
1691
+        public function group_arguments( $arguments ) {
1692
+            if ( ! empty( $arguments ) ) {
1693
+                $temp_arguments = array();
1694
+                $general        = __( "General", 'ayecode-connect' );
1695
+                $add_sections   = false;
1696
+                foreach ( $arguments as $key => $args ) {
1697
+                    if ( isset( $args['group'] ) ) {
1698
+                        $temp_arguments[ $args['group'] ][ $key ] = $args;
1699
+                        $add_sections                             = true;
1700
+                    } else {
1701
+                        $temp_arguments[ $general ][ $key ] = $args;
1702
+                    }
1703
+                }
1704
+
1705
+                // only add sections if more than one
1706
+                if ( $add_sections ) {
1707
+                    $arguments = $temp_arguments;
1708
+                }
1709
+            }
1710
+
1711
+            return $arguments;
1712
+        }
1713
+
1714
+        /**
1715
+         * Parse used group tabs.
1716
+         *
1717
+         * @since 1.1.17
1718
+         */
1719
+        public function group_block_tabs( $tabs, $arguments ) {
1720
+            if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1721
+                $has_sections = false;
1722
+
1723
+                foreach ( $this->arguments as $key => $args ) {
1724
+                    if ( isset( $args['group'] ) ) {
1725
+                        $has_sections = true;
1726
+                        break;
1727
+                    }
1728
+                }
1729
+
1730
+                if ( ! $has_sections ) {
1731
+                    return $tabs;
1732
+                }
1733
+
1734
+                $new_tabs = array();
1735
+
1736
+                foreach ( $tabs as $tab_key => $tab ) {
1737
+                    $new_groups = array();
1738
+
1739
+                    if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1740
+                        foreach ( $tab['groups'] as $group ) {
1741
+                            if ( isset( $arguments[ $group ] ) ) {
1742
+                                $new_groups[] = $group;
1743
+                            }
1744
+                        }
1745
+                    }
1746
+
1747
+                    if ( ! empty( $new_groups ) ) {
1748
+                        $tab['groups'] = $new_groups;
1749
+
1750
+                        $new_tabs[ $tab_key ] = $tab;
1751
+                    }
1752
+                }
1753
+
1754
+                $tabs = $new_tabs;
1755
+            }
1756
+
1757
+            return $tabs;
1758
+        }
1759
+
1760
+        /**
1761
+         * Output the JS for building the dynamic Guntenberg block.
1762
+         *
1763
+         * @return mixed
1764
+         *@since 1.0.9 Save numbers as numbers and not strings.
1765
+         * @since 1.1.0 Font Awesome classes can be used for icons.
1766
+         * @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.
1767
+         */
1768
+        public function block() {
1769
+            global $sd_is_js_functions_loaded, $aui_bs5;
1770
+
1771
+            $show_advanced = $this->block_show_advanced();
1772
+
1773
+            ob_start();
1774
+            ?>
1775
+			<script>
1776
+			<?php
1777
+            if ( ! $sd_is_js_functions_loaded ) {
1778
+                $sd_is_js_functions_loaded = true;
1779
+            ?>
1780
+function sd_show_view_options($this){
1781
+	if(jQuery($this).html().length){
1782
+		jQuery($this).html('');
1783
+	}else{
1784
+		jQuery($this).html('<div class="position-absolute d-flex flex-column bg-white p-1 rounded border shadow-lg " style="top:-80px;left:-5px;"><div class="dashicons dashicons-desktop mb-1" onclick="sd_set_view_type(\'Desktop\');"></div><div class="dashicons dashicons-tablet mb-1" onclick="sd_set_view_type(\'Tablet\');"></div><div class="dashicons dashicons-smartphone" onclick="sd_set_view_type(\'Mobile\');"></div></div>');
1785
+	}
1786
+}
1303 1787
 
1304
-			return $options;
1305
-		}
1788
+function sd_set_view_type($device){
1789
+	wp.data.dispatch('core/edit-site') ? wp.data.dispatch('core/edit-site').__experimentalSetPreviewDeviceType($device) : wp.data.dispatch('core/edit-post').__experimentalSetPreviewDeviceType($device);
1790
+}
1306 1791
 
1307
-		/**
1308
-		 * Register the parent shortcode.
1309
-		 *
1310
-		 * @since 1.0.0
1311
-		 */
1312
-		public function register_shortcode() {
1313
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1314
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1792
+jQuery(function(){
1793
+	sd_block_visibility_init();
1794
+});
1795
+function sd_block_visibility_init() {
1796
+	jQuery(document).off('change', '.bs-vc-modal-form').on('change', '.bs-vc-modal-form', function() {
1797
+		try {
1798
+			aui_conditional_fields('.bs-vc-modal-form');
1799
+		} catch(err) {
1800
+			console.log(err.message);
1315 1801
 		}
1802
+	});
1316 1803
 
1317
-		/**
1318
-		 * Render the shortcode via ajax so we can return it to Gutenberg.
1319
-		 *
1320
-		 * @since 1.0.0
1321
-		 */
1322
-		public function render_shortcode() {
1323
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1324
-			if ( ! current_user_can( 'manage_options' ) ) {
1325
-				wp_die();
1326
-			}
1327
-
1328
-			// we might need the $post value here so lets set it.
1329
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1330
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1331
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1332
-					global $post;
1333
-					$post = $post_obj;
1334
-				}
1335
-			}
1336
-
1337
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1338
-				$is_preview = $this->is_preview();
1339
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1340
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1341
-				$attributes       = '';
1342
-				if ( ! empty( $attributes_array ) ) {
1343
-					foreach ( $attributes_array as $key => $value ) {
1344
-						if ( is_array( $value ) ) {
1345
-							$value = implode( ",", $value );
1346
-						}
1347
-
1348
-						if ( ! empty( $value ) ) {
1349
-							$value = wp_unslash( $value );
1350
-
1351
-							// Encode [ and ].
1352
-							if ( $is_preview ) {
1353
-								$value = $this->encode_shortcodes( $value );
1354
-							}
1355
-						}
1356
-						$attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1804
+	jQuery(document).off('click', '.bs-vc-save').on('click', '.bs-vc-save', function() {
1805
+		var $bsvcModal = jQuery(this).closest('.bs-vc-modal'), $bsvcForm = $bsvcModal.find('.bs-vc-modal-form'), vOutput = jQuery('#bsvc_output', $bsvcForm).val(), rawValue = '', oVal = {}, oOut = {}, iRule = 0;
1806
+		jQuery(this).addClass('disabled');
1807
+		jQuery('.bs-vc-modal-form .bs-vc-rule-sets .bs-vc-rule').each(function(){
1808
+			vRule = jQuery(this).find('.bsvc_rule').val(), oRule = {};
1809
+			if (vRule == 'logged_in' || vRule == 'logged_out' || vRule == 'post_author') {
1810
+				oRule.type = vRule;
1811
+			} else if (vRule == 'user_roles') {
1812
+				oRule.type = vRule;
1813
+				if (jQuery(this).find('.bsvc_user_roles:checked').length) {
1814
+					var user_roles = jQuery(this).find('.bsvc_user_roles:checked').map(function() {
1815
+						return jQuery(this).val();
1816
+					}).get();
1817
+					if (user_roles && user_roles.length) {
1818
+						oRule.user_roles = user_roles.join(",");
1357 1819
 					}
1358 1820
 				}
1359
-
1360
-				$shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1361
-
1362
-				$content = do_shortcode( $shortcode );
1363
-
1364
-				// Decode [ and ].
1365
-				if ( ! empty( $content ) && $is_preview ) {
1366
-					$content = $this->decode_shortcodes( $content );
1821
+			} else if (vRule == 'gd_field') {
1822
+				if (jQuery(this).find('.bsvc_gd_field ').val() && jQuery(this).find('.bsvc_gd_field_condition').val()) {
1823
+					oRule.type = vRule;
1824
+					oRule.field = jQuery(this).find('.bsvc_gd_field ').val();
1825
+					oRule.condition = jQuery(this).find('.bsvc_gd_field_condition').val();
1826
+					if (oRule.condition != 'is_empty' && oRule.condition != 'is_not_empty') {
1827
+						oRule.search = jQuery(this).find('.bsvc_gd_field_search').val();
1828
+					}
1367 1829
 				}
1368
-
1369
-				echo $content;
1370 1830
 			}
1371
-			wp_die();
1372
-		}
1373
-
1374
-		/**
1375
-		 * Output the shortcode.
1376
-		 *
1377
-		 * @param array $args
1378
-		 * @param string $content
1379
-		 *
1380
-		 * @return string
1381
-		 */
1382
-		public function shortcode_output( $args = array(), $content = '' ) {
1383
-			$_instance = $args;
1384
-
1385
-			$args = $this->argument_values( $args );
1386
-
1387
-			// add extra argument so we know its a output to gutenberg
1388
-			//$args
1389
-			$args = $this->string_to_bool( $args );
1390
-
1391
-			// if we have a enclosed shortcode we add it to the special `html` argument
1392
-			if ( ! empty( $content ) ) {
1393
-				$args['html'] = $content;
1831
+			if (Object.keys(oRule).length > 0) {
1832
+				iRule++;
1833
+				oVal['rule'+iRule] = oRule;
1394 1834
 			}
1395
-
1396
-			if ( ! $this->is_preview() ) {
1397
-				/**
1398
-				 * Filters the settings for a particular widget args.
1399
-				 *
1400
-				 * @param array          $args      The current widget instance's settings.
1401
-				 * @param WP_Super_Duper $widget    The current widget settings.
1402
-				 * @param array          $_instance An array of default widget arguments.
1403
-				 *
1404
-				 *@since 1.0.28
1405
-				 *
1406
-				 */
1407
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1408
-
1409
-				if ( ! is_array( $args ) ) {
1410
-					return $args;
1835
+		});
1836
+		if (vOutput == 'hide') {
1837
+			oOut.type = vOutput;
1838
+		} else if (vOutput == 'message') {
1839
+			if (jQuery('#bsvc_message', $bsvcForm).val()) {
1840
+				oOut.type = vOutput;
1841
+				oOut.message = jQuery('#bsvc_message', $bsvcForm).val();
1842
+				if (jQuery('#bsvc_message_type', $bsvcForm).val()) {
1843
+					oOut.message_type = jQuery('#bsvc_message_type', $bsvcForm).val();
1411 1844
 				}
1412 1845
 			}
1413
-
1414
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1415
-			$class .= " sdel-".$this->get_instance_hash();
1416
-
1417
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1418
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1419
-
1420
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1421
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1422
-
1423
-			$shortcode_args = array();
1424
-			$output         = '';
1425
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1426
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1427
-				$no_wrap = true;
1428
-			}
1429
-			$main_content = $this->output( $args, $shortcode_args, $content );
1430
-			if ( $main_content && ! $no_wrap ) {
1431
-				// wrap the shortcode in a div with the same class as the widget
1432
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1433
-				if ( ! empty( $args['title'] ) ) {
1434
-					// if its a shortcode and there is a title try to grab the title wrappers
1435
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1436
-					if ( empty( $instance ) ) {
1437
-						global $wp_registered_sidebars;
1438
-						if ( ! empty( $wp_registered_sidebars ) ) {
1439
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1440
-								if ( ! empty( $sidebar['before_title'] ) ) {
1441
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1442
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1443
-									break;
1444
-								}
1445
-							}
1446
-						}
1447
-					}
1448
-					$output .= $this->output_title( $shortcode_args, $args );
1449
-				}
1450
-				$output .= $main_content;
1451
-				$output .= '</div>';
1452
-			} elseif ( $main_content && $no_wrap ) {
1453
-				$output .= $main_content;
1846
+		} else if (vOutput == 'page') {
1847
+			if (jQuery('#bsvc_page', $bsvcForm).val()) {
1848
+				oOut.type = vOutput;
1849
+				oOut.page = jQuery('#bsvc_page', $bsvcForm).val();
1454 1850
 			}
1455
-
1456
-			// if preview show a placeholder if empty
1457
-			if ( $this->is_preview() && $output == '' ) {
1458
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1851
+		} else if (vOutput == 'template_part') {
1852
+			if (jQuery('#bsvc_tmpl_part', $bsvcForm).val()) {
1853
+				oOut.type = vOutput;
1854
+				oOut.template_part = jQuery('#bsvc_tmpl_part', $bsvcForm).val();
1459 1855
 			}
1460
-
1461
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1462 1856
 		}
1463
-
1464
-		/**
1465
-		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1466
-		 *
1467
-		 * @param string $name
1468
-		 *
1469
-		 * @return string
1470
-		 */
1471
-		public function preview_placeholder_text( $name = '' ) {
1472
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1857
+		if (Object.keys(oOut).length > 0) {
1858
+			oVal.output = oOut;
1473 1859
 		}
1474
-
1475
-		/**
1476
-		 * Sometimes booleans values can be turned to strings, so we fix that.
1477
-		 *
1478
-		 * @param $options
1479
-		 *
1480
-		 * @return mixed
1481
-		 */
1482
-		public function string_to_bool( $options ) {
1483
-			// convert bool strings to booleans
1484
-			foreach ( $options as $key => $val ) {
1485
-				if ( $val == 'false' ) {
1486
-					$options[ $key ] = false;
1487
-				} elseif ( $val == 'true' ) {
1488
-					$options[ $key ] = true;
1489
-				}
1490
-			}
1491
-
1492
-			return $options;
1493
-		}
1494
-
1495
-		/**
1496
-		 * Get the argument values that are also filterable.
1497
-		 *
1498
-		 * @param $instance
1499
-		 *
1500
-		 * @return array
1501
-		 *@since 1.0.12 Don't set checkbox default value if the value is empty.
1502
-		 *
1503
-		 */
1504
-		public function argument_values( $instance ) {
1505
-			$argument_values = array();
1506
-
1507
-			// set widget instance
1508
-			$this->instance = $instance;
1509
-
1510
-			if ( empty( $this->arguments ) ) {
1511
-				$this->arguments = $this->get_arguments();
1512
-			}
1513
-
1514
-			if ( ! empty( $this->arguments ) ) {
1515
-				foreach ( $this->arguments as $key => $args ) {
1516
-					// set the input name from the key
1517
-					$args['name'] = $key;
1518
-					//
1519
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1520
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1521
-						// don't set default for an empty checkbox
1522
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1523
-						$argument_values[ $key ] = $args['default'];
1524
-					}
1525
-				}
1526
-			}
1527
-
1528
-			return $argument_values;
1529
-		}
1530
-
1531
-		/**
1532
-		 * Set arguments in super duper.
1533
-		 *
1534
-		 * @return array Set arguments.
1535
-		 *@since 1.0.0
1536
-		 *
1537
-		 */
1538
-		public function set_arguments() {
1539
-			return $this->arguments;
1540
-		}
1541
-
1542
-		/**
1543
-		 * Get arguments in super duper.
1544
-		 *
1545
-		 * @return array Get arguments.
1546
-		 *@since 1.0.0
1547
-		 *
1548
-		 */
1549
-		public function get_arguments() {
1550
-			if ( empty( $this->arguments ) ) {
1551
-				$this->arguments = $this->set_arguments();
1552
-			}
1553
-
1554
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1555
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1556
-
1557
-			return $this->arguments;
1558
-		}
1559
-
1560
-		/**
1561
-		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1562
-		 *
1563
-		 * @param array $args
1564
-		 * @param array $widget_args
1565
-		 * @param string $content
1566
-		 */
1567
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1568
-
1569
-		}
1570
-
1571
-		/**
1572
-		 * Add the dynamic block code inline when the wp-block in enqueued.
1573
-		 */
1574
-		public function register_block() {
1575
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1576
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1577
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1578
-			}
1579
-		}
1580
-
1581
-		/**
1582
-		 * Check if we need to show advanced options.
1583
-		 *
1584
-		 * @return bool
1585
-		 */
1586
-		public function block_show_advanced() {
1587
-
1588
-			$show      = false;
1589
-			$arguments = $this->get_arguments();
1590
-
1591
-			if ( ! empty( $arguments ) ) {
1592
-				foreach ( $arguments as $argument ) {
1593
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1594
-						$show = true;
1595
-						break; // no need to continue if we know we have it
1596
-					}
1597
-				}
1598
-			}
1599
-
1600
-			return $show;
1601
-		}
1602
-
1603
-		/**
1604
-		 * Get the url path to the current folder.
1605
-		 *
1606
-		 * @return string
1607
-		 */
1608
-		public function get_url() {
1609
-			$url = $this->url;
1610
-
1611
-			if ( ! $url ) {
1612
-				$content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1613
-				$content_url = untrailingslashit( WP_CONTENT_URL );
1614
-
1615
-				// Replace http:// to https://.
1616
-				if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1617
-					$content_url = str_replace( 'http://', 'https://', $content_url );
1618
-				}
1619
-
1620
-				// Check if we are inside a plugin
1621
-				$file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1622
-				$url = str_replace( $content_dir, $content_url, $file_dir );
1623
-				$url = trailingslashit( $url );
1624
-				$this->url = $url;
1625
-			}
1626
-
1627
-			return $url;
1628
-		}
1629
-
1630
-		/**
1631
-		 * Get the url path to the current folder.
1632
-		 *
1633
-		 * @return string
1634
-		 */
1635
-		public function get_url_old() {
1636
-
1637
-			$url = $this->url;
1638
-
1639
-			if ( ! $url ) {
1640
-				// check if we are inside a plugin
1641
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1642
-
1643
-				$dir_parts = explode( "/wp-content/", $file_dir );
1644
-				$url_parts = explode( "/wp-content/", plugins_url() );
1645
-
1646
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1647
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1648
-					$this->url = $url;
1649
-				}
1650
-			}
1651
-
1652
-
1653
-			return $url;
1654
-		}
1655
-
1656
-		/**
1657
-		 * Generate the block icon.
1658
-		 *
1659
-		 * Enables the use of Font Awesome icons.
1660
-		 *
1661
-		 * @note xlink:href is actually deprecated but href is not supported by all so we use both.
1662
-		 *
1663
-		 * @param $icon
1664
-		 *
1665
-		 * @return string
1666
-		 *@since 1.1.0
1667
-		 */
1668
-		public function get_block_icon( $icon ) {
1669
-
1670
-			// check if we have a Font Awesome icon
1671
-			$fa_type = '';
1672
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1673
-				$fa_type = 'solid';
1674
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1675
-				$fa_type = 'regular';
1676
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1677
-				$fa_type = 'brands';
1678
-			} else {
1679
-				$icon = "'" . $icon . "'";
1680
-			}
1681
-
1682
-			// set the icon if we found one
1683
-			if ( $fa_type ) {
1684
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1685
-				$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 . "'}))";
1686
-			}
1687
-
1688
-			return $icon;
1689
-		}
1690
-
1691
-		public function group_arguments( $arguments ) {
1692
-			if ( ! empty( $arguments ) ) {
1693
-				$temp_arguments = array();
1694
-				$general        = __( "General", 'ayecode-connect' );
1695
-				$add_sections   = false;
1696
-				foreach ( $arguments as $key => $args ) {
1697
-					if ( isset( $args['group'] ) ) {
1698
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1699
-						$add_sections                             = true;
1700
-					} else {
1701
-						$temp_arguments[ $general ][ $key ] = $args;
1702
-					}
1703
-				}
1704
-
1705
-				// only add sections if more than one
1706
-				if ( $add_sections ) {
1707
-					$arguments = $temp_arguments;
1708
-				}
1709
-			}
1710
-
1711
-			return $arguments;
1712
-		}
1713
-
1714
-		/**
1715
-		 * Parse used group tabs.
1716
-		 *
1717
-		 * @since 1.1.17
1718
-		 */
1719
-		public function group_block_tabs( $tabs, $arguments ) {
1720
-			if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1721
-				$has_sections = false;
1722
-
1723
-				foreach ( $this->arguments as $key => $args ) {
1724
-					if ( isset( $args['group'] ) ) {
1725
-						$has_sections = true;
1726
-						break;
1727
-					}
1728
-				}
1729
-
1730
-				if ( ! $has_sections ) {
1731
-					return $tabs;
1732
-				}
1733
-
1734
-				$new_tabs = array();
1735
-
1736
-				foreach ( $tabs as $tab_key => $tab ) {
1737
-					$new_groups = array();
1738
-
1739
-					if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1740
-						foreach ( $tab['groups'] as $group ) {
1741
-							if ( isset( $arguments[ $group ] ) ) {
1742
-								$new_groups[] = $group;
1743
-							}
1744
-						}
1745
-					}
1746
-
1747
-					if ( ! empty( $new_groups ) ) {
1748
-						$tab['groups'] = $new_groups;
1749
-
1750
-						$new_tabs[ $tab_key ] = $tab;
1751
-					}
1752
-				}
1753
-
1754
-				$tabs = $new_tabs;
1755
-			}
1756
-
1757
-			return $tabs;
1758
-		}
1759
-
1760
-		/**
1761
-		 * Output the JS for building the dynamic Guntenberg block.
1762
-		 *
1763
-		 * @return mixed
1764
-		 *@since 1.0.9 Save numbers as numbers and not strings.
1765
-		 * @since 1.1.0 Font Awesome classes can be used for icons.
1766
-		 * @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.
1767
-		 */
1768
-		public function block() {
1769
-			global $sd_is_js_functions_loaded, $aui_bs5;
1770
-
1771
-			$show_advanced = $this->block_show_advanced();
1772
-
1773
-			ob_start();
1774
-			?>
1775
-			<script>
1776
-			<?php
1777
-			if ( ! $sd_is_js_functions_loaded ) {
1778
-				$sd_is_js_functions_loaded = true;
1779
-			?>
1780
-function sd_show_view_options($this){
1781
-	if(jQuery($this).html().length){
1782
-		jQuery($this).html('');
1783
-	}else{
1784
-		jQuery($this).html('<div class="position-absolute d-flex flex-column bg-white p-1 rounded border shadow-lg " style="top:-80px;left:-5px;"><div class="dashicons dashicons-desktop mb-1" onclick="sd_set_view_type(\'Desktop\');"></div><div class="dashicons dashicons-tablet mb-1" onclick="sd_set_view_type(\'Tablet\');"></div><div class="dashicons dashicons-smartphone" onclick="sd_set_view_type(\'Mobile\');"></div></div>');
1785
-	}
1786
-}
1787
-
1788
-function sd_set_view_type($device){
1789
-	wp.data.dispatch('core/edit-site') ? wp.data.dispatch('core/edit-site').__experimentalSetPreviewDeviceType($device) : wp.data.dispatch('core/edit-post').__experimentalSetPreviewDeviceType($device);
1790
-}
1791
-
1792
-jQuery(function(){
1793
-	sd_block_visibility_init();
1794
-});
1795
-function sd_block_visibility_init() {
1796
-	jQuery(document).off('change', '.bs-vc-modal-form').on('change', '.bs-vc-modal-form', function() {
1797
-		try {
1798
-			aui_conditional_fields('.bs-vc-modal-form');
1799
-		} catch(err) {
1800
-			console.log(err.message);
1801
-		}
1802
-	});
1803
-
1804
-	jQuery(document).off('click', '.bs-vc-save').on('click', '.bs-vc-save', function() {
1805
-		var $bsvcModal = jQuery(this).closest('.bs-vc-modal'), $bsvcForm = $bsvcModal.find('.bs-vc-modal-form'), vOutput = jQuery('#bsvc_output', $bsvcForm).val(), rawValue = '', oVal = {}, oOut = {}, iRule = 0;
1806
-		jQuery(this).addClass('disabled');
1807
-		jQuery('.bs-vc-modal-form .bs-vc-rule-sets .bs-vc-rule').each(function(){
1808
-			vRule = jQuery(this).find('.bsvc_rule').val(), oRule = {};
1809
-			if (vRule == 'logged_in' || vRule == 'logged_out' || vRule == 'post_author') {
1810
-				oRule.type = vRule;
1811
-			} else if (vRule == 'user_roles') {
1812
-				oRule.type = vRule;
1813
-				if (jQuery(this).find('.bsvc_user_roles:checked').length) {
1814
-					var user_roles = jQuery(this).find('.bsvc_user_roles:checked').map(function() {
1815
-						return jQuery(this).val();
1816
-					}).get();
1817
-					if (user_roles && user_roles.length) {
1818
-						oRule.user_roles = user_roles.join(",");
1819
-					}
1820
-				}
1821
-			} else if (vRule == 'gd_field') {
1822
-				if (jQuery(this).find('.bsvc_gd_field ').val() && jQuery(this).find('.bsvc_gd_field_condition').val()) {
1823
-					oRule.type = vRule;
1824
-					oRule.field = jQuery(this).find('.bsvc_gd_field ').val();
1825
-					oRule.condition = jQuery(this).find('.bsvc_gd_field_condition').val();
1826
-					if (oRule.condition != 'is_empty' && oRule.condition != 'is_not_empty') {
1827
-						oRule.search = jQuery(this).find('.bsvc_gd_field_search').val();
1828
-					}
1829
-				}
1830
-			}
1831
-			if (Object.keys(oRule).length > 0) {
1832
-				iRule++;
1833
-				oVal['rule'+iRule] = oRule;
1834
-			}
1835
-		});
1836
-		if (vOutput == 'hide') {
1837
-			oOut.type = vOutput;
1838
-		} else if (vOutput == 'message') {
1839
-			if (jQuery('#bsvc_message', $bsvcForm).val()) {
1840
-				oOut.type = vOutput;
1841
-				oOut.message = jQuery('#bsvc_message', $bsvcForm).val();
1842
-				if (jQuery('#bsvc_message_type', $bsvcForm).val()) {
1843
-					oOut.message_type = jQuery('#bsvc_message_type', $bsvcForm).val();
1844
-				}
1845
-			}
1846
-		} else if (vOutput == 'page') {
1847
-			if (jQuery('#bsvc_page', $bsvcForm).val()) {
1848
-				oOut.type = vOutput;
1849
-				oOut.page = jQuery('#bsvc_page', $bsvcForm).val();
1850
-			}
1851
-		} else if (vOutput == 'template_part') {
1852
-			if (jQuery('#bsvc_tmpl_part', $bsvcForm).val()) {
1853
-				oOut.type = vOutput;
1854
-				oOut.template_part = jQuery('#bsvc_tmpl_part', $bsvcForm).val();
1855
-			}
1856
-		}
1857
-		if (Object.keys(oOut).length > 0) {
1858
-			oVal.output = oOut;
1859
-		}
1860
-		if (Object.keys(oVal).length > 0) {
1861
-			rawValue = JSON.stringify(oVal);
1860
+		if (Object.keys(oVal).length > 0) {
1861
+			rawValue = JSON.stringify(oVal);
1862 1862
 		}
1863 1863
 		$bsvcModal.find('[name="bsvc_raw_value"]').val(rawValue).trigger('change');
1864 1864
 		$bsvcModal.find('.bs-vc-close').trigger('click');
@@ -2222,8 +2222,8 @@  discard block
 block discarded – undo
2222 2222
 				$classes = [];
2223 2223
 
2224 2224
 				<?php
2225
-				if($aui_bs5){
2226
-					?>
2225
+                if($aui_bs5){
2226
+                    ?>
2227 2227
 				$aui_bs5 = true;
2228 2228
 				$p_ml = 'ms-';
2229 2229
 				$p_mr = 'me-';
@@ -2231,8 +2231,8 @@  discard block
 block discarded – undo
2231 2231
 				$p_pl = 'ps-';
2232 2232
 				$p_pr = 'pe-';
2233 2233
 					<?php
2234
-				}else{
2235
-						?>
2234
+                }else{
2235
+                        ?>
2236 2236
 				$aui_bs5 = false;
2237 2237
 				$p_ml = 'ml-';
2238 2238
 				$p_mr = 'mr-';
@@ -2240,8 +2240,8 @@  discard block
 block discarded – undo
2240 2240
 				$p_pl = 'pl-';
2241 2241
 				$p_pr = 'pr-';
2242 2242
 					<?php
2243
-				}
2244
-				?>
2243
+                }
2244
+                ?>
2245 2245
 
2246 2246
 				// margins
2247 2247
 				if ( $args['mt'] !== undefined && $args['mt'] !== '' ) { $classes.push( "mt-" + $args['mt'] );  $mt = $args['mt']; }else{$mt = null;}
@@ -2425,12 +2425,12 @@  discard block
 block discarded – undo
2425 2425
 			<?php
2426 2426
 
2427 2427
 
2428
-			}
2428
+            }
2429 2429
 
2430
-			if(method_exists($this,'block_global_js')){
2431
-					echo $this->block_global_js();
2432
-			}
2433
-			?>
2430
+            if(method_exists($this,'block_global_js')){
2431
+                    echo $this->block_global_js();
2432
+            }
2433
+            ?>
2434 2434
 
2435 2435
 jQuery(function() {
2436 2436
 
@@ -2483,13 +2483,13 @@  discard block
 block discarded – undo
2483 2483
 						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/.
2484 2484
 						supports: {
2485 2485
 							<?php
2486
-							if(!isset($this->options['block-supports']['renaming'])){
2487
-								$this->options['block-supports']['renaming'] = false;
2488
-							}
2489
-							if ( isset( $this->options['block-supports'] ) ) {
2490
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2491
-							}
2492
-							?>
2486
+                            if(!isset($this->options['block-supports']['renaming'])){
2487
+                                $this->options['block-supports']['renaming'] = false;
2488
+                            }
2489
+                            if ( isset( $this->options['block-supports'] ) ) {
2490
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
2491
+                            }
2492
+                            ?>
2493 2493
 						},
2494 2494
 						__experimentalLabel( attributes, { context } ) {
2495 2495
 							var visibility_html = attributes && attributes.visibility_conditions ? ' &#128065;' : '';
@@ -2499,174 +2499,174 @@  discard block
 block discarded – undo
2499 2499
 						},
2500 2500
 						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.
2501 2501
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
2502
-						echo "keywords : " . $this->options['block-keywords'] . ",";
2503
-						}
2504
-
2505
-
2506
-						// block hover preview.
2507
-						$example_args = array();
2508
-						if(!empty($this->arguments)){
2509
-							foreach($this->arguments as $key => $a_args){
2510
-								if(isset($a_args['example'])){
2511
-									$example_args[$key] = $a_args['example'];
2512
-								}
2513
-							}
2514
-						}
2515
-						$viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2516
-						$example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2517
-						if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2518
-							// no preview if set to false
2519
-						}elseif( !empty( $example_args ) ){
2520
-							echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2521
-						}elseif( !empty( $this->options['example'] ) ){
2522
-							unset($this->options['example']['viewportWidth']);
2523
-							unset($this->options['example']['innerBlocks']);
2524
-							$example_atts = $this->array_to_attributes( $this->options['example'] );
2525
-							$example_parts = array();
2526
-							if($example_atts){
2527
-								$example_parts[] = rtrim($example_atts,",");
2528
-							}
2529
-							if($viewport_width){
2530
-								$example_parts[] = $viewport_width;
2531
-							}
2532
-							if($example_inner_blocks){
2533
-								$example_parts[] = $example_inner_blocks;
2534
-							}
2535
-							if(!empty($example_parts)){
2536
-								echo "example : {".implode(',', $example_parts)."},";
2537
-							}
2538
-						}else{
2539
-							echo 'example : {viewportWidth: 500},';
2540
-						}
2541
-
2542
-
2543
-
2544
-						// limit to parent
2545
-						if( !empty( $this->options['parent'] ) ){
2546
-							echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2547
-						}
2548
-
2549
-						// limit allowed blocks
2550
-						if( !empty( $this->options['allowed-blocks'] ) ){
2551
-							echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2552
-						}
2553
-
2554
-						// maybe set no_wrap
2555
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2556
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2557
-							$no_wrap = true;
2558
-						}
2559
-						if ( $no_wrap ) {
2560
-							$this->options['block-wrap'] = '';
2561
-						}
2562
-
2563
-						// maybe load the drag/drop functions.
2564
-						$img_drag_drop = false;
2565
-
2566
-						$show_alignment = false;
2567
-						// align feature
2568
-						/*echo "supports: {";
2502
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
2503
+                        }
2504
+
2505
+
2506
+                        // block hover preview.
2507
+                        $example_args = array();
2508
+                        if(!empty($this->arguments)){
2509
+                            foreach($this->arguments as $key => $a_args){
2510
+                                if(isset($a_args['example'])){
2511
+                                    $example_args[$key] = $a_args['example'];
2512
+                                }
2513
+                            }
2514
+                        }
2515
+                        $viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2516
+                        $example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2517
+                        if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2518
+                            // no preview if set to false
2519
+                        }elseif( !empty( $example_args ) ){
2520
+                            echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2521
+                        }elseif( !empty( $this->options['example'] ) ){
2522
+                            unset($this->options['example']['viewportWidth']);
2523
+                            unset($this->options['example']['innerBlocks']);
2524
+                            $example_atts = $this->array_to_attributes( $this->options['example'] );
2525
+                            $example_parts = array();
2526
+                            if($example_atts){
2527
+                                $example_parts[] = rtrim($example_atts,",");
2528
+                            }
2529
+                            if($viewport_width){
2530
+                                $example_parts[] = $viewport_width;
2531
+                            }
2532
+                            if($example_inner_blocks){
2533
+                                $example_parts[] = $example_inner_blocks;
2534
+                            }
2535
+                            if(!empty($example_parts)){
2536
+                                echo "example : {".implode(',', $example_parts)."},";
2537
+                            }
2538
+                        }else{
2539
+                            echo 'example : {viewportWidth: 500},';
2540
+                        }
2541
+
2542
+
2543
+
2544
+                        // limit to parent
2545
+                        if( !empty( $this->options['parent'] ) ){
2546
+                            echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2547
+                        }
2548
+
2549
+                        // limit allowed blocks
2550
+                        if( !empty( $this->options['allowed-blocks'] ) ){
2551
+                            echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2552
+                        }
2553
+
2554
+                        // maybe set no_wrap
2555
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2556
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2557
+                            $no_wrap = true;
2558
+                        }
2559
+                        if ( $no_wrap ) {
2560
+                            $this->options['block-wrap'] = '';
2561
+                        }
2562
+
2563
+                        // maybe load the drag/drop functions.
2564
+                        $img_drag_drop = false;
2565
+
2566
+                        $show_alignment = false;
2567
+                        // align feature
2568
+                        /*echo "supports: {";
2569 2569
 						echo "	align: true,";
2570 2570
 						echo "  html: false";
2571 2571
 						echo "},";*/
2572 2572
 
2573 2573
 
2574
-							echo "attributes : {";
2575
-
2576
-							if ( $show_advanced ) {
2577
-								echo "show_advanced: {";
2578
-								echo "	type: 'boolean',";
2579
-								echo "  default: false,";
2580
-								echo "},";
2581
-							}
2582
-
2583
-							// block wrap element
2584
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2585
-								echo "block_wrap: {";
2586
-								echo "	type: 'string',";
2587
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2588
-								echo "},";
2589
-							}
2590
-
2591
-
2592
-							if ( ! empty( $this->arguments ) ) {
2593
-
2594
-								foreach ( $this->arguments as $key => $args ) {
2595
-
2596
-									if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2597
-										$img_drag_drop = true;
2598
-									}
2599
-
2600
-									// set if we should show alignment
2601
-									if ( $key == 'alignment' ) {
2602
-										$show_alignment = true;
2603
-									}
2604
-
2605
-									$extra = '';
2606
-
2607
-									if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2608
-										continue;
2609
-									}
2610
-									elseif ( $args['type'] == 'checkbox' ) {
2611
-										$type    = 'boolean';
2612
-										$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2613
-									} elseif ( $args['type'] == 'number' ) {
2614
-										$type    = 'number';
2615
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2616
-									} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2617
-										$type = 'array';
2618
-										if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2619
-											$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2620
-										} else {
2621
-											$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2622
-										}
2623
-									} elseif ( $args['type'] == 'tagselect' ) {
2624
-										$type    = 'array';
2625
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2626
-									} elseif ( $args['type'] == 'multiselect' ) {
2627
-										$type    = 'array';
2628
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2629
-									} elseif ( $args['type'] == 'image_xy' ) {
2630
-										$type    = 'object';
2631
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2632
-									} elseif ( $args['type'] == 'image' ) {
2633
-										$type    = 'string';
2634
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2635
-
2636
-										// add a field for ID
2637
-	//                                    echo $key . "_id : {";
2638
-	//                                    echo "type : 'number',";
2639
-	//                                    echo "},";
2640
-	//                                    echo $key . "_xy : {";
2641
-	//                                    echo "type : 'object',";
2642
-	//                                    echo "},";
2643
-
2644
-									} else {
2645
-										$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2646
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2647
-
2648
-									}
2649
-									echo $key . " : {";
2650
-									echo "type : '$type',";
2651
-									echo "default : $default,";
2652
-									echo "},";
2653
-								}
2654
-							}
2655
-
2656
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2657
-							echo "sd_shortcode : {type : 'string',default: ''},";
2658
-
2659
-							if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2660
-								echo "sd_shortcode_close : {type : 'string',default: ''},";
2661
-							}
2662
-
2663
-							echo "className: { type: 'string', default: '' },";
2664
-
2665
-							echo "},";
2666
-
2667
-
2668
-
2669
-						?>
2574
+                            echo "attributes : {";
2575
+
2576
+                            if ( $show_advanced ) {
2577
+                                echo "show_advanced: {";
2578
+                                echo "	type: 'boolean',";
2579
+                                echo "  default: false,";
2580
+                                echo "},";
2581
+                            }
2582
+
2583
+                            // block wrap element
2584
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2585
+                                echo "block_wrap: {";
2586
+                                echo "	type: 'string',";
2587
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2588
+                                echo "},";
2589
+                            }
2590
+
2591
+
2592
+                            if ( ! empty( $this->arguments ) ) {
2593
+
2594
+                                foreach ( $this->arguments as $key => $args ) {
2595
+
2596
+                                    if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2597
+                                        $img_drag_drop = true;
2598
+                                    }
2599
+
2600
+                                    // set if we should show alignment
2601
+                                    if ( $key == 'alignment' ) {
2602
+                                        $show_alignment = true;
2603
+                                    }
2604
+
2605
+                                    $extra = '';
2606
+
2607
+                                    if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2608
+                                        continue;
2609
+                                    }
2610
+                                    elseif ( $args['type'] == 'checkbox' ) {
2611
+                                        $type    = 'boolean';
2612
+                                        $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2613
+                                    } elseif ( $args['type'] == 'number' ) {
2614
+                                        $type    = 'number';
2615
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2616
+                                    } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2617
+                                        $type = 'array';
2618
+                                        if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2619
+                                            $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2620
+                                        } else {
2621
+                                            $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2622
+                                        }
2623
+                                    } elseif ( $args['type'] == 'tagselect' ) {
2624
+                                        $type    = 'array';
2625
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2626
+                                    } elseif ( $args['type'] == 'multiselect' ) {
2627
+                                        $type    = 'array';
2628
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2629
+                                    } elseif ( $args['type'] == 'image_xy' ) {
2630
+                                        $type    = 'object';
2631
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2632
+                                    } elseif ( $args['type'] == 'image' ) {
2633
+                                        $type    = 'string';
2634
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2635
+
2636
+                                        // add a field for ID
2637
+    //                                    echo $key . "_id : {";
2638
+    //                                    echo "type : 'number',";
2639
+    //                                    echo "},";
2640
+    //                                    echo $key . "_xy : {";
2641
+    //                                    echo "type : 'object',";
2642
+    //                                    echo "},";
2643
+
2644
+                                    } else {
2645
+                                        $type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2646
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2647
+
2648
+                                    }
2649
+                                    echo $key . " : {";
2650
+                                    echo "type : '$type',";
2651
+                                    echo "default : $default,";
2652
+                                    echo "},";
2653
+                                }
2654
+                            }
2655
+
2656
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2657
+                            echo "sd_shortcode : {type : 'string',default: ''},";
2658
+
2659
+                            if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2660
+                                echo "sd_shortcode_close : {type : 'string',default: ''},";
2661
+                            }
2662
+
2663
+                            echo "className: { type: 'string', default: '' },";
2664
+
2665
+                            echo "},";
2666
+
2667
+
2668
+
2669
+                        ?>
2670 2670
 
2671 2671
 						// The "edit" property must be a valid function.
2672 2672
 						edit: function (props) {
@@ -2740,10 +2740,10 @@  discard block
 block discarded – undo
2740 2740
 							}
2741 2741
 
2742 2742
 							<?php
2743
-							if(!empty($this->options['block-edit-raw'])) {
2744
-								echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2745
-							}else{
2746
-							?>
2743
+                            if(!empty($this->options['block-edit-raw'])) {
2744
+                                echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2745
+                            }else{
2746
+                            ?>
2747 2747
 
2748 2748
 function hasSelectedInnerBlock(props) {
2749 2749
 	const select = wp.data.select('core/editor');
@@ -2765,9 +2765,9 @@  discard block
 block discarded – undo
2765 2765
 
2766 2766
 	var $value = '';
2767 2767
 	<?php
2768
-	// if we have a post_type and a category then link them
2769
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2770
-	?>
2768
+    // if we have a post_type and a category then link them
2769
+    if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2770
+    ?>
2771 2771
 	if(typeof(prev_attributes[props.clientId]) != 'undefined'){
2772 2772
 		$pt = props.attributes.post_type;
2773 2773
 		if(post_type_rest_slugs.length){
@@ -2780,11 +2780,11 @@  discard block
 block discarded – undo
2780 2780
 			term_query_type = $pt;
2781 2781
 		}
2782 2782
 <?php
2783
-	$cat_path = '';
2784
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2785
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2786
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2787
-	}
2783
+    $cat_path = '';
2784
+    if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2785
+        $cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2786
+        $cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2787
+    }
2788 2788
 ?>
2789 2789
 		/* taxonomies */
2790 2790
 		if($value && 'post_type' in prev_attributes[props.clientId] && 'category' in prev_attributes[props.clientId] && run){
@@ -2876,7 +2876,7 @@  discard block
 block discarded – undo
2876 2876
 <?php
2877 2877
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2878 2878
 if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2879
-	echo 'const { deviceType } = "";';
2879
+    echo 'const { deviceType } = "";';
2880 2880
 }else{
2881 2881
 ?>
2882 2882
 /** Get device type const. */
@@ -2911,8 +2911,8 @@  discard block
 block discarded – undo
2911 2911
 										'attributes': props.attributes,
2912 2912
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
2913 2913
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
2914
-										echo $post->ID;
2915
-									}else{echo '0';}?>,
2914
+                                        echo $post->ID;
2915
+                                    }else{echo '0';}?>,
2916 2916
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
2917 2917
 									};
2918 2918
 
@@ -2926,20 +2926,20 @@  discard block
 block discarded – undo
2926 2926
 										}
2927 2927
 
2928 2928
 										 <?php
2929
-										if(!empty($this->options['nested-block'])){
2930
-											?>
2929
+                                        if(!empty($this->options['nested-block'])){
2930
+                                            ?>
2931 2931
 											// props.setAttributes({content: env});
2932 2932
 										is_fetching = false;
2933 2933
 										prev_attributes[props.clientId] = props.attributes;
2934 2934
 											 <?php
2935
-										}else{
2936
-										?>
2935
+                                        }else{
2936
+                                        ?>
2937 2937
 										props.setAttributes({content: env});
2938 2938
 										is_fetching = false;
2939 2939
 										prev_attributes[props.clientId] = props.attributes;
2940 2940
 										<?php
2941
-										}
2942
-										?>
2941
+                                        }
2942
+                                        ?>
2943 2943
 
2944 2944
 
2945 2945
 										// if AUI is active call the js init function
@@ -2958,31 +2958,31 @@  discard block
 block discarded – undo
2958 2958
 							}
2959 2959
 
2960 2960
 							<?php
2961
-							if(!empty($this->options['block-edit-js'])) {
2962
-								echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
2963
-							}
2961
+                            if(!empty($this->options['block-edit-js'])) {
2962
+                                echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
2963
+                            }
2964 2964
 
2965 2965
 
2966 2966
 
2967 2967
 
2968
-							if(empty($this->options['block-save-return'])){
2969
-							?>
2968
+                            if(empty($this->options['block-save-return'])){
2969
+                            ?>
2970 2970
 								///////////////////////////////////////////////////////////////////////
2971 2971
 
2972 2972
 									 // build the shortcode.
2973 2973
 								shortcode = "[<?php echo $this->options['base_id'];?>";
2974 2974
 								<?php
2975 2975
 
2976
-								if(! empty( $this->arguments )){
2976
+                                if(! empty( $this->arguments )){
2977 2977
 
2978
-								foreach($this->arguments as $key => $args){
2979
-								   // if($args['type']=='tabs'){continue;}
2978
+                                foreach($this->arguments as $key => $args){
2979
+                                    // if($args['type']=='tabs'){continue;}
2980 2980
 
2981
-								   // don't add metadata arguments
2982
-								   if (substr($key, 0, 9 ) === 'metadata_') {
2983
-									   continue;
2984
-								   }
2985
-								?>
2981
+                                    // don't add metadata arguments
2982
+                                    if (substr($key, 0, 9 ) === 'metadata_') {
2983
+                                        continue;
2984
+                                    }
2985
+                                ?>
2986 2986
 								if (props.attributes.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
2987 2987
 									if ('<?php echo esc_attr( $key );?>' == 'html') {
2988 2988
 									} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
@@ -2993,10 +2993,10 @@  discard block
 block discarded – undo
2993 2993
 									}
2994 2994
 								}
2995 2995
 								<?php
2996
-								}
2997
-								}
2996
+                                }
2997
+                                }
2998 2998
 
2999
-								?>
2999
+                                ?>
3000 3000
 								shortcode += "]";
3001 3001
 
3002 3002
 								if(shortcode){
@@ -3004,17 +3004,17 @@  discard block
 block discarded – undo
3004 3004
 									props.setAttributes({sd_shortcode: shortcode});
3005 3005
 
3006 3006
 									<?php
3007
-									if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3008
-										echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3009
-									}
3010
-									?>
3007
+                                    if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3008
+                                        echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3009
+                                    }
3010
+                                    ?>
3011 3011
 								}
3012 3012
 
3013 3013
 
3014 3014
 							///////////////////////////////////////////////////////////////////////
3015 3015
 							<?php
3016
-							} // end nested block check
3017
-							?>
3016
+                            } // end nested block check
3017
+                            ?>
3018 3018
 
3019 3019
 							return [
3020 3020
 
@@ -3038,10 +3038,10 @@  discard block
 block discarded – undo
3038 3038
 
3039 3039
 									<?php
3040 3040
 
3041
-									if(! empty( $this->arguments )){
3041
+                                    if(! empty( $this->arguments )){
3042 3042
 
3043
-									if ( $show_advanced ) {
3044
-									?>
3043
+                                    if ( $show_advanced ) {
3044
+                                    ?>
3045 3045
 									el('div', {
3046 3046
 											style: {'padding-left': '16px','padding-right': '16px'}
3047 3047
 										},
@@ -3058,119 +3058,119 @@  discard block
 block discarded – undo
3058 3058
 									)
3059 3059
 									,
3060 3060
 									<?php
3061
-									}
3062
-
3063
-									$arguments = $this->group_arguments( $this->arguments );
3064
-									$block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3065
-
3066
-									// Do we have sections?
3067
-									$has_sections = $arguments == $this->arguments ? false : true;
3068
-
3069
-									if($has_sections){
3070
-									$panel_count = 0;
3071
-									$open_tab = '';
3072
-
3073
-									$open_tab_groups = array();
3074
-									$used_tabs = array();
3075
-
3076
-									foreach ( $arguments as $key => $args ) {
3077
-										$close_tab = false;
3078
-										$close_tabs = false;
3079
-
3080
-										 if ( ! empty( $block_group_tabs ) ) {
3081
-											foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3082
-												if ( in_array( $key, $tab_args['groups'] ) ) {
3083
-													$open_tab_groups[] = $key;
3084
-
3085
-													if ( $open_tab != $tab_name ) {
3086
-														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3087
-														$tab_args['tab']['open'] = true;
3088
-
3089
-														$this->block_tab_start( '', $tab_args );
3090
-														$open_tab = $tab_name;
3091
-														$used_tabs[] = $tab_name;
3092
-													}
3093
-
3094
-													if ( $open_tab_groups == $tab_args['groups'] ) {
3095
-														$close_tab = true;
3096
-														$open_tab_groups = array();
3097
-
3098
-														if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3099
-															$close_tabs = true;
3100
-														}
3101
-													}
3102
-												}
3103
-											}
3104
-										}
3105
-										?>
3061
+                                    }
3062
+
3063
+                                    $arguments = $this->group_arguments( $this->arguments );
3064
+                                    $block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3065
+
3066
+                                    // Do we have sections?
3067
+                                    $has_sections = $arguments == $this->arguments ? false : true;
3068
+
3069
+                                    if($has_sections){
3070
+                                    $panel_count = 0;
3071
+                                    $open_tab = '';
3072
+
3073
+                                    $open_tab_groups = array();
3074
+                                    $used_tabs = array();
3075
+
3076
+                                    foreach ( $arguments as $key => $args ) {
3077
+                                        $close_tab = false;
3078
+                                        $close_tabs = false;
3079
+
3080
+                                            if ( ! empty( $block_group_tabs ) ) {
3081
+                                            foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3082
+                                                if ( in_array( $key, $tab_args['groups'] ) ) {
3083
+                                                    $open_tab_groups[] = $key;
3084
+
3085
+                                                    if ( $open_tab != $tab_name ) {
3086
+                                                        $tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3087
+                                                        $tab_args['tab']['open'] = true;
3088
+
3089
+                                                        $this->block_tab_start( '', $tab_args );
3090
+                                                        $open_tab = $tab_name;
3091
+                                                        $used_tabs[] = $tab_name;
3092
+                                                    }
3093
+
3094
+                                                    if ( $open_tab_groups == $tab_args['groups'] ) {
3095
+                                                        $close_tab = true;
3096
+                                                        $open_tab_groups = array();
3097
+
3098
+                                                        if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3099
+                                                            $close_tabs = true;
3100
+                                                        }
3101
+                                                    }
3102
+                                                }
3103
+                                            }
3104
+                                        }
3105
+                                        ?>
3106 3106
 										el(wp.components.PanelBody, {
3107 3107
 												title: '<?php esc_attr_e( $key ); ?>',
3108 3108
 												initialOpen: <?php if ( $panel_count ) {
3109
-												echo "false";
3110
-											} else {
3111
-												echo "true";
3112
-											}?>
3109
+                                                echo "false";
3110
+                                            } else {
3111
+                                                echo "true";
3112
+                                            }?>
3113 3113
 											},
3114 3114
 											<?php
3115
-											foreach ( $args as $k => $a ) {
3116
-												$this->block_tab_start( $k, $a );
3117
-												$this->block_row_start( $k, $a );
3118
-												$this->build_block_arguments( $k, $a );
3119
-												$this->block_row_end( $k, $a );
3120
-												$this->block_tab_end( $k, $a );
3121
-											}
3122
-											?>
3115
+                                            foreach ( $args as $k => $a ) {
3116
+                                                $this->block_tab_start( $k, $a );
3117
+                                                $this->block_row_start( $k, $a );
3118
+                                                $this->build_block_arguments( $k, $a );
3119
+                                                $this->block_row_end( $k, $a );
3120
+                                                $this->block_tab_end( $k, $a );
3121
+                                            }
3122
+                                            ?>
3123 3123
 										),
3124 3124
 										<?php
3125
-										$panel_count ++;
3125
+                                        $panel_count ++;
3126 3126
 
3127
-										if($close_tab || $close_tabs){
3128
-											$tab_args = array(
3129
-												'tab'	=> array(
3130
-													'tabs_close' => $close_tabs,
3131
-												'close' => true,
3132
-												)
3127
+                                        if($close_tab || $close_tabs){
3128
+                                            $tab_args = array(
3129
+                                                'tab'	=> array(
3130
+                                                    'tabs_close' => $close_tabs,
3131
+                                                'close' => true,
3132
+                                                )
3133 3133
 
3134
-											);
3135
-											$this->block_tab_end( '', $tab_args );
3134
+                                            );
3135
+                                            $this->block_tab_end( '', $tab_args );
3136 3136
 //											echo '###close'; print_r($tab_args);
3137
-											$panel_count = 0;
3138
-										}
3137
+                                            $panel_count = 0;
3138
+                                        }
3139 3139
 //
3140 3140
 
3141
-									}
3142
-									}else {
3143
-									?>
3141
+                                    }
3142
+                                    }else {
3143
+                                    ?>
3144 3144
 									el(wp.components.PanelBody, {
3145 3145
 											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
3146 3146
 											initialOpen: true
3147 3147
 										},
3148 3148
 										<?php
3149
-										foreach ( $this->arguments as $key => $args ) {
3150
-											$this->block_row_start( $key, $args );
3151
-											$this->build_block_arguments( $key, $args );
3152
-											$this->block_row_end( $key, $args );
3153
-										}
3154
-										?>
3149
+                                        foreach ( $this->arguments as $key => $args ) {
3150
+                                            $this->block_row_start( $key, $args );
3151
+                                            $this->build_block_arguments( $key, $args );
3152
+                                            $this->block_row_end( $key, $args );
3153
+                                        }
3154
+                                        ?>
3155 3155
 									),
3156 3156
 									<?php
3157
-									}
3157
+                                    }
3158 3158
 
3159
-									}
3160
-									?>
3159
+                                    }
3160
+                                    ?>
3161 3161
 
3162 3162
 								),
3163 3163
 
3164 3164
 								<?php
3165
-								// If the user sets block-output array then build it
3166
-								if ( ! empty( $this->options['block-output'] ) ) {
3167
-								$this->block_element( $this->options['block-output'] );
3168
-							}elseif(!empty($this->options['block-edit-return'])){
3169
-								   echo $this->options['block-edit-return'];
3170
-							}else{
3171
-								// if no block-output is set then we try and get the shortcode html output via ajax.
3172
-								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3173
-								?>
3165
+                                // If the user sets block-output array then build it
3166
+                                if ( ! empty( $this->options['block-output'] ) ) {
3167
+                                $this->block_element( $this->options['block-output'] );
3168
+                            }elseif(!empty($this->options['block-edit-return'])){
3169
+                                    echo $this->options['block-edit-return'];
3170
+                            }else{
3171
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
3172
+                                $block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3173
+                                ?>
3174 3174
 								el('<?php echo esc_attr($block_edit_wrap_tag); ?>', wp.blockEditor.useBlockProps({
3175 3175
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
3176 3176
 									className: props.className,
@@ -3178,13 +3178,13 @@  discard block
 block discarded – undo
3178 3178
 									style: {'minHeight': '30px'}
3179 3179
 								}))
3180 3180
 								<?php
3181
-								}
3182
-								?>
3181
+                                }
3182
+                                ?>
3183 3183
 							]; // end return
3184 3184
 
3185 3185
 							<?php
3186
-							} // end block-edit-raw else
3187
-							?>
3186
+                            } // end block-edit-raw else
3187
+                            ?>
3188 3188
 						},
3189 3189
 
3190 3190
 						// The "save" property must be specified and must be a valid function.
@@ -3198,16 +3198,16 @@  discard block
 block discarded – undo
3198 3198
 							$html = '';
3199 3199
 							<?php
3200 3200
 
3201
-							if(! empty( $this->arguments )){
3201
+                            if(! empty( $this->arguments )){
3202 3202
 
3203
-							foreach($this->arguments as $key => $args){
3204
-							   // if($args['type']=='tabs'){continue;}
3203
+                            foreach($this->arguments as $key => $args){
3204
+                                // if($args['type']=='tabs'){continue;}
3205 3205
 
3206
-							   // don't add metadata arguments
3207
-							   if (substr($key, 0, 9 ) === 'metadata_') {
3208
-								   continue;
3209
-							   }
3210
-							?>
3206
+                                // don't add metadata arguments
3207
+                                if (substr($key, 0, 9 ) === 'metadata_') {
3208
+                                    continue;
3209
+                                }
3210
+                            ?>
3211 3211
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3212 3212
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
3213 3213
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -3218,10 +3218,10 @@  discard block
 block discarded – undo
3218 3218
 								}
3219 3219
 							}
3220 3220
 							<?php
3221
-							}
3222
-							}
3221
+                            }
3222
+                            }
3223 3223
 
3224
-							?>
3224
+                            ?>
3225 3225
 							content += "]";
3226 3226
 							 content = '';
3227 3227
 
@@ -3231,7 +3231,7 @@  discard block
 block discarded – undo
3231 3231
 //                                $html = 'el( InnerBlocks.Content )';
3232 3232
 //                                <?php
3233 3233
 //                            }
3234
-							?>
3234
+                            ?>
3235 3235
 							// if has html element
3236 3236
 							if ($html) {
3237 3237
 								//content += $html + "[/<?php echo $this->options['base_id'];?>]";
@@ -3264,12 +3264,12 @@  discard block
 block discarded – undo
3264 3264
 //                                <x?php
3265 3265
 //							}else
3266 3266
 
3267
-							if(!empty($this->options['block-output'])){
3267
+                            if(!empty($this->options['block-output'])){
3268 3268
 //                               echo "return";
3269 3269
 //                               $this->block_element( $this->options['block-output'], true );
3270 3270
 //                               echo ";";
3271 3271
 
3272
-							   ?>
3272
+                                ?>
3273 3273
 							  return el(
3274 3274
 								   '',
3275 3275
 								   {},
@@ -3279,10 +3279,10 @@  discard block
 block discarded – undo
3279 3279
 							   );
3280 3280
 								<?php
3281 3281
 
3282
-							}elseif(!empty($this->options['block-save-return'])){
3283
-								   echo 'return ' . $this->options['block-save-return'];
3284
-							}elseif(!empty($this->options['nested-block'])){
3285
-								?>
3282
+                            }elseif(!empty($this->options['block-save-return'])){
3283
+                                    echo 'return ' . $this->options['block-save-return'];
3284
+                            }elseif(!empty($this->options['nested-block'])){
3285
+                                ?>
3286 3286
 							  return el(
3287 3287
 								   '',
3288 3288
 								   {},
@@ -3291,22 +3291,22 @@  discard block
 block discarded – undo
3291 3291
 								 //  el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3292 3292
 							   );
3293 3293
 								<?php
3294
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3295
-								echo "return ". $this->options['block-edit-return'].";";
3296
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3297
-							?>
3294
+                            }elseif(!empty( $this->options['block-save-return'] ) ){
3295
+                                echo "return ". $this->options['block-edit-return'].";";
3296
+                            }elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3297
+                            ?>
3298 3298
 							return content;
3299 3299
 							<?php
3300
-							}else{
3301
-							?>
3300
+                            }else{
3301
+                            ?>
3302 3302
 							var block_wrap = 'div';
3303 3303
 							if (attr.hasOwnProperty("block_wrap")) {
3304 3304
 								block_wrap = attr.block_wrap;
3305 3305
 							}
3306 3306
 							return el(block_wrap, wp.blockEditor.useBlockProps.save( {dangerouslySetInnerHTML: {__html: content}, className: align} ));
3307 3307
 							<?php
3308
-							}
3309
-							?>
3308
+                            }
3309
+                            ?>
3310 3310
 
3311 3311
 
3312 3312
 						}
@@ -3320,43 +3320,43 @@  discard block
 block discarded – undo
3320 3320
 				});
3321 3321
 			</script>
3322 3322
 			<?php
3323
-			$output = ob_get_clean();
3323
+            $output = ob_get_clean();
3324 3324
 
3325
-			/*
3325
+            /*
3326 3326
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
3327 3327
 			 */
3328 3328
 
3329
-			return str_replace( array(
3330
-				'<script>',
3331
-				'</script>'
3332
-			), '', $output );
3333
-		}
3329
+            return str_replace( array(
3330
+                '<script>',
3331
+                '</script>'
3332
+            ), '', $output );
3333
+        }
3334 3334
 
3335 3335
 
3336 3336
 
3337
-		public function block_row_start($key, $args){
3337
+        public function block_row_start($key, $args){
3338 3338
 
3339
-			// check for row
3340
-			if(!empty($args['row'])){
3339
+            // check for row
3340
+            if(!empty($args['row'])){
3341 3341
 
3342
-				if(!empty($args['row']['open'])){
3342
+                if(!empty($args['row']['open'])){
3343 3343
 
3344
-				// element require
3345
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3346
-				$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3347
-				$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3348
-				$device_type_icon = '';
3349
-				if($device_type=='Desktop'){
3350
-					$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3351
-				}elseif($device_type=='Tablet'){
3352
-					$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3353
-				}elseif($device_type=='Mobile'){
3354
-					$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3355
-				}
3356
-				echo $element_require;
3357
-				echo $device_type_require;
3344
+                // element require
3345
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3346
+                $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3347
+                $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3348
+                $device_type_icon = '';
3349
+                if($device_type=='Desktop'){
3350
+                    $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3351
+                }elseif($device_type=='Tablet'){
3352
+                    $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3353
+                }elseif($device_type=='Mobile'){
3354
+                    $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3355
+                }
3356
+                echo $element_require;
3357
+                echo $device_type_require;
3358 3358
 
3359
-					if(false){?><script><?php }?>
3359
+                    if(false){?><script><?php }?>
3360 3360
 						el('div', {
3361 3361
 								className: 'bsui components-base-control',
3362 3362
 							},
@@ -3369,8 +3369,8 @@  discard block
 block discarded – undo
3369 3369
 								<?php if($device_type_icon){ ?>
3370 3370
 									deviceType == '<?php echo $device_type;?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})
3371 3371
 								<?php
3372
-								}
3373
-								?>
3372
+                                }
3373
+                                ?>
3374 3374
 
3375 3375
 
3376 3376
 							),
@@ -3394,51 +3394,51 @@  discard block
 block discarded – undo
3394 3394
 									},
3395 3395
 
3396 3396
 					<?php
3397
-					if(false){?></script><?php }
3398
-				}elseif(!empty($args['row']['close'])){
3399
-					if(false){?><script><?php }?>
3397
+                    if(false){?></script><?php }
3398
+                }elseif(!empty($args['row']['close'])){
3399
+                    if(false){?><script><?php }?>
3400 3400
 						el(
3401 3401
 							'div',
3402 3402
 							{
3403 3403
 								className: 'col pl-0 ps-0',
3404 3404
 							},
3405 3405
 					<?php
3406
-					if(false){?></script><?php }
3407
-				}else{
3408
-					if(false){?><script><?php }?>
3406
+                    if(false){?></script><?php }
3407
+                }else{
3408
+                    if(false){?><script><?php }?>
3409 3409
 						el(
3410 3410
 							'div',
3411 3411
 							{
3412 3412
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3413 3413
 							},
3414 3414
 					<?php
3415
-					if(false){?></script><?php }
3416
-				}
3415
+                    if(false){?></script><?php }
3416
+                }
3417 3417
 
3418
-			}
3418
+            }
3419 3419
 
3420
-		}
3420
+        }
3421 3421
 
3422
-		public function block_row_end($key, $args){
3422
+        public function block_row_end($key, $args){
3423 3423
 
3424
-			if(!empty($args['row'])){
3425
-				// maybe close
3426
-				if(!empty($args['row']['close'])){
3427
-					echo "))";
3428
-				}
3424
+            if(!empty($args['row'])){
3425
+                // maybe close
3426
+                if(!empty($args['row']['close'])){
3427
+                    echo "))";
3428
+                }
3429 3429
 
3430
-				echo "),";
3431
-			}
3432
-		}
3430
+                echo "),";
3431
+            }
3432
+        }
3433 3433
 
3434
-		public function block_tab_start($key, $args){
3434
+        public function block_tab_start($key, $args){
3435 3435
 
3436
-			// check for row
3437
-			if(!empty($args['tab'])){
3436
+            // check for row
3437
+            if(!empty($args['tab'])){
3438 3438
 
3439
-				if(!empty($args['tab']['tabs_open'])){
3439
+                if(!empty($args['tab']['tabs_open'])){
3440 3440
 
3441
-					if(false){?><script><?php }?>
3441
+                    if(false){?><script><?php }?>
3442 3442
 
3443 3443
 el('div',{className: 'bsui'},
3444 3444
 
@@ -3451,12 +3451,12 @@  discard block
 block discarded – undo
3451 3451
 										tabs: [
3452 3452
 
3453 3453
 					<?php
3454
-					if(false){?></script><?php }
3455
-				}
3454
+                    if(false){?></script><?php }
3455
+                }
3456 3456
 
3457
-				if(!empty($args['tab']['open'])){
3457
+                if(!empty($args['tab']['open'])){
3458 3458
 
3459
-					if(false){?><script><?php }?>
3459
+                    if(false){?><script><?php }?>
3460 3460
 							{
3461 3461
 												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3462 3462
 												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
@@ -3465,93 +3465,93 @@  discard block
 block discarded – undo
3465 3465
 									className: 'components-base-control__help mb-0',
3466 3466
 									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3467 3467
 								}),<?php }
3468
-					if(false){?></script><?php }
3469
-				}
3468
+                    if(false){?></script><?php }
3469
+                }
3470 3470
 
3471
-			}
3471
+            }
3472 3472
 
3473
-		}
3473
+        }
3474 3474
 
3475
-		public function block_tab_end($key, $args){
3475
+        public function block_tab_end($key, $args){
3476 3476
 
3477
-			if(!empty($args['tab'])){
3478
-				// maybe close
3479
-				if(!empty($args['tab']['close'])){
3480
-					echo ")}, /* tab close */";
3481
-				}
3477
+            if(!empty($args['tab'])){
3478
+                // maybe close
3479
+                if(!empty($args['tab']['close'])){
3480
+                    echo ")}, /* tab close */";
3481
+                }
3482 3482
 
3483
-				if(!empty($args['tab']['tabs_close'])){
3484
-					if(false){?><script><?php }?>
3483
+                if(!empty($args['tab']['tabs_close'])){
3484
+                    if(false){?><script><?php }?>
3485 3485
 						]}, ( tab ) => {
3486 3486
 								return tab.content;
3487 3487
 							}
3488 3488
 						)), /* tabs close */
3489 3489
 					<?php if(false){ ?></script><?php }
3490
-				}
3491
-			}
3492
-		}
3493
-
3494
-		public function build_block_arguments( $key, $args ) {
3495
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3496
-			$options           = '';
3497
-			$extra             = '';
3498
-			$require           = '';
3499
-			$inside_elements   = '';
3500
-			$after_elements	   = '';
3501
-
3502
-			// `content` is a protected and special argument
3503
-			if ( $key == 'content' ) {
3504
-				return;
3505
-			}
3506
-
3507
-			$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3508
-			$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3509
-			$device_type_icon = '';
3510
-			if($device_type=='Desktop'){
3511
-				$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3512
-			}elseif($device_type=='Tablet'){
3513
-				$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3514
-			}elseif($device_type=='Mobile'){
3515
-				$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3516
-			}
3517
-
3518
-			// icon
3519
-			$icon = '';
3520
-			if( !empty( $args['icon'] ) ){
3521
-				$icon .= "el('div', {";
3522
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3523
-									$icon .= "className: 'text-center',";
3524
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3525
-								$icon .= "}),";
3526
-
3527
-				// blank title as its added to the icon.
3528
-				$args['title'] = '';
3529
-			}
3530
-
3531
-			// require advanced
3532
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3533
-
3534
-			// element require
3535
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3536
-
3537
-
3538
-			$onchange  = "props.setAttributes({ $key: $key } )";
3539
-			$onchangecomplete  = "";
3540
-			$value     = "props.attributes.$key";
3541
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3542
-			if ( in_array( $args['type'], $text_type ) ) {
3543
-				$type = 'TextControl';
3544
-				// Save numbers as numbers and not strings
3545
-				if ( $args['type'] == 'number' ) {
3546
-					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3547
-				}
3548
-
3549
-				if (substr($key, 0, 9 ) === 'metadata_') {
3550
-					$real_key = str_replace('metadata_','', $key );
3551
-					$onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3552
-					$value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3553
-				}
3554
-			}
3490
+                }
3491
+            }
3492
+        }
3493
+
3494
+        public function build_block_arguments( $key, $args ) {
3495
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3496
+            $options           = '';
3497
+            $extra             = '';
3498
+            $require           = '';
3499
+            $inside_elements   = '';
3500
+            $after_elements	   = '';
3501
+
3502
+            // `content` is a protected and special argument
3503
+            if ( $key == 'content' ) {
3504
+                return;
3505
+            }
3506
+
3507
+            $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3508
+            $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3509
+            $device_type_icon = '';
3510
+            if($device_type=='Desktop'){
3511
+                $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3512
+            }elseif($device_type=='Tablet'){
3513
+                $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3514
+            }elseif($device_type=='Mobile'){
3515
+                $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3516
+            }
3517
+
3518
+            // icon
3519
+            $icon = '';
3520
+            if( !empty( $args['icon'] ) ){
3521
+                $icon .= "el('div', {";
3522
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3523
+                                    $icon .= "className: 'text-center',";
3524
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
3525
+                                $icon .= "}),";
3526
+
3527
+                // blank title as its added to the icon.
3528
+                $args['title'] = '';
3529
+            }
3530
+
3531
+            // require advanced
3532
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3533
+
3534
+            // element require
3535
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3536
+
3537
+
3538
+            $onchange  = "props.setAttributes({ $key: $key } )";
3539
+            $onchangecomplete  = "";
3540
+            $value     = "props.attributes.$key";
3541
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3542
+            if ( in_array( $args['type'], $text_type ) ) {
3543
+                $type = 'TextControl';
3544
+                // Save numbers as numbers and not strings
3545
+                if ( $args['type'] == 'number' ) {
3546
+                    $onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3547
+                }
3548
+
3549
+                if (substr($key, 0, 9 ) === 'metadata_') {
3550
+                    $real_key = str_replace('metadata_','', $key );
3551
+                    $onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3552
+                    $value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3553
+                }
3554
+            }
3555 3555
 //			else if ( $args['type'] == 'popup' ) {
3556 3556
 //				$type = 'TextControl';
3557 3557
 //				$args['type'] == 'text';
@@ -3569,21 +3569,21 @@  discard block
 block discarded – undo
3569 3569
 //
3570 3570
 //				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3571 3571
 //			}
3572
-			else if ( $args['type'] == 'styleid' ) {
3573
-				$type = 'TextControl';
3574
-				$args['type'] == 'text';
3575
-				// Save numbers as numbers and not strings
3576
-				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3577
-			}else if ( $args['type'] == 'notice' ) {
3578
-
3579
-				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3580
-				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3581
-
3582
-				$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'}}))),";
3583
-				echo $notice_message ? $element_require . $notice : '';
3584
-				return;
3585
-			}
3586
-			/*
3572
+            else if ( $args['type'] == 'styleid' ) {
3573
+                $type = 'TextControl';
3574
+                $args['type'] == 'text';
3575
+                // Save numbers as numbers and not strings
3576
+                $value     = "props.attributes.$key ? props.attributes.$key : ''";
3577
+            }else if ( $args['type'] == 'notice' ) {
3578
+
3579
+                $notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3580
+                $notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3581
+
3582
+                $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'}}))),";
3583
+                echo $notice_message ? $element_require . $notice : '';
3584
+                return;
3585
+            }
3586
+            /*
3587 3587
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
3588 3588
 						elseif($args['type']=='tabs'){
3589 3589
 							?>
@@ -3636,22 +3636,22 @@  discard block
 block discarded – undo
3636 3636
 							return;
3637 3637
 						}
3638 3638
 */
3639
-			elseif ( $args['type'] == 'color' ) {
3640
-				$type = 'ColorPicker';
3641
-				$onchange = "";
3642
-				$extra = "color: $value,";
3643
-				if(!empty($args['disable_alpha'])){
3644
-					$extra .= "disableAlpha: true,";
3645
-				}
3646
-				$onchangecomplete = "onChangeComplete: function($key) {
3639
+            elseif ( $args['type'] == 'color' ) {
3640
+                $type = 'ColorPicker';
3641
+                $onchange = "";
3642
+                $extra = "color: $value,";
3643
+                if(!empty($args['disable_alpha'])){
3644
+                    $extra .= "disableAlpha: true,";
3645
+                }
3646
+                $onchangecomplete = "onChangeComplete: function($key) {
3647 3647
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
3648 3648
 						props.setAttributes({
3649 3649
 							$key: value
3650 3650
 						});
3651 3651
 					},";
3652
-			}elseif ( $args['type'] == 'gradient' ) {
3653
-				$type = 'GradientPicker';
3654
-				$extra .= "gradients: [{
3652
+            }elseif ( $args['type'] == 'gradient' ) {
3653
+                $type = 'GradientPicker';
3654
+                $extra .= "gradients: [{
3655 3655
 			name: 'Vivid cyan blue to vivid purple',
3656 3656
 			gradient:
3657 3657
 				'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
@@ -3688,10 +3688,10 @@  discard block
 block discarded – undo
3688 3688
 			slug: 'cool-to-warm-spectrum',
3689 3689
 		}],";
3690 3690
 
3691
-			}elseif ( $args['type'] == 'image' ) {
3691
+            }elseif ( $args['type'] == 'image' ) {
3692 3692
 //                print_r($args);
3693 3693
 
3694
-				$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,{
3694
+                $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,{
3695 3695
 							url:  props.attributes.{$key}_use_featured === true ? ''  : props.attributes.$key,
3696 3696
 							value: props.attributes.{$key}_xy.x !== undefined && props.attributes.{$key}_xy.x >= 0 ? props.attributes.{$key}_xy  : {x: 0.5,y: 0.5,},
3697 3697
 //                            value: props.attributes.{$key}_xy,
@@ -3712,16 +3712,16 @@  discard block
 block discarded – undo
3712 3712
 						}), ";
3713 3713
 
3714 3714
 
3715
-				$value = '""';
3716
-				$type = 'MediaUpload';
3717
-				$extra .= "onSelect: function(media){
3715
+                $value = '""';
3716
+                $type = 'MediaUpload';
3717
+                $extra .= "onSelect: function(media){
3718 3718
 					  return props.setAttributes({
3719 3719
 						  $key: media.url,
3720 3720
 						  {$key}_id: media.id
3721 3721
 						});
3722 3722
 					  },";
3723
-				   $extra .= "type: 'image',";
3724
-				   $extra .= "render: function (obj) {
3723
+                    $extra .= "type: 'image',";
3724
+                    $extra .= "render: function (obj) {
3725 3725
 						return el( 'div',{},
3726 3726
 						( !props.attributes.$key && !props.attributes.{$key}_use_featured ) && el( wp.components.Button, {
3727 3727
 						  className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
@@ -3747,11 +3747,11 @@  discard block
 block discarded – undo
3747 3747
 
3748 3748
 
3749 3749
 					  }";
3750
-				$onchange = "";
3750
+                $onchange = "";
3751 3751
 
3752
-				//$inside_elements = ",el('div',{},'file upload')";
3753
-			} else if ( $args['type'] == 'images' ) {
3754
-				$img_preview = "props.attributes.$key && (function() {
3752
+                //$inside_elements = ",el('div',{},'file upload')";
3753
+            } else if ( $args['type'] == 'images' ) {
3754
+                $img_preview = "props.attributes.$key && (function() {
3755 3755
 	let uploads = JSON.parse('['+props.attributes.$key+']');
3756 3756
 	let images = [];
3757 3757
 	uploads.map((upload, index) => (
@@ -3778,9 +3778,9 @@  discard block
 block discarded – undo
3778 3778
 })(),";
3779 3779
 
3780 3780
 
3781
-				$value = '""';
3782
-				$type = 'MediaUpload';
3783
-				$extra .= "onSelect: function(media){
3781
+                $value = '""';
3782
+                $type = 'MediaUpload';
3783
+                $extra .= "onSelect: function(media){
3784 3784
 	let slim_images = props.attributes.$key ? JSON.parse('['+props.attributes.$key+']') : [];
3785 3785
 	if(media.length){
3786 3786
 		for (var i=0; i < media.length; i++) {
@@ -3793,9 +3793,9 @@  discard block
 block discarded – undo
3793 3793
 	}
3794 3794
 	return props.setAttributes({ $key: slimImagesV});
3795 3795
 },";
3796
-				$extra .= "type: 'image',";
3797
-				$extra .= "multiple: true,";
3798
-				$extra .= "render: function (obj) {
3796
+                $extra .= "type: 'image',";
3797
+                $extra .= "multiple: true,";
3798
+                $extra .= "render: function (obj) {
3799 3799
 	/* Init the sort */
3800 3800
 	enableDragSort('sd-sortable');
3801 3801
 	return el( 'div',{},
@@ -3822,40 +3822,40 @@  discard block
 block discarded – undo
3822 3822
 		)
3823 3823
 	)
3824 3824
 }";
3825
-				$onchange = "";
3826
-
3827
-				//$inside_elements = ",el('div',{},'file upload')";
3828
-			}
3829
-			elseif ( $args['type'] == 'checkbox' ) {
3830
-				$type = 'CheckboxControl';
3831
-				$extra .= "checked: props.attributes.$key,";
3832
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3833
-			} elseif ( $args['type'] == 'textarea' ) {
3834
-				$type = 'TextareaControl';
3835
-
3836
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3837
-				$type = 'SelectControl';
3838
-
3839
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3840
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3841
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3842
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3843
-				}else {
3844
-
3845
-					if ( ! empty( $args['options'] ) ) {
3846
-						$options .= "options: [";
3847
-						foreach ( $args['options'] as $option_val => $option_label ) {
3848
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3849
-						}
3850
-						$options .= "],";
3851
-					}
3852
-				}
3853
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3854
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3855
-				}
3856
-
3857
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3858
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3825
+                $onchange = "";
3826
+
3827
+                //$inside_elements = ",el('div',{},'file upload')";
3828
+            }
3829
+            elseif ( $args['type'] == 'checkbox' ) {
3830
+                $type = 'CheckboxControl';
3831
+                $extra .= "checked: props.attributes.$key,";
3832
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3833
+            } elseif ( $args['type'] == 'textarea' ) {
3834
+                $type = 'TextareaControl';
3835
+
3836
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3837
+                $type = 'SelectControl';
3838
+
3839
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3840
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3841
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3842
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3843
+                }else {
3844
+
3845
+                    if ( ! empty( $args['options'] ) ) {
3846
+                        $options .= "options: [";
3847
+                        foreach ( $args['options'] as $option_val => $option_label ) {
3848
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3849
+                        }
3850
+                        $options .= "],";
3851
+                    }
3852
+                }
3853
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3854
+                    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3855
+                }
3856
+
3857
+                if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3858
+                    $after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3859 3859
 									  className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3860 3860
 									  style: {margin:'-8px 0 8px 0',display: 'block'},
3861 3861
 									  onClick: function(){
@@ -3866,8 +3866,8 @@  discard block
 block discarded – undo
3866 3866
 									},
3867 3867
 									'Clear'
3868 3868
 							),";
3869
-				}
3870
-			} elseif ( $args['type'] == 'tagselect' ) {
3869
+                }
3870
+            } elseif ( $args['type'] == 'tagselect' ) {
3871 3871
 //				$type = 'FormTokenField';
3872 3872
 //
3873 3873
 //				if ( ! empty( $args['options'] ) ) {
@@ -3902,20 +3902,20 @@  discard block
 block discarded – undo
3902 3902
 //				$value     = "[]";
3903 3903
 //				$extra .= ' __experimentalExpandOnFocus: true,';
3904 3904
 
3905
-			} else if ( $args['type'] == 'alignment' ) {
3906
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3907
-			} else if ( $args['type'] == 'margins' ) {
3908
-
3909
-			} else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
3910
-				$type = 'TextControl';
3911
-				$value = "(props.attributes.$key ? props.attributes.$key : '')";
3912
-				$args['type'] = 'text';
3913
-				$options .= 'disabled:true,';
3914
-				$bsvc_title = esc_attr( addslashes( $args['title'] ) );
3915
-				$bsvc_body = $this->block_visibility_fields( $args );
3916
-				// @TODO reset button
3917
-				$bsvc_footer = '<button type="button" class="btn btn-danger d-none">' . __( 'Reset', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-secondary bs-vc-close text-white" data-bs-dismiss="modal">' . __( 'Close', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-primary bs-vc-save">' . __( 'Save Rules', 'ayecode-connect' ) . '</button>';
3918
-				$after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
3905
+            } else if ( $args['type'] == 'alignment' ) {
3906
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3907
+            } else if ( $args['type'] == 'margins' ) {
3908
+
3909
+            } else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
3910
+                $type = 'TextControl';
3911
+                $value = "(props.attributes.$key ? props.attributes.$key : '')";
3912
+                $args['type'] = 'text';
3913
+                $options .= 'disabled:true,';
3914
+                $bsvc_title = esc_attr( addslashes( $args['title'] ) );
3915
+                $bsvc_body = $this->block_visibility_fields( $args );
3916
+                // @TODO reset button
3917
+                $bsvc_footer = '<button type="button" class="btn btn-danger d-none">' . __( 'Reset', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-secondary bs-vc-close text-white" data-bs-dismiss="modal">' . __( 'Close', 'ayecode-connect' ) . '</button><button type="button" class="btn btn-primary bs-vc-save">' . __( 'Save Rules', 'ayecode-connect' ) . '</button>';
3918
+                $after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
3919 3919
 						className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
3920 3920
 						onClick: function() {
3921 3921
 							var sValue = props.attributes." . $key . ";
@@ -3941,39 +3941,39 @@  discard block
 block discarded – undo
3941 3941
 					},
3942 3942
 					'" . addslashes( ! empty( $args['button_title'] ) ? $args['button_title'] : $args['title'] ) . "'
3943 3943
 				) ),";
3944
-			} else {
3945
-				return;// if we have not implemented the control then don't break the JS.
3946
-			}
3947
-
3948
-			// color input does not show the labels so we add them
3949
-			if($args['type']=='color'){
3950
-				// add show only if advanced
3951
-				echo $require_advanced;
3952
-				// add setting require if defined
3953
-				echo $element_require;
3954
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3955
-			}
3956
-
3957
-			// add show only if advanced
3958
-			echo $require_advanced;
3959
-			// add setting require if defined
3960
-			echo $element_require;
3961
-			echo $device_type_require;
3962
-
3963
-			// icon
3964
-			echo $icon;
3965
-			?>
3944
+            } else {
3945
+                return;// if we have not implemented the control then don't break the JS.
3946
+            }
3947
+
3948
+            // color input does not show the labels so we add them
3949
+            if($args['type']=='color'){
3950
+                // add show only if advanced
3951
+                echo $require_advanced;
3952
+                // add setting require if defined
3953
+                echo $element_require;
3954
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3955
+            }
3956
+
3957
+            // add show only if advanced
3958
+            echo $require_advanced;
3959
+            // add setting require if defined
3960
+            echo $element_require;
3961
+            echo $device_type_require;
3962
+
3963
+            // icon
3964
+            echo $icon;
3965
+            ?>
3966 3966
 			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
3967 3967
 			label: <?php if ( empty( $args['title'] ) ) { echo "''"; } else if ( empty( $args['row'] ) && ! empty( $args['device_type'] ) ) { ?>el('label',{className:'components-base-control__label',style:{width:"100%"}},el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes( $args['title'] ) ?>'}}),<?php if ( $device_type_icon ) { ?>deviceType == '<?php echo $device_type;?>' && el('span',{dangerouslySetInnerHTML: {__html: '<?php echo $device_type_icon; ?>'},title: deviceType + ": Set preview mode to change",style: {right:"0",position:"absolute",color:"var(--wp-admin-theme-color)"}})<?php } ?>)<?php
3968
-			} else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
3968
+            } else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
3969 3969
 			help: <?php echo ( isset( $args['desc'] ) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim( wp_kses_post( addslashes( $args['desc'] ) ) ) . "'}})" : "''" ); ?>,
3970 3970
 			value: <?php echo $value; ?>,
3971 3971
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
3972
-				echo "type: '" . addslashes( $args['type'] ) . "',";
3973
-			} ?>
3972
+                echo "type: '" . addslashes( $args['type'] ) . "',";
3973
+            } ?>
3974 3974
 			<?php if ( ! empty( $args['placeholder'] ) ) {
3975
-				echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
3976
-			} ?>
3975
+                echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
3976
+            } ?>
3977 3977
 			<?php echo $options; ?>
3978 3978
 			<?php echo $extra; ?>
3979 3979
 			<?php echo $custom_attributes; ?>
@@ -3985,1250 +3985,1250 @@  discard block
 block discarded – undo
3985 3985
 			<?php } ?>
3986 3986
 		} <?php echo $inside_elements; ?> ),
3987 3987
 			<?php
3988
-			echo $after_elements;
3989
-		}
3990
-
3991
-		/**
3992
-		 * Convert an array of attributes to block string.
3993
-		 *
3994
-		 * @param $custom_attributes
3995
-		 *
3996
-		 * @return string
3997
-		 *@todo there is prob a faster way to do this, also we could add some validation here.
3998
-		 *
3999
-		 */
4000
-		public function array_to_attributes( $custom_attributes, $html = false ) {
4001
-			$attributes = '';
4002
-			if ( ! empty( $custom_attributes ) ) {
4003
-
4004
-				foreach ( $custom_attributes as $key => $val ) {
4005
-					if(is_array($val)){
4006
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4007
-					}else{
4008
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4009
-					}
4010
-				}
4011
-
4012
-			}
4013
-
4014
-			return $attributes;
4015
-		}
4016
-
4017
-
4018
-
4019
-		/**
4020
-		 * A self looping function to create the output for JS block elements.
4021
-		 *
4022
-		 * This is what is output in the WP Editor visual view.
4023
-		 *
4024
-		 * @param $args
4025
-		 */
4026
-		public function block_element( $args, $save = false ) {
3988
+            echo $after_elements;
3989
+        }
3990
+
3991
+        /**
3992
+         * Convert an array of attributes to block string.
3993
+         *
3994
+         * @param $custom_attributes
3995
+         *
3996
+         * @return string
3997
+         *@todo there is prob a faster way to do this, also we could add some validation here.
3998
+         *
3999
+         */
4000
+        public function array_to_attributes( $custom_attributes, $html = false ) {
4001
+            $attributes = '';
4002
+            if ( ! empty( $custom_attributes ) ) {
4003
+
4004
+                foreach ( $custom_attributes as $key => $val ) {
4005
+                    if(is_array($val)){
4006
+                        $attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4007
+                    }else{
4008
+                        $attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4009
+                    }
4010
+                }
4011
+
4012
+            }
4013
+
4014
+            return $attributes;
4015
+        }
4016
+
4017
+
4018
+
4019
+        /**
4020
+         * A self looping function to create the output for JS block elements.
4021
+         *
4022
+         * This is what is output in the WP Editor visual view.
4023
+         *
4024
+         * @param $args
4025
+         */
4026
+        public function block_element( $args, $save = false ) {
4027 4027
 
4028 4028
 //            print_r($args);echo '###';exit;
4029 4029
 
4030
-			if ( ! empty( $args ) ) {
4031
-				foreach ( $args as $element => $new_args ) {
4030
+            if ( ! empty( $args ) ) {
4031
+                foreach ( $args as $element => $new_args ) {
4032 4032
 
4033
-					if ( is_array( $new_args ) ) { // its an element
4033
+                    if ( is_array( $new_args ) ) { // its an element
4034 4034
 
4035 4035
 
4036
-						if ( isset( $new_args['element'] ) ) {
4036
+                        if ( isset( $new_args['element'] ) ) {
4037 4037
 
4038
-							if ( isset( $new_args['element_require'] ) ) {
4039
-								echo str_replace( array(
4040
-										"'+",
4041
-										"+'"
4042
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4043
-								unset( $new_args['element_require'] );
4044
-							}
4038
+                            if ( isset( $new_args['element_require'] ) ) {
4039
+                                echo str_replace( array(
4040
+                                        "'+",
4041
+                                        "+'"
4042
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4043
+                                unset( $new_args['element_require'] );
4044
+                            }
4045 4045
 
4046
-							if($new_args['element']=='InnerBlocks'){
4047
-								echo "\n el( InnerBlocks, {";
4048
-							}elseif($new_args['element']=='innerBlocksProps'){
4049
-								$element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4050
-							  //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4046
+                            if($new_args['element']=='InnerBlocks'){
4047
+                                echo "\n el( InnerBlocks, {";
4048
+                            }elseif($new_args['element']=='innerBlocksProps'){
4049
+                                $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4050
+                                //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4051 4051
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4052
-								echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4053
-								echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4054
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4055
-
4056
-								echo "} ), {";
4057
-								echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4058
-							//    echo '###';
4059
-
4060
-							  //  echo '###';
4061
-							}elseif($new_args['element']=='BlocksProps'){
4062
-
4063
-								if ( isset($new_args['if_inner_element']) ) {
4064
-									$element = $new_args['if_inner_element'];
4065
-								}else {
4066
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4067
-								}
4068
-
4069
-								unset($new_args['inner_element']);
4070
-								echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4071
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4072
-
4073
-
4074
-							   // echo "} ),";
4075
-
4076
-							}else{
4077
-								echo "\n el( '" . $new_args['element'] . "', {";
4078
-							}
4079
-
4080
-
4081
-							// get the attributes
4082
-							foreach ( $new_args as $new_key => $new_value ) {
4083
-
4084
-
4085
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4086
-									// do nothing
4087
-								} else {
4088
-									echo $this->block_element( array( $new_key => $new_value ),$save );
4089
-								}
4090
-							}
4091
-
4092
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4093
-
4094
-							// get the content
4095
-							$first_item = 0;
4096
-							foreach ( $new_args as $new_key => $new_value ) {
4097
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4098
-
4099
-									if ( $new_key === 'content' ) {
4100
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4101
-									}else if ( $new_key === 'if_content' ) {
4102
-										echo  $this->block_props_replace(  $new_value  );
4103
-									}
4104
-
4105
-									if ( is_array( $new_value ) ) {
4106
-
4107
-										if ( isset( $new_value['element_require'] ) ) {
4108
-											echo str_replace( array(
4109
-													"'+",
4110
-													"+'"
4111
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4112
-											unset( $new_value['element_require'] );
4113
-										}
4114
-
4115
-										if ( isset( $new_value['element_repeat'] ) ) {
4116
-											$x = 1;
4117
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
4118
-												$this->block_element( array( '' => $new_value ),$save );
4119
-												$x ++;
4120
-											}
4121
-										} else {
4122
-											$this->block_element( array( '' => $new_value ),$save );
4123
-										}
4124
-									}
4125
-									$first_item ++;
4126
-								}
4127
-							}
4128
-
4129
-							if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4130
-								echo "))";// end content
4131
-							}else{
4132
-								echo ")";// end content
4133
-							}
4134
-
4135
-
4136
-							echo ", \n";
4137
-
4138
-						}
4139
-					} else {
4140
-
4141
-						if ( substr( $element, 0, 3 ) === "if_" ) {
4142
-							$extra = '';
4143
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
4144
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4145
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4146
-							}
4147
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4148
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4149
-							$new_args = str_replace('[%WrapStyle%]','',$new_args);
4150
-							echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4052
+                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4053
+                                echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4054
+                                echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4055
+
4056
+                                echo "} ), {";
4057
+                                echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4058
+                            //    echo '###';
4059
+
4060
+                                //  echo '###';
4061
+                            }elseif($new_args['element']=='BlocksProps'){
4062
+
4063
+                                if ( isset($new_args['if_inner_element']) ) {
4064
+                                    $element = $new_args['if_inner_element'];
4065
+                                }else {
4066
+                                    $element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4067
+                                }
4068
+
4069
+                                unset($new_args['inner_element']);
4070
+                                echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4071
+                                echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4072
+
4073
+
4074
+                                // echo "} ),";
4075
+
4076
+                            }else{
4077
+                                echo "\n el( '" . $new_args['element'] . "', {";
4078
+                            }
4079
+
4080
+
4081
+                            // get the attributes
4082
+                            foreach ( $new_args as $new_key => $new_value ) {
4083
+
4084
+
4085
+                                if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4086
+                                    // do nothing
4087
+                                } else {
4088
+                                    echo $this->block_element( array( $new_key => $new_value ),$save );
4089
+                                }
4090
+                            }
4091
+
4092
+                            echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4093
+
4094
+                            // get the content
4095
+                            $first_item = 0;
4096
+                            foreach ( $new_args as $new_key => $new_value ) {
4097
+                                if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4098
+
4099
+                                    if ( $new_key === 'content' ) {
4100
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4101
+                                    }else if ( $new_key === 'if_content' ) {
4102
+                                        echo  $this->block_props_replace(  $new_value  );
4103
+                                    }
4104
+
4105
+                                    if ( is_array( $new_value ) ) {
4106
+
4107
+                                        if ( isset( $new_value['element_require'] ) ) {
4108
+                                            echo str_replace( array(
4109
+                                                    "'+",
4110
+                                                    "+'"
4111
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4112
+                                            unset( $new_value['element_require'] );
4113
+                                        }
4114
+
4115
+                                        if ( isset( $new_value['element_repeat'] ) ) {
4116
+                                            $x = 1;
4117
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
4118
+                                                $this->block_element( array( '' => $new_value ),$save );
4119
+                                                $x ++;
4120
+                                            }
4121
+                                        } else {
4122
+                                            $this->block_element( array( '' => $new_value ),$save );
4123
+                                        }
4124
+                                    }
4125
+                                    $first_item ++;
4126
+                                }
4127
+                            }
4128
+
4129
+                            if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4130
+                                echo "))";// end content
4131
+                            }else{
4132
+                                echo ")";// end content
4133
+                            }
4134
+
4135
+
4136
+                            echo ", \n";
4137
+
4138
+                        }
4139
+                    } else {
4140
+
4141
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
4142
+                            $extra = '';
4143
+                            if( strpos($new_args, '[%WrapClass%]') !== false ){
4144
+                                $new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4145
+                                $new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4146
+                            }
4147
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4148
+                        } elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4149
+                            $new_args = str_replace('[%WrapStyle%]','',$new_args);
4150
+                            echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4151 4151
 //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4152
-						} elseif ( $element == 'style' ) {
4153
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4154
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4155
-							$new_args = str_replace('[%WrapClass%]','',$new_args);
4156
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4157
-						} elseif ( $element == 'template' && $new_args ) {
4158
-							echo $element . ": $new_args,";
4159
-						} else {
4160
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4161
-						}
4162
-
4163
-					}
4164
-				}
4165
-			}
4166
-		}
4167
-
4168
-		/**
4169
-		 * Replace block attributes placeholders with the proper naming.
4170
-		 *
4171
-		 * @param $string
4172
-		 *
4173
-		 * @return mixed
4174
-		 */
4175
-		public function block_props_replace( $string, $no_wrap = false ) {
4176
-			if ( $no_wrap ) {
4177
-				$string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4178
-			} else {
4179
-				$string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4180
-			}
4181
-
4182
-			return $string;
4183
-		}
4184
-
4185
-		/**
4186
-		 * Outputs the content of the widget
4187
-		 *
4188
-		 * @param array $args
4189
-		 * @param array $instance
4190
-		 */
4191
-		public function widget( $args, $instance ) {
4192
-			if ( ! is_array( $args ) ) {
4193
-				$args = array();
4194
-			}
4195
-
4196
-			// Get the filtered values
4197
-			$argument_values = $this->argument_values( $instance );
4198
-			$argument_values = $this->string_to_bool( $argument_values );
4199
-			$output          = $this->output( $argument_values, $args );
4200
-
4201
-			$no_wrap = false;
4202
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4203
-				$no_wrap = true;
4204
-			}
4205
-
4206
-			ob_start();
4207
-			if ( $output && ! $no_wrap ) {
4208
-
4209
-				$class_original = $this->options['widget_ops']['classname'];
4210
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4211
-
4212
-				// Before widget
4213
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4214
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4215
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4216
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4217
-
4218
-				// After widget
4219
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4220
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4221
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4222
-
4223
-				echo $before_widget;
4224
-				// elementor strips the widget wrapping div so we check for and add it back if needed
4225
-				if ( $this->is_elementor_widget_output() ) {
4226
-					// Filter class & attrs for elementor widget output.
4227
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4228
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4229
-
4230
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4231
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4232
-
4233
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4234
-				}
4235
-				echo $this->output_title( $args, $instance );
4236
-				echo $output;
4237
-				if ( $this->is_elementor_widget_output() ) {
4238
-					echo "</span>";
4239
-				}
4240
-				echo $after_widget;
4241
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4242
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4243
-				echo $output;
4244
-			} elseif ( $output && $no_wrap ) {
4245
-				echo $output;
4246
-			}
4247
-			$output = ob_get_clean();
4248
-
4249
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4250
-
4251
-			echo $output;
4252
-		}
4253
-
4254
-		/**
4255
-		 * Tests if the current output is inside a elementor container.
4256
-		 *
4257
-		 * @return bool
4258
-		 *@since 1.0.4
4259
-		 */
4260
-		public function is_elementor_widget_output() {
4261
-			$result = false;
4262
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4263
-				$result = true;
4264
-			}
4265
-
4266
-			return $result;
4267
-		}
4268
-
4269
-		/**
4270
-		 * Tests if the current output is inside a elementor preview.
4271
-		 *
4272
-		 * @return bool
4273
-		 *@since 1.0.4
4274
-		 */
4275
-		public function is_elementor_preview() {
4276
-			$result = false;
4277
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4278
-				$result = true;
4279
-			}
4280
-
4281
-			return $result;
4282
-		}
4283
-
4284
-		/**
4285
-		 * Tests if the current output is inside a Divi preview.
4286
-		 *
4287
-		 * @return bool
4288
-		 *@since 1.0.6
4289
-		 */
4290
-		public function is_divi_preview() {
4291
-			$result = false;
4292
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4293
-				$result = true;
4294
-			}
4295
-
4296
-			return $result;
4297
-		}
4298
-
4299
-		/**
4300
-		 * Tests if the current output is inside a Beaver builder preview.
4301
-		 *
4302
-		 * @return bool
4303
-		 *@since 1.0.6
4304
-		 */
4305
-		public function is_beaver_preview() {
4306
-			$result = false;
4307
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
4308
-				$result = true;
4309
-			}
4310
-
4311
-			return $result;
4312
-		}
4313
-
4314
-		/**
4315
-		 * Tests if the current output is inside a siteorigin builder preview.
4316
-		 *
4317
-		 * @return bool
4318
-		 *@since 1.0.6
4319
-		 */
4320
-		public function is_siteorigin_preview() {
4321
-			$result = false;
4322
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4323
-				$result = true;
4324
-			}
4325
-
4326
-			return $result;
4327
-		}
4328
-
4329
-		/**
4330
-		 * Tests if the current output is inside a cornerstone builder preview.
4331
-		 *
4332
-		 * @return bool
4333
-		 *@since 1.0.8
4334
-		 */
4335
-		public function is_cornerstone_preview() {
4336
-			$result = false;
4337
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4338
-				$result = true;
4339
-			}
4340
-
4341
-			return $result;
4342
-		}
4343
-
4344
-		/**
4345
-		 * Tests if the current output is inside a fusion builder preview.
4346
-		 *
4347
-		 * @return bool
4348
-		 *@since 1.1.0
4349
-		 */
4350
-		public function is_fusion_preview() {
4351
-			$result = false;
4352
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4353
-				$result = true;
4354
-			}
4355
-
4356
-			return $result;
4357
-		}
4358
-
4359
-		/**
4360
-		 * Tests if the current output is inside a Oxygen builder preview.
4361
-		 *
4362
-		 * @return bool
4363
-		 *@since 1.0.18
4364
-		 */
4365
-		public function is_oxygen_preview() {
4366
-			$result = false;
4367
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4368
-				$result = true;
4369
-			}
4370
-
4371
-			return $result;
4372
-		}
4373
-
4374
-		/**
4375
-		 * Check for Kallyas theme Zion builder preview.
4376
-		 *
4377
-		 * @since 1.1.22
4378
-		 *
4379
-		 * @return bool True when preview page otherwise false.
4380
-		 */
4381
-		public function is_kallyas_zion_preview() {
4382
-			$result = false;
4383
-
4384
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4385
-				$result = true;
4386
-			}
4387
-
4388
-			return $result;
4389
-		}
4390
-
4391
-		/**
4392
-		 * Check for Bricks theme builder preview.
4393
-		 *
4394
-		 * @since 1.1.31
4395
-		 *
4396
-		 * @return bool True when preview page otherwise false.
4397
-		 */
4398
-		public function is_bricks_preview() {
4399
-			$result = false;
4400
-
4401
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4402
-				$result = true;
4403
-			}
4404
-
4405
-			return $result;
4406
-		}
4407
-
4408
-		/**
4409
-		 * General function to check if we are in a preview situation.
4410
-		 *
4411
-		 * @return bool
4412
-		 *@since 1.0.6
4413
-		 */
4414
-		public function is_preview() {
4415
-			$preview = false;
4416
-			if ( $this->is_divi_preview() ) {
4417
-				$preview = true;
4418
-			} elseif ( $this->is_elementor_preview() ) {
4419
-				$preview = true;
4420
-			} elseif ( $this->is_beaver_preview() ) {
4421
-				$preview = true;
4422
-			} elseif ( $this->is_siteorigin_preview() ) {
4423
-				$preview = true;
4424
-			} elseif ( $this->is_cornerstone_preview() ) {
4425
-				$preview = true;
4426
-			} elseif ( $this->is_fusion_preview() ) {
4427
-				$preview = true;
4428
-			} elseif ( $this->is_oxygen_preview() ) {
4429
-				$preview = true;
4430
-			} elseif( $this->is_kallyas_zion_preview() ) {
4431
-				$preview = true;
4432
-			} elseif( $this->is_block_content_call() ) {
4433
-				$preview = true;
4434
-			} elseif( $this->is_bricks_preview() ) {
4435
-				$preview = true;
4436
-			}
4437
-
4438
-			return $preview;
4439
-		}
4440
-
4441
-		/**
4442
-		 * Output the super title.
4443
-		 *
4444
-		 * @param $args
4445
-		 * @param array $instance
4446
-		 *
4447
-		 * @return string
4448
-		 */
4449
-		public function output_title( $args, $instance = array() ) {
4450
-			$output = '';
4451
-			if ( ! empty( $instance['title'] ) ) {
4452
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4453
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4454
-
4455
-				if ( empty( $instance['widget_title_tag'] ) ) {
4456
-					if ( ! isset( $args['before_title'] ) ) {
4457
-						$args['before_title'] = '';
4458
-					}
4459
-
4460
-					if ( ! isset( $args['after_title'] ) ) {
4461
-						$args['after_title'] = '';
4462
-					}
4463
-
4464
-					$output = $args['before_title'] . $title . $args['after_title'];
4465
-				} else {
4466
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
4467
-
4468
-					// classes
4469
-					$title_classes = array();
4470
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4471
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4472
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4473
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4474
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4475
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4476
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4477
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4478
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4479
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4480
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4481
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4482
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4483
-
4484
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4485
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
4486
-				}
4487
-
4488
-			}
4489
-
4490
-			return $output;
4491
-		}
4492
-
4493
-		/**
4494
-		 * Outputs the options form inputs for the widget.
4495
-		 *
4496
-		 * @param array $instance The widget options.
4497
-		 */
4498
-		public function form( $instance ) {
4499
-
4500
-			// set widget instance
4501
-			$this->instance = $instance;
4502
-
4503
-			// set it as a SD widget
4504
-			echo $this->widget_advanced_toggle();
4505
-
4506
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4507
-			$arguments_raw = $this->get_arguments();
4508
-
4509
-			if ( is_array( $arguments_raw ) ) {
4510
-
4511
-				$arguments = $this->group_arguments( $arguments_raw );
4512
-
4513
-				// Do we have sections?
4514
-				$has_sections = $arguments == $arguments_raw ? false : true;
4515
-
4516
-
4517
-				if ( $has_sections ) {
4518
-					$panel_count = 0;
4519
-					foreach ( $arguments as $key => $args ) {
4520
-
4521
-						?>
4152
+                        } elseif ( $element == 'style' ) {
4153
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4154
+                        } elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4155
+                            $new_args = str_replace('[%WrapClass%]','',$new_args);
4156
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4157
+                        } elseif ( $element == 'template' && $new_args ) {
4158
+                            echo $element . ": $new_args,";
4159
+                        } else {
4160
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4161
+                        }
4162
+
4163
+                    }
4164
+                }
4165
+            }
4166
+        }
4167
+
4168
+        /**
4169
+         * Replace block attributes placeholders with the proper naming.
4170
+         *
4171
+         * @param $string
4172
+         *
4173
+         * @return mixed
4174
+         */
4175
+        public function block_props_replace( $string, $no_wrap = false ) {
4176
+            if ( $no_wrap ) {
4177
+                $string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4178
+            } else {
4179
+                $string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4180
+            }
4181
+
4182
+            return $string;
4183
+        }
4184
+
4185
+        /**
4186
+         * Outputs the content of the widget
4187
+         *
4188
+         * @param array $args
4189
+         * @param array $instance
4190
+         */
4191
+        public function widget( $args, $instance ) {
4192
+            if ( ! is_array( $args ) ) {
4193
+                $args = array();
4194
+            }
4195
+
4196
+            // Get the filtered values
4197
+            $argument_values = $this->argument_values( $instance );
4198
+            $argument_values = $this->string_to_bool( $argument_values );
4199
+            $output          = $this->output( $argument_values, $args );
4200
+
4201
+            $no_wrap = false;
4202
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4203
+                $no_wrap = true;
4204
+            }
4205
+
4206
+            ob_start();
4207
+            if ( $output && ! $no_wrap ) {
4208
+
4209
+                $class_original = $this->options['widget_ops']['classname'];
4210
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4211
+
4212
+                // Before widget
4213
+                $before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4214
+                $before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4215
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4216
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4217
+
4218
+                // After widget
4219
+                $after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4220
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4221
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4222
+
4223
+                echo $before_widget;
4224
+                // elementor strips the widget wrapping div so we check for and add it back if needed
4225
+                if ( $this->is_elementor_widget_output() ) {
4226
+                    // Filter class & attrs for elementor widget output.
4227
+                    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4228
+                    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4229
+
4230
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4231
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4232
+
4233
+                    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4234
+                }
4235
+                echo $this->output_title( $args, $instance );
4236
+                echo $output;
4237
+                if ( $this->is_elementor_widget_output() ) {
4238
+                    echo "</span>";
4239
+                }
4240
+                echo $after_widget;
4241
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4242
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4243
+                echo $output;
4244
+            } elseif ( $output && $no_wrap ) {
4245
+                echo $output;
4246
+            }
4247
+            $output = ob_get_clean();
4248
+
4249
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4250
+
4251
+            echo $output;
4252
+        }
4253
+
4254
+        /**
4255
+         * Tests if the current output is inside a elementor container.
4256
+         *
4257
+         * @return bool
4258
+         *@since 1.0.4
4259
+         */
4260
+        public function is_elementor_widget_output() {
4261
+            $result = false;
4262
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4263
+                $result = true;
4264
+            }
4265
+
4266
+            return $result;
4267
+        }
4268
+
4269
+        /**
4270
+         * Tests if the current output is inside a elementor preview.
4271
+         *
4272
+         * @return bool
4273
+         *@since 1.0.4
4274
+         */
4275
+        public function is_elementor_preview() {
4276
+            $result = false;
4277
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4278
+                $result = true;
4279
+            }
4280
+
4281
+            return $result;
4282
+        }
4283
+
4284
+        /**
4285
+         * Tests if the current output is inside a Divi preview.
4286
+         *
4287
+         * @return bool
4288
+         *@since 1.0.6
4289
+         */
4290
+        public function is_divi_preview() {
4291
+            $result = false;
4292
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4293
+                $result = true;
4294
+            }
4295
+
4296
+            return $result;
4297
+        }
4298
+
4299
+        /**
4300
+         * Tests if the current output is inside a Beaver builder preview.
4301
+         *
4302
+         * @return bool
4303
+         *@since 1.0.6
4304
+         */
4305
+        public function is_beaver_preview() {
4306
+            $result = false;
4307
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
4308
+                $result = true;
4309
+            }
4310
+
4311
+            return $result;
4312
+        }
4313
+
4314
+        /**
4315
+         * Tests if the current output is inside a siteorigin builder preview.
4316
+         *
4317
+         * @return bool
4318
+         *@since 1.0.6
4319
+         */
4320
+        public function is_siteorigin_preview() {
4321
+            $result = false;
4322
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4323
+                $result = true;
4324
+            }
4325
+
4326
+            return $result;
4327
+        }
4328
+
4329
+        /**
4330
+         * Tests if the current output is inside a cornerstone builder preview.
4331
+         *
4332
+         * @return bool
4333
+         *@since 1.0.8
4334
+         */
4335
+        public function is_cornerstone_preview() {
4336
+            $result = false;
4337
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4338
+                $result = true;
4339
+            }
4340
+
4341
+            return $result;
4342
+        }
4343
+
4344
+        /**
4345
+         * Tests if the current output is inside a fusion builder preview.
4346
+         *
4347
+         * @return bool
4348
+         *@since 1.1.0
4349
+         */
4350
+        public function is_fusion_preview() {
4351
+            $result = false;
4352
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4353
+                $result = true;
4354
+            }
4355
+
4356
+            return $result;
4357
+        }
4358
+
4359
+        /**
4360
+         * Tests if the current output is inside a Oxygen builder preview.
4361
+         *
4362
+         * @return bool
4363
+         *@since 1.0.18
4364
+         */
4365
+        public function is_oxygen_preview() {
4366
+            $result = false;
4367
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4368
+                $result = true;
4369
+            }
4370
+
4371
+            return $result;
4372
+        }
4373
+
4374
+        /**
4375
+         * Check for Kallyas theme Zion builder preview.
4376
+         *
4377
+         * @since 1.1.22
4378
+         *
4379
+         * @return bool True when preview page otherwise false.
4380
+         */
4381
+        public function is_kallyas_zion_preview() {
4382
+            $result = false;
4383
+
4384
+            if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4385
+                $result = true;
4386
+            }
4387
+
4388
+            return $result;
4389
+        }
4390
+
4391
+        /**
4392
+         * Check for Bricks theme builder preview.
4393
+         *
4394
+         * @since 1.1.31
4395
+         *
4396
+         * @return bool True when preview page otherwise false.
4397
+         */
4398
+        public function is_bricks_preview() {
4399
+            $result = false;
4400
+
4401
+            if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4402
+                $result = true;
4403
+            }
4404
+
4405
+            return $result;
4406
+        }
4407
+
4408
+        /**
4409
+         * General function to check if we are in a preview situation.
4410
+         *
4411
+         * @return bool
4412
+         *@since 1.0.6
4413
+         */
4414
+        public function is_preview() {
4415
+            $preview = false;
4416
+            if ( $this->is_divi_preview() ) {
4417
+                $preview = true;
4418
+            } elseif ( $this->is_elementor_preview() ) {
4419
+                $preview = true;
4420
+            } elseif ( $this->is_beaver_preview() ) {
4421
+                $preview = true;
4422
+            } elseif ( $this->is_siteorigin_preview() ) {
4423
+                $preview = true;
4424
+            } elseif ( $this->is_cornerstone_preview() ) {
4425
+                $preview = true;
4426
+            } elseif ( $this->is_fusion_preview() ) {
4427
+                $preview = true;
4428
+            } elseif ( $this->is_oxygen_preview() ) {
4429
+                $preview = true;
4430
+            } elseif( $this->is_kallyas_zion_preview() ) {
4431
+                $preview = true;
4432
+            } elseif( $this->is_block_content_call() ) {
4433
+                $preview = true;
4434
+            } elseif( $this->is_bricks_preview() ) {
4435
+                $preview = true;
4436
+            }
4437
+
4438
+            return $preview;
4439
+        }
4440
+
4441
+        /**
4442
+         * Output the super title.
4443
+         *
4444
+         * @param $args
4445
+         * @param array $instance
4446
+         *
4447
+         * @return string
4448
+         */
4449
+        public function output_title( $args, $instance = array() ) {
4450
+            $output = '';
4451
+            if ( ! empty( $instance['title'] ) ) {
4452
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4453
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4454
+
4455
+                if ( empty( $instance['widget_title_tag'] ) ) {
4456
+                    if ( ! isset( $args['before_title'] ) ) {
4457
+                        $args['before_title'] = '';
4458
+                    }
4459
+
4460
+                    if ( ! isset( $args['after_title'] ) ) {
4461
+                        $args['after_title'] = '';
4462
+                    }
4463
+
4464
+                    $output = $args['before_title'] . $title . $args['after_title'];
4465
+                } else {
4466
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
4467
+
4468
+                    // classes
4469
+                    $title_classes = array();
4470
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4471
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4472
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4473
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4474
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4475
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4476
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4477
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4478
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4479
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4480
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4481
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4482
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4483
+
4484
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4485
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
4486
+                }
4487
+
4488
+            }
4489
+
4490
+            return $output;
4491
+        }
4492
+
4493
+        /**
4494
+         * Outputs the options form inputs for the widget.
4495
+         *
4496
+         * @param array $instance The widget options.
4497
+         */
4498
+        public function form( $instance ) {
4499
+
4500
+            // set widget instance
4501
+            $this->instance = $instance;
4502
+
4503
+            // set it as a SD widget
4504
+            echo $this->widget_advanced_toggle();
4505
+
4506
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4507
+            $arguments_raw = $this->get_arguments();
4508
+
4509
+            if ( is_array( $arguments_raw ) ) {
4510
+
4511
+                $arguments = $this->group_arguments( $arguments_raw );
4512
+
4513
+                // Do we have sections?
4514
+                $has_sections = $arguments == $arguments_raw ? false : true;
4515
+
4516
+
4517
+                if ( $has_sections ) {
4518
+                    $panel_count = 0;
4519
+                    foreach ( $arguments as $key => $args ) {
4520
+
4521
+                        ?>
4522 4522
 						<script>
4523 4523
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
4524 4524
 						</script>
4525 4525
 						<?php
4526 4526
 
4527
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
4528
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4529
-						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>";
4530
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4527
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
4528
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4529
+                        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>";
4530
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4531 4531
 
4532
-						foreach ( $args as $k => $a ) {
4532
+                        foreach ( $args as $k => $a ) {
4533 4533
 
4534
-							$this->widget_inputs_row_start($k, $a);
4535
-							$this->widget_inputs( $a, $instance );
4536
-							$this->widget_inputs_row_end($k, $a);
4534
+                            $this->widget_inputs_row_start($k, $a);
4535
+                            $this->widget_inputs( $a, $instance );
4536
+                            $this->widget_inputs_row_end($k, $a);
4537 4537
 
4538
-						}
4538
+                        }
4539 4539
 
4540
-						echo "</div>";
4540
+                        echo "</div>";
4541 4541
 
4542
-						$panel_count ++;
4542
+                        $panel_count ++;
4543 4543
 
4544
-					}
4545
-				} else {
4546
-					foreach ( $arguments as $key => $args ) {
4547
-						$this->widget_inputs_row_start($key, $args);
4548
-						$this->widget_inputs( $args, $instance );
4549
-						$this->widget_inputs_row_end($key, $args);
4550
-					}
4551
-				}
4544
+                    }
4545
+                } else {
4546
+                    foreach ( $arguments as $key => $args ) {
4547
+                        $this->widget_inputs_row_start($key, $args);
4548
+                        $this->widget_inputs( $args, $instance );
4549
+                        $this->widget_inputs_row_end($key, $args);
4550
+                    }
4551
+                }
4552 4552
 
4553
-			}
4554
-		}
4553
+            }
4554
+        }
4555 4555
 
4556
-		public function widget_inputs_row_start( $key, $args ) {
4557
-			if ( ! empty( $args['row'] ) ) {
4558
-				// Maybe open
4559
-				if ( ! empty( $args['row']['open'] ) ) {
4560
-					?>
4556
+        public function widget_inputs_row_start( $key, $args ) {
4557
+            if ( ! empty( $args['row'] ) ) {
4558
+                // Maybe open
4559
+                if ( ! empty( $args['row']['open'] ) ) {
4560
+                    ?>
4561 4561
 					<div class='bsui sd-argument' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php echo ( ! empty( $args['row']['element_require'] ) ? $this->convert_element_require( $args['row']['element_require'] ) : '' ); ?>'>
4562 4562
 					<?php if ( ! empty( $args['row']['title'] ) ) { ?>
4563 4563
 					<?php
4564
-						if ( isset( $args['row']['icon'] ) ) {
4565
-							$args['row']['icon'] = '';
4566
-						}
4567
-
4568
-						if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4569
-							$args['row']['device_type'] = $args['device_type'];
4570
-						}
4571
-					?>
4564
+                        if ( isset( $args['row']['icon'] ) ) {
4565
+                            $args['row']['icon'] = '';
4566
+                        }
4567
+
4568
+                        if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4569
+                            $args['row']['device_type'] = $args['device_type'];
4570
+                        }
4571
+                    ?>
4572 4572
 					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4573 4573
 					<?php } ?>
4574 4574
 					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4575 4575
 					<div class='col pr-2'>
4576 4576
 					<?php
4577
-				} else if ( ! empty( $args['row']['close'] ) ) {
4578
-					echo "<div class='col pl-0 ps-0'>";
4579
-				} else {
4580
-					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4581
-				}
4582
-			}
4583
-		}
4584
-
4585
-		public function widget_inputs_row_end( $key, $args ) {
4586
-			if ( ! empty( $args['row'] ) ) {
4587
-				// Maybe close
4588
-				if ( ! empty( $args['row']['close'] ) ) {
4589
-					echo "</div></div>";
4590
-				}
4591
-				echo "</div>";
4592
-			}
4593
-		}
4594
-
4595
-		/**
4596
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
4597
-		 *
4598
-		 * @return string
4599
-		 */
4600
-		public function widget_advanced_toggle() {
4601
-
4602
-			$output = '';
4603
-			if ( $this->block_show_advanced() ) {
4604
-				$val = 1;
4605
-			} else {
4606
-				$val = 0;
4607
-			}
4608
-
4609
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4610
-
4611
-			return $output;
4612
-		}
4613
-
4614
-		/**
4615
-		 * Convert require element.
4616
-		 *
4617
-		 * @param string $input Input element.
4618
-		 *
4619
-		 * @return string $output
4620
-		 *@since 1.0.0
4621
-		 *
4622
-		 */
4623
-		public function convert_element_require( $input ) {
4624
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4625
-
4626
-			$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4627
-				"jQuery(form).find('[data-argument=\"",
4628
-				"\"]').find('input,select,textarea').val()",
4629
-				"\"]').find('input:checked').val()"
4630
-			), $input ) );
4631
-
4632
-			return $output;
4633
-		}
4634
-
4635
-		/**
4636
-		 * Builds the inputs for the widget options.
4637
-		 *
4638
-		 * @param $args
4639
-		 * @param $instance
4640
-		 */
4641
-		public function widget_inputs( $args, $instance ) {
4642
-
4643
-			$class             = "";
4644
-			$element_require   = "";
4645
-			$custom_attributes = "";
4646
-
4647
-			// get value
4648
-			if ( isset( $instance[ $args['name'] ] ) ) {
4649
-				$value = $instance[ $args['name'] ];
4650
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4651
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4652
-			} else {
4653
-				$value = '';
4654
-			}
4655
-
4656
-			// get placeholder
4657
-			if ( ! empty( $args['placeholder'] ) ) {
4658
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4659
-			} else {
4660
-				$placeholder = '';
4661
-			}
4662
-
4663
-			// get if advanced
4664
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4665
-				$class .= " sd-advanced-setting ";
4666
-			}
4667
-
4668
-			// element_require
4669
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4670
-				$element_require = $args['element_require'];
4671
-			}
4672
-
4673
-			// custom_attributes
4674
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4675
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4676
-			}
4677
-
4678
-			// before wrapper
4679
-			?>
4577
+                } else if ( ! empty( $args['row']['close'] ) ) {
4578
+                    echo "<div class='col pl-0 ps-0'>";
4579
+                } else {
4580
+                    echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4581
+                }
4582
+            }
4583
+        }
4584
+
4585
+        public function widget_inputs_row_end( $key, $args ) {
4586
+            if ( ! empty( $args['row'] ) ) {
4587
+                // Maybe close
4588
+                if ( ! empty( $args['row']['close'] ) ) {
4589
+                    echo "</div></div>";
4590
+                }
4591
+                echo "</div>";
4592
+            }
4593
+        }
4594
+
4595
+        /**
4596
+         * Get the hidden input that when added makes the advanced button show on widget settings.
4597
+         *
4598
+         * @return string
4599
+         */
4600
+        public function widget_advanced_toggle() {
4601
+
4602
+            $output = '';
4603
+            if ( $this->block_show_advanced() ) {
4604
+                $val = 1;
4605
+            } else {
4606
+                $val = 0;
4607
+            }
4608
+
4609
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4610
+
4611
+            return $output;
4612
+        }
4613
+
4614
+        /**
4615
+         * Convert require element.
4616
+         *
4617
+         * @param string $input Input element.
4618
+         *
4619
+         * @return string $output
4620
+         *@since 1.0.0
4621
+         *
4622
+         */
4623
+        public function convert_element_require( $input ) {
4624
+            $input = str_replace( "'", '"', $input );// we only want double quotes
4625
+
4626
+            $output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4627
+                "jQuery(form).find('[data-argument=\"",
4628
+                "\"]').find('input,select,textarea').val()",
4629
+                "\"]').find('input:checked').val()"
4630
+            ), $input ) );
4631
+
4632
+            return $output;
4633
+        }
4634
+
4635
+        /**
4636
+         * Builds the inputs for the widget options.
4637
+         *
4638
+         * @param $args
4639
+         * @param $instance
4640
+         */
4641
+        public function widget_inputs( $args, $instance ) {
4642
+
4643
+            $class             = "";
4644
+            $element_require   = "";
4645
+            $custom_attributes = "";
4646
+
4647
+            // get value
4648
+            if ( isset( $instance[ $args['name'] ] ) ) {
4649
+                $value = $instance[ $args['name'] ];
4650
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4651
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4652
+            } else {
4653
+                $value = '';
4654
+            }
4655
+
4656
+            // get placeholder
4657
+            if ( ! empty( $args['placeholder'] ) ) {
4658
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4659
+            } else {
4660
+                $placeholder = '';
4661
+            }
4662
+
4663
+            // get if advanced
4664
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4665
+                $class .= " sd-advanced-setting ";
4666
+            }
4667
+
4668
+            // element_require
4669
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4670
+                $element_require = $args['element_require'];
4671
+            }
4672
+
4673
+            // custom_attributes
4674
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4675
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4676
+            }
4677
+
4678
+            // before wrapper
4679
+            ?>
4680 4680
 			<p class="sd-argument <?php echo esc_attr( $class ); ?>" data-argument='<?php echo esc_attr( $args['name'] ); ?>' data-element_require='<?php if ( $element_require ) { echo $this->convert_element_require( $element_require );} ?>'>
4681 4681
 			<?php
4682
-			switch ( $args['type'] ) {
4683
-				//array('text','password','number','email','tel','url','color')
4684
-				case "text":
4685
-				case "password":
4686
-				case "number":
4687
-				case "email":
4688
-				case "tel":
4689
-				case "url":
4690
-				case "color":
4691
-					?>
4682
+            switch ( $args['type'] ) {
4683
+                //array('text','password','number','email','tel','url','color')
4684
+                case "text":
4685
+                case "password":
4686
+                case "number":
4687
+                case "email":
4688
+                case "tel":
4689
+                case "url":
4690
+                case "color":
4691
+                    ?>
4692 4692
 					<label 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>
4693 4693
 					<input <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="<?php echo esc_attr( $args['type'] ); ?>" value="<?php echo esc_attr( $value ); ?>">
4694 4694
 					<?php
4695 4695
 
4696
-					break;
4697
-				case "select":
4698
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4699
-					if ( $multiple ) {
4700
-						if ( empty( $value ) ) {
4701
-							$value = array();
4702
-						}
4703
-					}
4704
-					?>
4696
+                    break;
4697
+                case "select":
4698
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4699
+                    if ( $multiple ) {
4700
+                        if ( empty( $value ) ) {
4701
+                            $value = array();
4702
+                        }
4703
+                    }
4704
+                    ?>
4705 4705
 					<label 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>
4706 4706
 					<select <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); if ( $multiple ) { echo "[]"; } ?>"
4707 4707
 						<?php if ( $multiple ) {
4708
-							echo "multiple";
4709
-						} //@todo not implemented yet due to gutenberg not supporting it
4710
-						?>>
4708
+                            echo "multiple";
4709
+                        } //@todo not implemented yet due to gutenberg not supporting it
4710
+                        ?>>
4711 4711
 						<?php
4712 4712
 
4713
-						if ( ! empty( $args['options'] ) ) {
4714
-							foreach ( $args['options'] as $val => $label ) {
4715
-								if ( $multiple ) {
4716
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4717
-								} else {
4718
-									$selected = selected( $value, $val, false );
4719
-								}
4720
-								echo "<option value='$val' " . $selected . ">$label</option>";
4721
-							}
4722
-						}
4723
-						?>
4713
+                        if ( ! empty( $args['options'] ) ) {
4714
+                            foreach ( $args['options'] as $val => $label ) {
4715
+                                if ( $multiple ) {
4716
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4717
+                                } else {
4718
+                                    $selected = selected( $value, $val, false );
4719
+                                }
4720
+                                echo "<option value='$val' " . $selected . ">$label</option>";
4721
+                            }
4722
+                        }
4723
+                        ?>
4724 4724
 					</select>
4725 4725
 					<?php
4726
-					break;
4727
-				case "checkbox":
4728
-					?>
4726
+                    break;
4727
+                case "checkbox":
4728
+                    ?>
4729 4729
 					<input <?php echo $placeholder; ?> <?php checked( 1, $value, true ) ?> <?php echo $custom_attributes; ?> class="widefat" id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="checkbox" value="1">
4730 4730
 					<label 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>
4731 4731
 					<?php
4732
-					break;
4733
-				case "textarea":
4734
-					?>
4732
+                    break;
4733
+                case "textarea":
4734
+                    ?>
4735 4735
 					<label 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>
4736 4736
 					<textarea <?php echo $placeholder; ?> class="widefat" <?php echo $custom_attributes; ?> id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>"><?php echo esc_attr( $value ); ?></textarea>
4737 4737
 					<?php
4738 4738
 
4739
-					break;
4740
-				case "hidden":
4741
-					?>
4739
+                    break;
4740
+                case "hidden":
4741
+                    ?>
4742 4742
 					<input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden" value="<?php echo esc_attr( $value ); ?>">
4743 4743
 					<?php
4744
-					break;
4745
-				default:
4746
-					echo "No input type found!"; // @todo we need to add more input types.
4747
-			}
4748
-			// after wrapper
4749
-			?></p><?php
4750
-		}
4751
-
4752
-		public function get_widget_icon($icon = 'box-top', $title = ''){
4753
-			if($icon=='box-top'){
4754
-				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>';
4755
-			}elseif($icon=='box-right'){
4756
-				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>';
4757
-			}elseif($icon=='box-bottom'){
4758
-				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>';
4759
-			}elseif($icon=='box-left'){
4760
-				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>';
4761
-			}
4762
-		}
4763
-
4764
-		/**
4765
-		 * Get the widget input description html.
4766
-		 *
4767
-		 * @param $args
4768
-		 *
4769
-		 * @return string
4770
-		 * @todo, need to make its own tooltip script
4771
-		 */
4772
-		public function widget_field_desc( $args ) {
4773
-
4774
-			$description = '';
4775
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
4776
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4777
-					$description = $this->desc_tip( $args['desc'] );
4778
-				} else {
4779
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4780
-				}
4781
-			}
4782
-
4783
-			return $description;
4784
-		}
4785
-
4786
-		/**
4787
-		 * Get the widget input title html.
4788
-		 *
4789
-		 * @param $args
4790
-		 *
4791
-		 * @return string
4792
-		 */
4793
-		public function widget_field_title( $args ) {
4794
-			$title = '';
4795
-
4796
-			if ( isset( $args['title'] ) && $args['title'] ) {
4797
-				if ( ! empty( $args['device_type'] ) ) {
4798
-					$args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4799
-				}
4800
-
4801
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
4802
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
4803
-				} else {
4804
-					$title = esc_attr( $args['title'] );
4805
-				}
4806
-			}
4807
-
4808
-			return $title;
4809
-		}
4810
-
4811
-		/**
4812
-		 * Get the tool tip html.
4813
-		 *
4814
-		 * @param $tip
4815
-		 * @param bool $allow_html
4816
-		 *
4817
-		 * @return string
4818
-		 */
4819
-		function desc_tip( $tip, $allow_html = false ) {
4820
-			if ( $allow_html ) {
4821
-				$tip = $this->sanitize_tooltip( $tip );
4822
-			} else {
4823
-				$tip = esc_attr( $tip );
4824
-			}
4825
-
4826
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4827
-		}
4828
-
4829
-		/**
4830
-		 * Sanitize a string destined to be a tooltip.
4831
-		 *
4832
-		 * @param string $var
4833
-		 *
4834
-		 * @return string
4835
-		 */
4836
-		public function sanitize_tooltip( $var ) {
4837
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4838
-				'br'     => array(),
4839
-				'em'     => array(),
4840
-				'strong' => array(),
4841
-				'small'  => array(),
4842
-				'span'   => array(),
4843
-				'ul'     => array(),
4844
-				'li'     => array(),
4845
-				'ol'     => array(),
4846
-				'p'      => array(),
4847
-			) ) );
4848
-		}
4849
-
4850
-		/**
4851
-		 * Processing widget options on save
4852
-		 *
4853
-		 * @param array $new_instance The new options
4854
-		 * @param array $old_instance The previous options
4855
-		 *
4856
-		 * @return array
4857
-		 * @todo we should add some sanitation here.
4858
-		 */
4859
-		public function update( $new_instance, $old_instance ) {
4860
-
4861
-			//save the widget
4862
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
4863
-
4864
-			// set widget instance
4865
-			$this->instance = $instance;
4866
-
4867
-			if ( empty( $this->arguments ) ) {
4868
-				$this->get_arguments();
4869
-			}
4870
-
4871
-			// check for checkboxes
4872
-			if ( ! empty( $this->arguments ) ) {
4873
-				foreach ( $this->arguments as $argument ) {
4874
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4875
-						$instance[ $argument['name'] ] = '0';
4876
-					}
4877
-				}
4878
-			}
4879
-
4880
-			return $instance;
4881
-		}
4882
-
4883
-		/**
4884
-		 * Checks if the current call is a ajax call to get the block content.
4885
-		 *
4886
-		 * This can be used in your widget to return different content as the block content.
4887
-		 *
4888
-		 * @return bool
4889
-		 *@since 1.0.3
4890
-		 */
4891
-		public function is_block_content_call() {
4892
-			$result = false;
4893
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4894
-				$result = true;
4895
-			}
4896
-
4897
-			return $result;
4898
-		}
4899
-
4900
-		/**
4901
-		 * Get an instance hash that will be unique to the type and settings.
4902
-		 *
4903
-		 * @return string
4904
-		 *@since 1.0.20
4905
-		 */
4906
-		public function get_instance_hash(){
4907
-			$instance_string = $this->base_id.serialize($this->instance);
4908
-			return hash('crc32b',$instance_string);
4909
-		}
4910
-
4911
-		/**
4912
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
4913
-		 *
4914
-		 * @param array $rules
4915
-		 *
4916
-		 * @return string
4917
-		 *@since 1.0.20
4918
-		 */
4919
-		public function get_instance_style($rules = array()){
4920
-			$css = '';
4921
-
4922
-			if(!empty($rules)){
4923
-				$rules = array_unique($rules);
4924
-				$instance_hash = $this->get_instance_hash();
4925
-				$css .= "<style>";
4926
-				foreach($rules as $rule){
4927
-					$css .= ".sdel-$instance_hash $rule";
4928
-				}
4929
-				$css .= "</style>";
4930
-			}
4931
-
4932
-			return $css;
4933
-		}
4934
-
4935
-		/**
4936
-		 * Encode shortcodes tags.
4937
-		 *
4938
-		 * @param string $content Content to search for shortcode tags.
4939
-		 *
4744
+                    break;
4745
+                default:
4746
+                    echo "No input type found!"; // @todo we need to add more input types.
4747
+            }
4748
+            // after wrapper
4749
+            ?></p><?php
4750
+        }
4751
+
4752
+        public function get_widget_icon($icon = 'box-top', $title = ''){
4753
+            if($icon=='box-top'){
4754
+                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>';
4755
+            }elseif($icon=='box-right'){
4756
+                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>';
4757
+            }elseif($icon=='box-bottom'){
4758
+                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>';
4759
+            }elseif($icon=='box-left'){
4760
+                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>';
4761
+            }
4762
+        }
4763
+
4764
+        /**
4765
+         * Get the widget input description html.
4766
+         *
4767
+         * @param $args
4768
+         *
4769
+         * @return string
4770
+         * @todo, need to make its own tooltip script
4771
+         */
4772
+        public function widget_field_desc( $args ) {
4773
+
4774
+            $description = '';
4775
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
4776
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4777
+                    $description = $this->desc_tip( $args['desc'] );
4778
+                } else {
4779
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4780
+                }
4781
+            }
4782
+
4783
+            return $description;
4784
+        }
4785
+
4786
+        /**
4787
+         * Get the widget input title html.
4788
+         *
4789
+         * @param $args
4790
+         *
4791
+         * @return string
4792
+         */
4793
+        public function widget_field_title( $args ) {
4794
+            $title = '';
4795
+
4796
+            if ( isset( $args['title'] ) && $args['title'] ) {
4797
+                if ( ! empty( $args['device_type'] ) ) {
4798
+                    $args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4799
+                }
4800
+
4801
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
4802
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
4803
+                } else {
4804
+                    $title = esc_attr( $args['title'] );
4805
+                }
4806
+            }
4807
+
4808
+            return $title;
4809
+        }
4810
+
4811
+        /**
4812
+         * Get the tool tip html.
4813
+         *
4814
+         * @param $tip
4815
+         * @param bool $allow_html
4816
+         *
4817
+         * @return string
4818
+         */
4819
+        function desc_tip( $tip, $allow_html = false ) {
4820
+            if ( $allow_html ) {
4821
+                $tip = $this->sanitize_tooltip( $tip );
4822
+            } else {
4823
+                $tip = esc_attr( $tip );
4824
+            }
4825
+
4826
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4827
+        }
4828
+
4829
+        /**
4830
+         * Sanitize a string destined to be a tooltip.
4831
+         *
4832
+         * @param string $var
4833
+         *
4834
+         * @return string
4835
+         */
4836
+        public function sanitize_tooltip( $var ) {
4837
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4838
+                'br'     => array(),
4839
+                'em'     => array(),
4840
+                'strong' => array(),
4841
+                'small'  => array(),
4842
+                'span'   => array(),
4843
+                'ul'     => array(),
4844
+                'li'     => array(),
4845
+                'ol'     => array(),
4846
+                'p'      => array(),
4847
+            ) ) );
4848
+        }
4849
+
4850
+        /**
4851
+         * Processing widget options on save
4852
+         *
4853
+         * @param array $new_instance The new options
4854
+         * @param array $old_instance The previous options
4855
+         *
4856
+         * @return array
4857
+         * @todo we should add some sanitation here.
4858
+         */
4859
+        public function update( $new_instance, $old_instance ) {
4860
+
4861
+            //save the widget
4862
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
4863
+
4864
+            // set widget instance
4865
+            $this->instance = $instance;
4866
+
4867
+            if ( empty( $this->arguments ) ) {
4868
+                $this->get_arguments();
4869
+            }
4870
+
4871
+            // check for checkboxes
4872
+            if ( ! empty( $this->arguments ) ) {
4873
+                foreach ( $this->arguments as $argument ) {
4874
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4875
+                        $instance[ $argument['name'] ] = '0';
4876
+                    }
4877
+                }
4878
+            }
4879
+
4880
+            return $instance;
4881
+        }
4882
+
4883
+        /**
4884
+         * Checks if the current call is a ajax call to get the block content.
4885
+         *
4886
+         * This can be used in your widget to return different content as the block content.
4887
+         *
4888
+         * @return bool
4889
+         *@since 1.0.3
4890
+         */
4891
+        public function is_block_content_call() {
4892
+            $result = false;
4893
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4894
+                $result = true;
4895
+            }
4896
+
4897
+            return $result;
4898
+        }
4899
+
4900
+        /**
4901
+         * Get an instance hash that will be unique to the type and settings.
4902
+         *
4903
+         * @return string
4904
+         *@since 1.0.20
4905
+         */
4906
+        public function get_instance_hash(){
4907
+            $instance_string = $this->base_id.serialize($this->instance);
4908
+            return hash('crc32b',$instance_string);
4909
+        }
4910
+
4911
+        /**
4912
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
4913
+         *
4914
+         * @param array $rules
4915
+         *
4916
+         * @return string
4917
+         *@since 1.0.20
4918
+         */
4919
+        public function get_instance_style($rules = array()){
4920
+            $css = '';
4921
+
4922
+            if(!empty($rules)){
4923
+                $rules = array_unique($rules);
4924
+                $instance_hash = $this->get_instance_hash();
4925
+                $css .= "<style>";
4926
+                foreach($rules as $rule){
4927
+                    $css .= ".sdel-$instance_hash $rule";
4928
+                }
4929
+                $css .= "</style>";
4930
+            }
4931
+
4932
+            return $css;
4933
+        }
4934
+
4935
+        /**
4936
+         * Encode shortcodes tags.
4937
+         *
4938
+         * @param string $content Content to search for shortcode tags.
4939
+         *
4940 4940
 *@return string Content with shortcode tags removed.
4941
-		 *@since 1.0.28
4942
-		 *
4943
-		 */
4944
-		public function encode_shortcodes( $content ) {
4945
-			// Avoids existing encoded tags.
4946
-			$trans   = array(
4947
-				'&#91;' => '&#091;',
4948
-				'&#93;' => '&#093;',
4949
-				'&amp;#91;' => '&#091;',
4950
-				'&amp;#93;' => '&#093;',
4951
-				'&lt;' => '&0lt;',
4952
-				'&gt;' => '&0gt;',
4953
-				'&amp;lt;' => '&0lt;',
4954
-				'&amp;gt;' => '&0gt;',
4955
-			);
4956
-
4957
-			$content = strtr( $content, $trans );
4958
-
4959
-			$trans   = array(
4960
-				'[' => '&#91;',
4961
-				']' => '&#93;',
4962
-				'<' => '&lt;',
4963
-				'>' => '&gt;',
4964
-				'"' => '&quot;',
4965
-				"'" => '&#39;',
4966
-			);
4967
-
4968
-			$content = strtr( $content, $trans );
4969
-
4970
-			return $content;
4971
-		}
4972
-
4973
-		/**
4974
-		 * Remove encoded shortcod tags.
4975
-		 *
4976
-		 * @param string $content Content to search for shortcode tags.
4977
-		 *
4941
+         *@since 1.0.28
4942
+         *
4943
+         */
4944
+        public function encode_shortcodes( $content ) {
4945
+            // Avoids existing encoded tags.
4946
+            $trans   = array(
4947
+                '&#91;' => '&#091;',
4948
+                '&#93;' => '&#093;',
4949
+                '&amp;#91;' => '&#091;',
4950
+                '&amp;#93;' => '&#093;',
4951
+                '&lt;' => '&0lt;',
4952
+                '&gt;' => '&0gt;',
4953
+                '&amp;lt;' => '&0lt;',
4954
+                '&amp;gt;' => '&0gt;',
4955
+            );
4956
+
4957
+            $content = strtr( $content, $trans );
4958
+
4959
+            $trans   = array(
4960
+                '[' => '&#91;',
4961
+                ']' => '&#93;',
4962
+                '<' => '&lt;',
4963
+                '>' => '&gt;',
4964
+                '"' => '&quot;',
4965
+                "'" => '&#39;',
4966
+            );
4967
+
4968
+            $content = strtr( $content, $trans );
4969
+
4970
+            return $content;
4971
+        }
4972
+
4973
+        /**
4974
+         * Remove encoded shortcod tags.
4975
+         *
4976
+         * @param string $content Content to search for shortcode tags.
4977
+         *
4978 4978
 *@return string Content with decoded shortcode tags.
4979
-		 *@since 1.0.28
4980
-		 *
4981
-		 */
4982
-		public function decode_shortcodes( $content ) {
4983
-			$trans   = array(
4984
-				'&#91;' => '[',
4985
-				'&#93;' => ']',
4986
-				'&amp;#91;' => '[',
4987
-				'&amp;#93;' => ']',
4988
-				'&lt;' => '<',
4989
-				'&gt;' => '>',
4990
-				'&amp;lt;' => '<',
4991
-				'&amp;gt;' => '>',
4992
-				'&quot;' => '"',
4993
-				'&apos;' => "'",
4994
-			);
4995
-
4996
-			$content = strtr( $content, $trans );
4997
-
4998
-			$trans   = array(
4999
-				'&#091;' => '&#91;',
5000
-				'&#093;' => '&#93;',
5001
-				'&amp;#091;' => '&#91;',
5002
-				'&amp;#093;' => '&#93;',
5003
-				'&0lt;' => '&lt;',
5004
-				'&0gt;' => '&gt;',
5005
-				'&amp;0lt;' => '&lt;',
5006
-				'&amp;0gt;' => '&gt;',
5007
-			);
5008
-
5009
-			$content = strtr( $content, $trans );
5010
-
5011
-			return $content;
5012
-		}
5013
-
5014
-		public function block_visibility_fields( $args ) {
5015
-			$value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
5016
-			$content = '<div class="bs-vc-rule-template d-none">';
5017
-				$content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
5018
-					$content .= '<div class="row">';
5019
-						$content .= '<div class="col-sm-12">';
5020
-							$content .= '<div class="bs-rule-action position-absolute top-0 end-0 p-2 zindex-5"><span class="text-danger c-pointer bs-vc-remove-rule" title="' . esc_attr__( 'Remove Rule', 'ayecode-connect' ) . '"><i class="fas fa-circle-minus fs-6"></i></span></div>';
5021
-							$content .= aui()->select(
5022
-								array(
5023
-									'id'          => 'bsvc_rule_BSVCINDEX',
5024
-									'name'        => 'bsvc_rule_BSVCINDEX',
5025
-									'label'       => __( 'Rule', 'ayecode-connect' ),
5026
-									'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
5027
-									'class'       => 'bsvc_rule form-select-sm no-select2 mw-100',
5028
-									'options'     => sd_visibility_rules_options(),
5029
-									'default'     => '',
5030
-									'value'       => '',
5031
-									'label_type'  => '',
5032
-									'select2'     => false,
5033
-									'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
5034
-									'extra_attributes' => array(
5035
-										'data-minimum-results-for-search' => '-1'
5036
-									)
5037
-								)
5038
-							);
5039
-
5040
-						$content .= '</div>';
5041
-
5042
-						if ( class_exists( 'GeoDirectory' ) ) {
5043
-							$content .= '<div class="col-md-7 col-sm-12">';
5044
-
5045
-								$content .= aui()->select(
5046
-									array(
5047
-										'id'          => 'bsvc_gd_field_BSVCINDEX',
5048
-										'name'        => 'bsvc_gd_field_BSVCINDEX',
5049
-										'label'       => __( 'FIELD', 'ayecode-connect' ),
5050
-										'placeholder' => __( 'FIELD', 'ayecode-connect' ),
5051
-										'class'       => 'bsvc_gd_field form-select-sm no-select2 mw-100',
5052
-										'options'     => sd_visibility_gd_field_options(),
5053
-										'default'     => '',
5054
-										'value'       => '',
5055
-										'label_type'  => '',
5056
-										'select2'     => false,
5057
-										'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5058
-										'extra_attributes' => array(
5059
-											'data-minimum-results-for-search' => '-1'
5060
-										)
5061
-									)
5062
-								);
5063
-
5064
-							$content .= '</div>';
5065
-							$content .= '<div class="col-md-5 col-sm-12">';
5066
-
5067
-								$content .= aui()->select(
5068
-									array(
5069
-										'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
5070
-										'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
5071
-										'label'       => __( 'CONDITION', 'ayecode-connect' ),
5072
-										'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
5073
-										'class'       => 'bsvc_gd_field_condition form-select-sm no-select2 mw-100',
5074
-										'options'     => sd_visibility_field_condition_options(),
5075
-										'default'     => '',
5076
-										'value'       => '',
5077
-										'label_type'  => '',
5078
-										'select2'     => false,
5079
-										'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5080
-										'extra_attributes' => array(
5081
-											'data-minimum-results-for-search' => '-1'
5082
-										)
5083
-									)
5084
-								);
5085
-
5086
-							$content .= '</div>';
5087
-							$content .= '<div class="col-sm-12">';
5088
-
5089
-								$content .= aui()->input(
5090
-									array(
5091
-										'type'            => 'text',
5092
-										'id'              => 'bsvc_gd_field_search_BSVCINDEX',
5093
-										'name'            => 'bsvc_gd_field_search_BSVCINDEX',
5094
-										'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5095
-										'class'           => 'bsvc_gd_field_search form-control-sm',
5096
-										'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5097
-										'label_type'      => '',
5098
-										'value'           => '',
5099
-										'element_require' => '([%bsvc_rule_BSVCINDEX%]=="gd_field" && [%bsvc_gd_field_condition_BSVCINDEX%] && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_empty" && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_not_empty")'
5100
-									)
5101
-								);
5102
-
5103
-							$content .= '</div>';
5104
-						}
5105
-
5106
-					$content .= '</div>';
5107
-
5108
-					$content .= '<div class="row aui-conditional-field" data-element-require="jQuery(form).find(\'[name=bsvc_rule_BSVCINDEX]\').val()==\'user_roles\'" data-argument="bsvc_user_roles_BSVCINDEX_1"><label for="bsvc_user_roles_BSVCINDEX_1" class="form-label mb-3">' . __( 'Select User Roles:', 'ayecode-connect' ) . '</label>';
5109
-						$role_options = sd_user_roles_options();
5110
-
5111
-						$role_option_i = 0;
5112
-						foreach ( $role_options as $role_option_key => $role_option_name ) {
5113
-							$role_option_i++;
5114
-
5115
-							$content .= '<div class="col-sm-6">';
5116
-							$content .= aui()->input(
5117
-								array(
5118
-									'id'               => 'bsvc_user_roles_BSVCINDEX_' . $role_option_i,
5119
-									'name'             => 'bsvc_user_roles_BSVCINDEX[]',
5120
-									'type'             => 'checkbox',
5121
-									'label'            => $role_option_name,
5122
-									'label_type'       => 'hidden',
5123
-									'class'            => 'bsvc_user_roles',
5124
-									'value'            => $role_option_key,
5125
-									'switch'           => 'md',
5126
-									'no_wrap'          => true
5127
-								)
5128
-							);
5129
-							$content .= '</div>';
5130
-						}
5131
-					$content .= '</div>';
5132
-				$content .= '</div>';
5133
-			$content .= '</div>';
5134
-			$content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5135
-			$content .= '<div class="bs-vc-rule-sets"></div>';
5136
-			$content .= '<div class="row"><div class="col-sm-12 text-center pt-1 pb-4"><button type="button" class="btn btn-sm btn-primary d-block w-100 bs-vc-add-rule"><i class="fas fa-plus"></i> ' . __( 'Add Rule', 'ayecode-connect' ) . '</button></div></div>';
5137
-			$content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5138
-			$content .= aui()->select(
5139
-				array(
5140
-					'id'          => 'bsvc_output',
5141
-					'name'        => 'bsvc_output',
5142
-					'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5143
-					'placeholder' => __( 'Default Output', 'ayecode-connect' ),
5144
-					'class'       => 'bsvc_output form-select-sm no-select2 mw-100',
5145
-					'options'     => sd_visibility_output_options(),
5146
-					'default'     => '',
5147
-					'value'       => '',
5148
-					'label_type'  => 'top',
5149
-					'select2'     => false,
5150
-					'extra_attributes' => array(
5151
-						'data-minimum-results-for-search' => '-1'
5152
-					)
5153
-				)
5154
-			);
5155
-
5156
-			$content .= '</div><div class="col-md-6 col-sm-12">';
5157
-
5158
-			$content .= aui()->select(
5159
-				array(
5160
-					'id'              => 'bsvc_page',
5161
-					'name'            => 'bsvc_page',
5162
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5163
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5164
-					'class'           => 'bsvc_page form-select-sm no-select2 mw-100',
5165
-					'options'         => sd_template_page_options(),
5166
-					'default'         => '',
5167
-					'value'           => '',
5168
-					'label_type'      => 'top',
5169
-					'select2'         => false,
5170
-					'element_require' => '[%bsvc_output%]=="page"'
5171
-				)
5172
-			);
5173
-
5174
-			$content .= aui()->select(
5175
-				array(
5176
-					'id'          => 'bsvc_tmpl_part',
5177
-					'name'        => 'bsvc_tmpl_part',
5178
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5179
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5180
-					'class'       => 'bsvc_tmpl_part form-select-sm no-select2 mw-100',
5181
-					'options'     => sd_template_part_options(),
5182
-					'default'     => '',
5183
-					'value'       => '',
5184
-					'label_type'  => 'top',
5185
-					'select2'     => false,
5186
-					'element_require'  => '[%bsvc_output%]=="template_part"',
5187
-					'extra_attributes' => array(
5188
-						'data-minimum-results-for-search' => '-1'
5189
-					)
5190
-				)
5191
-			);
5192
-
5193
-			$content .= aui()->select(
5194
-				array(
5195
-					'id'               => 'bsvc_message_type',
5196
-					'name'             => 'bsvc_message_type',
5197
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5198
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5199
-					'class'            => 'bsvc_message_type form-select-sm no-select2 mw-100',
5200
-					'options'          => sd_aui_colors(),
5201
-					'default'          => '',
5202
-					'value'            => '',
5203
-					'label_type'       => 'top',
5204
-					'select2'          => false,
5205
-					'element_require'  => '[%bsvc_output%]=="message"',
5206
-					'extra_attributes' => array(
5207
-						'data-minimum-results-for-search' => '-1'
5208
-					)
5209
-				)
5210
-			);
5211
-
5212
-			$content .= '</div><div class="col-sm-12">';
5213
-
5214
-			$content .= aui()->input(
5215
-				array(
5216
-					'type'            => 'text',
5217
-					'id'              => 'bsvc_message',
5218
-					'name'            => 'bsvc_message',
5219
-					'label'           => '',
5220
-					'class'           => 'bsvc_message form-control-sm',
5221
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5222
-					'label_type'      => '',
5223
-					'value'           => '',
5224
-					'form_group_class' => ' ',
5225
-					'element_require' => '[%bsvc_output%]=="message"',
5226
-				)
5227
-			);
5228
-
5229
-			$content .= '</div></div></form><input type="hidden" id="bsvc_raw_value" name="bsvc_raw_value" value="' . $value . '">';
5230
-
5231
-			return $content;
5232
-		}
5233
-	}
4979
+         *@since 1.0.28
4980
+         *
4981
+         */
4982
+        public function decode_shortcodes( $content ) {
4983
+            $trans   = array(
4984
+                '&#91;' => '[',
4985
+                '&#93;' => ']',
4986
+                '&amp;#91;' => '[',
4987
+                '&amp;#93;' => ']',
4988
+                '&lt;' => '<',
4989
+                '&gt;' => '>',
4990
+                '&amp;lt;' => '<',
4991
+                '&amp;gt;' => '>',
4992
+                '&quot;' => '"',
4993
+                '&apos;' => "'",
4994
+            );
4995
+
4996
+            $content = strtr( $content, $trans );
4997
+
4998
+            $trans   = array(
4999
+                '&#091;' => '&#91;',
5000
+                '&#093;' => '&#93;',
5001
+                '&amp;#091;' => '&#91;',
5002
+                '&amp;#093;' => '&#93;',
5003
+                '&0lt;' => '&lt;',
5004
+                '&0gt;' => '&gt;',
5005
+                '&amp;0lt;' => '&lt;',
5006
+                '&amp;0gt;' => '&gt;',
5007
+            );
5008
+
5009
+            $content = strtr( $content, $trans );
5010
+
5011
+            return $content;
5012
+        }
5013
+
5014
+        public function block_visibility_fields( $args ) {
5015
+            $value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
5016
+            $content = '<div class="bs-vc-rule-template d-none">';
5017
+                $content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
5018
+                    $content .= '<div class="row">';
5019
+                        $content .= '<div class="col-sm-12">';
5020
+                            $content .= '<div class="bs-rule-action position-absolute top-0 end-0 p-2 zindex-5"><span class="text-danger c-pointer bs-vc-remove-rule" title="' . esc_attr__( 'Remove Rule', 'ayecode-connect' ) . '"><i class="fas fa-circle-minus fs-6"></i></span></div>';
5021
+                            $content .= aui()->select(
5022
+                                array(
5023
+                                    'id'          => 'bsvc_rule_BSVCINDEX',
5024
+                                    'name'        => 'bsvc_rule_BSVCINDEX',
5025
+                                    'label'       => __( 'Rule', 'ayecode-connect' ),
5026
+                                    'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
5027
+                                    'class'       => 'bsvc_rule form-select-sm no-select2 mw-100',
5028
+                                    'options'     => sd_visibility_rules_options(),
5029
+                                    'default'     => '',
5030
+                                    'value'       => '',
5031
+                                    'label_type'  => '',
5032
+                                    'select2'     => false,
5033
+                                    'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
5034
+                                    'extra_attributes' => array(
5035
+                                        'data-minimum-results-for-search' => '-1'
5036
+                                    )
5037
+                                )
5038
+                            );
5039
+
5040
+                        $content .= '</div>';
5041
+
5042
+                        if ( class_exists( 'GeoDirectory' ) ) {
5043
+                            $content .= '<div class="col-md-7 col-sm-12">';
5044
+
5045
+                                $content .= aui()->select(
5046
+                                    array(
5047
+                                        'id'          => 'bsvc_gd_field_BSVCINDEX',
5048
+                                        'name'        => 'bsvc_gd_field_BSVCINDEX',
5049
+                                        'label'       => __( 'FIELD', 'ayecode-connect' ),
5050
+                                        'placeholder' => __( 'FIELD', 'ayecode-connect' ),
5051
+                                        'class'       => 'bsvc_gd_field form-select-sm no-select2 mw-100',
5052
+                                        'options'     => sd_visibility_gd_field_options(),
5053
+                                        'default'     => '',
5054
+                                        'value'       => '',
5055
+                                        'label_type'  => '',
5056
+                                        'select2'     => false,
5057
+                                        'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5058
+                                        'extra_attributes' => array(
5059
+                                            'data-minimum-results-for-search' => '-1'
5060
+                                        )
5061
+                                    )
5062
+                                );
5063
+
5064
+                            $content .= '</div>';
5065
+                            $content .= '<div class="col-md-5 col-sm-12">';
5066
+
5067
+                                $content .= aui()->select(
5068
+                                    array(
5069
+                                        'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
5070
+                                        'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
5071
+                                        'label'       => __( 'CONDITION', 'ayecode-connect' ),
5072
+                                        'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
5073
+                                        'class'       => 'bsvc_gd_field_condition form-select-sm no-select2 mw-100',
5074
+                                        'options'     => sd_visibility_field_condition_options(),
5075
+                                        'default'     => '',
5076
+                                        'value'       => '',
5077
+                                        'label_type'  => '',
5078
+                                        'select2'     => false,
5079
+                                        'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
5080
+                                        'extra_attributes' => array(
5081
+                                            'data-minimum-results-for-search' => '-1'
5082
+                                        )
5083
+                                    )
5084
+                                );
5085
+
5086
+                            $content .= '</div>';
5087
+                            $content .= '<div class="col-sm-12">';
5088
+
5089
+                                $content .= aui()->input(
5090
+                                    array(
5091
+                                        'type'            => 'text',
5092
+                                        'id'              => 'bsvc_gd_field_search_BSVCINDEX',
5093
+                                        'name'            => 'bsvc_gd_field_search_BSVCINDEX',
5094
+                                        'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5095
+                                        'class'           => 'bsvc_gd_field_search form-control-sm',
5096
+                                        'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
5097
+                                        'label_type'      => '',
5098
+                                        'value'           => '',
5099
+                                        'element_require' => '([%bsvc_rule_BSVCINDEX%]=="gd_field" && [%bsvc_gd_field_condition_BSVCINDEX%] && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_empty" && [%bsvc_gd_field_condition_BSVCINDEX%]!="is_not_empty")'
5100
+                                    )
5101
+                                );
5102
+
5103
+                            $content .= '</div>';
5104
+                        }
5105
+
5106
+                    $content .= '</div>';
5107
+
5108
+                    $content .= '<div class="row aui-conditional-field" data-element-require="jQuery(form).find(\'[name=bsvc_rule_BSVCINDEX]\').val()==\'user_roles\'" data-argument="bsvc_user_roles_BSVCINDEX_1"><label for="bsvc_user_roles_BSVCINDEX_1" class="form-label mb-3">' . __( 'Select User Roles:', 'ayecode-connect' ) . '</label>';
5109
+                        $role_options = sd_user_roles_options();
5110
+
5111
+                        $role_option_i = 0;
5112
+                        foreach ( $role_options as $role_option_key => $role_option_name ) {
5113
+                            $role_option_i++;
5114
+
5115
+                            $content .= '<div class="col-sm-6">';
5116
+                            $content .= aui()->input(
5117
+                                array(
5118
+                                    'id'               => 'bsvc_user_roles_BSVCINDEX_' . $role_option_i,
5119
+                                    'name'             => 'bsvc_user_roles_BSVCINDEX[]',
5120
+                                    'type'             => 'checkbox',
5121
+                                    'label'            => $role_option_name,
5122
+                                    'label_type'       => 'hidden',
5123
+                                    'class'            => 'bsvc_user_roles',
5124
+                                    'value'            => $role_option_key,
5125
+                                    'switch'           => 'md',
5126
+                                    'no_wrap'          => true
5127
+                                )
5128
+                            );
5129
+                            $content .= '</div>';
5130
+                        }
5131
+                    $content .= '</div>';
5132
+                $content .= '</div>';
5133
+            $content .= '</div>';
5134
+            $content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5135
+            $content .= '<div class="bs-vc-rule-sets"></div>';
5136
+            $content .= '<div class="row"><div class="col-sm-12 text-center pt-1 pb-4"><button type="button" class="btn btn-sm btn-primary d-block w-100 bs-vc-add-rule"><i class="fas fa-plus"></i> ' . __( 'Add Rule', 'ayecode-connect' ) . '</button></div></div>';
5137
+            $content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5138
+            $content .= aui()->select(
5139
+                array(
5140
+                    'id'          => 'bsvc_output',
5141
+                    'name'        => 'bsvc_output',
5142
+                    'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5143
+                    'placeholder' => __( 'Default Output', 'ayecode-connect' ),
5144
+                    'class'       => 'bsvc_output form-select-sm no-select2 mw-100',
5145
+                    'options'     => sd_visibility_output_options(),
5146
+                    'default'     => '',
5147
+                    'value'       => '',
5148
+                    'label_type'  => 'top',
5149
+                    'select2'     => false,
5150
+                    'extra_attributes' => array(
5151
+                        'data-minimum-results-for-search' => '-1'
5152
+                    )
5153
+                )
5154
+            );
5155
+
5156
+            $content .= '</div><div class="col-md-6 col-sm-12">';
5157
+
5158
+            $content .= aui()->select(
5159
+                array(
5160
+                    'id'              => 'bsvc_page',
5161
+                    'name'            => 'bsvc_page',
5162
+                    'label'           => __( 'Page Content', 'ayecode-connect' ),
5163
+                    'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5164
+                    'class'           => 'bsvc_page form-select-sm no-select2 mw-100',
5165
+                    'options'         => sd_template_page_options(),
5166
+                    'default'         => '',
5167
+                    'value'           => '',
5168
+                    'label_type'      => 'top',
5169
+                    'select2'         => false,
5170
+                    'element_require' => '[%bsvc_output%]=="page"'
5171
+                )
5172
+            );
5173
+
5174
+            $content .= aui()->select(
5175
+                array(
5176
+                    'id'          => 'bsvc_tmpl_part',
5177
+                    'name'        => 'bsvc_tmpl_part',
5178
+                    'label'       => __( 'Template Part', 'ayecode-connect' ),
5179
+                    'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5180
+                    'class'       => 'bsvc_tmpl_part form-select-sm no-select2 mw-100',
5181
+                    'options'     => sd_template_part_options(),
5182
+                    'default'     => '',
5183
+                    'value'       => '',
5184
+                    'label_type'  => 'top',
5185
+                    'select2'     => false,
5186
+                    'element_require'  => '[%bsvc_output%]=="template_part"',
5187
+                    'extra_attributes' => array(
5188
+                        'data-minimum-results-for-search' => '-1'
5189
+                    )
5190
+                )
5191
+            );
5192
+
5193
+            $content .= aui()->select(
5194
+                array(
5195
+                    'id'               => 'bsvc_message_type',
5196
+                    'name'             => 'bsvc_message_type',
5197
+                    'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5198
+                    'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5199
+                    'class'            => 'bsvc_message_type form-select-sm no-select2 mw-100',
5200
+                    'options'          => sd_aui_colors(),
5201
+                    'default'          => '',
5202
+                    'value'            => '',
5203
+                    'label_type'       => 'top',
5204
+                    'select2'          => false,
5205
+                    'element_require'  => '[%bsvc_output%]=="message"',
5206
+                    'extra_attributes' => array(
5207
+                        'data-minimum-results-for-search' => '-1'
5208
+                    )
5209
+                )
5210
+            );
5211
+
5212
+            $content .= '</div><div class="col-sm-12">';
5213
+
5214
+            $content .= aui()->input(
5215
+                array(
5216
+                    'type'            => 'text',
5217
+                    'id'              => 'bsvc_message',
5218
+                    'name'            => 'bsvc_message',
5219
+                    'label'           => '',
5220
+                    'class'           => 'bsvc_message form-control-sm',
5221
+                    'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5222
+                    'label_type'      => '',
5223
+                    'value'           => '',
5224
+                    'form_group_class' => ' ',
5225
+                    'element_require' => '[%bsvc_output%]=="message"',
5226
+                )
5227
+            );
5228
+
5229
+            $content .= '</div></div></form><input type="hidden" id="bsvc_raw_value" name="bsvc_raw_value" value="' . $value . '">';
5230
+
5231
+            return $content;
5232
+        }
5233
+    }
5234 5234
 }
Please login to merge, or discard this patch.