Passed
Pull Request — master (#790)
by Kiran
05:35
created
wp-ayecode-ui/includes/components/class-aui-component-pagination.php 2 patches
Indentation   +108 added lines, -108 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,112 +11,112 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI_Component_Pagination {
13 13
 
14
-	/**
15
-	 * Build the component.
16
-	 *
17
-	 * @param array $args
18
-	 *
19
-	 * @return string The rendered component.
20
-	 */
21
-	public static function get( $args = array() ) {
22
-		global $wp_query, $aui_bs5;
23
-
24
-		$defaults = array(
25
-			'class'              => '',
26
-			'mid_size'           => 2,
27
-			'prev_text'          => '<i class="fas fa-chevron-left"></i>',
28
-			'next_text'          => '<i class="fas fa-chevron-right"></i>',
29
-			'screen_reader_text' => __( 'Posts navigation', 'ayecode-connect' ),
30
-			'before_paging'      => '',
31
-			'after_paging'       => '',
32
-			'type'               => 'array',
33
-			'total'              => isset( $wp_query->max_num_pages ) ? $wp_query->max_num_pages : 1,
34
-			'links'              => array(), // an array of links if using custom links, this includes the a tag.
35
-			'rounded_style'      => false,
36
-			'custom_next_text'   => '', // Custom next page text
37
-			'custom_prev_text'   => '', // Custom prev page text
38
-		);
39
-
40
-		/**
41
-		 * Parse incoming $args into an array and merge it with $defaults
42
-		 */
43
-		$args = wp_parse_args( $args, $defaults );
44
-
45
-		$output = '';
46
-
47
-		// Don't print empty markup if there's only one page.
48
-		if ( $args['total'] > 1 ) {
49
-			// Set up paginated links.
50
-			$links = !empty(  $args['links'] ) ? $args['links'] :  paginate_links( $args );
51
-
52
-			$class = !empty($args['class']) ? $args['class'] : '';
53
-
54
-			$custom_prev_link = '';
55
-			$custom_next_link = '';
56
-
57
-			// make the output bootstrap ready
58
-			$links_html = "<ul class='pagination m-0 p-0 $class'>";
59
-			if ( ! empty( $links ) ) {
60
-				foreach ( $links as $link ) {
61
-					$_link = $link;
62
-
63
-					if ( $aui_bs5 ) {
64
-						$link_class = $args['rounded_style'] ? 'page-link badge rounded-pill border-0 mx-1 fs-base text-dark link-primary' : 'page-link';
65
-						$link_class_active = $args['rounded_style'] ? ' current active fw-bold badge rounded-pill' : ' current active';
66
-						$links_html .= "<li class='page-item mx-0'>";
67
-						$link = str_replace( array( "page-numbers", " current" ), array( $link_class, $link_class_active ), $link );
68
-						$link = str_replace( 'text-dark link-primary current', 'current', $link );
69
-						$links_html .=  $link;
70
-						$links_html .= "</li>";
71
-					} else {
72
-						$active = strpos( $link, 'current' ) !== false ? 'active' : '';
73
-						$links_html .= "<li class='page-item $active'>";
74
-						$links_html .= str_replace( "page-numbers", "page-link", $link );
75
-						$links_html .= "</li>";
76
-					}
77
-
78
-					if ( strpos( $_link, 'next page-numbers' ) || strpos( $_link, 'prev page-numbers' ) ) {
79
-						$link = str_replace( array( "page-numbers", " current" ), array( 'btn btn-outline-primary rounded' . ( $args['rounded_style'] ? '-pill' : '' ) . ' mx-1 fs-base text-dark link-primary', ' current active fw-bold badge rounded-pill' ), $_link );
80
-						$link = str_replace( 'text-dark link-primary current', 'current', $link );
81
-
82
-						if ( strpos( $_link, 'next page-numbers' ) && ! empty( $args['custom_next_text'] ) ) {
83
-							$custom_next_link = str_replace( $args['next_text'], $args['custom_next_text'], $link );
84
-						} else if ( strpos( $_link, 'prev page-numbers' ) && ! empty( $args['custom_prev_text'] ) ) {
85
-							$custom_prev_link = str_replace( $args['prev_text'], $args['custom_prev_text'], $link );
86
-						}
87
-					}
88
-				}
89
-			}
90
-			$links_html .= "</ul>";
91
-
92
-			if ( $links ) {
93
-				$output .= '<section class="px-0 py-2 w-100">';
94
-				$output .= _navigation_markup( $links_html, 'aui-pagination', $args['screen_reader_text'] );
95
-				$output .= '</section>';
96
-			}
97
-
98
-			$output = str_replace( "screen-reader-text", "screen-reader-text sr-only", $output );
99
-			$output = str_replace( "nav-links", "aui-nav-links", $output );
100
-		}
101
-
102
-		if ( $output ) {
103
-			if ( $custom_next_link || $custom_prev_link ) {
104
-				$total   = isset( $wp_query->max_num_pages ) ? $wp_query->max_num_pages : 1;
105
-				$current = get_query_var( 'paged' ) ? (int) get_query_var( 'paged' ) : 1;
106
-
107
-				$output = '<div class="row d-flex align-items-center justify-content-between"><div class="col text-start">' . $custom_prev_link . '</div><div class="col text-center d-none d-md-block">' . $output . '</div><div class="col text-center d-md-none">' . $current . '/' . $args['total'] . '</div><div class="col text-end">' . $custom_next_link . '</div></div>';
108
-			}
109
-
110
-			if ( ! empty( $args['before_paging'] ) ) {
111
-				$output = $args['before_paging'] . $output;
112
-			}
113
-
114
-			if ( ! empty( $args['after_paging'] ) ) {
115
-				$output = $output . $args['after_paging'];
116
-			}
117
-		}
118
-
119
-		return $output;
120
-	}
14
+    /**
15
+     * Build the component.
16
+     *
17
+     * @param array $args
18
+     *
19
+     * @return string The rendered component.
20
+     */
21
+    public static function get( $args = array() ) {
22
+        global $wp_query, $aui_bs5;
23
+
24
+        $defaults = array(
25
+            'class'              => '',
26
+            'mid_size'           => 2,
27
+            'prev_text'          => '<i class="fas fa-chevron-left"></i>',
28
+            'next_text'          => '<i class="fas fa-chevron-right"></i>',
29
+            'screen_reader_text' => __( 'Posts navigation', 'ayecode-connect' ),
30
+            'before_paging'      => '',
31
+            'after_paging'       => '',
32
+            'type'               => 'array',
33
+            'total'              => isset( $wp_query->max_num_pages ) ? $wp_query->max_num_pages : 1,
34
+            'links'              => array(), // an array of links if using custom links, this includes the a tag.
35
+            'rounded_style'      => false,
36
+            'custom_next_text'   => '', // Custom next page text
37
+            'custom_prev_text'   => '', // Custom prev page text
38
+        );
39
+
40
+        /**
41
+         * Parse incoming $args into an array and merge it with $defaults
42
+         */
43
+        $args = wp_parse_args( $args, $defaults );
44
+
45
+        $output = '';
46
+
47
+        // Don't print empty markup if there's only one page.
48
+        if ( $args['total'] > 1 ) {
49
+            // Set up paginated links.
50
+            $links = !empty(  $args['links'] ) ? $args['links'] :  paginate_links( $args );
51
+
52
+            $class = !empty($args['class']) ? $args['class'] : '';
53
+
54
+            $custom_prev_link = '';
55
+            $custom_next_link = '';
56
+
57
+            // make the output bootstrap ready
58
+            $links_html = "<ul class='pagination m-0 p-0 $class'>";
59
+            if ( ! empty( $links ) ) {
60
+                foreach ( $links as $link ) {
61
+                    $_link = $link;
62
+
63
+                    if ( $aui_bs5 ) {
64
+                        $link_class = $args['rounded_style'] ? 'page-link badge rounded-pill border-0 mx-1 fs-base text-dark link-primary' : 'page-link';
65
+                        $link_class_active = $args['rounded_style'] ? ' current active fw-bold badge rounded-pill' : ' current active';
66
+                        $links_html .= "<li class='page-item mx-0'>";
67
+                        $link = str_replace( array( "page-numbers", " current" ), array( $link_class, $link_class_active ), $link );
68
+                        $link = str_replace( 'text-dark link-primary current', 'current', $link );
69
+                        $links_html .=  $link;
70
+                        $links_html .= "</li>";
71
+                    } else {
72
+                        $active = strpos( $link, 'current' ) !== false ? 'active' : '';
73
+                        $links_html .= "<li class='page-item $active'>";
74
+                        $links_html .= str_replace( "page-numbers", "page-link", $link );
75
+                        $links_html .= "</li>";
76
+                    }
77
+
78
+                    if ( strpos( $_link, 'next page-numbers' ) || strpos( $_link, 'prev page-numbers' ) ) {
79
+                        $link = str_replace( array( "page-numbers", " current" ), array( 'btn btn-outline-primary rounded' . ( $args['rounded_style'] ? '-pill' : '' ) . ' mx-1 fs-base text-dark link-primary', ' current active fw-bold badge rounded-pill' ), $_link );
80
+                        $link = str_replace( 'text-dark link-primary current', 'current', $link );
81
+
82
+                        if ( strpos( $_link, 'next page-numbers' ) && ! empty( $args['custom_next_text'] ) ) {
83
+                            $custom_next_link = str_replace( $args['next_text'], $args['custom_next_text'], $link );
84
+                        } else if ( strpos( $_link, 'prev page-numbers' ) && ! empty( $args['custom_prev_text'] ) ) {
85
+                            $custom_prev_link = str_replace( $args['prev_text'], $args['custom_prev_text'], $link );
86
+                        }
87
+                    }
88
+                }
89
+            }
90
+            $links_html .= "</ul>";
91
+
92
+            if ( $links ) {
93
+                $output .= '<section class="px-0 py-2 w-100">';
94
+                $output .= _navigation_markup( $links_html, 'aui-pagination', $args['screen_reader_text'] );
95
+                $output .= '</section>';
96
+            }
97
+
98
+            $output = str_replace( "screen-reader-text", "screen-reader-text sr-only", $output );
99
+            $output = str_replace( "nav-links", "aui-nav-links", $output );
100
+        }
101
+
102
+        if ( $output ) {
103
+            if ( $custom_next_link || $custom_prev_link ) {
104
+                $total   = isset( $wp_query->max_num_pages ) ? $wp_query->max_num_pages : 1;
105
+                $current = get_query_var( 'paged' ) ? (int) get_query_var( 'paged' ) : 1;
106
+
107
+                $output = '<div class="row d-flex align-items-center justify-content-between"><div class="col text-start">' . $custom_prev_link . '</div><div class="col text-center d-none d-md-block">' . $output . '</div><div class="col text-center d-md-none">' . $current . '/' . $args['total'] . '</div><div class="col text-end">' . $custom_next_link . '</div></div>';
108
+            }
109
+
110
+            if ( ! empty( $args['before_paging'] ) ) {
111
+                $output = $args['before_paging'] . $output;
112
+            }
113
+
114
+            if ( ! empty( $args['after_paging'] ) ) {
115
+                $output = $output . $args['after_paging'];
116
+            }
117
+        }
118
+
119
+        return $output;
120
+    }
121 121
 
122 122
 }
123 123
\ No newline at end of file
Please login to merge, or discard this patch.
Spacing   +32 added lines, -32 removed lines patch added patch discarded remove patch
@@ -1,6 +1,6 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3
-if ( ! defined( 'ABSPATH' ) ) {
3
+if (!defined('ABSPATH')) {
4 4
 	exit; // Exit if accessed directly
5 5
 }
6 6
 
@@ -18,7 +18,7 @@  discard block
 block discarded – undo
18 18
 	 *
19 19
 	 * @return string The rendered component.
20 20
 	 */
21
-	public static function get( $args = array() ) {
21
+	public static function get($args = array()) {
22 22
 		global $wp_query, $aui_bs5;
23 23
 
24 24
 		$defaults = array(
@@ -26,11 +26,11 @@  discard block
 block discarded – undo
26 26
 			'mid_size'           => 2,
27 27
 			'prev_text'          => '<i class="fas fa-chevron-left"></i>',
28 28
 			'next_text'          => '<i class="fas fa-chevron-right"></i>',
29
-			'screen_reader_text' => __( 'Posts navigation', 'ayecode-connect' ),
29
+			'screen_reader_text' => __('Posts navigation', 'ayecode-connect'),
30 30
 			'before_paging'      => '',
31 31
 			'after_paging'       => '',
32 32
 			'type'               => 'array',
33
-			'total'              => isset( $wp_query->max_num_pages ) ? $wp_query->max_num_pages : 1,
33
+			'total'              => isset($wp_query->max_num_pages) ? $wp_query->max_num_pages : 1,
34 34
 			'links'              => array(), // an array of links if using custom links, this includes the a tag.
35 35
 			'rounded_style'      => false,
36 36
 			'custom_next_text'   => '', // Custom next page text
@@ -40,14 +40,14 @@  discard block
 block discarded – undo
40 40
 		/**
41 41
 		 * Parse incoming $args into an array and merge it with $defaults
42 42
 		 */
43
-		$args = wp_parse_args( $args, $defaults );
43
+		$args = wp_parse_args($args, $defaults);
44 44
 
45 45
 		$output = '';
46 46
 
47 47
 		// Don't print empty markup if there's only one page.
48
-		if ( $args['total'] > 1 ) {
48
+		if ($args['total'] > 1) {
49 49
 			// Set up paginated links.
50
-			$links = !empty(  $args['links'] ) ? $args['links'] :  paginate_links( $args );
50
+			$links = !empty($args['links']) ? $args['links'] : paginate_links($args);
51 51
 
52 52
 			$class = !empty($args['class']) ? $args['class'] : '';
53 53
 
@@ -56,62 +56,62 @@  discard block
 block discarded – undo
56 56
 
57 57
 			// make the output bootstrap ready
58 58
 			$links_html = "<ul class='pagination m-0 p-0 $class'>";
59
-			if ( ! empty( $links ) ) {
60
-				foreach ( $links as $link ) {
59
+			if (!empty($links)) {
60
+				foreach ($links as $link) {
61 61
 					$_link = $link;
62 62
 
63
-					if ( $aui_bs5 ) {
63
+					if ($aui_bs5) {
64 64
 						$link_class = $args['rounded_style'] ? 'page-link badge rounded-pill border-0 mx-1 fs-base text-dark link-primary' : 'page-link';
65 65
 						$link_class_active = $args['rounded_style'] ? ' current active fw-bold badge rounded-pill' : ' current active';
66 66
 						$links_html .= "<li class='page-item mx-0'>";
67
-						$link = str_replace( array( "page-numbers", " current" ), array( $link_class, $link_class_active ), $link );
68
-						$link = str_replace( 'text-dark link-primary current', 'current', $link );
69
-						$links_html .=  $link;
67
+						$link = str_replace(array("page-numbers", " current"), array($link_class, $link_class_active), $link);
68
+						$link = str_replace('text-dark link-primary current', 'current', $link);
69
+						$links_html .= $link;
70 70
 						$links_html .= "</li>";
71 71
 					} else {
72
-						$active = strpos( $link, 'current' ) !== false ? 'active' : '';
72
+						$active = strpos($link, 'current') !== false ? 'active' : '';
73 73
 						$links_html .= "<li class='page-item $active'>";
74
-						$links_html .= str_replace( "page-numbers", "page-link", $link );
74
+						$links_html .= str_replace("page-numbers", "page-link", $link);
75 75
 						$links_html .= "</li>";
76 76
 					}
77 77
 
78
-					if ( strpos( $_link, 'next page-numbers' ) || strpos( $_link, 'prev page-numbers' ) ) {
79
-						$link = str_replace( array( "page-numbers", " current" ), array( 'btn btn-outline-primary rounded' . ( $args['rounded_style'] ? '-pill' : '' ) . ' mx-1 fs-base text-dark link-primary', ' current active fw-bold badge rounded-pill' ), $_link );
80
-						$link = str_replace( 'text-dark link-primary current', 'current', $link );
78
+					if (strpos($_link, 'next page-numbers') || strpos($_link, 'prev page-numbers')) {
79
+						$link = str_replace(array("page-numbers", " current"), array('btn btn-outline-primary rounded' . ($args['rounded_style'] ? '-pill' : '') . ' mx-1 fs-base text-dark link-primary', ' current active fw-bold badge rounded-pill'), $_link);
80
+						$link = str_replace('text-dark link-primary current', 'current', $link);
81 81
 
82
-						if ( strpos( $_link, 'next page-numbers' ) && ! empty( $args['custom_next_text'] ) ) {
83
-							$custom_next_link = str_replace( $args['next_text'], $args['custom_next_text'], $link );
84
-						} else if ( strpos( $_link, 'prev page-numbers' ) && ! empty( $args['custom_prev_text'] ) ) {
85
-							$custom_prev_link = str_replace( $args['prev_text'], $args['custom_prev_text'], $link );
82
+						if (strpos($_link, 'next page-numbers') && !empty($args['custom_next_text'])) {
83
+							$custom_next_link = str_replace($args['next_text'], $args['custom_next_text'], $link);
84
+						} else if (strpos($_link, 'prev page-numbers') && !empty($args['custom_prev_text'])) {
85
+							$custom_prev_link = str_replace($args['prev_text'], $args['custom_prev_text'], $link);
86 86
 						}
87 87
 					}
88 88
 				}
89 89
 			}
90 90
 			$links_html .= "</ul>";
91 91
 
92
-			if ( $links ) {
92
+			if ($links) {
93 93
 				$output .= '<section class="px-0 py-2 w-100">';
94
-				$output .= _navigation_markup( $links_html, 'aui-pagination', $args['screen_reader_text'] );
94
+				$output .= _navigation_markup($links_html, 'aui-pagination', $args['screen_reader_text']);
95 95
 				$output .= '</section>';
96 96
 			}
97 97
 
98
-			$output = str_replace( "screen-reader-text", "screen-reader-text sr-only", $output );
99
-			$output = str_replace( "nav-links", "aui-nav-links", $output );
98
+			$output = str_replace("screen-reader-text", "screen-reader-text sr-only", $output);
99
+			$output = str_replace("nav-links", "aui-nav-links", $output);
100 100
 		}
101 101
 
102
-		if ( $output ) {
103
-			if ( $custom_next_link || $custom_prev_link ) {
104
-				$total   = isset( $wp_query->max_num_pages ) ? $wp_query->max_num_pages : 1;
105
-				$current = get_query_var( 'paged' ) ? (int) get_query_var( 'paged' ) : 1;
102
+		if ($output) {
103
+			if ($custom_next_link || $custom_prev_link) {
104
+				$total   = isset($wp_query->max_num_pages) ? $wp_query->max_num_pages : 1;
105
+				$current = get_query_var('paged') ? (int) get_query_var('paged') : 1;
106 106
 
107 107
 				$output = '<div class="row d-flex align-items-center justify-content-between"><div class="col text-start">' . $custom_prev_link . '</div><div class="col text-center d-none d-md-block">' . $output . '</div><div class="col text-center d-md-none">' . $current . '/' . $args['total'] . '</div><div class="col text-end">' . $custom_next_link . '</div></div>';
108 108
 			}
109 109
 
110
-			if ( ! empty( $args['before_paging'] ) ) {
110
+			if (!empty($args['before_paging'])) {
111 111
 				$output = $args['before_paging'] . $output;
112 112
 			}
113 113
 
114
-			if ( ! empty( $args['after_paging'] ) ) {
114
+			if (!empty($args['after_paging'])) {
115 115
 				$output = $output . $args['after_paging'];
116 116
 			}
117 117
 		}
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/inc/bs5-js.php 2 patches
Indentation   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -1001,8 +1001,8 @@
 block discarded – undo
1001 1001
     aui_flip_color_scheme_on_scroll();
1002 1002
 
1003 1003
 	<?php
1004
-	// FSE tweaks.
1005
-	if(!empty($_REQUEST['postType'])){ ?>
1004
+    // FSE tweaks.
1005
+    if(!empty($_REQUEST['postType'])){ ?>
1006 1006
     function aui_fse_set_data_scroll() {
1007 1007
         console.log('init scroll');
1008 1008
         let Iframe = document.getElementsByClassName("edit-site-visual-editor__editor-canvas");
Please login to merge, or discard this patch.
Spacing   +2 added lines, -2 removed lines patch added patch discarded remove patch
@@ -252,7 +252,7 @@  discard block
 block discarded – undo
252 252
     function aui_init_flatpickr(){
253 253
         if ( typeof jQuery.fn.flatpickr === "function" && !$aui_doing_init_flatpickr) {
254 254
             $aui_doing_init_flatpickr = true;
255
-			<?php if ( ! empty( $flatpickr_locale ) ) { ?>try{flatpickr.localize(<?php echo $flatpickr_locale; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>);}catch(err){console.log(err.message);}<?php } ?>
255
+			<?php if (!empty($flatpickr_locale)) { ?>try{flatpickr.localize(<?php echo $flatpickr_locale; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>);}catch(err){console.log(err.message);}<?php } ?>
256 256
             jQuery('input[data-aui-init="flatpickr"]:not(.flatpickr-input)').flatpickr();
257 257
         }
258 258
         $aui_doing_init_flatpickr = false;
@@ -1013,7 +1013,7 @@  discard block
 block discarded – undo
1013 1013
 
1014 1014
 	<?php
1015 1015
 	// FSE tweaks.
1016
-	if(!empty($_REQUEST['postType'])){ ?>
1016
+	if (!empty($_REQUEST['postType'])) { ?>
1017 1017
     function aui_fse_set_data_scroll() {
1018 1018
         console.log('init scroll');
1019 1019
         let Iframe = document.getElementsByClassName("edit-site-visual-editor__editor-canvas");
Please login to merge, or discard this patch.
vendor/ayecode/ayecode-connect-helper/ayecode-connect-helper.php 2 patches
Indentation   +302 added lines, -302 removed lines patch added patch discarded remove patch
@@ -1,264 +1,264 @@  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( "AyeCode_Connect_Helper" ) ) {
7
-	/**
8
-	 * Allow the quick setup and connection of our AyeCode Connect plugin.
9
-	 *
10
-	 * Class AyeCode_Connect_Helper
11
-	 */
12
-	class AyeCode_Connect_Helper {
13
-
14
-		// Hold the version number
15
-		var $version = "1.0.4";
16
-
17
-		// Hold the default strings.
18
-		var $strings = array();
19
-
20
-		// Hold the default pages.
21
-		var $pages = array();
22
-
23
-		/**
24
-		 * The constructor.
25
-		 *
26
-		 * AyeCode_Connect_Helper constructor.
27
-		 *
28
-		 * @param array $strings
29
-		 * @param array $pages
30
-		 */
31
-		public function __construct( $strings = array(), $pages = array() ) {
32
-			// Only fire if not localhost and the current user has the right permissions.
33
-			if ( ! $this->is_localhost() && current_user_can( 'manage_options' ) ) {
34
-				// set default strings
35
-				$default_strings = array(
36
-					'connect_title'     => __( "Thanks for choosing an AyeCode Product!", 'ayecode-connect' ),
37
-					'connect_external'  => __( "Please confirm you wish to connect your site?", 'ayecode-connect' ),
38
-					'connect'           => wp_sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s", 'ayecode-connect' ), "<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>", "</a>" ),
39
-					'connect_button'    => __( "Connect Site", 'ayecode-connect' ),
40
-					'connecting_button' => __( "Connecting...", 'ayecode-connect' ),
41
-					'error_localhost'   => __( "This service will only work with a live domain, not a localhost.", 'ayecode-connect' ),
42
-					'error'             => __( "Something went wrong, please refresh and try again.", 'ayecode-connect' ),
43
-				);
44
-				$this->strings   = array_merge( $default_strings, $strings );
45
-
46
-				// set default pages
47
-				$default_pages = array();
48
-				$this->pages   = array_merge( $default_pages, $pages );
49
-
50
-				// maybe show connect site notice
51
-				add_action( 'admin_notices', array( $this, 'ayecode_connect_install_notice' ) );
52
-
53
-				// add ajax action if not already added
54
-				if ( ! has_action( 'wp_ajax_ayecode_connect_helper' ) ) {
55
-					add_action( 'wp_ajax_ayecode_connect_helper', array( $this, 'ayecode_connect_install' ) );
56
-				}
57
-			}
58
-
59
-			// add ajax action if not already added
60
-			if ( ! has_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed' ) ) {
61
-				add_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed', array( $this, 'ayecode_connect_helper_installed' ) );
62
-			}
63
-		}
64
-
65
-		/**
66
-		 * Give a way to check we can connect via a external redirect.
67
-		 */
68
-		public function ayecode_connect_helper_installed(){
69
-			$active = array(
70
-				'gd'    =>  defined('GEODIRECTORY_VERSION') && version_compare(GEODIRECTORY_VERSION,'2.0.0.79','>') ? 1 : 0,
71
-				'uwp'    =>  defined('USERSWP_VERSION') && version_compare(USERSWP_VERSION,'1.2.1.5','>') ? 1 : 0,
72
-				'wpi'    =>  defined('WPINV_VERSION') && version_compare(WPINV_VERSION,'1.0.14','>') ? 1 : 0,
73
-			);
74
-			wp_send_json_success( $active );
75
-			wp_die();
76
-		}
77
-
78
-		/**
79
-		 * Get slug from path
80
-		 *
81
-		 * @param  string $key
82
-		 *
83
-		 * @return string
84
-		 */
85
-		private function format_plugin_slug( $key ) {
86
-			$slug = explode( '/', $key );
87
-			$slug = explode( '.', end( $slug ) );
88
-
89
-			return $slug[0];
90
-		}
91
-
92
-		/**
93
-		 * Install and activate the AyeCode Connect Plugin
94
-		 */
95
-		public function ayecode_connect_install() {
96
-			// bail if localhost
97
-			if ( $this->is_localhost() ) {
98
-				wp_send_json_error( $this->strings['error_localhost'] );
99
-			}
100
-
101
-			// Explicitly clear the event.
102
-			wp_clear_scheduled_hook( 'geodir_plugin_background_installer', func_get_args() );
103
-
104
-			$success     = true;
105
-			$plugin_slug = "ayecode-connect";
106
-			if ( ! empty( $plugin_slug ) ) {
107
-				require_once( ABSPATH . 'wp-admin/includes/file.php' );
108
-				require_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );
109
-				require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
110
-				require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
111
-
112
-				WP_Filesystem();
113
-
114
-				$skin              = new Automatic_Upgrader_Skin;
115
-				$upgrader          = new WP_Upgrader( $skin );
116
-				$installed_plugins = array_map( array( $this, 'format_plugin_slug' ), array_keys( get_plugins() ) );
117
-				$plugin_slug       = $plugin_slug;
118
-				$plugin            = $plugin_slug . '/' . $plugin_slug . '.php';
119
-				$installed         = false;
120
-				$activate          = false;
121
-
122
-				// See if the plugin is installed already
123
-				if ( in_array( $plugin_slug, $installed_plugins ) ) {
124
-					$installed = true;
125
-					$activate  = ! is_plugin_active( $plugin );
126
-				}
127
-
128
-				// Install this thing!
129
-				if ( ! $installed ) {
130
-
131
-					// Suppress feedback
132
-					ob_start();
133
-
134
-					try {
135
-						$plugin_information = plugins_api( 'plugin_information', array(
136
-							'slug'   => $plugin_slug,
137
-							'fields' => array(
138
-								'short_description' => false,
139
-								'sections'          => false,
140
-								'requires'          => false,
141
-								'rating'            => false,
142
-								'ratings'           => false,
143
-								'downloaded'        => false,
144
-								'last_updated'      => false,
145
-								'added'             => false,
146
-								'tags'              => false,
147
-								'homepage'          => false,
148
-								'donate_link'       => false,
149
-								'author_profile'    => false,
150
-								'author'            => false,
151
-							),
152
-						) );
153
-
154
-						if ( is_wp_error( $plugin_information ) ) {
155
-							throw new Exception( $plugin_information->get_error_message() );
156
-						}
157
-
158
-						$package  = $plugin_information->download_link;
159
-						$download = $upgrader->download_package( $package );
160
-
161
-						if ( is_wp_error( $download ) ) {
162
-							throw new Exception( $download->get_error_message() );
163
-						}
164
-
165
-						$working_dir = $upgrader->unpack_package( $download, true );
166
-
167
-						if ( is_wp_error( $working_dir ) ) {
168
-							throw new Exception( $working_dir->get_error_message() );
169
-						}
170
-
171
-						$result = $upgrader->install_package( array(
172
-							'source'                      => $working_dir,
173
-							'destination'                 => WP_PLUGIN_DIR,
174
-							'clear_destination'           => false,
175
-							'abort_if_destination_exists' => false,
176
-							'clear_working'               => true,
177
-							'hook_extra'                  => array(
178
-								'type'   => 'plugin',
179
-								'action' => 'install',
180
-							),
181
-						) );
182
-
183
-						if ( is_wp_error( $result ) ) {
184
-							throw new Exception( $result->get_error_message() );
185
-						}
186
-
187
-						$activate = true;
188
-
189
-					} catch ( Exception $e ) {
190
-						$success = false;
191
-					}
192
-
193
-					// Discard feedback
194
-					ob_end_clean();
195
-				}
196
-
197
-				wp_clean_plugins_cache();
198
-
199
-				// Activate this thing
200
-				if ( $activate ) {
201
-					try {
202
-						$result = activate_plugin( $plugin );
203
-
204
-						if ( is_wp_error( $result ) ) {
205
-							$success = false;
206
-						} else {
207
-							$success = true;
208
-						}
209
-					} catch ( Exception $e ) {
210
-						$success = false;
211
-					}
212
-				}
213
-			}
214
-
215
-			if ( $success && function_exists( 'ayecode_connect_args' ) ) {
216
-				ayecode_connect();// init
217
-				$args        = ayecode_connect_args();
218
-				$client      = new AyeCode_Connect( $args );
219
-				$redirect_to = ! empty( $_POST['redirect_to'] ) ? esc_url_raw( $_POST['redirect_to'] ) : '';
220
-				$redirect    = $client->build_connect_url( $redirect_to );
221
-				wp_send_json_success( array( 'connect_url' => $redirect ) );
222
-			} else {
223
-				wp_send_json_error( $this->strings['error_localhost'] );
224
-			}
225
-			wp_die();
226
-		}
227
-
228
-		/**
229
-		 * Check if maybe localhost.
230
-		 *
231
-		 * @return bool
232
-		 */
233
-		public function is_localhost() {
234
-			$localhost = false;
235
-
236
-			$host              = isset( $_SERVER['HTTP_HOST'] ) ? $_SERVER['HTTP_HOST'] : '';
237
-			$localhost_domains = array(
238
-				'localhost',
239
-				'localhost.localdomain',
240
-				'127.0.0.1',
241
-				'::1'
242
-			);
243
-
244
-			if ( in_array( $host, $localhost_domains ) ) {
245
-				$localhost = true;
246
-			}
247
-
248
-			return $localhost;
249
-		}
250
-
251
-		/**
252
-		 * Show notice to connect site.
253
-		 */
254
-		public function ayecode_connect_install_notice() {
255
-			if ( $this->maybe_show() ) {
256
-				$connect_title_string     = $this->strings['connect_title'];
257
-				$connect_external_string  = $this->strings['connect_external'];
258
-				$connect_string           = $this->strings['connect'];
259
-				$connect_button_string    = $this->strings['connect_button'];
260
-				$connecting_button_string = $this->strings['connecting_button'];
261
-				?>
7
+    /**
8
+     * Allow the quick setup and connection of our AyeCode Connect plugin.
9
+     *
10
+     * Class AyeCode_Connect_Helper
11
+     */
12
+    class AyeCode_Connect_Helper {
13
+
14
+        // Hold the version number
15
+        var $version = "1.0.4";
16
+
17
+        // Hold the default strings.
18
+        var $strings = array();
19
+
20
+        // Hold the default pages.
21
+        var $pages = array();
22
+
23
+        /**
24
+         * The constructor.
25
+         *
26
+         * AyeCode_Connect_Helper constructor.
27
+         *
28
+         * @param array $strings
29
+         * @param array $pages
30
+         */
31
+        public function __construct( $strings = array(), $pages = array() ) {
32
+            // Only fire if not localhost and the current user has the right permissions.
33
+            if ( ! $this->is_localhost() && current_user_can( 'manage_options' ) ) {
34
+                // set default strings
35
+                $default_strings = array(
36
+                    'connect_title'     => __( "Thanks for choosing an AyeCode Product!", 'ayecode-connect' ),
37
+                    'connect_external'  => __( "Please confirm you wish to connect your site?", 'ayecode-connect' ),
38
+                    'connect'           => wp_sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s", 'ayecode-connect' ), "<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>", "</a>" ),
39
+                    'connect_button'    => __( "Connect Site", 'ayecode-connect' ),
40
+                    'connecting_button' => __( "Connecting...", 'ayecode-connect' ),
41
+                    'error_localhost'   => __( "This service will only work with a live domain, not a localhost.", 'ayecode-connect' ),
42
+                    'error'             => __( "Something went wrong, please refresh and try again.", 'ayecode-connect' ),
43
+                );
44
+                $this->strings   = array_merge( $default_strings, $strings );
45
+
46
+                // set default pages
47
+                $default_pages = array();
48
+                $this->pages   = array_merge( $default_pages, $pages );
49
+
50
+                // maybe show connect site notice
51
+                add_action( 'admin_notices', array( $this, 'ayecode_connect_install_notice' ) );
52
+
53
+                // add ajax action if not already added
54
+                if ( ! has_action( 'wp_ajax_ayecode_connect_helper' ) ) {
55
+                    add_action( 'wp_ajax_ayecode_connect_helper', array( $this, 'ayecode_connect_install' ) );
56
+                }
57
+            }
58
+
59
+            // add ajax action if not already added
60
+            if ( ! has_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed' ) ) {
61
+                add_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed', array( $this, 'ayecode_connect_helper_installed' ) );
62
+            }
63
+        }
64
+
65
+        /**
66
+         * Give a way to check we can connect via a external redirect.
67
+         */
68
+        public function ayecode_connect_helper_installed(){
69
+            $active = array(
70
+                'gd'    =>  defined('GEODIRECTORY_VERSION') && version_compare(GEODIRECTORY_VERSION,'2.0.0.79','>') ? 1 : 0,
71
+                'uwp'    =>  defined('USERSWP_VERSION') && version_compare(USERSWP_VERSION,'1.2.1.5','>') ? 1 : 0,
72
+                'wpi'    =>  defined('WPINV_VERSION') && version_compare(WPINV_VERSION,'1.0.14','>') ? 1 : 0,
73
+            );
74
+            wp_send_json_success( $active );
75
+            wp_die();
76
+        }
77
+
78
+        /**
79
+         * Get slug from path
80
+         *
81
+         * @param  string $key
82
+         *
83
+         * @return string
84
+         */
85
+        private function format_plugin_slug( $key ) {
86
+            $slug = explode( '/', $key );
87
+            $slug = explode( '.', end( $slug ) );
88
+
89
+            return $slug[0];
90
+        }
91
+
92
+        /**
93
+         * Install and activate the AyeCode Connect Plugin
94
+         */
95
+        public function ayecode_connect_install() {
96
+            // bail if localhost
97
+            if ( $this->is_localhost() ) {
98
+                wp_send_json_error( $this->strings['error_localhost'] );
99
+            }
100
+
101
+            // Explicitly clear the event.
102
+            wp_clear_scheduled_hook( 'geodir_plugin_background_installer', func_get_args() );
103
+
104
+            $success     = true;
105
+            $plugin_slug = "ayecode-connect";
106
+            if ( ! empty( $plugin_slug ) ) {
107
+                require_once( ABSPATH . 'wp-admin/includes/file.php' );
108
+                require_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );
109
+                require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
110
+                require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
111
+
112
+                WP_Filesystem();
113
+
114
+                $skin              = new Automatic_Upgrader_Skin;
115
+                $upgrader          = new WP_Upgrader( $skin );
116
+                $installed_plugins = array_map( array( $this, 'format_plugin_slug' ), array_keys( get_plugins() ) );
117
+                $plugin_slug       = $plugin_slug;
118
+                $plugin            = $plugin_slug . '/' . $plugin_slug . '.php';
119
+                $installed         = false;
120
+                $activate          = false;
121
+
122
+                // See if the plugin is installed already
123
+                if ( in_array( $plugin_slug, $installed_plugins ) ) {
124
+                    $installed = true;
125
+                    $activate  = ! is_plugin_active( $plugin );
126
+                }
127
+
128
+                // Install this thing!
129
+                if ( ! $installed ) {
130
+
131
+                    // Suppress feedback
132
+                    ob_start();
133
+
134
+                    try {
135
+                        $plugin_information = plugins_api( 'plugin_information', array(
136
+                            'slug'   => $plugin_slug,
137
+                            'fields' => array(
138
+                                'short_description' => false,
139
+                                'sections'          => false,
140
+                                'requires'          => false,
141
+                                'rating'            => false,
142
+                                'ratings'           => false,
143
+                                'downloaded'        => false,
144
+                                'last_updated'      => false,
145
+                                'added'             => false,
146
+                                'tags'              => false,
147
+                                'homepage'          => false,
148
+                                'donate_link'       => false,
149
+                                'author_profile'    => false,
150
+                                'author'            => false,
151
+                            ),
152
+                        ) );
153
+
154
+                        if ( is_wp_error( $plugin_information ) ) {
155
+                            throw new Exception( $plugin_information->get_error_message() );
156
+                        }
157
+
158
+                        $package  = $plugin_information->download_link;
159
+                        $download = $upgrader->download_package( $package );
160
+
161
+                        if ( is_wp_error( $download ) ) {
162
+                            throw new Exception( $download->get_error_message() );
163
+                        }
164
+
165
+                        $working_dir = $upgrader->unpack_package( $download, true );
166
+
167
+                        if ( is_wp_error( $working_dir ) ) {
168
+                            throw new Exception( $working_dir->get_error_message() );
169
+                        }
170
+
171
+                        $result = $upgrader->install_package( array(
172
+                            'source'                      => $working_dir,
173
+                            'destination'                 => WP_PLUGIN_DIR,
174
+                            'clear_destination'           => false,
175
+                            'abort_if_destination_exists' => false,
176
+                            'clear_working'               => true,
177
+                            'hook_extra'                  => array(
178
+                                'type'   => 'plugin',
179
+                                'action' => 'install',
180
+                            ),
181
+                        ) );
182
+
183
+                        if ( is_wp_error( $result ) ) {
184
+                            throw new Exception( $result->get_error_message() );
185
+                        }
186
+
187
+                        $activate = true;
188
+
189
+                    } catch ( Exception $e ) {
190
+                        $success = false;
191
+                    }
192
+
193
+                    // Discard feedback
194
+                    ob_end_clean();
195
+                }
196
+
197
+                wp_clean_plugins_cache();
198
+
199
+                // Activate this thing
200
+                if ( $activate ) {
201
+                    try {
202
+                        $result = activate_plugin( $plugin );
203
+
204
+                        if ( is_wp_error( $result ) ) {
205
+                            $success = false;
206
+                        } else {
207
+                            $success = true;
208
+                        }
209
+                    } catch ( Exception $e ) {
210
+                        $success = false;
211
+                    }
212
+                }
213
+            }
214
+
215
+            if ( $success && function_exists( 'ayecode_connect_args' ) ) {
216
+                ayecode_connect();// init
217
+                $args        = ayecode_connect_args();
218
+                $client      = new AyeCode_Connect( $args );
219
+                $redirect_to = ! empty( $_POST['redirect_to'] ) ? esc_url_raw( $_POST['redirect_to'] ) : '';
220
+                $redirect    = $client->build_connect_url( $redirect_to );
221
+                wp_send_json_success( array( 'connect_url' => $redirect ) );
222
+            } else {
223
+                wp_send_json_error( $this->strings['error_localhost'] );
224
+            }
225
+            wp_die();
226
+        }
227
+
228
+        /**
229
+         * Check if maybe localhost.
230
+         *
231
+         * @return bool
232
+         */
233
+        public function is_localhost() {
234
+            $localhost = false;
235
+
236
+            $host              = isset( $_SERVER['HTTP_HOST'] ) ? $_SERVER['HTTP_HOST'] : '';
237
+            $localhost_domains = array(
238
+                'localhost',
239
+                'localhost.localdomain',
240
+                '127.0.0.1',
241
+                '::1'
242
+            );
243
+
244
+            if ( in_array( $host, $localhost_domains ) ) {
245
+                $localhost = true;
246
+            }
247
+
248
+            return $localhost;
249
+        }
250
+
251
+        /**
252
+         * Show notice to connect site.
253
+         */
254
+        public function ayecode_connect_install_notice() {
255
+            if ( $this->maybe_show() ) {
256
+                $connect_title_string     = $this->strings['connect_title'];
257
+                $connect_external_string  = $this->strings['connect_external'];
258
+                $connect_string           = $this->strings['connect'];
259
+                $connect_button_string    = $this->strings['connect_button'];
260
+                $connecting_button_string = $this->strings['connecting_button'];
261
+                ?>
262 262
 				<div class="notice notice-info acch-notice">
263 263
 					<span class="acch-float-left">
264 264
 						<svg width="61px" height="61px" viewBox="0 0 61 61" version="1.1"
@@ -305,9 +305,9 @@  discard block
 block discarded – undo
305 305
 				</div>
306 306
 
307 307
 				<?php
308
-				// only include the popup HTML if needed.
309
-				if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
310
-					?>
308
+                // only include the popup HTML if needed.
309
+                if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
310
+                    ?>
311 311
 					<div id="ayecode-connect-helper-external-confirm" style="display:none;">
312 312
 						<div class="noticex notice-info acch-notice" style="border: none;">
313 313
 					<span class="acch-float-left">
@@ -353,23 +353,23 @@  discard block
 block discarded – undo
353 353
 						</div>
354 354
 					</div>
355 355
 					<?php
356
-				}
357
-
358
-				// add required scripts
359
-				$this->script();
360
-			}
361
-		}
362
-
363
-		/**
364
-		 * Get the JS Script.
365
-		 */
366
-		public function script() {
367
-
368
-			// add thickbox if external request is requested
369
-			if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
370
-				add_thickbox();
371
-			}
372
-			?>
356
+                }
357
+
358
+                // add required scripts
359
+                $this->script();
360
+            }
361
+        }
362
+
363
+        /**
364
+         * Get the JS Script.
365
+         */
366
+        public function script() {
367
+
368
+            // add thickbox if external request is requested
369
+            if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
370
+                add_thickbox();
371
+            }
372
+            ?>
373 373
 			<style>
374 374
 				.acch-title {
375 375
 					margin: 0;
@@ -435,38 +435,38 @@  discard block
 block discarded – undo
435 435
 					});
436 436
 				} 
437 437
 				<?php
438
-				// add thickbox if external request is requested
439
-				if(! empty( $_REQUEST['external-connect-request'] )) {
440
-				?>
438
+                // add thickbox if external request is requested
439
+                if(! empty( $_REQUEST['external-connect-request'] )) {
440
+                ?>
441 441
 				jQuery(function () {
442 442
 					setTimeout(function () {
443 443
 						tb_show("AyeCode Connect", "?TB_inline?width=300&height=80&inlineId=ayecode-connect-helper-external-confirm");
444 444
 					}, 200);
445 445
 				});
446 446
 				<?php
447
-				}
448
-				?>
447
+                }
448
+                ?>
449 449
 			</script>
450 450
 			<?php
451
-		}
452
-
453
-		/**
454
-		 * Decide what pages to show on.
455
-		 *
456
-		 * @return bool
457
-		 */
458
-		public function maybe_show() {
459
-			$show = false;
460
-
461
-			// check if on a page set to show
462
-			if ( isset( $_REQUEST['page'] ) && in_array( $_REQUEST['page'], $this->pages ) ) {
463
-				// check if not active and connected
464
-				if ( ! defined( 'AYECODE_CONNECT_VERSION' ) || ! get_option( 'ayecode_connect_blog_token' ) ) {
465
-					$show = true;
466
-				}
467
-			}
468
-
469
-			return $show;
470
-		}
471
-	}
451
+        }
452
+
453
+        /**
454
+         * Decide what pages to show on.
455
+         *
456
+         * @return bool
457
+         */
458
+        public function maybe_show() {
459
+            $show = false;
460
+
461
+            // check if on a page set to show
462
+            if ( isset( $_REQUEST['page'] ) && in_array( $_REQUEST['page'], $this->pages ) ) {
463
+                // check if not active and connected
464
+                if ( ! defined( 'AYECODE_CONNECT_VERSION' ) || ! get_option( 'ayecode_connect_blog_token' ) ) {
465
+                    $show = true;
466
+                }
467
+            }
468
+
469
+            return $show;
470
+        }
471
+    }
472 472
 }
Please login to merge, or discard this patch.
Spacing   +78 added lines, -78 removed lines patch added patch discarded remove patch
@@ -1,9 +1,9 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) {
2
+if (!defined('ABSPATH')) {
3 3
 	exit;
4 4
 }
5 5
 
6
-if ( ! class_exists( "AyeCode_Connect_Helper" ) ) {
6
+if (!class_exists("AyeCode_Connect_Helper")) {
7 7
 	/**
8 8
 	 * Allow the quick setup and connection of our AyeCode Connect plugin.
9 9
 	 *
@@ -28,50 +28,50 @@  discard block
 block discarded – undo
28 28
 		 * @param array $strings
29 29
 		 * @param array $pages
30 30
 		 */
31
-		public function __construct( $strings = array(), $pages = array() ) {
31
+		public function __construct($strings = array(), $pages = array()) {
32 32
 			// Only fire if not localhost and the current user has the right permissions.
33
-			if ( ! $this->is_localhost() && current_user_can( 'manage_options' ) ) {
33
+			if (!$this->is_localhost() && current_user_can('manage_options')) {
34 34
 				// set default strings
35 35
 				$default_strings = array(
36
-					'connect_title'     => __( "Thanks for choosing an AyeCode Product!", 'ayecode-connect' ),
37
-					'connect_external'  => __( "Please confirm you wish to connect your site?", 'ayecode-connect' ),
38
-					'connect'           => wp_sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s", 'ayecode-connect' ), "<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>", "</a>" ),
39
-					'connect_button'    => __( "Connect Site", 'ayecode-connect' ),
40
-					'connecting_button' => __( "Connecting...", 'ayecode-connect' ),
41
-					'error_localhost'   => __( "This service will only work with a live domain, not a localhost.", 'ayecode-connect' ),
42
-					'error'             => __( "Something went wrong, please refresh and try again.", 'ayecode-connect' ),
36
+					'connect_title'     => __("Thanks for choosing an AyeCode Product!", 'ayecode-connect'),
37
+					'connect_external'  => __("Please confirm you wish to connect your site?", 'ayecode-connect'),
38
+					'connect'           => wp_sprintf(__("<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s", 'ayecode-connect'), "<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>", "</a>"),
39
+					'connect_button'    => __("Connect Site", 'ayecode-connect'),
40
+					'connecting_button' => __("Connecting...", 'ayecode-connect'),
41
+					'error_localhost'   => __("This service will only work with a live domain, not a localhost.", 'ayecode-connect'),
42
+					'error'             => __("Something went wrong, please refresh and try again.", 'ayecode-connect'),
43 43
 				);
44
-				$this->strings   = array_merge( $default_strings, $strings );
44
+				$this->strings = array_merge($default_strings, $strings);
45 45
 
46 46
 				// set default pages
47 47
 				$default_pages = array();
48
-				$this->pages   = array_merge( $default_pages, $pages );
48
+				$this->pages   = array_merge($default_pages, $pages);
49 49
 
50 50
 				// maybe show connect site notice
51
-				add_action( 'admin_notices', array( $this, 'ayecode_connect_install_notice' ) );
51
+				add_action('admin_notices', array($this, 'ayecode_connect_install_notice'));
52 52
 
53 53
 				// add ajax action if not already added
54
-				if ( ! has_action( 'wp_ajax_ayecode_connect_helper' ) ) {
55
-					add_action( 'wp_ajax_ayecode_connect_helper', array( $this, 'ayecode_connect_install' ) );
54
+				if (!has_action('wp_ajax_ayecode_connect_helper')) {
55
+					add_action('wp_ajax_ayecode_connect_helper', array($this, 'ayecode_connect_install'));
56 56
 				}
57 57
 			}
58 58
 
59 59
 			// add ajax action if not already added
60
-			if ( ! has_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed' ) ) {
61
-				add_action( 'wp_ajax_nopriv_ayecode_connect_helper_installed', array( $this, 'ayecode_connect_helper_installed' ) );
60
+			if (!has_action('wp_ajax_nopriv_ayecode_connect_helper_installed')) {
61
+				add_action('wp_ajax_nopriv_ayecode_connect_helper_installed', array($this, 'ayecode_connect_helper_installed'));
62 62
 			}
63 63
 		}
64 64
 
65 65
 		/**
66 66
 		 * Give a way to check we can connect via a external redirect.
67 67
 		 */
68
-		public function ayecode_connect_helper_installed(){
68
+		public function ayecode_connect_helper_installed() {
69 69
 			$active = array(
70
-				'gd'    =>  defined('GEODIRECTORY_VERSION') && version_compare(GEODIRECTORY_VERSION,'2.0.0.79','>') ? 1 : 0,
71
-				'uwp'    =>  defined('USERSWP_VERSION') && version_compare(USERSWP_VERSION,'1.2.1.5','>') ? 1 : 0,
72
-				'wpi'    =>  defined('WPINV_VERSION') && version_compare(WPINV_VERSION,'1.0.14','>') ? 1 : 0,
70
+				'gd'    =>  defined('GEODIRECTORY_VERSION') && version_compare(GEODIRECTORY_VERSION, '2.0.0.79', '>') ? 1 : 0,
71
+				'uwp'    =>  defined('USERSWP_VERSION') && version_compare(USERSWP_VERSION, '1.2.1.5', '>') ? 1 : 0,
72
+				'wpi'    =>  defined('WPINV_VERSION') && version_compare(WPINV_VERSION, '1.0.14', '>') ? 1 : 0,
73 73
 			);
74
-			wp_send_json_success( $active );
74
+			wp_send_json_success($active);
75 75
 			wp_die();
76 76
 		}
77 77
 
@@ -82,9 +82,9 @@  discard block
 block discarded – undo
82 82
 		 *
83 83
 		 * @return string
84 84
 		 */
85
-		private function format_plugin_slug( $key ) {
86
-			$slug = explode( '/', $key );
87
-			$slug = explode( '.', end( $slug ) );
85
+		private function format_plugin_slug($key) {
86
+			$slug = explode('/', $key);
87
+			$slug = explode('.', end($slug));
88 88
 
89 89
 			return $slug[0];
90 90
 		}
@@ -94,45 +94,45 @@  discard block
 block discarded – undo
94 94
 		 */
95 95
 		public function ayecode_connect_install() {
96 96
 			// bail if localhost
97
-			if ( $this->is_localhost() ) {
98
-				wp_send_json_error( $this->strings['error_localhost'] );
97
+			if ($this->is_localhost()) {
98
+				wp_send_json_error($this->strings['error_localhost']);
99 99
 			}
100 100
 
101 101
 			// Explicitly clear the event.
102
-			wp_clear_scheduled_hook( 'geodir_plugin_background_installer', func_get_args() );
102
+			wp_clear_scheduled_hook('geodir_plugin_background_installer', func_get_args());
103 103
 
104 104
 			$success     = true;
105 105
 			$plugin_slug = "ayecode-connect";
106
-			if ( ! empty( $plugin_slug ) ) {
107
-				require_once( ABSPATH . 'wp-admin/includes/file.php' );
108
-				require_once( ABSPATH . 'wp-admin/includes/plugin-install.php' );
109
-				require_once( ABSPATH . 'wp-admin/includes/class-wp-upgrader.php' );
110
-				require_once( ABSPATH . 'wp-admin/includes/plugin.php' );
106
+			if (!empty($plugin_slug)) {
107
+				require_once(ABSPATH . 'wp-admin/includes/file.php');
108
+				require_once(ABSPATH . 'wp-admin/includes/plugin-install.php');
109
+				require_once(ABSPATH . 'wp-admin/includes/class-wp-upgrader.php');
110
+				require_once(ABSPATH . 'wp-admin/includes/plugin.php');
111 111
 
112 112
 				WP_Filesystem();
113 113
 
114 114
 				$skin              = new Automatic_Upgrader_Skin;
115
-				$upgrader          = new WP_Upgrader( $skin );
116
-				$installed_plugins = array_map( array( $this, 'format_plugin_slug' ), array_keys( get_plugins() ) );
115
+				$upgrader          = new WP_Upgrader($skin);
116
+				$installed_plugins = array_map(array($this, 'format_plugin_slug'), array_keys(get_plugins()));
117 117
 				$plugin_slug       = $plugin_slug;
118 118
 				$plugin            = $plugin_slug . '/' . $plugin_slug . '.php';
119 119
 				$installed         = false;
120 120
 				$activate          = false;
121 121
 
122 122
 				// See if the plugin is installed already
123
-				if ( in_array( $plugin_slug, $installed_plugins ) ) {
123
+				if (in_array($plugin_slug, $installed_plugins)) {
124 124
 					$installed = true;
125
-					$activate  = ! is_plugin_active( $plugin );
125
+					$activate  = !is_plugin_active($plugin);
126 126
 				}
127 127
 
128 128
 				// Install this thing!
129
-				if ( ! $installed ) {
129
+				if (!$installed) {
130 130
 
131 131
 					// Suppress feedback
132 132
 					ob_start();
133 133
 
134 134
 					try {
135
-						$plugin_information = plugins_api( 'plugin_information', array(
135
+						$plugin_information = plugins_api('plugin_information', array(
136 136
 							'slug'   => $plugin_slug,
137 137
 							'fields' => array(
138 138
 								'short_description' => false,
@@ -149,26 +149,26 @@  discard block
 block discarded – undo
149 149
 								'author_profile'    => false,
150 150
 								'author'            => false,
151 151
 							),
152
-						) );
152
+						));
153 153
 
154
-						if ( is_wp_error( $plugin_information ) ) {
155
-							throw new Exception( $plugin_information->get_error_message() );
154
+						if (is_wp_error($plugin_information)) {
155
+							throw new Exception($plugin_information->get_error_message());
156 156
 						}
157 157
 
158 158
 						$package  = $plugin_information->download_link;
159
-						$download = $upgrader->download_package( $package );
159
+						$download = $upgrader->download_package($package);
160 160
 
161
-						if ( is_wp_error( $download ) ) {
162
-							throw new Exception( $download->get_error_message() );
161
+						if (is_wp_error($download)) {
162
+							throw new Exception($download->get_error_message());
163 163
 						}
164 164
 
165
-						$working_dir = $upgrader->unpack_package( $download, true );
165
+						$working_dir = $upgrader->unpack_package($download, true);
166 166
 
167
-						if ( is_wp_error( $working_dir ) ) {
168
-							throw new Exception( $working_dir->get_error_message() );
167
+						if (is_wp_error($working_dir)) {
168
+							throw new Exception($working_dir->get_error_message());
169 169
 						}
170 170
 
171
-						$result = $upgrader->install_package( array(
171
+						$result = $upgrader->install_package(array(
172 172
 							'source'                      => $working_dir,
173 173
 							'destination'                 => WP_PLUGIN_DIR,
174 174
 							'clear_destination'           => false,
@@ -178,15 +178,15 @@  discard block
 block discarded – undo
178 178
 								'type'   => 'plugin',
179 179
 								'action' => 'install',
180 180
 							),
181
-						) );
181
+						));
182 182
 
183
-						if ( is_wp_error( $result ) ) {
184
-							throw new Exception( $result->get_error_message() );
183
+						if (is_wp_error($result)) {
184
+							throw new Exception($result->get_error_message());
185 185
 						}
186 186
 
187 187
 						$activate = true;
188 188
 
189
-					} catch ( Exception $e ) {
189
+					} catch (Exception $e) {
190 190
 						$success = false;
191 191
 					}
192 192
 
@@ -197,30 +197,30 @@  discard block
 block discarded – undo
197 197
 				wp_clean_plugins_cache();
198 198
 
199 199
 				// Activate this thing
200
-				if ( $activate ) {
200
+				if ($activate) {
201 201
 					try {
202
-						$result = activate_plugin( $plugin );
202
+						$result = activate_plugin($plugin);
203 203
 
204
-						if ( is_wp_error( $result ) ) {
204
+						if (is_wp_error($result)) {
205 205
 							$success = false;
206 206
 						} else {
207 207
 							$success = true;
208 208
 						}
209
-					} catch ( Exception $e ) {
209
+					} catch (Exception $e) {
210 210
 						$success = false;
211 211
 					}
212 212
 				}
213 213
 			}
214 214
 
215
-			if ( $success && function_exists( 'ayecode_connect_args' ) ) {
216
-				ayecode_connect();// init
215
+			if ($success && function_exists('ayecode_connect_args')) {
216
+				ayecode_connect(); // init
217 217
 				$args        = ayecode_connect_args();
218
-				$client      = new AyeCode_Connect( $args );
219
-				$redirect_to = ! empty( $_POST['redirect_to'] ) ? esc_url_raw( $_POST['redirect_to'] ) : '';
220
-				$redirect    = $client->build_connect_url( $redirect_to );
221
-				wp_send_json_success( array( 'connect_url' => $redirect ) );
218
+				$client      = new AyeCode_Connect($args);
219
+				$redirect_to = !empty($_POST['redirect_to']) ? esc_url_raw($_POST['redirect_to']) : '';
220
+				$redirect    = $client->build_connect_url($redirect_to);
221
+				wp_send_json_success(array('connect_url' => $redirect));
222 222
 			} else {
223
-				wp_send_json_error( $this->strings['error_localhost'] );
223
+				wp_send_json_error($this->strings['error_localhost']);
224 224
 			}
225 225
 			wp_die();
226 226
 		}
@@ -233,7 +233,7 @@  discard block
 block discarded – undo
233 233
 		public function is_localhost() {
234 234
 			$localhost = false;
235 235
 
236
-			$host              = isset( $_SERVER['HTTP_HOST'] ) ? $_SERVER['HTTP_HOST'] : '';
236
+			$host              = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '';
237 237
 			$localhost_domains = array(
238 238
 				'localhost',
239 239
 				'localhost.localdomain',
@@ -241,7 +241,7 @@  discard block
 block discarded – undo
241 241
 				'::1'
242 242
 			);
243 243
 
244
-			if ( in_array( $host, $localhost_domains ) ) {
244
+			if (in_array($host, $localhost_domains)) {
245 245
 				$localhost = true;
246 246
 			}
247 247
 
@@ -252,7 +252,7 @@  discard block
 block discarded – undo
252 252
 		 * Show notice to connect site.
253 253
 		 */
254 254
 		public function ayecode_connect_install_notice() {
255
-			if ( $this->maybe_show() ) {
255
+			if ($this->maybe_show()) {
256 256
 				$connect_title_string     = $this->strings['connect_title'];
257 257
 				$connect_external_string  = $this->strings['connect_external'];
258 258
 				$connect_string           = $this->strings['connect'];
@@ -294,19 +294,19 @@  discard block
 block discarded – undo
294 294
 					</svg>
295 295
 					</span>
296 296
 					<span class="acch-float-left acch-text">
297
-						<h3 class="acch-title"><?php echo esc_attr( $connect_title_string ); ?></h3>
297
+						<h3 class="acch-title"><?php echo esc_attr($connect_title_string); ?></h3>
298 298
 					<p><?php echo $connect_string; ?>
299 299
 					</p>
300 300
 					</span>
301 301
 
302 302
 					<span class="acch-float-left acch-button">
303
-						<button onclick="ayecode_connect_helper(this);" id="gd-connect-site" class="button button-primary" data-connecting="<?php echo esc_attr( $connecting_button_string ); ?>"><?php echo esc_attr( $connect_button_string ) ?></button>
303
+						<button onclick="ayecode_connect_helper(this);" id="gd-connect-site" class="button button-primary" data-connecting="<?php echo esc_attr($connecting_button_string); ?>"><?php echo esc_attr($connect_button_string) ?></button>
304 304
 					</span>
305 305
 				</div>
306 306
 
307 307
 				<?php
308 308
 				// only include the popup HTML if needed.
309
-				if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
309
+				if (!empty($_REQUEST['external-connect-request'])) {
310 310
 					?>
311 311
 					<div id="ayecode-connect-helper-external-confirm" style="display:none;">
312 312
 						<div class="noticex notice-info acch-notice" style="border: none;">
@@ -344,11 +344,11 @@  discard block
 block discarded – undo
344 344
 					</svg>
345 345
 					</span>
346 346
 					<span class="acch-float-left acch-text">
347
-						<h3 class="acch-title"><?php echo esc_attr( $connect_external_string ); ?></h3>
347
+						<h3 class="acch-title"><?php echo esc_attr($connect_external_string); ?></h3>
348 348
 					</span>
349 349
 
350 350
 					<span class="acch-float-left acch-button">
351
-						<button onclick="ayecode_connect_helper(this);" id="gd-connect-site" class="button button-primary" data-connecting="<?php echo esc_attr( $connecting_button_string ); ?>"><?php echo esc_attr( $connect_button_string ) ?></button>
351
+						<button onclick="ayecode_connect_helper(this);" id="gd-connect-site" class="button button-primary" data-connecting="<?php echo esc_attr($connecting_button_string); ?>"><?php echo esc_attr($connect_button_string) ?></button>
352 352
 					</span>
353 353
 						</div>
354 354
 					</div>
@@ -366,7 +366,7 @@  discard block
 block discarded – undo
366 366
 		public function script() {
367 367
 
368 368
 			// add thickbox if external request is requested
369
-			if ( ! empty( $_REQUEST['external-connect-request'] ) ) {
369
+			if (!empty($_REQUEST['external-connect-request'])) {
370 370
 				add_thickbox();
371 371
 			}
372 372
 			?>
@@ -417,7 +417,7 @@  discard block
 block discarded – undo
417 417
 						url: ajaxurl,
418 418
 						data: {
419 419
 							action: 'ayecode_connect_helper',
420
-							security: '<?php echo wp_create_nonce( 'ayecode-connect-helper' );?>',
420
+							security: '<?php echo wp_create_nonce('ayecode-connect-helper'); ?>',
421 421
 							redirect_to: $current_url
422 422
 						},
423 423
 						beforeSend: function () {
@@ -436,7 +436,7 @@  discard block
 block discarded – undo
436 436
 				} 
437 437
 				<?php
438 438
 				// add thickbox if external request is requested
439
-				if(! empty( $_REQUEST['external-connect-request'] )) {
439
+				if (!empty($_REQUEST['external-connect-request'])) {
440 440
 				?>
441 441
 				jQuery(function () {
442 442
 					setTimeout(function () {
@@ -459,9 +459,9 @@  discard block
 block discarded – undo
459 459
 			$show = false;
460 460
 
461 461
 			// check if on a page set to show
462
-			if ( isset( $_REQUEST['page'] ) && in_array( $_REQUEST['page'], $this->pages ) ) {
462
+			if (isset($_REQUEST['page']) && in_array($_REQUEST['page'], $this->pages)) {
463 463
 				// check if not active and connected
464
-				if ( ! defined( 'AYECODE_CONNECT_VERSION' ) || ! get_option( 'ayecode_connect_blog_token' ) ) {
464
+				if (!defined('AYECODE_CONNECT_VERSION') || !get_option('ayecode_connect_blog_token')) {
465 465
 					$show = true;
466 466
 				}
467 467
 			}
Please login to merge, or discard this patch.
vendor/ayecode/wp-deactivation-survey/wp-deactivation-survey.php 2 patches
Indentation   +75 added lines, -75 removed lines patch added patch discarded remove patch
@@ -1,99 +1,99 @@
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit;
4
+    exit;
5 5
 }
6 6
 
7 7
 if ( ! class_exists( 'AyeCode_Deactivation_Survey' ) ) {
8 8
 
9
-	class AyeCode_Deactivation_Survey {
9
+    class AyeCode_Deactivation_Survey {
10 10
 
11
-		/**
12
-		 * AyeCode_Deactivation_Survey instance.
13
-		 *
14
-		 * @access private
15
-		 * @since  1.0.0
16
-		 * @var    AyeCode_Deactivation_Survey There can be only one!
17
-		 */
18
-		private static $instance = null;
11
+        /**
12
+         * AyeCode_Deactivation_Survey instance.
13
+         *
14
+         * @access private
15
+         * @since  1.0.0
16
+         * @var    AyeCode_Deactivation_Survey There can be only one!
17
+         */
18
+        private static $instance = null;
19 19
 
20
-		public static $plugins;
20
+        public static $plugins;
21 21
 
22
-		public $version = "1.0.7";
22
+        public $version = "1.0.7";
23 23
 
24
-		public static function instance( $plugin = array() ) {
25
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_Deactivation_Survey ) ) {
26
-				self::$instance = new AyeCode_Deactivation_Survey;
27
-				self::$plugins = array();
24
+        public static function instance( $plugin = array() ) {
25
+            if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_Deactivation_Survey ) ) {
26
+                self::$instance = new AyeCode_Deactivation_Survey;
27
+                self::$plugins = array();
28 28
 
29
-				add_action( 'admin_enqueue_scripts', array( self::$instance, 'scripts' ) );
29
+                add_action( 'admin_enqueue_scripts', array( self::$instance, 'scripts' ) );
30 30
 
31
-				do_action( 'ayecode_deactivation_survey_loaded' );
32
-			}
31
+                do_action( 'ayecode_deactivation_survey_loaded' );
32
+            }
33 33
 
34
-			if(!empty($plugin)){
35
-				self::$plugins[] = (object)$plugin;
36
-			}
34
+            if(!empty($plugin)){
35
+                self::$plugins[] = (object)$plugin;
36
+            }
37 37
 
38
-			return self::$instance;
39
-		}
38
+            return self::$instance;
39
+        }
40 40
 
41
-		public function scripts() {
42
-			global $pagenow;
41
+        public function scripts() {
42
+            global $pagenow;
43 43
 
44
-			// Bail if we are not on the plugins page
45
-			if ( $pagenow != "plugins.php" ) {
46
-				return;
47
-			}
44
+            // Bail if we are not on the plugins page
45
+            if ( $pagenow != "plugins.php" ) {
46
+                return;
47
+            }
48 48
 
49
-			// Enqueue scripts
50
-			add_thickbox();
51
-			wp_enqueue_script('ayecode-deactivation-survey', plugin_dir_url(__FILE__) . 'ayecode-ds.js');
49
+            // Enqueue scripts
50
+            add_thickbox();
51
+            wp_enqueue_script('ayecode-deactivation-survey', plugin_dir_url(__FILE__) . 'ayecode-ds.js');
52 52
 
53
-			/*
53
+            /*
54 54
 			 * Localized strings. Strings can be localised by plugins using this class.
55 55
 			 * We deliberately don't add textdomains here so that double textdomain warning is not given in theme review.
56 56
 			 */
57
-			wp_localize_script('ayecode-deactivation-survey', 'ayecodeds_deactivate_feedback_form_strings', array(
58
-				'quick_feedback'			=> __( 'Quick Feedback', 'ayecode-connect' ),
59
-				'foreword'					=> __( 'If you would be kind enough, please tell us why you\'re deactivating?', 'ayecode-connect' ),
60
-				'better_plugins_name'		=> __( 'Please tell us which plugin?', 'ayecode-connect' ),
61
-				'please_tell_us'			=> __( 'Please tell us the reason so we can improve the plugin', 'ayecode-connect' ),
62
-				'do_not_attach_email'		=> __( 'Do not send my e-mail address with this feedback', 'ayecode-connect' ),
63
-				'brief_description'			=> __( 'Please give us any feedback that could help us improve', 'ayecode-connect' ),
64
-				'cancel'					=> __( 'Cancel', 'ayecode-connect' ),
65
-				'skip_and_deactivate'		=> __( 'Skip &amp; Deactivate', 'ayecode-connect' ),
66
-				'submit_and_deactivate'		=> __( 'Submit &amp; Deactivate', 'ayecode-connect' ),
67
-				'please_wait'				=> __( 'Please wait', 'ayecode-connect' ),
68
-				'get_support'				=> __( 'Get Support', 'ayecode-connect' ),
69
-				'documentation'				=> __( 'Documentation', 'ayecode-connect' ),
70
-				'thank_you'					=> __( 'Thank you!', 'ayecode-connect' ),
71
-			));
72
-
73
-			// Plugins
74
-			$plugins = apply_filters('ayecode_deactivation_survey_plugins', self::$plugins);
75
-
76
-			// Reasons
77
-			$defaultReasons = array(
78
-				'suddenly-stopped-working'	=> __( 'The plugin suddenly stopped working', 'ayecode-connect' ),
79
-				'plugin-broke-site'			=> __( 'The plugin broke my site', 'ayecode-connect' ),
80
-				'plugin-setup-difficult'	=> __( 'Too difficult to setup', 'ayecode-connect' ),
81
-				'plugin-design-difficult'	=> __( 'Too difficult to get the design i want', 'ayecode-connect' ),
82
-				'no-longer-needed'			=> __( 'I don\'t need this plugin any more', 'ayecode-connect' ),
83
-				'found-better-plugin'		=> __( 'I found a better plugin', 'ayecode-connect' ),
84
-				'temporary-deactivation'	=> __( 'It\'s a temporary deactivation, I\'m troubleshooting', 'ayecode-connect' ),
85
-				'other'						=> __( 'Other', 'ayecode-connect' ),
86
-			);
87
-
88
-			foreach( $plugins as $plugin ) {
89
-				$plugin->reasons = apply_filters( 'ayecode_deactivation_survey_reasons', $defaultReasons, $plugin );
90
-				$plugin->url = home_url();
91
-				$plugin->activated = 0;
92
-			}
93
-
94
-			// Send plugin data
95
-			wp_localize_script('ayecode-deactivation-survey', 'ayecodeds_deactivate_feedback_form_plugins', $plugins);
96
-		}
97
-	}
57
+            wp_localize_script('ayecode-deactivation-survey', 'ayecodeds_deactivate_feedback_form_strings', array(
58
+                'quick_feedback'			=> __( 'Quick Feedback', 'ayecode-connect' ),
59
+                'foreword'					=> __( 'If you would be kind enough, please tell us why you\'re deactivating?', 'ayecode-connect' ),
60
+                'better_plugins_name'		=> __( 'Please tell us which plugin?', 'ayecode-connect' ),
61
+                'please_tell_us'			=> __( 'Please tell us the reason so we can improve the plugin', 'ayecode-connect' ),
62
+                'do_not_attach_email'		=> __( 'Do not send my e-mail address with this feedback', 'ayecode-connect' ),
63
+                'brief_description'			=> __( 'Please give us any feedback that could help us improve', 'ayecode-connect' ),
64
+                'cancel'					=> __( 'Cancel', 'ayecode-connect' ),
65
+                'skip_and_deactivate'		=> __( 'Skip &amp; Deactivate', 'ayecode-connect' ),
66
+                'submit_and_deactivate'		=> __( 'Submit &amp; Deactivate', 'ayecode-connect' ),
67
+                'please_wait'				=> __( 'Please wait', 'ayecode-connect' ),
68
+                'get_support'				=> __( 'Get Support', 'ayecode-connect' ),
69
+                'documentation'				=> __( 'Documentation', 'ayecode-connect' ),
70
+                'thank_you'					=> __( 'Thank you!', 'ayecode-connect' ),
71
+            ));
72
+
73
+            // Plugins
74
+            $plugins = apply_filters('ayecode_deactivation_survey_plugins', self::$plugins);
75
+
76
+            // Reasons
77
+            $defaultReasons = array(
78
+                'suddenly-stopped-working'	=> __( 'The plugin suddenly stopped working', 'ayecode-connect' ),
79
+                'plugin-broke-site'			=> __( 'The plugin broke my site', 'ayecode-connect' ),
80
+                'plugin-setup-difficult'	=> __( 'Too difficult to setup', 'ayecode-connect' ),
81
+                'plugin-design-difficult'	=> __( 'Too difficult to get the design i want', 'ayecode-connect' ),
82
+                'no-longer-needed'			=> __( 'I don\'t need this plugin any more', 'ayecode-connect' ),
83
+                'found-better-plugin'		=> __( 'I found a better plugin', 'ayecode-connect' ),
84
+                'temporary-deactivation'	=> __( 'It\'s a temporary deactivation, I\'m troubleshooting', 'ayecode-connect' ),
85
+                'other'						=> __( 'Other', 'ayecode-connect' ),
86
+            );
87
+
88
+            foreach( $plugins as $plugin ) {
89
+                $plugin->reasons = apply_filters( 'ayecode_deactivation_survey_reasons', $defaultReasons, $plugin );
90
+                $plugin->url = home_url();
91
+                $plugin->activated = 0;
92
+            }
93
+
94
+            // Send plugin data
95
+            wp_localize_script('ayecode-deactivation-survey', 'ayecodeds_deactivate_feedback_form_plugins', $plugins);
96
+        }
97
+    }
98 98
 
99 99
 }
100 100
\ No newline at end of file
Please login to merge, or discard this patch.
Spacing   +32 added lines, -32 removed lines patch added patch discarded remove patch
@@ -1,10 +1,10 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3
-if ( ! defined( 'ABSPATH' ) ) {
3
+if (!defined('ABSPATH')) {
4 4
 	exit;
5 5
 }
6 6
 
7
-if ( ! class_exists( 'AyeCode_Deactivation_Survey' ) ) {
7
+if (!class_exists('AyeCode_Deactivation_Survey')) {
8 8
 
9 9
 	class AyeCode_Deactivation_Survey {
10 10
 
@@ -21,18 +21,18 @@  discard block
 block discarded – undo
21 21
 
22 22
 		public $version = "1.0.7";
23 23
 
24
-		public static function instance( $plugin = array() ) {
25
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_Deactivation_Survey ) ) {
24
+		public static function instance($plugin = array()) {
25
+			if (!isset(self::$instance) && !(self::$instance instanceof AyeCode_Deactivation_Survey)) {
26 26
 				self::$instance = new AyeCode_Deactivation_Survey;
27 27
 				self::$plugins = array();
28 28
 
29
-				add_action( 'admin_enqueue_scripts', array( self::$instance, 'scripts' ) );
29
+				add_action('admin_enqueue_scripts', array(self::$instance, 'scripts'));
30 30
 
31
-				do_action( 'ayecode_deactivation_survey_loaded' );
31
+				do_action('ayecode_deactivation_survey_loaded');
32 32
 			}
33 33
 
34
-			if(!empty($plugin)){
35
-				self::$plugins[] = (object)$plugin;
34
+			if (!empty($plugin)) {
35
+				self::$plugins[] = (object) $plugin;
36 36
 			}
37 37
 
38 38
 			return self::$instance;
@@ -42,7 +42,7 @@  discard block
 block discarded – undo
42 42
 			global $pagenow;
43 43
 
44 44
 			// Bail if we are not on the plugins page
45
-			if ( $pagenow != "plugins.php" ) {
45
+			if ($pagenow != "plugins.php") {
46 46
 				return;
47 47
 			}
48 48
 
@@ -55,19 +55,19 @@  discard block
 block discarded – undo
55 55
 			 * We deliberately don't add textdomains here so that double textdomain warning is not given in theme review.
56 56
 			 */
57 57
 			wp_localize_script('ayecode-deactivation-survey', 'ayecodeds_deactivate_feedback_form_strings', array(
58
-				'quick_feedback'			=> __( 'Quick Feedback', 'ayecode-connect' ),
59
-				'foreword'					=> __( 'If you would be kind enough, please tell us why you\'re deactivating?', 'ayecode-connect' ),
60
-				'better_plugins_name'		=> __( 'Please tell us which plugin?', 'ayecode-connect' ),
61
-				'please_tell_us'			=> __( 'Please tell us the reason so we can improve the plugin', 'ayecode-connect' ),
62
-				'do_not_attach_email'		=> __( 'Do not send my e-mail address with this feedback', 'ayecode-connect' ),
63
-				'brief_description'			=> __( 'Please give us any feedback that could help us improve', 'ayecode-connect' ),
64
-				'cancel'					=> __( 'Cancel', 'ayecode-connect' ),
65
-				'skip_and_deactivate'		=> __( 'Skip &amp; Deactivate', 'ayecode-connect' ),
66
-				'submit_and_deactivate'		=> __( 'Submit &amp; Deactivate', 'ayecode-connect' ),
67
-				'please_wait'				=> __( 'Please wait', 'ayecode-connect' ),
68
-				'get_support'				=> __( 'Get Support', 'ayecode-connect' ),
69
-				'documentation'				=> __( 'Documentation', 'ayecode-connect' ),
70
-				'thank_you'					=> __( 'Thank you!', 'ayecode-connect' ),
58
+				'quick_feedback'			=> __('Quick Feedback', 'ayecode-connect'),
59
+				'foreword'					=> __('If you would be kind enough, please tell us why you\'re deactivating?', 'ayecode-connect'),
60
+				'better_plugins_name'		=> __('Please tell us which plugin?', 'ayecode-connect'),
61
+				'please_tell_us'			=> __('Please tell us the reason so we can improve the plugin', 'ayecode-connect'),
62
+				'do_not_attach_email'		=> __('Do not send my e-mail address with this feedback', 'ayecode-connect'),
63
+				'brief_description'			=> __('Please give us any feedback that could help us improve', 'ayecode-connect'),
64
+				'cancel'					=> __('Cancel', 'ayecode-connect'),
65
+				'skip_and_deactivate'		=> __('Skip &amp; Deactivate', 'ayecode-connect'),
66
+				'submit_and_deactivate'		=> __('Submit &amp; Deactivate', 'ayecode-connect'),
67
+				'please_wait'				=> __('Please wait', 'ayecode-connect'),
68
+				'get_support'				=> __('Get Support', 'ayecode-connect'),
69
+				'documentation'				=> __('Documentation', 'ayecode-connect'),
70
+				'thank_you'					=> __('Thank you!', 'ayecode-connect'),
71 71
 			));
72 72
 
73 73
 			// Plugins
@@ -75,18 +75,18 @@  discard block
 block discarded – undo
75 75
 
76 76
 			// Reasons
77 77
 			$defaultReasons = array(
78
-				'suddenly-stopped-working'	=> __( 'The plugin suddenly stopped working', 'ayecode-connect' ),
79
-				'plugin-broke-site'			=> __( 'The plugin broke my site', 'ayecode-connect' ),
80
-				'plugin-setup-difficult'	=> __( 'Too difficult to setup', 'ayecode-connect' ),
81
-				'plugin-design-difficult'	=> __( 'Too difficult to get the design i want', 'ayecode-connect' ),
82
-				'no-longer-needed'			=> __( 'I don\'t need this plugin any more', 'ayecode-connect' ),
83
-				'found-better-plugin'		=> __( 'I found a better plugin', 'ayecode-connect' ),
84
-				'temporary-deactivation'	=> __( 'It\'s a temporary deactivation, I\'m troubleshooting', 'ayecode-connect' ),
85
-				'other'						=> __( 'Other', 'ayecode-connect' ),
78
+				'suddenly-stopped-working'	=> __('The plugin suddenly stopped working', 'ayecode-connect'),
79
+				'plugin-broke-site'			=> __('The plugin broke my site', 'ayecode-connect'),
80
+				'plugin-setup-difficult'	=> __('Too difficult to setup', 'ayecode-connect'),
81
+				'plugin-design-difficult'	=> __('Too difficult to get the design i want', 'ayecode-connect'),
82
+				'no-longer-needed'			=> __('I don\'t need this plugin any more', 'ayecode-connect'),
83
+				'found-better-plugin'		=> __('I found a better plugin', 'ayecode-connect'),
84
+				'temporary-deactivation'	=> __('It\'s a temporary deactivation, I\'m troubleshooting', 'ayecode-connect'),
85
+				'other'						=> __('Other', 'ayecode-connect'),
86 86
 			);
87 87
 
88
-			foreach( $plugins as $plugin ) {
89
-				$plugin->reasons = apply_filters( 'ayecode_deactivation_survey_reasons', $defaultReasons, $plugin );
88
+			foreach ($plugins as $plugin) {
89
+				$plugin->reasons = apply_filters('ayecode_deactivation_survey_reasons', $defaultReasons, $plugin);
90 90
 				$plugin->url = home_url();
91 91
 				$plugin->activated = 0;
92 92
 			}
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/hello-world.php 2 patches
Indentation   +102 added lines, -102 removed lines patch added patch discarded remove patch
@@ -3,102 +3,102 @@  discard block
 block discarded – undo
3 3
 class SD_Hello_World extends WP_Super_Duper {
4 4
 
5 5
 
6
-	public $arguments;
7
-
8
-	/**
9
-	 * Sets up the widgets name etc
10
-	 */
11
-	public function __construct() {
12
-
13
-		$options = array(
14
-			'textdomain'     => 'super-duper',
15
-			// textdomain of the plugin/theme (used to prefix the Gutenberg block)
16
-			'block-icon'     => 'fas fa-globe-americas',
17
-			// Dash icon name for the block: https://developer.wordpress.org/resource/dashicons/#arrow-right
18
-			// OR font-awesome 5 class name: fas fa-globe-americas
19
-			'block-category' => 'widgets',
20
-			// the category for the block, 'common', 'formatting', 'layout', 'widgets', 'embed'.
21
-			'block-keywords' => "['hello','world']",
22
-			// used in the block search, MAX 3
23
-			'block-output'   => array( // the block visual output elements as an array
24
-				array(
25
-					'element' => 'p',
26
-					'title'   => __( 'Placeholder', 'ayecode-connect' ),
27
-					'class'   => '[%className%]',
28
-					'content' => 'Hello: [%after_text%]' // block properties can be added by wrapping them in [%name%]
29
-				)
30
-			),
31
-			'block-wrap'    => '', // You can specify the type of element to wrap the block `div` or `span` etc.. Or blank for no wrap at all.
32
-			'class_name'     => __CLASS__,
33
-			// The calling class name
34
-			'base_id'        => 'hello_world',
35
-			// this is used as the widget id and the shortcode id.
36
-			'name'           => __( 'Hello World', 'ayecode-connect' ),
37
-			// the name of the widget/block
38
-			'widget_ops'     => array(
39
-				'classname'   => 'hello-world-class',
40
-				// widget class
41
-				'description' => esc_html__( 'This is an example that will take a text parameter and output it after `Hello:`.', 'ayecode-connect' ),
42
-				// widget description
43
-			),
44
-			'no_wrap'       => true, // This will prevent the widget being wrapped in the containing widget class div.
45
-			'arguments'      => array( // these are the arguments that will be used in the widget, shortcode and block settings.
46
-				'after_text' => array( // this is the input name=''
47
-					'title'       => __( 'Text after hello:', 'ayecode-connect' ),
48
-					// input title
49
-					'desc'        => __( 'This is the text that will appear after `Hello:`.', 'ayecode-connect' ),
50
-					// input description
51
-					'type'        => 'text',
52
-					// the type of input, test, select, checkbox etc.
53
-					'placeholder' => 'World',
54
-					// the input placeholder text.
55
-					'desc_tip'    => true,
56
-					// if the input should show the widget description text as a tooltip.
57
-					'default'     => 'World',
58
-					// the input default value.
59
-					'advanced'    => false
60
-					// not yet implemented
61
-				),
62
-			)
63
-		);
64
-
65
-		parent::__construct( $options );
66
-	}
67
-
68
-
69
-	/**
70
-	 * This is the output function for the widget, shortcode and block (front end).
71
-	 *
72
-	 * @param array $args The arguments values.
73
-	 * @param array $widget_args The widget arguments when used.
74
-	 * @param string $content The shortcode content argument
75
-	 *
76
-	 * @return string
77
-	 */
78
-	public function output( $args = array(), $widget_args = array(), $content = '' ) {
79
-
80
-		/**
81
-		 * @var string $after_text
82
-		 * @var string $another_input This is added by filter below.
83
-		 */
84
-		extract( $args, EXTR_SKIP );
85
-
86
-		/*
6
+    public $arguments;
7
+
8
+    /**
9
+     * Sets up the widgets name etc
10
+     */
11
+    public function __construct() {
12
+
13
+        $options = array(
14
+            'textdomain'     => 'super-duper',
15
+            // textdomain of the plugin/theme (used to prefix the Gutenberg block)
16
+            'block-icon'     => 'fas fa-globe-americas',
17
+            // Dash icon name for the block: https://developer.wordpress.org/resource/dashicons/#arrow-right
18
+            // OR font-awesome 5 class name: fas fa-globe-americas
19
+            'block-category' => 'widgets',
20
+            // the category for the block, 'common', 'formatting', 'layout', 'widgets', 'embed'.
21
+            'block-keywords' => "['hello','world']",
22
+            // used in the block search, MAX 3
23
+            'block-output'   => array( // the block visual output elements as an array
24
+                array(
25
+                    'element' => 'p',
26
+                    'title'   => __( 'Placeholder', 'ayecode-connect' ),
27
+                    'class'   => '[%className%]',
28
+                    'content' => 'Hello: [%after_text%]' // block properties can be added by wrapping them in [%name%]
29
+                )
30
+            ),
31
+            'block-wrap'    => '', // You can specify the type of element to wrap the block `div` or `span` etc.. Or blank for no wrap at all.
32
+            'class_name'     => __CLASS__,
33
+            // The calling class name
34
+            'base_id'        => 'hello_world',
35
+            // this is used as the widget id and the shortcode id.
36
+            'name'           => __( 'Hello World', 'ayecode-connect' ),
37
+            // the name of the widget/block
38
+            'widget_ops'     => array(
39
+                'classname'   => 'hello-world-class',
40
+                // widget class
41
+                'description' => esc_html__( 'This is an example that will take a text parameter and output it after `Hello:`.', 'ayecode-connect' ),
42
+                // widget description
43
+            ),
44
+            'no_wrap'       => true, // This will prevent the widget being wrapped in the containing widget class div.
45
+            'arguments'      => array( // these are the arguments that will be used in the widget, shortcode and block settings.
46
+                'after_text' => array( // this is the input name=''
47
+                    'title'       => __( 'Text after hello:', 'ayecode-connect' ),
48
+                    // input title
49
+                    'desc'        => __( 'This is the text that will appear after `Hello:`.', 'ayecode-connect' ),
50
+                    // input description
51
+                    'type'        => 'text',
52
+                    // the type of input, test, select, checkbox etc.
53
+                    'placeholder' => 'World',
54
+                    // the input placeholder text.
55
+                    'desc_tip'    => true,
56
+                    // if the input should show the widget description text as a tooltip.
57
+                    'default'     => 'World',
58
+                    // the input default value.
59
+                    'advanced'    => false
60
+                    // not yet implemented
61
+                ),
62
+            )
63
+        );
64
+
65
+        parent::__construct( $options );
66
+    }
67
+
68
+
69
+    /**
70
+     * This is the output function for the widget, shortcode and block (front end).
71
+     *
72
+     * @param array $args The arguments values.
73
+     * @param array $widget_args The widget arguments when used.
74
+     * @param string $content The shortcode content argument
75
+     *
76
+     * @return string
77
+     */
78
+    public function output( $args = array(), $widget_args = array(), $content = '' ) {
79
+
80
+        /**
81
+         * @var string $after_text
82
+         * @var string $another_input This is added by filter below.
83
+         */
84
+        extract( $args, EXTR_SKIP );
85
+
86
+        /*
87 87
 		 * This value is added by filter so might not exist if filter is removed so we check.
88 88
 		 */
89
-		if ( ! isset( $another_input ) ) {
90
-			$another_input = '';
91
-		}
89
+        if ( ! isset( $another_input ) ) {
90
+            $another_input = '';
91
+        }
92 92
 
93
-		return "Hello: " . $after_text . "" . $another_input;
93
+        return "Hello: " . $after_text . "" . $another_input;
94 94
 
95
-	}
95
+    }
96 96
 
97 97
 }
98 98
 
99 99
 // register it.
100 100
 add_action( 'widgets_init', function () {
101
-	register_widget( 'SD_Hello_World' );
101
+    register_widget( 'SD_Hello_World' );
102 102
 } );
103 103
 
104 104
 
@@ -111,26 +111,26 @@  discard block
 block discarded – undo
111 111
  */
112 112
 function _my_extra_arguments( $options ) {
113 113
 
114
-	/*
114
+    /*
115 115
 	 * Add a new input option.
116 116
 	 */
117
-	$options['arguments']['another_input'] = array(
118
-		'name'        => 'another_input', // this is the input name=''
119
-		'title'       => __( 'Another input:', 'ayecode-connect' ), // input title
120
-		'desc'        => __( 'This is an input added via filter.', 'ayecode-connect' ), // input description
121
-		'type'        => 'text', // the type of input, test, select, checkbox etc.
122
-		'placeholder' => 'Placeholder text', // the input placeholder text.
123
-		'desc_tip'    => true, // if the input should show the widget description text as a tooltip.
124
-		'default'     => '', // the input default value.
125
-		'advanced'    => false // not yet implemented
126
-	);
127
-
128
-	/*
117
+    $options['arguments']['another_input'] = array(
118
+        'name'        => 'another_input', // this is the input name=''
119
+        'title'       => __( 'Another input:', 'ayecode-connect' ), // input title
120
+        'desc'        => __( 'This is an input added via filter.', 'ayecode-connect' ), // input description
121
+        'type'        => 'text', // the type of input, test, select, checkbox etc.
122
+        'placeholder' => 'Placeholder text', // the input placeholder text.
123
+        'desc_tip'    => true, // if the input should show the widget description text as a tooltip.
124
+        'default'     => '', // the input default value.
125
+        'advanced'    => false // not yet implemented
126
+    );
127
+
128
+    /*
129 129
 	 * Output the new option in the block output also.
130 130
 	 */
131
-	$options['block-output']['element::p']['content'] = $options['block-output']['element::p']['content'] . " [%another_input%]";;
131
+    $options['block-output']['element::p']['content'] = $options['block-output']['element::p']['content'] . " [%another_input%]";;
132 132
 
133
-	return $options;
133
+    return $options;
134 134
 }
135 135
 
136 136
 //add_filter( 'wp_super_duper_options_hello_world', '_my_extra_arguments' );
137 137
\ No newline at end of file
Please login to merge, or discard this patch.
Spacing   +15 added lines, -15 removed lines patch added patch discarded remove patch
@@ -23,7 +23,7 @@  discard block
 block discarded – undo
23 23
 			'block-output'   => array( // the block visual output elements as an array
24 24
 				array(
25 25
 					'element' => 'p',
26
-					'title'   => __( 'Placeholder', 'ayecode-connect' ),
26
+					'title'   => __('Placeholder', 'ayecode-connect'),
27 27
 					'class'   => '[%className%]',
28 28
 					'content' => 'Hello: [%after_text%]' // block properties can be added by wrapping them in [%name%]
29 29
 				)
@@ -33,20 +33,20 @@  discard block
 block discarded – undo
33 33
 			// The calling class name
34 34
 			'base_id'        => 'hello_world',
35 35
 			// this is used as the widget id and the shortcode id.
36
-			'name'           => __( 'Hello World', 'ayecode-connect' ),
36
+			'name'           => __('Hello World', 'ayecode-connect'),
37 37
 			// the name of the widget/block
38 38
 			'widget_ops'     => array(
39 39
 				'classname'   => 'hello-world-class',
40 40
 				// widget class
41
-				'description' => esc_html__( 'This is an example that will take a text parameter and output it after `Hello:`.', 'ayecode-connect' ),
41
+				'description' => esc_html__('This is an example that will take a text parameter and output it after `Hello:`.', 'ayecode-connect'),
42 42
 				// widget description
43 43
 			),
44 44
 			'no_wrap'       => true, // This will prevent the widget being wrapped in the containing widget class div.
45 45
 			'arguments'      => array( // these are the arguments that will be used in the widget, shortcode and block settings.
46 46
 				'after_text' => array( // this is the input name=''
47
-					'title'       => __( 'Text after hello:', 'ayecode-connect' ),
47
+					'title'       => __('Text after hello:', 'ayecode-connect'),
48 48
 					// input title
49
-					'desc'        => __( 'This is the text that will appear after `Hello:`.', 'ayecode-connect' ),
49
+					'desc'        => __('This is the text that will appear after `Hello:`.', 'ayecode-connect'),
50 50
 					// input description
51 51
 					'type'        => 'text',
52 52
 					// the type of input, test, select, checkbox etc.
@@ -62,7 +62,7 @@  discard block
 block discarded – undo
62 62
 			)
63 63
 		);
64 64
 
65
-		parent::__construct( $options );
65
+		parent::__construct($options);
66 66
 	}
67 67
 
68 68
 
@@ -75,18 +75,18 @@  discard block
 block discarded – undo
75 75
 	 *
76 76
 	 * @return string
77 77
 	 */
78
-	public function output( $args = array(), $widget_args = array(), $content = '' ) {
78
+	public function output($args = array(), $widget_args = array(), $content = '') {
79 79
 
80 80
 		/**
81 81
 		 * @var string $after_text
82 82
 		 * @var string $another_input This is added by filter below.
83 83
 		 */
84
-		extract( $args, EXTR_SKIP );
84
+		extract($args, EXTR_SKIP);
85 85
 
86 86
 		/*
87 87
 		 * This value is added by filter so might not exist if filter is removed so we check.
88 88
 		 */
89
-		if ( ! isset( $another_input ) ) {
89
+		if (!isset($another_input)) {
90 90
 			$another_input = '';
91 91
 		}
92 92
 
@@ -97,8 +97,8 @@  discard block
 block discarded – undo
97 97
 }
98 98
 
99 99
 // register it.
100
-add_action( 'widgets_init', function () {
101
-	register_widget( 'SD_Hello_World' );
100
+add_action('widgets_init', function() {
101
+	register_widget('SD_Hello_World');
102 102
 } );
103 103
 
104 104
 
@@ -109,15 +109,15 @@  discard block
 block discarded – undo
109 109
  *
110 110
  * @return mixed
111 111
  */
112
-function _my_extra_arguments( $options ) {
112
+function _my_extra_arguments($options) {
113 113
 
114 114
 	/*
115 115
 	 * Add a new input option.
116 116
 	 */
117 117
 	$options['arguments']['another_input'] = array(
118 118
 		'name'        => 'another_input', // this is the input name=''
119
-		'title'       => __( 'Another input:', 'ayecode-connect' ), // input title
120
-		'desc'        => __( 'This is an input added via filter.', 'ayecode-connect' ), // input description
119
+		'title'       => __('Another input:', 'ayecode-connect'), // input title
120
+		'desc'        => __('This is an input added via filter.', 'ayecode-connect'), // input description
121 121
 		'type'        => 'text', // the type of input, test, select, checkbox etc.
122 122
 		'placeholder' => 'Placeholder text', // the input placeholder text.
123 123
 		'desc_tip'    => true, // if the input should show the widget description text as a tooltip.
@@ -128,7 +128,7 @@  discard block
 block discarded – undo
128 128
 	/*
129 129
 	 * Output the new option in the block output also.
130 130
 	 */
131
-	$options['block-output']['element::p']['content'] = $options['block-output']['element::p']['content'] . " [%another_input%]";;
131
+	$options['block-output']['element::p']['content'] = $options['block-output']['element::p']['content'] . " [%another_input%]"; ;
132 132
 
133 133
 	return $options;
134 134
 }
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 3 patches
Braces   +40 added lines, -42 removed lines patch added patch discarded remove patch
@@ -60,7 +60,7 @@  discard block
 block discarded – undo
60 60
             if(!empty($this->options['nested-block'])){
61 61
                 if(empty($this->options['output_types'])){
62 62
                     $this->options['output_types'] = array('shortcode','block');
63
-                }elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
63
+                } elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64 64
                     unset($this->options['output_types'][$key]);
65 65
                 }
66 66
             }
@@ -715,7 +715,7 @@  discard block
 block discarded – undo
715 715
 				<?php
716 716
 				if(! empty( $insert_shortcode_function )){
717 717
 					echo $insert_shortcode_function;
718
-				}else{
718
+				} else{
719 719
 
720 720
 				/**
721 721
 				 * Function for super duper insert shortcode.
@@ -2233,7 +2233,7 @@  discard block
 block discarded – undo
2233 2233
 				$p_pl = 'ps-';
2234 2234
 				$p_pr = 'pe-';
2235 2235
 					<?php
2236
-				}else{
2236
+				} else{
2237 2237
 						?>
2238 2238
 				$aui_bs5 = false;
2239 2239
 				$p_ml = 'ml-';
@@ -2455,7 +2455,7 @@  discard block
 block discarded – undo
2455 2455
                     var InnerBlocks = blockEditor.InnerBlocks;
2456 2456
 
2457 2457
 					var term_query_type = '';
2458
-					var post_type_rest_slugs = <?php if(! empty( $this->arguments ) && isset($this->arguments['post_type']['onchange_rest']['values'])){echo "[".json_encode($this->arguments['post_type']['onchange_rest']['values'])."]";}else{echo "[]";} ?>;
2458
+					var post_type_rest_slugs = <?php if(! empty( $this->arguments ) && isset($this->arguments['post_type']['onchange_rest']['values'])){echo "[".json_encode($this->arguments['post_type']['onchange_rest']['values'])."]";} else{echo "[]";} ?>;
2459 2459
 					const taxonomies_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2460 2460
 					const sort_by_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2461 2461
                     const MediaUpload = wp.blockEditor.MediaUpload;
@@ -2574,8 +2574,7 @@  discard block
 block discarded – undo
2574 2574
 
2575 2575
 								if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2576 2576
 									continue;
2577
-								}
2578
-								elseif ( $args['type'] == 'checkbox' ) {
2577
+								} elseif ( $args['type'] == 'checkbox' ) {
2579 2578
 									$type    = 'boolean';
2580 2579
 									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2581 2580
 								} elseif ( $args['type'] == 'number' ) {
@@ -2703,7 +2702,7 @@  discard block
 block discarded – undo
2703 2702
                             <?php
2704 2703
                             if(!empty($this->options['block-edit-raw'])) {
2705 2704
                                 echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2706
-                            }else{
2705
+                            } else{
2707 2706
                             ?>
2708 2707
 
2709 2708
 function hasSelectedInnerBlock(props) {
@@ -2838,7 +2837,7 @@  discard block
 block discarded – undo
2838 2837
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2839 2838
 if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2840 2839
 	echo 'const { deviceType } = "";';
2841
-}else{
2840
+} else{
2842 2841
 ?>
2843 2842
 /** Get device type const. */
2844 2843
 const { deviceType } = wp.data.useSelect != 'undefined' ?  wp.data.useSelect(select => {
@@ -2872,7 +2871,7 @@  discard block
 block discarded – undo
2872 2871
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
2873 2872
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
2874 2873
 										echo $post->ID;
2875
-									}else{echo '0';}?>,
2874
+									} else{echo '0';}?>,
2876 2875
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
2877 2876
 									};
2878 2877
 
@@ -2892,7 +2891,7 @@  discard block
 block discarded – undo
2892 2891
 										is_fetching = false;
2893 2892
 										prev_attributes[props.clientId] = props.attributes;
2894 2893
                                              <?php
2895
-                                        }else{
2894
+                                        } else{
2896 2895
                                         ?>
2897 2896
                                         props.setAttributes({content: env});
2898 2897
 										is_fetching = false;
@@ -3050,7 +3049,7 @@  discard block
 block discarded – undo
3050 3049
 //
3051 3050
 
3052 3051
 									}
3053
-									}else {
3052
+									} else {
3054 3053
 									?>
3055 3054
 									el(wp.components.PanelBody, {
3056 3055
 											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
@@ -3076,9 +3075,9 @@  discard block
 block discarded – undo
3076 3075
 								// If the user sets block-output array then build it
3077 3076
 								if ( ! empty( $this->options['block-output'] ) ) {
3078 3077
 								$this->block_element( $this->options['block-output'] );
3079
-							}elseif(!empty($this->options['block-edit-return'])){
3078
+							} elseif(!empty($this->options['block-edit-return'])){
3080 3079
                                    echo $this->options['block-edit-return'];
3081
-							}else{
3080
+							} else{
3082 3081
 								// if no block-output is set then we try and get the shortcode html output via ajax.
3083 3082
 								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3084 3083
 								?>
@@ -3183,9 +3182,9 @@  discard block
 block discarded – undo
3183 3182
                                );
3184 3183
                                 <?php
3185 3184
 
3186
-							}elseif(!empty($this->options['block-save-return'])){
3185
+							} elseif(!empty($this->options['block-save-return'])){
3187 3186
                                    echo 'return ' . $this->options['block-save-return'];
3188
-							}elseif(!empty($this->options['nested-block'])){
3187
+							} elseif(!empty($this->options['nested-block'])){
3189 3188
                                 ?>
3190 3189
                               return el(
3191 3190
                                    '',
@@ -3195,13 +3194,13 @@  discard block
 block discarded – undo
3195 3194
                                    el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3196 3195
                                );
3197 3196
                                 <?php
3198
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3197
+							} elseif(!empty( $this->options['block-save-return'] ) ){
3199 3198
                                 echo "return ". $this->options['block-edit-return'].";";
3200
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3199
+							} elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3201 3200
 							?>
3202 3201
 							return content;
3203 3202
 							<?php
3204
-							}else{
3203
+							} else{
3205 3204
 							?>
3206 3205
 							var block_wrap = 'div';
3207 3206
 							if (attr.hasOwnProperty("block_wrap")) {
@@ -3252,9 +3251,9 @@  discard block
 block discarded – undo
3252 3251
                 $device_type_icon = '';
3253 3252
                 if($device_type=='Desktop'){
3254 3253
                     $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3255
-                }elseif($device_type=='Tablet'){
3254
+                } elseif($device_type=='Tablet'){
3256 3255
                     $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3257
-                }elseif($device_type=='Mobile'){
3256
+                } elseif($device_type=='Mobile'){
3258 3257
                     $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3259 3258
                 }
3260 3259
 				echo $element_require;
@@ -3299,7 +3298,7 @@  discard block
 block discarded – undo
3299 3298
 
3300 3299
 					<?php
3301 3300
 					if(false){?></script><?php }
3302
-				}elseif(!empty($args['row']['close'])){
3301
+				} elseif(!empty($args['row']['close'])){
3303 3302
 					if(false){?><script><?php }?>
3304 3303
 						el(
3305 3304
 							'div',
@@ -3308,7 +3307,7 @@  discard block
 block discarded – undo
3308 3307
 							},
3309 3308
 					<?php
3310 3309
 					if(false){?></script><?php }
3311
-				}else{
3310
+				} else{
3312 3311
 					if(false){?><script><?php }?>
3313 3312
 						el(
3314 3313
 							'div',
@@ -3413,9 +3412,9 @@  discard block
 block discarded – undo
3413 3412
             $device_type_icon = '';
3414 3413
             if($device_type=='Desktop'){
3415 3414
                 $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3416
-            }elseif($device_type=='Tablet'){
3415
+            } elseif($device_type=='Tablet'){
3417 3416
                 $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3418
-            }elseif($device_type=='Mobile'){
3417
+            } elseif($device_type=='Mobile'){
3419 3418
                 $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3420 3419
             }
3421 3420
 
@@ -3472,7 +3471,7 @@  discard block
 block discarded – undo
3472 3471
 				$args['type'] == 'text';
3473 3472
 				// Save numbers as numbers and not strings
3474 3473
 				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3475
-			}else if ( $args['type'] == 'notice' ) {
3474
+			} else if ( $args['type'] == 'notice' ) {
3476 3475
 
3477 3476
 				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3478 3477
 				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
@@ -3547,7 +3546,7 @@  discard block
 block discarded – undo
3547 3546
                             $key: value
3548 3547
                         });
3549 3548
                     },";
3550
-			}elseif ( $args['type'] == 'gradient' ) {
3549
+			} elseif ( $args['type'] == 'gradient' ) {
3551 3550
 				$type = 'GradientPicker';
3552 3551
 				$extra .= "gradients: [{
3553 3552
 			name: 'Vivid cyan blue to vivid purple',
@@ -3586,7 +3585,7 @@  discard block
 block discarded – undo
3586 3585
 			slug: 'cool-to-warm-spectrum',
3587 3586
 		}],";
3588 3587
 
3589
-			}elseif ( $args['type'] == 'image' ) {
3588
+			} elseif ( $args['type'] == 'image' ) {
3590 3589
 //                print_r($args);
3591 3590
 
3592 3591
                 $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,{
@@ -3723,8 +3722,7 @@  discard block
 block discarded – undo
3723 3722
                 $onchange = "";
3724 3723
 
3725 3724
                 //$inside_elements = ",el('div',{},'file upload')";
3726
-			}
3727
-			elseif ( $args['type'] == 'checkbox' ) {
3725
+			} elseif ( $args['type'] == 'checkbox' ) {
3728 3726
 				$type = 'CheckboxControl';
3729 3727
 				$extra .= "checked: props.attributes.$key,";
3730 3728
 				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
@@ -3736,9 +3734,9 @@  discard block
 block discarded – undo
3736 3734
 
3737 3735
 				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3738 3736
 					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3739
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3737
+				} elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3740 3738
 					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3741
-				}else {
3739
+				} else {
3742 3740
 
3743 3741
 					if ( ! empty( $args['options'] ) ) {
3744 3742
 						$options .= "options: [";
@@ -3902,7 +3900,7 @@  discard block
 block discarded – undo
3902 3900
 				foreach ( $custom_attributes as $key => $val ) {
3903 3901
 					if(is_array($val)){
3904 3902
 						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
3905
-					}else{
3903
+					} else{
3906 3904
 						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
3907 3905
 					}
3908 3906
 				}
@@ -3942,7 +3940,7 @@  discard block
 block discarded – undo
3942 3940
 
3943 3941
                             if($new_args['element']=='InnerBlocks'){
3944 3942
                                 echo "\n el( InnerBlocks, {";
3945
-                            }elseif($new_args['element']=='innerBlocksProps'){
3943
+                            } elseif($new_args['element']=='innerBlocksProps'){
3946 3944
                                 $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
3947 3945
                               //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
3948 3946
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
@@ -3955,11 +3953,11 @@  discard block
 block discarded – undo
3955 3953
                             //    echo '###';
3956 3954
 
3957 3955
                               //  echo '###';
3958
-                            }elseif($new_args['element']=='BlocksProps'){
3956
+                            } elseif($new_args['element']=='BlocksProps'){
3959 3957
 
3960 3958
 								if ( isset($new_args['if_inner_element']) ) {
3961 3959
 									$element = $new_args['if_inner_element'];
3962
-								}else {
3960
+								} else {
3963 3961
 									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
3964 3962
 								}
3965 3963
 
@@ -3970,7 +3968,7 @@  discard block
 block discarded – undo
3970 3968
 
3971 3969
                                // echo "} ),";
3972 3970
 
3973
-                            }else{
3971
+                            } else{
3974 3972
                                 echo "\n el( '" . $new_args['element'] . "', {";
3975 3973
                             }
3976 3974
 
@@ -3995,7 +3993,7 @@  discard block
 block discarded – undo
3995 3993
 
3996 3994
 									if ( $new_key === 'content' ) {
3997 3995
 										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
3998
-									}else if ( $new_key === 'if_content' ) {
3996
+									} else if ( $new_key === 'if_content' ) {
3999 3997
 										echo  $this->block_props_replace(  $new_value  );
4000 3998
 									}
4001 3999
 
@@ -4025,7 +4023,7 @@  discard block
 block discarded – undo
4025 4023
 
4026 4024
                             if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4027 4025
                                 echo "))";// end content
4028
-                            }else{
4026
+                            } else{
4029 4027
                                 echo ")";// end content
4030 4028
                             }
4031 4029
 
@@ -4351,7 +4349,7 @@  discard block
 block discarded – undo
4351 4349
 
4352 4350
 				if(empty($instance['widget_title_tag'])){
4353 4351
 					$output = $args['before_title'] . $title . $args['after_title'];
4354
-				}else{
4352
+				} else{
4355 4353
 					$title_tag = esc_attr( $instance['widget_title_tag'] );
4356 4354
 
4357 4355
 					// classes
@@ -4641,11 +4639,11 @@  discard block
 block discarded – undo
4641 4639
 		public function get_widget_icon($icon = 'box-top', $title = ''){
4642 4640
 			if($icon=='box-top'){
4643 4641
 				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>';
4644
-			}elseif($icon=='box-right'){
4642
+			} elseif($icon=='box-right'){
4645 4643
 				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>';
4646
-			}elseif($icon=='box-bottom'){
4644
+			} elseif($icon=='box-bottom'){
4647 4645
 				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>';
4648
-			}elseif($icon=='box-left'){
4646
+			} elseif($icon=='box-left'){
4649 4647
 				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>';
4650 4648
 			}
4651 4649
 		}
Please login to merge, or discard this patch.
Indentation   +2322 added lines, -2322 removed lines patch added patch discarded remove patch
@@ -1,60 +1,60 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
3
+    exit;
4 4
 }
5 5
 
6 6
 if ( ! class_exists( 'WP_Super_Duper' ) ) {
7 7
 
8
-	define( 'SUPER_DUPER_VER', '1.1.35' );
9
-
10
-	/**
11
-	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
12
-	 *
13
-	 * Should not be called direct but extended instead.
14
-	 *
15
-	 * Class WP_Super_Duper
16
-	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17
-	 * @ver 1.1.1
18
-	 */
19
-	class WP_Super_Duper extends WP_Widget {
20
-
21
-		public $version = SUPER_DUPER_VER;
22
-		public $font_awesome_icon_version = "5.11.2";
23
-		public $block_code;
24
-		public $options;
25
-		public $base_id;
26
-		public $settings_hash;
27
-		public $arguments = array();
28
-		public $instance = array();
29
-		private $class_name;
30
-
31
-		/**
32
-		 * The relative url to the current folder.
33
-		 *
34
-		 * @var string
35
-		 */
36
-		public $url = '';
37
-
38
-		/**
39
-		 * Take the array options and use them to build.
40
-		 */
41
-		public function __construct( $options ) {
42
-			global $sd_widgets;
43
-
44
-			$sd_widgets[ $options['base_id'] ] = array(
45
-				'name'       => $options['name'],
46
-				'class_name' => $options['class_name'],
47
-				'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
-			);
49
-			$this->base_id                     = $options['base_id'];
50
-			// lets filter the options before we do anything
51
-			$options       = apply_filters( "wp_super_duper_options", $options );
52
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
-			$options       = $this->add_name_from_key( $options );
54
-			$this->options = $options;
55
-
56
-			$this->base_id   = $options['base_id'];
57
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
8
+    define( 'SUPER_DUPER_VER', '1.1.35' );
9
+
10
+    /**
11
+     * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
12
+     *
13
+     * Should not be called direct but extended instead.
14
+     *
15
+     * Class WP_Super_Duper
16
+     * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17
+     * @ver 1.1.1
18
+     */
19
+    class WP_Super_Duper extends WP_Widget {
20
+
21
+        public $version = SUPER_DUPER_VER;
22
+        public $font_awesome_icon_version = "5.11.2";
23
+        public $block_code;
24
+        public $options;
25
+        public $base_id;
26
+        public $settings_hash;
27
+        public $arguments = array();
28
+        public $instance = array();
29
+        private $class_name;
30
+
31
+        /**
32
+         * The relative url to the current folder.
33
+         *
34
+         * @var string
35
+         */
36
+        public $url = '';
37
+
38
+        /**
39
+         * Take the array options and use them to build.
40
+         */
41
+        public function __construct( $options ) {
42
+            global $sd_widgets;
43
+
44
+            $sd_widgets[ $options['base_id'] ] = array(
45
+                'name'       => $options['name'],
46
+                'class_name' => $options['class_name'],
47
+                'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
+            );
49
+            $this->base_id                     = $options['base_id'];
50
+            // lets filter the options before we do anything
51
+            $options       = apply_filters( "wp_super_duper_options", $options );
52
+            $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
+            $options       = $this->add_name_from_key( $options );
54
+            $this->options = $options;
55
+
56
+            $this->base_id   = $options['base_id'];
57
+            $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
58 58
 
59 59
             // nested blocks can't work as a widget
60 60
             if(!empty($this->options['nested-block'])){
@@ -65,235 +65,235 @@  discard block
 block discarded – undo
65 65
                 }
66 66
             }
67 67
 
68
-			// init parent
69
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
68
+            // init parent
69
+            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70 70
                 parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
-			}
71
+            }
72 72
 
73 73
 
74
-			if ( isset( $options['class_name'] ) ) {
75
-				// register widget
76
-				$this->class_name = $options['class_name'];
74
+            if ( isset( $options['class_name'] ) ) {
75
+                // register widget
76
+                $this->class_name = $options['class_name'];
77 77
 
78
-				// register shortcode, this needs to be done even for blocks and widgets
78
+                // register shortcode, this needs to be done even for blocks and widgets
79 79
                 $this->register_shortcode();
80 80
 
81 81
 
82
-				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
85
-				}
82
+                // Fusion Builder (avada) support
83
+                if ( function_exists( 'fusion_builder_map' ) ) {
84
+                    add_action( 'init', array( $this, 'register_fusion_element' ) );
85
+                }
86 86
 
87
-				// register block
88
-				if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
89
-				    add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
87
+                // register block
88
+                if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
89
+                    add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
90 90
                 }
91
-			}
91
+            }
92 92
 
93
-			// add the CSS and JS we need ONCE
94
-			global $sd_widget_scripts;
93
+            // add the CSS and JS we need ONCE
94
+            global $sd_widget_scripts;
95 95
 
96
-			if ( ! $sd_widget_scripts ) {
97
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
98
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
99
-				wp_add_inline_style( 'widgets', $this->widget_css() );
96
+            if ( ! $sd_widget_scripts ) {
97
+                wp_add_inline_script( 'admin-widgets', $this->widget_js() );
98
+                wp_add_inline_script( 'customize-controls', $this->widget_js() );
99
+                wp_add_inline_style( 'widgets', $this->widget_css() );
100 100
 
101
-				// maybe add elementor editor styles
102
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
101
+                // maybe add elementor editor styles
102
+                add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
103 103
 
104
-				$sd_widget_scripts = true;
104
+                $sd_widget_scripts = true;
105 105
 
106
-				// add shortcode insert button once
107
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
108
-				// generatepress theme sections compatibility
109
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
110
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
111
-				}
112
-				/* Load script on Divi theme builder page */
113
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
114
-					add_thickbox();
115
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
116
-				}
106
+                // add shortcode insert button once
107
+                add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
108
+                // generatepress theme sections compatibility
109
+                if ( function_exists( 'generate_sections_sections_metabox' ) ) {
110
+                    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
111
+                }
112
+                /* Load script on Divi theme builder page */
113
+                if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
114
+                    add_thickbox();
115
+                    add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
116
+                }
117 117
 
118
-				if ( $this->is_preview() ) {
119
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
120
-					// this makes the insert button work for elementor
121
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
122
-						$this,
123
-						'shortcode_insert_button_script'
124
-					) ); // for elementor
125
-				}
126
-				// this makes the insert button work for cornerstone
127
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
118
+                if ( $this->is_preview() ) {
119
+                    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
120
+                    // this makes the insert button work for elementor
121
+                    add_action( 'elementor/editor/after_enqueue_scripts', array(
122
+                        $this,
123
+                        'shortcode_insert_button_script'
124
+                    ) ); // for elementor
125
+                }
126
+                // this makes the insert button work for cornerstone
127
+                add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
128 128
 
129
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
130
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
129
+                add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
130
+                add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
131 131
 
132
-				// add generator text to head
133
-				add_action( 'admin_head', array( $this, 'generator' ), 99 );
134
-				add_action( 'wp_head', array( $this, 'generator' ), 99 );
135
-			}
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 136
 
137
-			do_action( 'wp_super_duper_widget_init', $options, $this );
138
-		}
137
+            do_action( 'wp_super_duper_widget_init', $options, $this );
138
+        }
139 139
 
140 140
         /**
141 141
          * The register widget function
142 142
          * @return void
143 143
          */
144
-		public function _register() {
144
+        public function _register() {
145 145
             if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
146 146
                 parent::_register();
147
-			}
148
-		}
147
+            }
148
+        }
149 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
-		}
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 156
 
157
-		public function register_fusion_element() {
157
+        public function register_fusion_element() {
158 158
 
159
-			$options = $this->options;
159
+            $options = $this->options;
160 160
 
161
-			if ( $this->base_id ) {
161
+            if ( $this->base_id ) {
162 162
 
163
-				$params = $this->get_fusion_params();
163
+                $params = $this->get_fusion_params();
164 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
-				);
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 171
 
172
-				if ( ! empty( $params ) ) {
173
-					$args['params'] = $params;
174
-				}
172
+                if ( ! empty( $params ) ) {
173
+                    $args['params'] = $params;
174
+                }
175 175
 
176
-				fusion_builder_map( $args );
177
-			}
176
+                fusion_builder_map( $args );
177
+            }
178 178
 
179
-		}
179
+        }
180 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
-					}
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",
212 203
 
213
-					// heading
214
-					$param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
204
+                        ),
205
+                        $val['type'] );
215 206
 
216
-					// description
217
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
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
+                    }
218 212
 
219
-					// param_name
220
-					$param['param_name'] = $key;
213
+                    // heading
214
+                    $param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
221 215
 
222
-					// Default
223
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
216
+                    // description
217
+                    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
224 218
 
225
-					// Group
226
-					if ( isset( $val['group'] ) ) {
227
-						$param['group'] = $val['group'];
228
-					}
219
+                    // param_name
220
+                    $param['param_name'] = $key;
229 221
 
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
-					}
222
+                    // Default
223
+                    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
241 224
 
242
-					// setup the param
243
-					$params[] = $param;
225
+                    // Group
226
+                    if ( isset( $val['group'] ) ) {
227
+                        $param['group'] = $val['group'];
228
+                    }
244 229
 
245
-				}
246
-			}
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
+                    }
247 241
 
242
+                    // setup the param
243
+                    $params[] = $param;
248 244
 
249
-			return $params;
250
-		}
245
+                }
246
+            }
251 247
 
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 248
 
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
-			}
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 276
 
277
-			global $sd_widgets;
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>";
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 294
 
295
-				}
296
-				?>
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();
316
+            $html = ob_get_clean();
317 317
 
318
-			if ( wp_doing_ajax() ) {
319
-				echo $html;
320
-				$should_die = true;
318
+            if ( wp_doing_ajax() ) {
319
+                echo $html;
320
+                $should_die = true;
321 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
-				);
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 327
 
328
-				foreach ( $dont_die as $request ) {
329
-					if ( isset( $_REQUEST[ $request ] ) ) {
330
-						$should_die = false;
331
-					}
332
-				}
328
+                foreach ( $dont_die as $request ) {
329
+                    if ( isset( $_REQUEST[ $request ] ) ) {
330
+                        $should_die = false;
331
+                    }
332
+                }
333 333
 
334
-				if ( $should_die ) {
335
-					wp_die();
336
-				}
334
+                if ( $should_die ) {
335
+                    wp_die();
336
+                }
337 337
 
338
-			} else {
339
-				return $html;
340
-			}
338
+            } else {
339
+                return $html;
340
+            }
341 341
 
342
-			return '';
342
+            return '';
343 343
 
344
-		}
344
+        }
345 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
-			}
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 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
-		}
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 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
-			}
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 388
 
389
-			// invoke an instance method
390
-			$widget = new $class_name;
389
+            // invoke an instance method
390
+            $widget = new $class_name;
391 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
-			?>
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
-		}
400
+            wp_die();
401
+        }
402 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();
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 418
 
419 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
-			}
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 427
 
428
-			echo self::shortcode_button( 'this', 'true' );
428
+            echo self::shortcode_button( 'this', 'true' );
429 429
 
430
-			// see opening note
431
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
432
-				echo '</span>'; // end #insert-media-button
433
-			}
430
+            // see opening note
431
+            if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
432
+                echo '</span>'; // end #insert-media-button
433
+            }
434 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
-			}
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 440
 
441
-			$shortcode_insert_button_once = true;
442
-		}
441
+            $shortcode_insert_button_once = true;
442
+        }
443 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
-			?>
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();
470
+            $html = ob_get_clean();
471 471
 
472
-			// remove line breaks so we can use it in js
473
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
474
-		}
472
+            // remove line breaks so we can use it in js
473
+            return preg_replace( "/\r|\n/", "", trim( $html ) );
474
+        }
475 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
-			?>
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
-		}
566
+            return str_replace( array(
567
+                '<script>',
568
+                '</script>'
569
+            ), '', $output );
570
+        }
571 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
-			?>
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{
716
+                if(! empty( $insert_shortcode_function )){
717
+                    echo $insert_shortcode_function;
718
+                }else{
719 719
 
720
-				/**
721
-				 * Function for super duper insert shortcode.
722
-				 *
723
-				 * @since 1.0.0
724
-				 */
725
-				?>
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
-		}
1052
+        }
1053 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
-			?>
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
-		}
1109
+            return str_replace( array(
1110
+                '<style>',
1111
+                '</style>'
1112
+            ), '', $output );
1113
+        }
1114 1114
 
1115
-		/**
1116
-		 * Gets some JS for the widgets screen.
1117
-		 *
1118
-		 * @return mixed
1119
-		 */
1120
-		public function widget_js() {
1121
-			ob_start();
1122
-			?>
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,513 +1270,513 @@  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
-		}
1279
+            return str_replace( array(
1280
+                '<script>',
1281
+                '</script>'
1282
+            ), '', $output );
1283
+        }
1284 1284
 
1285 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
-			}
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 1303
 
1304
-			return $options;
1305
-		}
1304
+            return $options;
1305
+        }
1306 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
-		}
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 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
-			}
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 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
-			}
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 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
-						}
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 1347
 
1348
-						if ( ! empty( $value ) ) {
1349
-							$value = wp_unslash( $value );
1348
+                        if ( ! empty( $value ) ) {
1349
+                            $value = wp_unslash( $value );
1350 1350
 
1351
-							// Encode [ and ].
1352
-							if ( $is_preview ) {
1353
-								$value = $this->encode_shortcodes( $value );
1354
-							}
1355
-						}
1356
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1357
-					}
1358
-				}
1351
+                            // Encode [ and ].
1352
+                            if ( $is_preview ) {
1353
+                                $value = $this->encode_shortcodes( $value );
1354
+                            }
1355
+                        }
1356
+                        $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1357
+                    }
1358
+                }
1359 1359
 
1360
-				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1360
+                $shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1361 1361
 
1362
-				$content = do_shortcode( $shortcode );
1362
+                $content = do_shortcode( $shortcode );
1363 1363
 
1364
-				// Decode [ and ].
1365
-				if ( ! empty( $content ) && $is_preview ) {
1366
-					$content = $this->decode_shortcodes( $content );
1367
-				}
1364
+                // Decode [ and ].
1365
+                if ( ! empty( $content ) && $is_preview ) {
1366
+                    $content = $this->decode_shortcodes( $content );
1367
+                }
1368 1368
 
1369
-				echo $content;
1370
-			}
1371
-			wp_die();
1372
-		}
1369
+                echo $content;
1370
+            }
1371
+            wp_die();
1372
+        }
1373 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
-			}
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;
1395 1384
 
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 );
1385
+            $args = $this->argument_values( $args );
1408 1386
 
1409
-				if ( ! is_array( $args ) ) {
1410
-					return $args;
1411
-				}
1412
-			}
1387
+            // add extra argument so we know its a output to gutenberg
1388
+            //$args
1389
+            $args = $this->string_to_bool( $args );
1413 1390
 
1414
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1415
-			$class .= " sdel-".$this->get_instance_hash();
1391
+            // if we have a enclosed shortcode we add it to the special `html` argument
1392
+            if ( ! empty( $content ) ) {
1393
+                $args['html'] = $content;
1394
+            }
1416 1395
 
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 );
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
+            }
1419 1413
 
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 );
1414
+            $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1415
+            $class .= " sdel-".$this->get_instance_hash();
1422 1416
 
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
-			}
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 );
1455 1419
 
1456
-			// if preview show a placeholder if empty
1457
-			if ( $this->is_preview() && $output == '' ) {
1458
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1459
-			}
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 );
1460 1422
 
1461
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1462
-		}
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
+            }
1463 1455
 
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
-		}
1456
+            // if preview show a placeholder if empty
1457
+            if ( $this->is_preview() && $output == '' ) {
1458
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1459
+            }
1474 1460
 
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
-			}
1461
+            return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1462
+        }
1491 1463
 
1492
-			return $options;
1493
-		}
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
+        }
1494 1474
 
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
-			}
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
+            }
1513 1491
 
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
-			}
1492
+            return $options;
1493
+        }
1527 1494
 
1528
-			return $argument_values;
1529
-		}
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();
1530 1506
 
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
-		}
1507
+            // set widget instance
1508
+            $this->instance = $instance;
1541 1509
 
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
-			}
1510
+            if ( empty( $this->arguments ) ) {
1511
+                $this->arguments = $this->get_arguments();
1512
+            }
1553 1513
 
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 );
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
+            }
1556 1527
 
1557
-			return $this->arguments;
1558
-		}
1528
+            return $argument_values;
1529
+        }
1559 1530
 
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 = '' ) {
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
+        }
1568 1541
 
1569
-		}
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
+            }
1570 1553
 
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
-		}
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 );
1580 1556
 
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
-			}
1557
+            return $this->arguments;
1558
+        }
1599 1559
 
1600
-			return $show;
1601
-		}
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 = '' ) {
1602 1568
 
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
-				}
1569
+        }
1619 1570
 
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
-			}
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
+        }
1626 1580
 
1627
-			return $url;
1628
-		}
1581
+        /**
1582
+         * Check if we need to show advanced options.
1583
+         *
1584
+         * @return bool
1585
+         */
1586
+        public function block_show_advanced() {
1629 1587
 
1630
-		/**
1631
-		 * Get the url path to the current folder.
1632
-		 *
1633
-		 * @return string
1634
-		 */
1635
-		public function get_url_old() {
1588
+            $show      = false;
1589
+            $arguments = $this->get_arguments();
1636 1590
 
1637
-			$url = $this->url;
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
+            }
1638 1599
 
1639
-			if ( ! $url ) {
1640
-				// check if we are inside a plugin
1641
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1600
+            return $show;
1601
+        }
1642 1602
 
1643
-				$dir_parts = explode( "/wp-content/", $file_dir );
1644
-				$url_parts = explode( "/wp-content/", plugins_url() );
1603
+        /**
1604
+         * Get the url path to the current folder.
1605
+         *
1606
+         * @return string
1607
+         */
1608
+        public function get_url() {
1609
+            $url = $this->url;
1645 1610
 
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
-			}
1611
+            if ( ! $url ) {
1612
+                $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1613
+                $content_url = untrailingslashit( WP_CONTENT_URL );
1651 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
+                }
1652 1619
 
1653
-			return $url;
1654
-		}
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
+            }
1655 1626
 
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
-			}
1627
+            return $url;
1628
+        }
1681 1629
 
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
-			}
1630
+        /**
1631
+         * Get the url path to the current folder.
1632
+         *
1633
+         * @return string
1634
+         */
1635
+        public function get_url_old() {
1687 1636
 
1688
-			return $icon;
1689
-		}
1637
+            $url = $this->url;
1690 1638
 
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
-				}
1639
+            if ( ! $url ) {
1640
+                // check if we are inside a plugin
1641
+                $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1704 1642
 
1705
-				// only add sections if more than one
1706
-				if ( $add_sections ) {
1707
-					$arguments = $temp_arguments;
1708
-				}
1709
-			}
1643
+                $dir_parts = explode( "/wp-content/", $file_dir );
1644
+                $url_parts = explode( "/wp-content/", plugins_url() );
1710 1645
 
1711
-			return $arguments;
1712
-		}
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
+            }
1713 1651
 
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 1652
 
1730
-				if ( ! $has_sections ) {
1731
-					return $tabs;
1732
-				}
1653
+            return $url;
1654
+        }
1733 1655
 
1734
-				$new_tabs = array();
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
+            }
1735 1681
 
1736
-				foreach ( $tabs as $tab_key => $tab ) {
1737
-					$new_groups = array();
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
+            }
1738 1687
 
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
-					}
1688
+            return $icon;
1689
+        }
1746 1690
 
1747
-					if ( ! empty( $new_groups ) ) {
1748
-						$tab['groups'] = $new_groups;
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
+                }
1749 1704
 
1750
-						$new_tabs[ $tab_key ] = $tab;
1751
-					}
1752
-				}
1705
+                // only add sections if more than one
1706
+                if ( $add_sections ) {
1707
+                    $arguments = $temp_arguments;
1708
+                }
1709
+            }
1753 1710
 
1754
-				$tabs = $new_tabs;
1755
-			}
1711
+            return $arguments;
1712
+        }
1756 1713
 
1757
-			return $tabs;
1758
-		}
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
+            }
1759 1756
 
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
-			?>
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 1775
 			<script>
1776 1776
 			<?php
1777
-			if ( ! $sd_is_js_functions_loaded ) {
1778
-				$sd_is_js_functions_loaded = true;
1779
-			?>
1777
+            if ( ! $sd_is_js_functions_loaded ) {
1778
+                $sd_is_js_functions_loaded = true;
1779
+            ?>
1780 1780
 function sd_show_view_options($this){
1781 1781
 	if(jQuery($this).html().length){
1782 1782
 		jQuery($this).html('');
@@ -2226,8 +2226,8 @@  discard block
 block discarded – undo
2226 2226
                 $classes = [];
2227 2227
 
2228 2228
 				<?php
2229
-				if($aui_bs5){
2230
-					?>
2229
+                if($aui_bs5){
2230
+                    ?>
2231 2231
 				$aui_bs5 = true;
2232 2232
 				$p_ml = 'ms-';
2233 2233
 				$p_mr = 'me-';
@@ -2235,8 +2235,8 @@  discard block
 block discarded – undo
2235 2235
 				$p_pl = 'ps-';
2236 2236
 				$p_pr = 'pe-';
2237 2237
 					<?php
2238
-				}else{
2239
-						?>
2238
+                }else{
2239
+                        ?>
2240 2240
 				$aui_bs5 = false;
2241 2241
 				$p_ml = 'ml-';
2242 2242
 				$p_mr = 'mr-';
@@ -2244,8 +2244,8 @@  discard block
 block discarded – undo
2244 2244
 				$p_pl = 'pl-';
2245 2245
 				$p_pr = 'pr-';
2246 2246
 					<?php
2247
-				}
2248
-				?>
2247
+                }
2248
+                ?>
2249 2249
 
2250 2250
                 // margins
2251 2251
 	            if ( $args['mt'] !== undefined && $args['mt'] !== '' ) { $classes.push( "mt-" + $args['mt'] );  $mt = $args['mt']; }else{$mt = null;}
@@ -2428,10 +2428,10 @@  discard block
 block discarded – undo
2428 2428
 
2429 2429
             }
2430 2430
 
2431
-			if(method_exists($this,'block_global_js')){
2432
-					echo $this->block_global_js();
2433
-			}
2434
-			?>
2431
+            if(method_exists($this,'block_global_js')){
2432
+                    echo $this->block_global_js();
2433
+            }
2434
+            ?>
2435 2435
 
2436 2436
 jQuery(function() {
2437 2437
 
@@ -2481,14 +2481,14 @@  discard block
 block discarded – undo
2481 2481
 						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/.
2482 2482
 						supports: {
2483 2483
 							<?php
2484
-							if ( isset( $this->options['block-supports'] ) ) {
2485
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2486
-							}
2487
-							?>
2484
+                            if ( isset( $this->options['block-supports'] ) ) {
2485
+                                echo $this->array_to_attributes( $this->options['block-supports'] );
2486
+                            }
2487
+                            ?>
2488 2488
 						},
2489 2489
 						<?php
2490
-						if ( isset( $this->options['block-label'] ) ) {
2491
-						?>
2490
+                        if ( isset( $this->options['block-label'] ) ) {
2491
+                        ?>
2492 2492
 						__experimentalLabel( attributes, { context } ) {
2493 2493
                             return <?php echo $this->options['block-label']; ?>;
2494 2494
                         },
@@ -2497,7 +2497,7 @@  discard block
 block discarded – undo
2497 2497
                         ?>
2498 2498
 						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.
2499 2499
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
2500
-						echo "keywords : " . $this->options['block-keywords'] . ",";
2500
+                        echo "keywords : " . $this->options['block-keywords'] . ",";
2501 2501
 
2502 2502
 //						// block hover preview.
2503 2503
 //						$example_args = array();
@@ -2522,86 +2522,86 @@  discard block
 block discarded – undo
2522 2522
 
2523 2523
                         }
2524 2524
 
2525
-						// maybe set no_wrap
2526
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2527
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2528
-							$no_wrap = true;
2529
-						}
2530
-						if ( $no_wrap ) {
2531
-							$this->options['block-wrap'] = '';
2532
-						}
2525
+                        // maybe set no_wrap
2526
+                        $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2527
+                        if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2528
+                            $no_wrap = true;
2529
+                        }
2530
+                        if ( $no_wrap ) {
2531
+                            $this->options['block-wrap'] = '';
2532
+                        }
2533 2533
 
2534
-						// maybe load the drag/drop functions.
2535
-						$img_drag_drop = false;
2534
+                        // maybe load the drag/drop functions.
2535
+                        $img_drag_drop = false;
2536 2536
 
2537
-						$show_alignment = false;
2538
-						// align feature
2539
-						/*echo "supports: {";
2537
+                        $show_alignment = false;
2538
+                        // align feature
2539
+                        /*echo "supports: {";
2540 2540
 						echo "	align: true,";
2541 2541
 						echo "  html: false";
2542 2542
 						echo "},";*/
2543 2543
 
2544
-						if ( ! empty( $this->arguments ) ) {
2545
-							echo "attributes : {";
2544
+                        if ( ! empty( $this->arguments ) ) {
2545
+                            echo "attributes : {";
2546 2546
 
2547
-							if ( $show_advanced ) {
2548
-								echo "show_advanced: {";
2549
-								echo "	type: 'boolean',";
2550
-								echo "  default: false,";
2551
-								echo "},";
2552
-							}
2547
+                            if ( $show_advanced ) {
2548
+                                echo "show_advanced: {";
2549
+                                echo "	type: 'boolean',";
2550
+                                echo "  default: false,";
2551
+                                echo "},";
2552
+                            }
2553 2553
 
2554
-							// block wrap element
2555
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2556
-								echo "block_wrap: {";
2557
-								echo "	type: 'string',";
2558
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2559
-								echo "},";
2560
-							}
2554
+                            // block wrap element
2555
+                            if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2556
+                                echo "block_wrap: {";
2557
+                                echo "	type: 'string',";
2558
+                                echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2559
+                                echo "},";
2560
+                            }
2561 2561
 
2562 2562
 
2563 2563
 
2564
-							foreach ( $this->arguments as $key => $args ) {
2564
+                            foreach ( $this->arguments as $key => $args ) {
2565 2565
 
2566
-								if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2567
-									$img_drag_drop = true;
2568
-								}
2566
+                                if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2567
+                                    $img_drag_drop = true;
2568
+                                }
2569 2569
 
2570
-								// set if we should show alignment
2571
-								if ( $key == 'alignment' ) {
2572
-									$show_alignment = true;
2573
-								}
2570
+                                // set if we should show alignment
2571
+                                if ( $key == 'alignment' ) {
2572
+                                    $show_alignment = true;
2573
+                                }
2574 2574
 
2575
-								$extra = '';
2575
+                                $extra = '';
2576 2576
 
2577
-								if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2578
-									continue;
2579
-								}
2580
-								elseif ( $args['type'] == 'checkbox' ) {
2581
-									$type    = 'boolean';
2582
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2583
-								} elseif ( $args['type'] == 'number' ) {
2584
-									$type    = 'number';
2585
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2586
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2587
-									$type = 'array';
2588
-									if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2589
-										$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2590
-									} else {
2591
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2592
-									}
2593
-								} elseif ( $args['type'] == 'tagselect' ) {
2594
-									$type    = 'array';
2595
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2596
-								} elseif ( $args['type'] == 'multiselect' ) {
2597
-									$type    = 'array';
2598
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2599
-								} elseif ( $args['type'] == 'image_xy' ) {
2600
-									$type    = 'object';
2601
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2602
-								} elseif ( $args['type'] == 'image' ) {
2603
-									$type    = 'string';
2604
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2577
+                                if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2578
+                                    continue;
2579
+                                }
2580
+                                elseif ( $args['type'] == 'checkbox' ) {
2581
+                                    $type    = 'boolean';
2582
+                                    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2583
+                                } elseif ( $args['type'] == 'number' ) {
2584
+                                    $type    = 'number';
2585
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2586
+                                } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2587
+                                    $type = 'array';
2588
+                                    if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2589
+                                        $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2590
+                                    } else {
2591
+                                        $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2592
+                                    }
2593
+                                } elseif ( $args['type'] == 'tagselect' ) {
2594
+                                    $type    = 'array';
2595
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2596
+                                } elseif ( $args['type'] == 'multiselect' ) {
2597
+                                    $type    = 'array';
2598
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2599
+                                } elseif ( $args['type'] == 'image_xy' ) {
2600
+                                    $type    = 'object';
2601
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2602
+                                } elseif ( $args['type'] == 'image' ) {
2603
+                                    $type    = 'string';
2604
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2605 2605
 
2606 2606
                                     // add a field for ID
2607 2607
 //                                    echo $key . "_id : {";
@@ -2611,25 +2611,25 @@  discard block
 block discarded – undo
2611 2611
 //                                    echo "type : 'object',";
2612 2612
 //                                    echo "},";
2613 2613
 
2614
-								} else {
2615
-									$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2616
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2614
+                                } else {
2615
+                                    $type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2616
+                                    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2617 2617
 
2618
-								}
2619
-								echo $key . " : {";
2620
-								echo "type : '$type',";
2621
-								echo "default : $default,";
2622
-								echo "},";
2623
-							}
2618
+                                }
2619
+                                echo $key . " : {";
2620
+                                echo "type : '$type',";
2621
+                                echo "default : $default,";
2622
+                                echo "},";
2623
+                            }
2624 2624
 
2625
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2626
-							echo "className: { type: 'string', default: '' },";
2625
+                            echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2626
+                            echo "className: { type: 'string', default: '' },";
2627 2627
 
2628
-							echo "},";
2628
+                            echo "},";
2629 2629
 
2630
-						}
2630
+                        }
2631 2631
 
2632
-						?>
2632
+                        ?>
2633 2633
 
2634 2634
 						// The "edit" property must be a valid function.
2635 2635
 						edit: function (props) {
@@ -2728,9 +2728,9 @@  discard block
 block discarded – undo
2728 2728
 
2729 2729
 	var $value = '';
2730 2730
 	<?php
2731
-	// if we have a post_type and a category then link them
2732
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2733
-	?>
2731
+    // if we have a post_type and a category then link them
2732
+    if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2733
+    ?>
2734 2734
 	if(typeof(prev_attributes[props.clientId]) != 'undefined'){
2735 2735
 		$pt = props.attributes.post_type;
2736 2736
 		if(post_type_rest_slugs.length){
@@ -2743,11 +2743,11 @@  discard block
 block discarded – undo
2743 2743
 			term_query_type = $pt;
2744 2744
 		}
2745 2745
 <?php
2746
-	$cat_path = '';
2747
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2748
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2749
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2750
-	}
2746
+    $cat_path = '';
2747
+    if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2748
+        $cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2749
+        $cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2750
+    }
2751 2751
 ?>
2752 2752
 		/* taxonomies */
2753 2753
 		if($value && 'post_type' in prev_attributes[props.clientId] && 'category' in prev_attributes[props.clientId] && run){
@@ -2839,7 +2839,7 @@  discard block
 block discarded – undo
2839 2839
 <?php
2840 2840
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2841 2841
 if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2842
-	echo 'const { deviceType } = "";';
2842
+    echo 'const { deviceType } = "";';
2843 2843
 }else{
2844 2844
 ?>
2845 2845
 /** Get device type const. */
@@ -2873,8 +2873,8 @@  discard block
 block discarded – undo
2873 2873
 										'attributes': props.attributes,
2874 2874
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
2875 2875
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
2876
-										echo $post->ID;
2877
-									}else{echo '0';}?>,
2876
+                                        echo $post->ID;
2877
+                                    }else{echo '0';}?>,
2878 2878
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
2879 2879
 									};
2880 2880
 
@@ -2951,10 +2951,10 @@  discard block
 block discarded – undo
2951 2951
 
2952 2952
 									<?php
2953 2953
 
2954
-									if(! empty( $this->arguments )){
2954
+                                    if(! empty( $this->arguments )){
2955 2955
 
2956
-									if ( $show_advanced ) {
2957
-									?>
2956
+                                    if ( $show_advanced ) {
2957
+                                    ?>
2958 2958
 									el('div', {
2959 2959
 											style: {'padding-left': '16px','padding-right': '16px'}
2960 2960
 										},
@@ -2971,127 +2971,127 @@  discard block
 block discarded – undo
2971 2971
 									)
2972 2972
 									,
2973 2973
 									<?php
2974
-									}
2974
+                                    }
2975 2975
 
2976
-									$arguments = $this->group_arguments( $this->arguments );
2977
-									$block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
2976
+                                    $arguments = $this->group_arguments( $this->arguments );
2977
+                                    $block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
2978 2978
 
2979
-									// Do we have sections?
2980
-									$has_sections = $arguments == $this->arguments ? false : true;
2979
+                                    // Do we have sections?
2980
+                                    $has_sections = $arguments == $this->arguments ? false : true;
2981 2981
 
2982
-									if($has_sections){
2983
-									$panel_count = 0;
2984
-									$open_tab = '';
2982
+                                    if($has_sections){
2983
+                                    $panel_count = 0;
2984
+                                    $open_tab = '';
2985 2985
 
2986
-									$open_tab_groups = array();
2987
-									$used_tabs = array();
2986
+                                    $open_tab_groups = array();
2987
+                                    $used_tabs = array();
2988 2988
 
2989
-									foreach ( $arguments as $key => $args ) {
2990
-										$close_tab = false;
2991
-										$close_tabs = false;
2989
+                                    foreach ( $arguments as $key => $args ) {
2990
+                                        $close_tab = false;
2991
+                                        $close_tabs = false;
2992 2992
 
2993
-										 if ( ! empty( $block_group_tabs ) ) {
2994
-											foreach ( $block_group_tabs as $tab_name => $tab_args ) {
2995
-												if ( in_array( $key, $tab_args['groups'] ) ) {
2996
-													$open_tab_groups[] = $key;
2993
+                                            if ( ! empty( $block_group_tabs ) ) {
2994
+                                            foreach ( $block_group_tabs as $tab_name => $tab_args ) {
2995
+                                                if ( in_array( $key, $tab_args['groups'] ) ) {
2996
+                                                    $open_tab_groups[] = $key;
2997 2997
 
2998
-													if ( $open_tab != $tab_name ) {
2999
-														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3000
-														$tab_args['tab']['open'] = true;
2998
+                                                    if ( $open_tab != $tab_name ) {
2999
+                                                        $tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3000
+                                                        $tab_args['tab']['open'] = true;
3001 3001
 
3002
-														$this->block_tab_start( '', $tab_args );
3003
-														$open_tab = $tab_name;
3004
-														$used_tabs[] = $tab_name;
3005
-													}
3002
+                                                        $this->block_tab_start( '', $tab_args );
3003
+                                                        $open_tab = $tab_name;
3004
+                                                        $used_tabs[] = $tab_name;
3005
+                                                    }
3006 3006
 
3007
-													if ( $open_tab_groups == $tab_args['groups'] ) {
3008
-														$close_tab = true;
3009
-														$open_tab_groups = array();
3007
+                                                    if ( $open_tab_groups == $tab_args['groups'] ) {
3008
+                                                        $close_tab = true;
3009
+                                                        $open_tab_groups = array();
3010 3010
 
3011
-														if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3012
-															$close_tabs = true;
3013
-														}
3014
-													}
3015
-												}
3016
-											}
3017
-										}
3018
-										?>
3011
+                                                        if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3012
+                                                            $close_tabs = true;
3013
+                                                        }
3014
+                                                    }
3015
+                                                }
3016
+                                            }
3017
+                                        }
3018
+                                        ?>
3019 3019
 										el(wp.components.PanelBody, {
3020 3020
 												title: '<?php esc_attr_e( $key ); ?>',
3021 3021
 												initialOpen: <?php if ( $panel_count ) {
3022
-												echo "false";
3023
-											} else {
3024
-												echo "true";
3025
-											}?>
3022
+                                                echo "false";
3023
+                                            } else {
3024
+                                                echo "true";
3025
+                                            }?>
3026 3026
 											},
3027 3027
 											<?php
3028
-											foreach ( $args as $k => $a ) {
3029
-												$this->block_tab_start( $k, $a );
3030
-												$this->block_row_start( $k, $a );
3031
-												$this->build_block_arguments( $k, $a );
3032
-												$this->block_row_end( $k, $a );
3033
-												$this->block_tab_end( $k, $a );
3034
-											}
3035
-											?>
3028
+                                            foreach ( $args as $k => $a ) {
3029
+                                                $this->block_tab_start( $k, $a );
3030
+                                                $this->block_row_start( $k, $a );
3031
+                                                $this->build_block_arguments( $k, $a );
3032
+                                                $this->block_row_end( $k, $a );
3033
+                                                $this->block_tab_end( $k, $a );
3034
+                                            }
3035
+                                            ?>
3036 3036
 										),
3037 3037
 										<?php
3038
-										$panel_count ++;
3038
+                                        $panel_count ++;
3039 3039
 
3040
-										if($close_tab || $close_tabs){
3041
-											$tab_args = array(
3042
-												'tab'	=> array(
3043
-													'tabs_close' => $close_tabs,
3044
-												'close' => true,
3045
-												)
3040
+                                        if($close_tab || $close_tabs){
3041
+                                            $tab_args = array(
3042
+                                                'tab'	=> array(
3043
+                                                    'tabs_close' => $close_tabs,
3044
+                                                'close' => true,
3045
+                                                )
3046 3046
 
3047
-											);
3048
-											$this->block_tab_end( '', $tab_args );
3047
+                                            );
3048
+                                            $this->block_tab_end( '', $tab_args );
3049 3049
 //											echo '###close'; print_r($tab_args);
3050
-											$panel_count = 0;
3051
-										}
3050
+                                            $panel_count = 0;
3051
+                                        }
3052 3052
 //
3053 3053
 
3054
-									}
3055
-									}else {
3056
-									?>
3054
+                                    }
3055
+                                    }else {
3056
+                                    ?>
3057 3057
 									el(wp.components.PanelBody, {
3058 3058
 											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
3059 3059
 											initialOpen: true
3060 3060
 										},
3061 3061
 										<?php
3062
-										foreach ( $this->arguments as $key => $args ) {
3063
-											$this->block_row_start( $key, $args );
3064
-											$this->build_block_arguments( $key, $args );
3065
-											$this->block_row_end( $key, $args );
3066
-										}
3067
-										?>
3062
+                                        foreach ( $this->arguments as $key => $args ) {
3063
+                                            $this->block_row_start( $key, $args );
3064
+                                            $this->build_block_arguments( $key, $args );
3065
+                                            $this->block_row_end( $key, $args );
3066
+                                        }
3067
+                                        ?>
3068 3068
 									),
3069 3069
 									<?php
3070
-									}
3070
+                                    }
3071 3071
 
3072
-									}
3073
-									?>
3072
+                                    }
3073
+                                    ?>
3074 3074
 
3075 3075
 								),
3076 3076
 
3077 3077
 								<?php
3078
-								// If the user sets block-output array then build it
3079
-								if ( ! empty( $this->options['block-output'] ) ) {
3080
-								$this->block_element( $this->options['block-output'] );
3081
-							}elseif(!empty($this->options['block-edit-return'])){
3082
-                                   echo $this->options['block-edit-return'];
3083
-							}else{
3084
-								// if no block-output is set then we try and get the shortcode html output via ajax.
3085
-								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3086
-								?>
3078
+                                // If the user sets block-output array then build it
3079
+                                if ( ! empty( $this->options['block-output'] ) ) {
3080
+                                $this->block_element( $this->options['block-output'] );
3081
+                            }elseif(!empty($this->options['block-edit-return'])){
3082
+                                    echo $this->options['block-edit-return'];
3083
+                            }else{
3084
+                                // if no block-output is set then we try and get the shortcode html output via ajax.
3085
+                                $block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3086
+                                ?>
3087 3087
 								el('<?php echo esc_attr($block_edit_wrap_tag); ?>', wp.blockEditor.useBlockProps({
3088 3088
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
3089 3089
 									className: props.className,
3090 3090
 									style: {'minHeight': '30px'}
3091 3091
 								}))
3092 3092
 								<?php
3093
-								}
3094
-								?>
3093
+                                }
3094
+                                ?>
3095 3095
 							]; // end return
3096 3096
 
3097 3097
 							<?php
@@ -3110,11 +3110,11 @@  discard block
 block discarded – undo
3110 3110
 							$html = '';
3111 3111
 							<?php
3112 3112
 
3113
-							if(! empty( $this->arguments )){
3113
+                            if(! empty( $this->arguments )){
3114 3114
 
3115
-							foreach($this->arguments as $key => $args){
3116
-                               // if($args['type']=='tabs'){continue;}
3117
-							?>
3115
+                            foreach($this->arguments as $key => $args){
3116
+                                // if($args['type']=='tabs'){continue;}
3117
+                            ?>
3118 3118
 							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3119 3119
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
3120 3120
 									$html = attr.<?php echo esc_attr( $key );?>;
@@ -3125,10 +3125,10 @@  discard block
 block discarded – undo
3125 3125
 								}
3126 3126
 							}
3127 3127
 							<?php
3128
-							}
3129
-							}
3128
+                            }
3129
+                            }
3130 3130
 
3131
-							?>
3131
+                            ?>
3132 3132
 							content += "]";
3133 3133
 
3134 3134
                             <?php
@@ -3175,7 +3175,7 @@  discard block
 block discarded – undo
3175 3175
 //                               $this->block_element( $this->options['block-output'], true );
3176 3176
 //                               echo ";";
3177 3177
 
3178
-                               ?>
3178
+                                ?>
3179 3179
                               return el(
3180 3180
                                    '',
3181 3181
                                    {},
@@ -3185,9 +3185,9 @@  discard block
 block discarded – undo
3185 3185
                                );
3186 3186
                                 <?php
3187 3187
 
3188
-							}elseif(!empty($this->options['block-save-return'])){
3189
-                                   echo 'return ' . $this->options['block-save-return'];
3190
-							}elseif(!empty($this->options['nested-block'])){
3188
+                            }elseif(!empty($this->options['block-save-return'])){
3189
+                                    echo 'return ' . $this->options['block-save-return'];
3190
+                            }elseif(!empty($this->options['nested-block'])){
3191 3191
                                 ?>
3192 3192
                               return el(
3193 3193
                                    '',
@@ -3197,22 +3197,22 @@  discard block
 block discarded – undo
3197 3197
                                    el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3198 3198
                                );
3199 3199
                                 <?php
3200
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3200
+                            }elseif(!empty( $this->options['block-save-return'] ) ){
3201 3201
                                 echo "return ". $this->options['block-edit-return'].";";
3202
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3203
-							?>
3202
+                            }elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3203
+                            ?>
3204 3204
 							return content;
3205 3205
 							<?php
3206
-							}else{
3207
-							?>
3206
+                            }else{
3207
+                            ?>
3208 3208
 							var block_wrap = 'div';
3209 3209
 							if (attr.hasOwnProperty("block_wrap")) {
3210 3210
 								block_wrap = attr.block_wrap;
3211 3211
 							}
3212 3212
 							return el(block_wrap, wp.blockEditor.useBlockProps.save( {dangerouslySetInnerHTML: {__html: content}, className: align} ));
3213 3213
 							<?php
3214
-							}
3215
-							?>
3214
+                            }
3215
+                            ?>
3216 3216
 
3217 3217
 
3218 3218
 						}
@@ -3226,29 +3226,29 @@  discard block
 block discarded – undo
3226 3226
                 });
3227 3227
 			</script>
3228 3228
 			<?php
3229
-			$output = ob_get_clean();
3229
+            $output = ob_get_clean();
3230 3230
 
3231
-			/*
3231
+            /*
3232 3232
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
3233 3233
 			 */
3234 3234
 
3235
-			return str_replace( array(
3236
-				'<script>',
3237
-				'</script>'
3238
-			), '', $output );
3239
-		}
3235
+            return str_replace( array(
3236
+                '<script>',
3237
+                '</script>'
3238
+            ), '', $output );
3239
+        }
3240 3240
 
3241 3241
 
3242 3242
 
3243
-		public function block_row_start($key, $args){
3243
+        public function block_row_start($key, $args){
3244 3244
 
3245
-			// check for row
3246
-			if(!empty($args['row'])){
3245
+            // check for row
3246
+            if(!empty($args['row'])){
3247 3247
 
3248
-				if(!empty($args['row']['open'])){
3248
+                if(!empty($args['row']['open'])){
3249 3249
 
3250
-				// element require
3251
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3250
+                // element require
3251
+                $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3252 3252
                 $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3253 3253
                 $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3254 3254
                 $device_type_icon = '';
@@ -3259,10 +3259,10 @@  discard block
 block discarded – undo
3259 3259
                 }elseif($device_type=='Mobile'){
3260 3260
                     $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3261 3261
                 }
3262
-				echo $element_require;
3262
+                echo $element_require;
3263 3263
                 echo $device_type_require;
3264 3264
 
3265
-					if(false){?><script><?php }?>
3265
+                    if(false){?><script><?php }?>
3266 3266
 						el('div', {
3267 3267
 								className: 'bsui components-base-control',
3268 3268
 							},
@@ -3300,51 +3300,51 @@  discard block
 block discarded – undo
3300 3300
 									},
3301 3301
 
3302 3302
 					<?php
3303
-					if(false){?></script><?php }
3304
-				}elseif(!empty($args['row']['close'])){
3305
-					if(false){?><script><?php }?>
3303
+                    if(false){?></script><?php }
3304
+                }elseif(!empty($args['row']['close'])){
3305
+                    if(false){?><script><?php }?>
3306 3306
 						el(
3307 3307
 							'div',
3308 3308
 							{
3309 3309
 								className: 'col pl-0 ps-0',
3310 3310
 							},
3311 3311
 					<?php
3312
-					if(false){?></script><?php }
3313
-				}else{
3314
-					if(false){?><script><?php }?>
3312
+                    if(false){?></script><?php }
3313
+                }else{
3314
+                    if(false){?><script><?php }?>
3315 3315
 						el(
3316 3316
 							'div',
3317 3317
 							{
3318 3318
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3319 3319
 							},
3320 3320
 					<?php
3321
-					if(false){?></script><?php }
3322
-				}
3321
+                    if(false){?></script><?php }
3322
+                }
3323 3323
 
3324
-			}
3324
+            }
3325 3325
 
3326
-		}
3326
+        }
3327 3327
 
3328
-		public function block_row_end($key, $args){
3328
+        public function block_row_end($key, $args){
3329 3329
 
3330
-			if(!empty($args['row'])){
3331
-				// maybe close
3332
-				if(!empty($args['row']['close'])){
3333
-					echo "))";
3334
-				}
3330
+            if(!empty($args['row'])){
3331
+                // maybe close
3332
+                if(!empty($args['row']['close'])){
3333
+                    echo "))";
3334
+                }
3335 3335
 
3336
-				echo "),";
3337
-			}
3338
-		}
3336
+                echo "),";
3337
+            }
3338
+        }
3339 3339
 
3340
-		public function block_tab_start($key, $args){
3340
+        public function block_tab_start($key, $args){
3341 3341
 
3342
-			// check for row
3343
-			if(!empty($args['tab'])){
3342
+            // check for row
3343
+            if(!empty($args['tab'])){
3344 3344
 
3345
-				if(!empty($args['tab']['tabs_open'])){
3345
+                if(!empty($args['tab']['tabs_open'])){
3346 3346
 
3347
-					if(false){?><script><?php }?>
3347
+                    if(false){?><script><?php }?>
3348 3348
 
3349 3349
 el('div',{className: 'bsui'},
3350 3350
 
@@ -3357,12 +3357,12 @@  discard block
 block discarded – undo
3357 3357
 										tabs: [
3358 3358
 
3359 3359
 					<?php
3360
-					if(false){?></script><?php }
3361
-				}
3360
+                    if(false){?></script><?php }
3361
+                }
3362 3362
 
3363
-				if(!empty($args['tab']['open'])){
3363
+                if(!empty($args['tab']['open'])){
3364 3364
 
3365
-					if(false){?><script><?php }?>
3365
+                    if(false){?><script><?php }?>
3366 3366
 							{
3367 3367
 												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3368 3368
 												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
@@ -3371,44 +3371,44 @@  discard block
 block discarded – undo
3371 3371
 									className: 'components-base-control__help mb-0',
3372 3372
 									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3373 3373
 								}),<?php }
3374
-					if(false){?></script><?php }
3375
-				}
3374
+                    if(false){?></script><?php }
3375
+                }
3376 3376
 
3377
-			}
3377
+            }
3378 3378
 
3379
-		}
3379
+        }
3380 3380
 
3381
-		public function block_tab_end($key, $args){
3381
+        public function block_tab_end($key, $args){
3382 3382
 
3383
-			if(!empty($args['tab'])){
3384
-				// maybe close
3385
-				if(!empty($args['tab']['close'])){
3386
-					echo ")}, /* tab close */";
3387
-				}
3383
+            if(!empty($args['tab'])){
3384
+                // maybe close
3385
+                if(!empty($args['tab']['close'])){
3386
+                    echo ")}, /* tab close */";
3387
+                }
3388 3388
 
3389
-				if(!empty($args['tab']['tabs_close'])){
3390
-					if(false){?><script><?php }?>
3389
+                if(!empty($args['tab']['tabs_close'])){
3390
+                    if(false){?><script><?php }?>
3391 3391
 						]}, ( tab ) => {
3392 3392
 								return tab.content;
3393 3393
 							}
3394 3394
 						)), /* tabs close */
3395 3395
 					<?php if(false){ ?></script><?php }
3396
-				}
3397
-			}
3398
-		}
3396
+                }
3397
+            }
3398
+        }
3399 3399
 
3400
-		public function build_block_arguments( $key, $args ) {
3401
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3402
-			$options           = '';
3403
-			$extra             = '';
3404
-			$require           = '';
3400
+        public function build_block_arguments( $key, $args ) {
3401
+            $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3402
+            $options           = '';
3403
+            $extra             = '';
3404
+            $require           = '';
3405 3405
             $inside_elements   = '';
3406
-			$after_elements	   = '';
3406
+            $after_elements	   = '';
3407 3407
 
3408
-			// `content` is a protected and special argument
3409
-			if ( $key == 'content' ) {
3410
-				return;
3411
-			}
3408
+            // `content` is a protected and special argument
3409
+            if ( $key == 'content' ) {
3410
+                return;
3411
+            }
3412 3412
 
3413 3413
             $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3414 3414
             $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
@@ -3421,37 +3421,37 @@  discard block
 block discarded – undo
3421 3421
                 $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3422 3422
             }
3423 3423
 
3424
-			// icon
3425
-			$icon = '';
3426
-			if( !empty( $args['icon'] ) ){
3427
-				$icon .= "el('div', {";
3428
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3429
-									$icon .= "className: 'text-center',";
3430
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3431
-								$icon .= "}),";
3432
-
3433
-				// blank title as its added to the icon.
3434
-				$args['title'] = '';
3435
-			}
3424
+            // icon
3425
+            $icon = '';
3426
+            if( !empty( $args['icon'] ) ){
3427
+                $icon .= "el('div', {";
3428
+                                    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3429
+                                    $icon .= "className: 'text-center',";
3430
+                                    $icon .= "title: '".addslashes( $args['title'] )."',";
3431
+                                $icon .= "}),";
3432
+
3433
+                // blank title as its added to the icon.
3434
+                $args['title'] = '';
3435
+            }
3436 3436
 
3437
-			// require advanced
3438
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3437
+            // require advanced
3438
+            $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3439 3439
 
3440
-			// element require
3441
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3440
+            // element require
3441
+            $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3442 3442
 
3443 3443
 
3444
-			$onchange  = "props.setAttributes({ $key: $key } )";
3445
-			$onchangecomplete  = "";
3446
-			$value     = "props.attributes.$key";
3447
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3448
-			if ( in_array( $args['type'], $text_type ) ) {
3449
-				$type = 'TextControl';
3450
-				// Save numbers as numbers and not strings
3451
-				if ( $args['type'] == 'number' ) {
3452
-					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3453
-				}
3454
-			}
3444
+            $onchange  = "props.setAttributes({ $key: $key } )";
3445
+            $onchangecomplete  = "";
3446
+            $value     = "props.attributes.$key";
3447
+            $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3448
+            if ( in_array( $args['type'], $text_type ) ) {
3449
+                $type = 'TextControl';
3450
+                // Save numbers as numbers and not strings
3451
+                if ( $args['type'] == 'number' ) {
3452
+                    $onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3453
+                }
3454
+            }
3455 3455
 //			else if ( $args['type'] == 'popup' ) {
3456 3456
 //				$type = 'TextControl';
3457 3457
 //				$args['type'] == 'text';
@@ -3469,21 +3469,21 @@  discard block
 block discarded – undo
3469 3469
 //
3470 3470
 //				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3471 3471
 //			}
3472
-			else if ( $args['type'] == 'styleid' ) {
3473
-				$type = 'TextControl';
3474
-				$args['type'] == 'text';
3475
-				// Save numbers as numbers and not strings
3476
-				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3477
-			}else if ( $args['type'] == 'notice' ) {
3478
-
3479
-				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3480
-				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3481
-
3482
-				$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'}}))),";
3483
-				echo $notice_message ? $element_require . $notice : '';
3484
-				return;
3485
-			}
3486
-			/*
3472
+            else if ( $args['type'] == 'styleid' ) {
3473
+                $type = 'TextControl';
3474
+                $args['type'] == 'text';
3475
+                // Save numbers as numbers and not strings
3476
+                $value     = "props.attributes.$key ? props.attributes.$key : ''";
3477
+            }else if ( $args['type'] == 'notice' ) {
3478
+
3479
+                $notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3480
+                $notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3481
+
3482
+                $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'}}))),";
3483
+                echo $notice_message ? $element_require . $notice : '';
3484
+                return;
3485
+            }
3486
+            /*
3487 3487
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
3488 3488
 						elseif($args['type']=='tabs'){
3489 3489
 							?>
@@ -3536,22 +3536,22 @@  discard block
 block discarded – undo
3536 3536
 							return;
3537 3537
 						}
3538 3538
 */
3539
-			elseif ( $args['type'] == 'color' ) {
3540
-				$type = 'ColorPicker';
3541
-				$onchange = "";
3542
-				$extra = "color: $value,";
3543
-				if(!empty($args['disable_alpha'])){
3544
-					$extra .= "disableAlpha: true,";
3545
-				}
3546
-				$onchangecomplete = "onChangeComplete: function($key) {
3539
+            elseif ( $args['type'] == 'color' ) {
3540
+                $type = 'ColorPicker';
3541
+                $onchange = "";
3542
+                $extra = "color: $value,";
3543
+                if(!empty($args['disable_alpha'])){
3544
+                    $extra .= "disableAlpha: true,";
3545
+                }
3546
+                $onchangecomplete = "onChangeComplete: function($key) {
3547 3547
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
3548 3548
                         props.setAttributes({
3549 3549
                             $key: value
3550 3550
                         });
3551 3551
                     },";
3552
-			}elseif ( $args['type'] == 'gradient' ) {
3553
-				$type = 'GradientPicker';
3554
-				$extra .= "gradients: [{
3552
+            }elseif ( $args['type'] == 'gradient' ) {
3553
+                $type = 'GradientPicker';
3554
+                $extra .= "gradients: [{
3555 3555
 			name: 'Vivid cyan blue to vivid purple',
3556 3556
 			gradient:
3557 3557
 				'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
@@ -3588,7 +3588,7 @@  discard block
 block discarded – undo
3588 3588
 			slug: 'cool-to-warm-spectrum',
3589 3589
 		}],";
3590 3590
 
3591
-			}elseif ( $args['type'] == 'image' ) {
3591
+            }elseif ( $args['type'] == 'image' ) {
3592 3592
 //                print_r($args);
3593 3593
 
3594 3594
                 $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,{
@@ -3613,15 +3613,15 @@  discard block
 block discarded – undo
3613 3613
 
3614 3614
 
3615 3615
                 $value = '""';
3616
-				$type = 'MediaUpload';
3616
+                $type = 'MediaUpload';
3617 3617
                 $extra .= "onSelect: function(media){
3618 3618
                       return props.setAttributes({
3619 3619
                           $key: media.url,
3620 3620
                           {$key}_id: media.id
3621 3621
                         });
3622 3622
                       },";
3623
-                   $extra .= "type: 'image',";
3624
-                   $extra .= "render: function (obj) {
3623
+                    $extra .= "type: 'image',";
3624
+                    $extra .= "render: function (obj) {
3625 3625
                         return el( 'div',{},
3626 3626
                         ( !props.attributes.$key && !props.attributes.{$key}_use_featured ) && el( wp.components.Button, {
3627 3627
                           className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
@@ -3650,8 +3650,8 @@  discard block
 block discarded – undo
3650 3650
                 $onchange = "";
3651 3651
 
3652 3652
                 //$inside_elements = ",el('div',{},'file upload')";
3653
-			} else if ( $args['type'] == 'images' ) {
3654
-				$img_preview = "props.attributes.$key && (function() {
3653
+            } else if ( $args['type'] == 'images' ) {
3654
+                $img_preview = "props.attributes.$key && (function() {
3655 3655
 	let uploads = JSON.parse('['+props.attributes.$key+']');
3656 3656
 	let images = [];
3657 3657
 	uploads.map((upload, index) => (
@@ -3678,9 +3678,9 @@  discard block
 block discarded – undo
3678 3678
 })(),";
3679 3679
 
3680 3680
 
3681
-				$value = '""';
3682
-				$type = 'MediaUpload';
3683
-				$extra .= "onSelect: function(media){
3681
+                $value = '""';
3682
+                $type = 'MediaUpload';
3683
+                $extra .= "onSelect: function(media){
3684 3684
 	let slim_images = props.attributes.$key ? JSON.parse('['+props.attributes.$key+']') : [];
3685 3685
 	if(media.length){
3686 3686
 		for (var i=0; i < media.length; i++) {
@@ -3693,9 +3693,9 @@  discard block
 block discarded – undo
3693 3693
 	}
3694 3694
 	return props.setAttributes({ $key: slimImagesV});
3695 3695
 },";
3696
-				$extra .= "type: 'image',";
3697
-				$extra .= "multiple: true,";
3698
-				$extra .= "render: function (obj) {
3696
+                $extra .= "type: 'image',";
3697
+                $extra .= "multiple: true,";
3698
+                $extra .= "render: function (obj) {
3699 3699
 	/* Init the sort */
3700 3700
 	enableDragSort('sd-sortable');
3701 3701
 	return el( 'div',{},
@@ -3725,37 +3725,37 @@  discard block
 block discarded – undo
3725 3725
                 $onchange = "";
3726 3726
 
3727 3727
                 //$inside_elements = ",el('div',{},'file upload')";
3728
-			}
3729
-			elseif ( $args['type'] == 'checkbox' ) {
3730
-				$type = 'CheckboxControl';
3731
-				$extra .= "checked: props.attributes.$key,";
3732
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3733
-			} elseif ( $args['type'] == 'textarea' ) {
3734
-				$type = 'TextareaControl';
3735
-
3736
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3737
-				$type = 'SelectControl';
3738
-
3739
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3740
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3741
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3742
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3743
-				}else {
3744
-
3745
-					if ( ! empty( $args['options'] ) ) {
3746
-						$options .= "options: [";
3747
-						foreach ( $args['options'] as $option_val => $option_label ) {
3748
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3749
-						}
3750
-						$options .= "],";
3751
-					}
3752
-				}
3753
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3754
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3755
-				}
3728
+            }
3729
+            elseif ( $args['type'] == 'checkbox' ) {
3730
+                $type = 'CheckboxControl';
3731
+                $extra .= "checked: props.attributes.$key,";
3732
+                $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3733
+            } elseif ( $args['type'] == 'textarea' ) {
3734
+                $type = 'TextareaControl';
3735
+
3736
+            } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3737
+                $type = 'SelectControl';
3738
+
3739
+                if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3740
+                    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3741
+                }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3742
+                    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3743
+                }else {
3744
+
3745
+                    if ( ! empty( $args['options'] ) ) {
3746
+                        $options .= "options: [";
3747
+                        foreach ( $args['options'] as $option_val => $option_label ) {
3748
+                            $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3749
+                        }
3750
+                        $options .= "],";
3751
+                    }
3752
+                }
3753
+                if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3754
+                    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3755
+                }
3756 3756
 
3757
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3758
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3757
+                if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3758
+                    $after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3759 3759
                                       className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3760 3760
                                       style: {margin:'-8px 0 8px 0',display: 'block'},
3761 3761
                                       onClick: function(){
@@ -3766,8 +3766,8 @@  discard block
 block discarded – undo
3766 3766
                                     },
3767 3767
                                     'Clear'
3768 3768
                             ),";
3769
-				}
3770
-			} elseif ( $args['type'] == 'tagselect' ) {
3769
+                }
3770
+            } elseif ( $args['type'] == 'tagselect' ) {
3771 3771
 //				$type = 'FormTokenField';
3772 3772
 //
3773 3773
 //				if ( ! empty( $args['options'] ) ) {
@@ -3802,20 +3802,20 @@  discard block
 block discarded – undo
3802 3802
 //				$value     = "[]";
3803 3803
 //				$extra .= ' __experimentalExpandOnFocus: true,';
3804 3804
 
3805
-			} else if ( $args['type'] == 'alignment' ) {
3806
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3807
-			} else if ( $args['type'] == 'margins' ) {
3808
-
3809
-			} else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
3810
-				$type = 'TextControl';
3811
-				$value = "(props.attributes.$key ? props.attributes.$key : '')";
3812
-				$args['type'] = 'text';
3813
-				$options .= 'disabled:true,';
3814
-				$bsvc_title = esc_attr( addslashes( $args['title'] ) );
3815
-				$bsvc_body = $this->block_visibility_fields( $args );
3816
-				// @TODO reset button
3817
-				$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>';
3818
-				$after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
3805
+            } else if ( $args['type'] == 'alignment' ) {
3806
+                $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3807
+            } else if ( $args['type'] == 'margins' ) {
3808
+
3809
+            } else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
3810
+                $type = 'TextControl';
3811
+                $value = "(props.attributes.$key ? props.attributes.$key : '')";
3812
+                $args['type'] = 'text';
3813
+                $options .= 'disabled:true,';
3814
+                $bsvc_title = esc_attr( addslashes( $args['title'] ) );
3815
+                $bsvc_body = $this->block_visibility_fields( $args );
3816
+                // @TODO reset button
3817
+                $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>';
3818
+                $after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
3819 3819
 						className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
3820 3820
 						onClick: function() {
3821 3821
 							var sValue = props.attributes." . $key . ";
@@ -3841,39 +3841,39 @@  discard block
 block discarded – undo
3841 3841
 					},
3842 3842
 					'" . addslashes( ! empty( $args['button_title'] ) ? $args['button_title'] : $args['title'] ) . "'
3843 3843
 				) ),";
3844
-			} else {
3845
-				return;// if we have not implemented the control then don't break the JS.
3846
-			}
3844
+            } else {
3845
+                return;// if we have not implemented the control then don't break the JS.
3846
+            }
3847 3847
 
3848
-			// color input does not show the labels so we add them
3849
-			if($args['type']=='color'){
3850
-				// add show only if advanced
3851
-				echo $require_advanced;
3852
-				// add setting require if defined
3853
-				echo $element_require;
3854
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3855
-			}
3848
+            // color input does not show the labels so we add them
3849
+            if($args['type']=='color'){
3850
+                // add show only if advanced
3851
+                echo $require_advanced;
3852
+                // add setting require if defined
3853
+                echo $element_require;
3854
+                echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3855
+            }
3856 3856
 
3857
-			// add show only if advanced
3858
-			echo $require_advanced;
3859
-			// add setting require if defined
3860
-			echo $element_require;
3857
+            // add show only if advanced
3858
+            echo $require_advanced;
3859
+            // add setting require if defined
3860
+            echo $element_require;
3861 3861
             echo $device_type_require;
3862 3862
 
3863
-			// icon
3864
-			echo $icon;
3865
-			?>
3863
+            // icon
3864
+            echo $icon;
3865
+            ?>
3866 3866
 			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
3867 3867
 			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
3868
-			} else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
3868
+            } else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
3869 3869
 			help: <?php echo ( isset( $args['desc'] ) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim( wp_kses_post( addslashes( $args['desc'] ) ) ) . "'}})" : "''" ); ?>,
3870 3870
 			value: <?php echo $value; ?>,
3871 3871
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
3872
-				echo "type: '" . addslashes( $args['type'] ) . "',";
3873
-			} ?>
3872
+                echo "type: '" . addslashes( $args['type'] ) . "',";
3873
+            } ?>
3874 3874
 			<?php if ( ! empty( $args['placeholder'] ) ) {
3875
-				echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
3876
-			} ?>
3875
+                echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
3876
+            } ?>
3877 3877
 			<?php echo $options; ?>
3878 3878
 			<?php echo $extra; ?>
3879 3879
 			<?php echo $custom_attributes; ?>
@@ -3885,68 +3885,68 @@  discard block
 block discarded – undo
3885 3885
 			<?php } ?>
3886 3886
 		} <?php echo $inside_elements; ?> ),
3887 3887
 			<?php
3888
-			echo $after_elements;
3889
-		}
3888
+            echo $after_elements;
3889
+        }
3890 3890
 
3891
-		/**
3892
-		 * Convert an array of attributes to block string.
3893
-		 *
3894
-		 * @param $custom_attributes
3895
-		 *
3896
-		 * @return string
3897
-		 *@todo there is prob a faster way to do this, also we could add some validation here.
3898
-		 *
3899
-		 */
3900
-		public function array_to_attributes( $custom_attributes, $html = false ) {
3901
-			$attributes = '';
3902
-			if ( ! empty( $custom_attributes ) ) {
3903
-
3904
-				foreach ( $custom_attributes as $key => $val ) {
3905
-					if(is_array($val)){
3906
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
3907
-					}else{
3908
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
3909
-					}
3910
-				}
3891
+        /**
3892
+         * Convert an array of attributes to block string.
3893
+         *
3894
+         * @param $custom_attributes
3895
+         *
3896
+         * @return string
3897
+         *@todo there is prob a faster way to do this, also we could add some validation here.
3898
+         *
3899
+         */
3900
+        public function array_to_attributes( $custom_attributes, $html = false ) {
3901
+            $attributes = '';
3902
+            if ( ! empty( $custom_attributes ) ) {
3911 3903
 
3912
-			}
3904
+                foreach ( $custom_attributes as $key => $val ) {
3905
+                    if(is_array($val)){
3906
+                        $attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
3907
+                    }else{
3908
+                        $attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
3909
+                    }
3910
+                }
3913 3911
 
3914
-			return $attributes;
3915
-		}
3912
+            }
3913
+
3914
+            return $attributes;
3915
+        }
3916 3916
 
3917 3917
 
3918 3918
 
3919
-		/**
3920
-		 * A self looping function to create the output for JS block elements.
3921
-		 *
3922
-		 * This is what is output in the WP Editor visual view.
3923
-		 *
3924
-		 * @param $args
3925
-		 */
3926
-		public function block_element( $args, $save = false ) {
3919
+        /**
3920
+         * A self looping function to create the output for JS block elements.
3921
+         *
3922
+         * This is what is output in the WP Editor visual view.
3923
+         *
3924
+         * @param $args
3925
+         */
3926
+        public function block_element( $args, $save = false ) {
3927 3927
 
3928 3928
 
3929
-			if ( ! empty( $args ) ) {
3930
-				foreach ( $args as $element => $new_args ) {
3929
+            if ( ! empty( $args ) ) {
3930
+                foreach ( $args as $element => $new_args ) {
3931 3931
 
3932
-					if ( is_array( $new_args ) ) { // its an element
3932
+                    if ( is_array( $new_args ) ) { // its an element
3933 3933
 
3934 3934
 
3935
-						if ( isset( $new_args['element'] ) ) {
3935
+                        if ( isset( $new_args['element'] ) ) {
3936 3936
 
3937
-							if ( isset( $new_args['element_require'] ) ) {
3938
-								echo str_replace( array(
3939
-										"'+",
3940
-										"+'"
3941
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
3942
-								unset( $new_args['element_require'] );
3943
-							}
3937
+                            if ( isset( $new_args['element_require'] ) ) {
3938
+                                echo str_replace( array(
3939
+                                        "'+",
3940
+                                        "+'"
3941
+                                    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
3942
+                                unset( $new_args['element_require'] );
3943
+                            }
3944 3944
 
3945 3945
                             if($new_args['element']=='InnerBlocks'){
3946 3946
                                 echo "\n el( InnerBlocks, {";
3947 3947
                             }elseif($new_args['element']=='innerBlocksProps'){
3948 3948
                                 $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
3949
-                              //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
3949
+                                //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
3950 3950
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
3951 3951
                                 echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
3952 3952
                                 echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
@@ -3956,74 +3956,74 @@  discard block
 block discarded – undo
3956 3956
                                 echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
3957 3957
                             //    echo '###';
3958 3958
 
3959
-                              //  echo '###';
3959
+                                //  echo '###';
3960 3960
                             }elseif($new_args['element']=='BlocksProps'){
3961 3961
 
3962
-								if ( isset($new_args['if_inner_element']) ) {
3963
-									$element = $new_args['if_inner_element'];
3964
-								}else {
3965
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
3966
-								}
3962
+                                if ( isset($new_args['if_inner_element']) ) {
3963
+                                    $element = $new_args['if_inner_element'];
3964
+                                }else {
3965
+                                    $element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
3966
+                                }
3967 3967
 
3968
-								unset($new_args['inner_element']);
3968
+                                unset($new_args['inner_element']);
3969 3969
                                 echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
3970 3970
                                 echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
3971 3971
 
3972 3972
 
3973
-                               // echo "} ),";
3973
+                                // echo "} ),";
3974 3974
 
3975 3975
                             }else{
3976 3976
                                 echo "\n el( '" . $new_args['element'] . "', {";
3977 3977
                             }
3978 3978
 
3979 3979
 
3980
-							// get the attributes
3981
-							foreach ( $new_args as $new_key => $new_value ) {
3980
+                            // get the attributes
3981
+                            foreach ( $new_args as $new_key => $new_value ) {
3982 3982
 
3983 3983
 
3984
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
3985
-									// do nothing
3986
-								} else {
3987
-									echo $this->block_element( array( $new_key => $new_value ),$save );
3988
-								}
3989
-							}
3984
+                                if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
3985
+                                    // do nothing
3986
+                                } else {
3987
+                                    echo $this->block_element( array( $new_key => $new_value ),$save );
3988
+                                }
3989
+                            }
3990 3990
 
3991
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
3991
+                            echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
3992 3992
 
3993
-							// get the content
3994
-							$first_item = 0;
3995
-							foreach ( $new_args as $new_key => $new_value ) {
3996
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
3993
+                            // get the content
3994
+                            $first_item = 0;
3995
+                            foreach ( $new_args as $new_key => $new_value ) {
3996
+                                if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
3997 3997
 
3998
-									if ( $new_key === 'content' ) {
3999
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4000
-									}else if ( $new_key === 'if_content' ) {
4001
-										echo  $this->block_props_replace(  $new_value  );
4002
-									}
3998
+                                    if ( $new_key === 'content' ) {
3999
+                                        echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4000
+                                    }else if ( $new_key === 'if_content' ) {
4001
+                                        echo  $this->block_props_replace(  $new_value  );
4002
+                                    }
4003 4003
 
4004
-									if ( is_array( $new_value ) ) {
4004
+                                    if ( is_array( $new_value ) ) {
4005 4005
 
4006
-										if ( isset( $new_value['element_require'] ) ) {
4007
-											echo str_replace( array(
4008
-													"'+",
4009
-													"+'"
4010
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4011
-											unset( $new_value['element_require'] );
4012
-										}
4006
+                                        if ( isset( $new_value['element_require'] ) ) {
4007
+                                            echo str_replace( array(
4008
+                                                    "'+",
4009
+                                                    "+'"
4010
+                                                ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4011
+                                            unset( $new_value['element_require'] );
4012
+                                        }
4013 4013
 
4014
-										if ( isset( $new_value['element_repeat'] ) ) {
4015
-											$x = 1;
4016
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
4017
-												$this->block_element( array( '' => $new_value ),$save );
4018
-												$x ++;
4019
-											}
4020
-										} else {
4021
-											$this->block_element( array( '' => $new_value ),$save );
4022
-										}
4023
-									}
4024
-									$first_item ++;
4025
-								}
4026
-							}
4014
+                                        if ( isset( $new_value['element_repeat'] ) ) {
4015
+                                            $x = 1;
4016
+                                            while ( $x <= absint( $new_value['element_repeat'] ) ) {
4017
+                                                $this->block_element( array( '' => $new_value ),$save );
4018
+                                                $x ++;
4019
+                                            }
4020
+                                        } else {
4021
+                                            $this->block_element( array( '' => $new_value ),$save );
4022
+                                        }
4023
+                                    }
4024
+                                    $first_item ++;
4025
+                                }
4026
+                            }
4027 4027
 
4028 4028
                             if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4029 4029
                                 echo "))";// end content
@@ -4032,1094 +4032,1094 @@  discard block
 block discarded – undo
4032 4032
                             }
4033 4033
 
4034 4034
 
4035
-							echo ", \n";
4035
+                            echo ", \n";
4036 4036
 
4037
-						}
4038
-					} else {
4037
+                        }
4038
+                    } else {
4039 4039
 
4040
-						if ( substr( $element, 0, 3 ) === "if_" ) {
4041
-							$extra = '';
4042
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
4043
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4044
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4045
-							}
4046
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4047
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4040
+                        if ( substr( $element, 0, 3 ) === "if_" ) {
4041
+                            $extra = '';
4042
+                            if( strpos($new_args, '[%WrapClass%]') !== false ){
4043
+                                $new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4044
+                                $new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4045
+                            }
4046
+                            echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4047
+                        } elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4048 4048
                             $new_args = str_replace('[%WrapStyle%]','',$new_args);
4049 4049
                             echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4050 4050
 //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4051
-						} elseif ( $element == 'style' ) {
4052
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4053
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4051
+                        } elseif ( $element == 'style' ) {
4052
+                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4053
+                        } elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4054 4054
                             $new_args = str_replace('[%WrapClass%]','',$new_args);
4055 4055
                             echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4056
-						} elseif ( $element == 'template' && $new_args ) {
4057
-							echo $element . ": $new_args,";
4058
-						} else {
4059
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4060
-						}
4056
+                        } elseif ( $element == 'template' && $new_args ) {
4057
+                            echo $element . ": $new_args,";
4058
+                        } else {
4059
+                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4060
+                        }
4061 4061
 
4062
-					}
4063
-				}
4064
-			}
4065
-		}
4062
+                    }
4063
+                }
4064
+            }
4065
+        }
4066 4066
 
4067
-		/**
4068
-		 * Replace block attributes placeholders with the proper naming.
4069
-		 *
4070
-		 * @param $string
4071
-		 *
4072
-		 * @return mixed
4073
-		 */
4074
-		public function block_props_replace( $string, $no_wrap = false ) {
4075
-			if ( $no_wrap ) {
4076
-				$string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4077
-			} else {
4078
-				$string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4079
-			}
4067
+        /**
4068
+         * Replace block attributes placeholders with the proper naming.
4069
+         *
4070
+         * @param $string
4071
+         *
4072
+         * @return mixed
4073
+         */
4074
+        public function block_props_replace( $string, $no_wrap = false ) {
4075
+            if ( $no_wrap ) {
4076
+                $string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4077
+            } else {
4078
+                $string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4079
+            }
4080 4080
 
4081
-			return $string;
4082
-		}
4081
+            return $string;
4082
+        }
4083 4083
 
4084
-		/**
4085
-		 * Outputs the content of the widget
4086
-		 *
4087
-		 * @param array $args
4088
-		 * @param array $instance
4089
-		 */
4090
-		public function widget( $args, $instance ) {
4091
-			if ( ! is_array( $args ) ) {
4092
-				$args = array();
4093
-			}
4084
+        /**
4085
+         * Outputs the content of the widget
4086
+         *
4087
+         * @param array $args
4088
+         * @param array $instance
4089
+         */
4090
+        public function widget( $args, $instance ) {
4091
+            if ( ! is_array( $args ) ) {
4092
+                $args = array();
4093
+            }
4094 4094
 
4095
-			// Get the filtered values
4096
-			$argument_values = $this->argument_values( $instance );
4097
-			$argument_values = $this->string_to_bool( $argument_values );
4098
-			$output          = $this->output( $argument_values, $args );
4095
+            // Get the filtered values
4096
+            $argument_values = $this->argument_values( $instance );
4097
+            $argument_values = $this->string_to_bool( $argument_values );
4098
+            $output          = $this->output( $argument_values, $args );
4099 4099
 
4100
-			$no_wrap = false;
4101
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4102
-				$no_wrap = true;
4103
-			}
4100
+            $no_wrap = false;
4101
+            if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4102
+                $no_wrap = true;
4103
+            }
4104 4104
 
4105
-			ob_start();
4106
-			if ( $output && ! $no_wrap ) {
4105
+            ob_start();
4106
+            if ( $output && ! $no_wrap ) {
4107 4107
 
4108
-				$class_original = $this->options['widget_ops']['classname'];
4109
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4108
+                $class_original = $this->options['widget_ops']['classname'];
4109
+                $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4110 4110
 
4111
-				// Before widget
4112
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4113
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4114
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4115
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4111
+                // Before widget
4112
+                $before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4113
+                $before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4114
+                $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4115
+                $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4116 4116
 
4117
-				// After widget
4118
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4119
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4120
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4117
+                // After widget
4118
+                $after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4119
+                $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4120
+                $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4121 4121
 
4122
-				echo $before_widget;
4123
-				// elementor strips the widget wrapping div so we check for and add it back if needed
4124
-				if ( $this->is_elementor_widget_output() ) {
4125
-					// Filter class & attrs for elementor widget output.
4126
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4127
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4122
+                echo $before_widget;
4123
+                // elementor strips the widget wrapping div so we check for and add it back if needed
4124
+                if ( $this->is_elementor_widget_output() ) {
4125
+                    // Filter class & attrs for elementor widget output.
4126
+                    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4127
+                    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4128 4128
 
4129
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4130
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4129
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4130
+                    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4131 4131
 
4132
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4133
-				}
4134
-				echo $this->output_title( $args, $instance );
4135
-				echo $output;
4136
-				if ( $this->is_elementor_widget_output() ) {
4137
-					echo "</span>";
4138
-				}
4139
-				echo $after_widget;
4140
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4141
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4142
-				echo $output;
4143
-			} elseif ( $output && $no_wrap ) {
4144
-				echo $output;
4145
-			}
4146
-			$output = ob_get_clean();
4132
+                    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4133
+                }
4134
+                echo $this->output_title( $args, $instance );
4135
+                echo $output;
4136
+                if ( $this->is_elementor_widget_output() ) {
4137
+                    echo "</span>";
4138
+                }
4139
+                echo $after_widget;
4140
+            } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4141
+                $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4142
+                echo $output;
4143
+            } elseif ( $output && $no_wrap ) {
4144
+                echo $output;
4145
+            }
4146
+            $output = ob_get_clean();
4147 4147
 
4148
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4148
+            $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4149 4149
 
4150
-			echo $output;
4151
-		}
4150
+            echo $output;
4151
+        }
4152 4152
 
4153
-		/**
4154
-		 * Tests if the current output is inside a elementor container.
4155
-		 *
4156
-		 * @return bool
4157
-		 *@since 1.0.4
4158
-		 */
4159
-		public function is_elementor_widget_output() {
4160
-			$result = false;
4161
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4162
-				$result = true;
4163
-			}
4153
+        /**
4154
+         * Tests if the current output is inside a elementor container.
4155
+         *
4156
+         * @return bool
4157
+         *@since 1.0.4
4158
+         */
4159
+        public function is_elementor_widget_output() {
4160
+            $result = false;
4161
+            if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4162
+                $result = true;
4163
+            }
4164 4164
 
4165
-			return $result;
4166
-		}
4165
+            return $result;
4166
+        }
4167 4167
 
4168
-		/**
4169
-		 * Tests if the current output is inside a elementor preview.
4170
-		 *
4171
-		 * @return bool
4172
-		 *@since 1.0.4
4173
-		 */
4174
-		public function is_elementor_preview() {
4175
-			$result = false;
4176
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4177
-				$result = true;
4178
-			}
4168
+        /**
4169
+         * Tests if the current output is inside a elementor preview.
4170
+         *
4171
+         * @return bool
4172
+         *@since 1.0.4
4173
+         */
4174
+        public function is_elementor_preview() {
4175
+            $result = false;
4176
+            if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4177
+                $result = true;
4178
+            }
4179 4179
 
4180
-			return $result;
4181
-		}
4180
+            return $result;
4181
+        }
4182 4182
 
4183
-		/**
4184
-		 * Tests if the current output is inside a Divi preview.
4185
-		 *
4186
-		 * @return bool
4187
-		 *@since 1.0.6
4188
-		 */
4189
-		public function is_divi_preview() {
4190
-			$result = false;
4191
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4192
-				$result = true;
4193
-			}
4183
+        /**
4184
+         * Tests if the current output is inside a Divi preview.
4185
+         *
4186
+         * @return bool
4187
+         *@since 1.0.6
4188
+         */
4189
+        public function is_divi_preview() {
4190
+            $result = false;
4191
+            if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4192
+                $result = true;
4193
+            }
4194 4194
 
4195
-			return $result;
4196
-		}
4195
+            return $result;
4196
+        }
4197 4197
 
4198
-		/**
4199
-		 * Tests if the current output is inside a Beaver builder preview.
4200
-		 *
4201
-		 * @return bool
4202
-		 *@since 1.0.6
4203
-		 */
4204
-		public function is_beaver_preview() {
4205
-			$result = false;
4206
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
4207
-				$result = true;
4208
-			}
4198
+        /**
4199
+         * Tests if the current output is inside a Beaver builder preview.
4200
+         *
4201
+         * @return bool
4202
+         *@since 1.0.6
4203
+         */
4204
+        public function is_beaver_preview() {
4205
+            $result = false;
4206
+            if ( isset( $_REQUEST['fl_builder'] ) ) {
4207
+                $result = true;
4208
+            }
4209 4209
 
4210
-			return $result;
4211
-		}
4210
+            return $result;
4211
+        }
4212 4212
 
4213
-		/**
4214
-		 * Tests if the current output is inside a siteorigin builder preview.
4215
-		 *
4216
-		 * @return bool
4217
-		 *@since 1.0.6
4218
-		 */
4219
-		public function is_siteorigin_preview() {
4220
-			$result = false;
4221
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4222
-				$result = true;
4223
-			}
4213
+        /**
4214
+         * Tests if the current output is inside a siteorigin builder preview.
4215
+         *
4216
+         * @return bool
4217
+         *@since 1.0.6
4218
+         */
4219
+        public function is_siteorigin_preview() {
4220
+            $result = false;
4221
+            if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4222
+                $result = true;
4223
+            }
4224 4224
 
4225
-			return $result;
4226
-		}
4225
+            return $result;
4226
+        }
4227 4227
 
4228
-		/**
4229
-		 * Tests if the current output is inside a cornerstone builder preview.
4230
-		 *
4231
-		 * @return bool
4232
-		 *@since 1.0.8
4233
-		 */
4234
-		public function is_cornerstone_preview() {
4235
-			$result = false;
4236
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4237
-				$result = true;
4238
-			}
4228
+        /**
4229
+         * Tests if the current output is inside a cornerstone builder preview.
4230
+         *
4231
+         * @return bool
4232
+         *@since 1.0.8
4233
+         */
4234
+        public function is_cornerstone_preview() {
4235
+            $result = false;
4236
+            if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4237
+                $result = true;
4238
+            }
4239 4239
 
4240
-			return $result;
4241
-		}
4240
+            return $result;
4241
+        }
4242 4242
 
4243
-		/**
4244
-		 * Tests if the current output is inside a fusion builder preview.
4245
-		 *
4246
-		 * @return bool
4247
-		 *@since 1.1.0
4248
-		 */
4249
-		public function is_fusion_preview() {
4250
-			$result = false;
4251
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4252
-				$result = true;
4253
-			}
4243
+        /**
4244
+         * Tests if the current output is inside a fusion builder preview.
4245
+         *
4246
+         * @return bool
4247
+         *@since 1.1.0
4248
+         */
4249
+        public function is_fusion_preview() {
4250
+            $result = false;
4251
+            if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4252
+                $result = true;
4253
+            }
4254 4254
 
4255
-			return $result;
4256
-		}
4255
+            return $result;
4256
+        }
4257 4257
 
4258
-		/**
4259
-		 * Tests if the current output is inside a Oxygen builder preview.
4260
-		 *
4261
-		 * @return bool
4262
-		 *@since 1.0.18
4263
-		 */
4264
-		public function is_oxygen_preview() {
4265
-			$result = false;
4266
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4267
-				$result = true;
4268
-			}
4258
+        /**
4259
+         * Tests if the current output is inside a Oxygen builder preview.
4260
+         *
4261
+         * @return bool
4262
+         *@since 1.0.18
4263
+         */
4264
+        public function is_oxygen_preview() {
4265
+            $result = false;
4266
+            if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4267
+                $result = true;
4268
+            }
4269 4269
 
4270
-			return $result;
4271
-		}
4270
+            return $result;
4271
+        }
4272 4272
 
4273
-		/**
4274
-		 * Check for Kallyas theme Zion builder preview.
4275
-		 *
4276
-		 * @since 1.1.22
4277
-		 *
4278
-		 * @return bool True when preview page otherwise false.
4279
-		 */
4280
-		public function is_kallyas_zion_preview() {
4281
-			$result = false;
4282
-
4283
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4284
-				$result = true;
4285
-			}
4273
+        /**
4274
+         * Check for Kallyas theme Zion builder preview.
4275
+         *
4276
+         * @since 1.1.22
4277
+         *
4278
+         * @return bool True when preview page otherwise false.
4279
+         */
4280
+        public function is_kallyas_zion_preview() {
4281
+            $result = false;
4286 4282
 
4287
-			return $result;
4288
-		}
4283
+            if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4284
+                $result = true;
4285
+            }
4289 4286
 
4290
-		/**
4291
-		 * Check for Bricks theme builder preview.
4292
-		 *
4293
-		 * @since 1.1.31
4294
-		 *
4295
-		 * @return bool True when preview page otherwise false.
4296
-		 */
4297
-		public function is_bricks_preview() {
4298
-			$result = false;
4299
-
4300
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4301
-				$result = true;
4302
-			}
4287
+            return $result;
4288
+        }
4303 4289
 
4304
-			return $result;
4305
-		}
4290
+        /**
4291
+         * Check for Bricks theme builder preview.
4292
+         *
4293
+         * @since 1.1.31
4294
+         *
4295
+         * @return bool True when preview page otherwise false.
4296
+         */
4297
+        public function is_bricks_preview() {
4298
+            $result = false;
4306 4299
 
4307
-		/**
4308
-		 * General function to check if we are in a preview situation.
4309
-		 *
4310
-		 * @return bool
4311
-		 *@since 1.0.6
4312
-		 */
4313
-		public function is_preview() {
4314
-			$preview = false;
4315
-			if ( $this->is_divi_preview() ) {
4316
-				$preview = true;
4317
-			} elseif ( $this->is_elementor_preview() ) {
4318
-				$preview = true;
4319
-			} elseif ( $this->is_beaver_preview() ) {
4320
-				$preview = true;
4321
-			} elseif ( $this->is_siteorigin_preview() ) {
4322
-				$preview = true;
4323
-			} elseif ( $this->is_cornerstone_preview() ) {
4324
-				$preview = true;
4325
-			} elseif ( $this->is_fusion_preview() ) {
4326
-				$preview = true;
4327
-			} elseif ( $this->is_oxygen_preview() ) {
4328
-				$preview = true;
4329
-			} elseif( $this->is_kallyas_zion_preview() ) {
4330
-				$preview = true;
4331
-			} elseif( $this->is_block_content_call() ) {
4332
-				$preview = true;
4333
-			} elseif( $this->is_bricks_preview() ) {
4334
-				$preview = true;
4335
-			}
4300
+            if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4301
+                $result = true;
4302
+            }
4336 4303
 
4337
-			return $preview;
4338
-		}
4304
+            return $result;
4305
+        }
4339 4306
 
4340
-		/**
4341
-		 * Output the super title.
4342
-		 *
4343
-		 * @param $args
4344
-		 * @param array $instance
4345
-		 *
4346
-		 * @return string
4347
-		 */
4348
-		public function output_title( $args, $instance = array() ) {
4349
-			$output = '';
4350
-			if ( ! empty( $instance['title'] ) ) {
4351
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4352
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4353
-
4354
-				if(empty($instance['widget_title_tag'])){
4355
-					$output = $args['before_title'] . $title . $args['after_title'];
4356
-				}else{
4357
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
4358
-
4359
-					// classes
4360
-					$title_classes = array();
4361
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4362
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4363
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4364
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4365
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4366
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4367
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4368
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4369
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4370
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4371
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4372
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4373
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4374
-
4375
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4376
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
4377
-				}
4307
+        /**
4308
+         * General function to check if we are in a preview situation.
4309
+         *
4310
+         * @return bool
4311
+         *@since 1.0.6
4312
+         */
4313
+        public function is_preview() {
4314
+            $preview = false;
4315
+            if ( $this->is_divi_preview() ) {
4316
+                $preview = true;
4317
+            } elseif ( $this->is_elementor_preview() ) {
4318
+                $preview = true;
4319
+            } elseif ( $this->is_beaver_preview() ) {
4320
+                $preview = true;
4321
+            } elseif ( $this->is_siteorigin_preview() ) {
4322
+                $preview = true;
4323
+            } elseif ( $this->is_cornerstone_preview() ) {
4324
+                $preview = true;
4325
+            } elseif ( $this->is_fusion_preview() ) {
4326
+                $preview = true;
4327
+            } elseif ( $this->is_oxygen_preview() ) {
4328
+                $preview = true;
4329
+            } elseif( $this->is_kallyas_zion_preview() ) {
4330
+                $preview = true;
4331
+            } elseif( $this->is_block_content_call() ) {
4332
+                $preview = true;
4333
+            } elseif( $this->is_bricks_preview() ) {
4334
+                $preview = true;
4335
+            }
4378 4336
 
4379
-			}
4337
+            return $preview;
4338
+        }
4380 4339
 
4381
-			return $output;
4382
-		}
4340
+        /**
4341
+         * Output the super title.
4342
+         *
4343
+         * @param $args
4344
+         * @param array $instance
4345
+         *
4346
+         * @return string
4347
+         */
4348
+        public function output_title( $args, $instance = array() ) {
4349
+            $output = '';
4350
+            if ( ! empty( $instance['title'] ) ) {
4351
+                /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4352
+                $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4353
+
4354
+                if(empty($instance['widget_title_tag'])){
4355
+                    $output = $args['before_title'] . $title . $args['after_title'];
4356
+                }else{
4357
+                    $title_tag = esc_attr( $instance['widget_title_tag'] );
4358
+
4359
+                    // classes
4360
+                    $title_classes = array();
4361
+                    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4362
+                    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4363
+                    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4364
+                    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4365
+                    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4366
+                    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4367
+                    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4368
+                    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4369
+                    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4370
+                    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4371
+                    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4372
+                    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4373
+                    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4374
+
4375
+                    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4376
+                    $output = "<$title_tag class='$class' >$title</$title_tag>";
4377
+                }
4378
+
4379
+            }
4383 4380
 
4384
-		/**
4385
-		 * Outputs the options form inputs for the widget.
4386
-		 *
4387
-		 * @param array $instance The widget options.
4388
-		 */
4389
-		public function form( $instance ) {
4381
+            return $output;
4382
+        }
4383
+
4384
+        /**
4385
+         * Outputs the options form inputs for the widget.
4386
+         *
4387
+         * @param array $instance The widget options.
4388
+         */
4389
+        public function form( $instance ) {
4390 4390
 
4391
-			// set widget instance
4392
-			$this->instance = $instance;
4391
+            // set widget instance
4392
+            $this->instance = $instance;
4393 4393
 
4394
-			// set it as a SD widget
4395
-			echo $this->widget_advanced_toggle();
4394
+            // set it as a SD widget
4395
+            echo $this->widget_advanced_toggle();
4396 4396
 
4397
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4398
-			$arguments_raw = $this->get_arguments();
4397
+            echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4398
+            $arguments_raw = $this->get_arguments();
4399 4399
 
4400
-			if ( is_array( $arguments_raw ) ) {
4400
+            if ( is_array( $arguments_raw ) ) {
4401 4401
 
4402
-				$arguments = $this->group_arguments( $arguments_raw );
4402
+                $arguments = $this->group_arguments( $arguments_raw );
4403 4403
 
4404
-				// Do we have sections?
4405
-				$has_sections = $arguments == $arguments_raw ? false : true;
4404
+                // Do we have sections?
4405
+                $has_sections = $arguments == $arguments_raw ? false : true;
4406 4406
 
4407 4407
 
4408
-				if ( $has_sections ) {
4409
-					$panel_count = 0;
4410
-					foreach ( $arguments as $key => $args ) {
4408
+                if ( $has_sections ) {
4409
+                    $panel_count = 0;
4410
+                    foreach ( $arguments as $key => $args ) {
4411 4411
 
4412
-						?>
4412
+                        ?>
4413 4413
 						<script>
4414 4414
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
4415 4415
 						</script>
4416 4416
 						<?php
4417 4417
 
4418
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
4419
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4420
-						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>";
4421
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4418
+                        $hide       = $panel_count ? ' style="display:none;" ' : '';
4419
+                        $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4420
+                        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>";
4421
+                        echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4422 4422
 
4423
-						foreach ( $args as $k => $a ) {
4423
+                        foreach ( $args as $k => $a ) {
4424 4424
 
4425
-							$this->widget_inputs_row_start($k, $a);
4426
-							$this->widget_inputs( $a, $instance );
4427
-							$this->widget_inputs_row_end($k, $a);
4425
+                            $this->widget_inputs_row_start($k, $a);
4426
+                            $this->widget_inputs( $a, $instance );
4427
+                            $this->widget_inputs_row_end($k, $a);
4428 4428
 
4429
-						}
4429
+                        }
4430 4430
 
4431
-						echo "</div>";
4431
+                        echo "</div>";
4432 4432
 
4433
-						$panel_count ++;
4433
+                        $panel_count ++;
4434 4434
 
4435
-					}
4436
-				} else {
4437
-					foreach ( $arguments as $key => $args ) {
4438
-						$this->widget_inputs_row_start($key, $args);
4439
-						$this->widget_inputs( $args, $instance );
4440
-						$this->widget_inputs_row_end($key, $args);
4441
-					}
4442
-				}
4435
+                    }
4436
+                } else {
4437
+                    foreach ( $arguments as $key => $args ) {
4438
+                        $this->widget_inputs_row_start($key, $args);
4439
+                        $this->widget_inputs( $args, $instance );
4440
+                        $this->widget_inputs_row_end($key, $args);
4441
+                    }
4442
+                }
4443 4443
 
4444
-			}
4445
-		}
4444
+            }
4445
+        }
4446 4446
 
4447
-		public function widget_inputs_row_start( $key, $args ) {
4448
-			if ( ! empty( $args['row'] ) ) {
4449
-				// Maybe open
4450
-				if ( ! empty( $args['row']['open'] ) ) {
4451
-					?>
4447
+        public function widget_inputs_row_start( $key, $args ) {
4448
+            if ( ! empty( $args['row'] ) ) {
4449
+                // Maybe open
4450
+                if ( ! empty( $args['row']['open'] ) ) {
4451
+                    ?>
4452 4452
 					<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'] ) : '' ); ?>'>
4453 4453
 					<?php if ( ! empty( $args['row']['title'] ) ) { ?>
4454 4454
 					<?php 
4455
-						if ( isset( $args['row']['icon'] ) ) {
4456
-							$args['row']['icon'] = '';
4457
-						}
4455
+                        if ( isset( $args['row']['icon'] ) ) {
4456
+                            $args['row']['icon'] = '';
4457
+                        }
4458 4458
 
4459
-						if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4460
-							$args['row']['device_type'] = $args['device_type'];
4461
-						}
4462
-					?>
4459
+                        if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4460
+                            $args['row']['device_type'] = $args['device_type'];
4461
+                        }
4462
+                    ?>
4463 4463
 					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4464 4464
 					<?php } ?>
4465 4465
 					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4466 4466
 					<div class='col pr-2'>
4467 4467
 					<?php
4468
-				} else if ( ! empty( $args['row']['close'] ) ) {
4469
-					echo "<div class='col pl-0 ps-0'>";
4470
-				} else {
4471
-					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4472
-				}
4473
-			}
4474
-		}
4468
+                } else if ( ! empty( $args['row']['close'] ) ) {
4469
+                    echo "<div class='col pl-0 ps-0'>";
4470
+                } else {
4471
+                    echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4472
+                }
4473
+            }
4474
+        }
4475 4475
 
4476
-		public function widget_inputs_row_end( $key, $args ) {
4477
-			if ( ! empty( $args['row'] ) ) {
4478
-				// Maybe close
4479
-				if ( ! empty( $args['row']['close'] ) ) {
4480
-					echo "</div></div>";
4481
-				}
4482
-				echo "</div>";
4483
-			}
4484
-		}
4476
+        public function widget_inputs_row_end( $key, $args ) {
4477
+            if ( ! empty( $args['row'] ) ) {
4478
+                // Maybe close
4479
+                if ( ! empty( $args['row']['close'] ) ) {
4480
+                    echo "</div></div>";
4481
+                }
4482
+                echo "</div>";
4483
+            }
4484
+        }
4485 4485
 
4486
-		/**
4487
-		 * Get the hidden input that when added makes the advanced button show on widget settings.
4488
-		 *
4489
-		 * @return string
4490
-		 */
4491
-		public function widget_advanced_toggle() {
4486
+        /**
4487
+         * Get the hidden input that when added makes the advanced button show on widget settings.
4488
+         *
4489
+         * @return string
4490
+         */
4491
+        public function widget_advanced_toggle() {
4492 4492
 
4493
-			$output = '';
4494
-			if ( $this->block_show_advanced() ) {
4495
-				$val = 1;
4496
-			} else {
4497
-				$val = 0;
4498
-			}
4493
+            $output = '';
4494
+            if ( $this->block_show_advanced() ) {
4495
+                $val = 1;
4496
+            } else {
4497
+                $val = 0;
4498
+            }
4499 4499
 
4500
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4500
+            $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4501 4501
 
4502
-			return $output;
4503
-		}
4502
+            return $output;
4503
+        }
4504 4504
 
4505
-		/**
4506
-		 * Convert require element.
4507
-		 *
4508
-		 * @param string $input Input element.
4509
-		 *
4510
-		 * @return string $output
4511
-		 *@since 1.0.0
4512
-		 *
4513
-		 */
4514
-		public function convert_element_require( $input ) {
4515
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4516
-
4517
-			$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4518
-				"jQuery(form).find('[data-argument=\"",
4519
-				"\"]').find('input,select,textarea').val()",
4520
-				"\"]').find('input:checked').val()"
4521
-			), $input ) );
4522
-
4523
-			return $output;
4524
-		}
4505
+        /**
4506
+         * Convert require element.
4507
+         *
4508
+         * @param string $input Input element.
4509
+         *
4510
+         * @return string $output
4511
+         *@since 1.0.0
4512
+         *
4513
+         */
4514
+        public function convert_element_require( $input ) {
4515
+            $input = str_replace( "'", '"', $input );// we only want double quotes
4525 4516
 
4526
-		/**
4527
-		 * Builds the inputs for the widget options.
4528
-		 *
4529
-		 * @param $args
4530
-		 * @param $instance
4531
-		 */
4532
-		public function widget_inputs( $args, $instance ) {
4533
-
4534
-			$class             = "";
4535
-			$element_require   = "";
4536
-			$custom_attributes = "";
4537
-
4538
-			// get value
4539
-			if ( isset( $instance[ $args['name'] ] ) ) {
4540
-				$value = $instance[ $args['name'] ];
4541
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4542
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4543
-			} else {
4544
-				$value = '';
4545
-			}
4517
+            $output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4518
+                "jQuery(form).find('[data-argument=\"",
4519
+                "\"]').find('input,select,textarea').val()",
4520
+                "\"]').find('input:checked').val()"
4521
+            ), $input ) );
4546 4522
 
4547
-			// get placeholder
4548
-			if ( ! empty( $args['placeholder'] ) ) {
4549
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4550
-			} else {
4551
-				$placeholder = '';
4552
-			}
4523
+            return $output;
4524
+        }
4553 4525
 
4554
-			// get if advanced
4555
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4556
-				$class .= " sd-advanced-setting ";
4557
-			}
4526
+        /**
4527
+         * Builds the inputs for the widget options.
4528
+         *
4529
+         * @param $args
4530
+         * @param $instance
4531
+         */
4532
+        public function widget_inputs( $args, $instance ) {
4533
+
4534
+            $class             = "";
4535
+            $element_require   = "";
4536
+            $custom_attributes = "";
4537
+
4538
+            // get value
4539
+            if ( isset( $instance[ $args['name'] ] ) ) {
4540
+                $value = $instance[ $args['name'] ];
4541
+            } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4542
+                $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4543
+            } else {
4544
+                $value = '';
4545
+            }
4558 4546
 
4559
-			// element_require
4560
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4561
-				$element_require = $args['element_require'];
4562
-			}
4547
+            // get placeholder
4548
+            if ( ! empty( $args['placeholder'] ) ) {
4549
+                $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4550
+            } else {
4551
+                $placeholder = '';
4552
+            }
4563 4553
 
4564
-			// custom_attributes
4565
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4566
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4567
-			}
4554
+            // get if advanced
4555
+            if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4556
+                $class .= " sd-advanced-setting ";
4557
+            }
4558
+
4559
+            // element_require
4560
+            if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4561
+                $element_require = $args['element_require'];
4562
+            }
4568 4563
 
4569
-			// before wrapper
4570
-			?>
4564
+            // custom_attributes
4565
+            if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4566
+                $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4567
+            }
4568
+
4569
+            // before wrapper
4570
+            ?>
4571 4571
 			<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 );} ?>'>
4572 4572
 			<?php
4573
-			switch ( $args['type'] ) {
4574
-				//array('text','password','number','email','tel','url','color')
4575
-				case "text":
4576
-				case "password":
4577
-				case "number":
4578
-				case "email":
4579
-				case "tel":
4580
-				case "url":
4581
-				case "color":
4582
-					?>
4573
+            switch ( $args['type'] ) {
4574
+                //array('text','password','number','email','tel','url','color')
4575
+                case "text":
4576
+                case "password":
4577
+                case "number":
4578
+                case "email":
4579
+                case "tel":
4580
+                case "url":
4581
+                case "color":
4582
+                    ?>
4583 4583
 					<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>
4584 4584
 					<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 ); ?>">
4585 4585
 					<?php
4586 4586
 
4587
-					break;
4588
-				case "select":
4589
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4590
-					if ( $multiple ) {
4591
-						if ( empty( $value ) ) {
4592
-							$value = array();
4593
-						}
4594
-					}
4595
-					?>
4587
+                    break;
4588
+                case "select":
4589
+                    $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4590
+                    if ( $multiple ) {
4591
+                        if ( empty( $value ) ) {
4592
+                            $value = array();
4593
+                        }
4594
+                    }
4595
+                    ?>
4596 4596
 					<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>
4597 4597
 					<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 "[]"; } ?>"
4598 4598
 						<?php if ( $multiple ) {
4599
-							echo "multiple";
4600
-						} //@todo not implemented yet due to gutenberg not supporting it
4601
-						?>>
4599
+                            echo "multiple";
4600
+                        } //@todo not implemented yet due to gutenberg not supporting it
4601
+                        ?>>
4602 4602
 						<?php
4603 4603
 
4604
-						if ( ! empty( $args['options'] ) ) {
4605
-							foreach ( $args['options'] as $val => $label ) {
4606
-								if ( $multiple ) {
4607
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4608
-								} else {
4609
-									$selected = selected( $value, $val, false );
4610
-								}
4611
-								echo "<option value='$val' " . $selected . ">$label</option>";
4612
-							}
4613
-						}
4614
-						?>
4604
+                        if ( ! empty( $args['options'] ) ) {
4605
+                            foreach ( $args['options'] as $val => $label ) {
4606
+                                if ( $multiple ) {
4607
+                                    $selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4608
+                                } else {
4609
+                                    $selected = selected( $value, $val, false );
4610
+                                }
4611
+                                echo "<option value='$val' " . $selected . ">$label</option>";
4612
+                            }
4613
+                        }
4614
+                        ?>
4615 4615
 					</select>
4616 4616
 					<?php
4617
-					break;
4618
-				case "checkbox":
4619
-					?>
4617
+                    break;
4618
+                case "checkbox":
4619
+                    ?>
4620 4620
 					<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">
4621 4621
 					<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>
4622 4622
 					<?php
4623
-					break;
4624
-				case "textarea":
4625
-					?>
4623
+                    break;
4624
+                case "textarea":
4625
+                    ?>
4626 4626
 					<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>
4627 4627
 					<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>
4628 4628
 					<?php
4629 4629
 
4630
-					break;
4631
-				case "hidden":
4632
-					?>
4630
+                    break;
4631
+                case "hidden":
4632
+                    ?>
4633 4633
 					<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 ); ?>">
4634 4634
 					<?php
4635
-					break;
4636
-				default:
4637
-					echo "No input type found!"; // @todo we need to add more input types.
4638
-			}
4639
-			// after wrapper
4640
-			?></p><?php
4641
-		}
4635
+                    break;
4636
+                default:
4637
+                    echo "No input type found!"; // @todo we need to add more input types.
4638
+            }
4639
+            // after wrapper
4640
+            ?></p><?php
4641
+        }
4642 4642
 
4643
-		public function get_widget_icon($icon = 'box-top', $title = ''){
4644
-			if($icon=='box-top'){
4645
-				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>';
4646
-			}elseif($icon=='box-right'){
4647
-				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>';
4648
-			}elseif($icon=='box-bottom'){
4649
-				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>';
4650
-			}elseif($icon=='box-left'){
4651
-				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>';
4652
-			}
4653
-		}
4643
+        public function get_widget_icon($icon = 'box-top', $title = ''){
4644
+            if($icon=='box-top'){
4645
+                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>';
4646
+            }elseif($icon=='box-right'){
4647
+                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>';
4648
+            }elseif($icon=='box-bottom'){
4649
+                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>';
4650
+            }elseif($icon=='box-left'){
4651
+                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>';
4652
+            }
4653
+        }
4654 4654
 
4655
-		/**
4656
-		 * Get the widget input description html.
4657
-		 *
4658
-		 * @param $args
4659
-		 *
4660
-		 * @return string
4661
-		 * @todo, need to make its own tooltip script
4662
-		 */
4663
-		public function widget_field_desc( $args ) {
4664
-
4665
-			$description = '';
4666
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
4667
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4668
-					$description = $this->desc_tip( $args['desc'] );
4669
-				} else {
4670
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4671
-				}
4672
-			}
4655
+        /**
4656
+         * Get the widget input description html.
4657
+         *
4658
+         * @param $args
4659
+         *
4660
+         * @return string
4661
+         * @todo, need to make its own tooltip script
4662
+         */
4663
+        public function widget_field_desc( $args ) {
4664
+
4665
+            $description = '';
4666
+            if ( isset( $args['desc'] ) && $args['desc'] ) {
4667
+                if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4668
+                    $description = $this->desc_tip( $args['desc'] );
4669
+                } else {
4670
+                    $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4671
+                }
4672
+            }
4673 4673
 
4674
-			return $description;
4675
-		}
4674
+            return $description;
4675
+        }
4676 4676
 
4677
-		/**
4678
-		 * Get the widget input title html.
4679
-		 *
4680
-		 * @param $args
4681
-		 *
4682
-		 * @return string
4683
-		 */
4684
-		public function widget_field_title( $args ) {
4685
-			$title = '';
4686
-
4687
-			if ( isset( $args['title'] ) && $args['title'] ) {
4688
-				if ( ! empty( $args['device_type'] ) ) {
4689
-					$args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4690
-				}
4677
+        /**
4678
+         * Get the widget input title html.
4679
+         *
4680
+         * @param $args
4681
+         *
4682
+         * @return string
4683
+         */
4684
+        public function widget_field_title( $args ) {
4685
+            $title = '';
4691 4686
 
4692
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
4693
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
4694
-				} else {
4695
-					$title = esc_attr( $args['title'] );
4696
-				}
4697
-			}
4687
+            if ( isset( $args['title'] ) && $args['title'] ) {
4688
+                if ( ! empty( $args['device_type'] ) ) {
4689
+                    $args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4690
+                }
4698 4691
 
4699
-			return $title;
4700
-		}
4692
+                if ( isset( $args['icon'] ) && $args['icon'] ) {
4693
+                    $title = self::get_widget_icon( $args['icon'], $args['title']  );
4694
+                } else {
4695
+                    $title = esc_attr( $args['title'] );
4696
+                }
4697
+            }
4701 4698
 
4702
-		/**
4703
-		 * Get the tool tip html.
4704
-		 *
4705
-		 * @param $tip
4706
-		 * @param bool $allow_html
4707
-		 *
4708
-		 * @return string
4709
-		 */
4710
-		function desc_tip( $tip, $allow_html = false ) {
4711
-			if ( $allow_html ) {
4712
-				$tip = $this->sanitize_tooltip( $tip );
4713
-			} else {
4714
-				$tip = esc_attr( $tip );
4715
-			}
4699
+            return $title;
4700
+        }
4716 4701
 
4717
-			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4718
-		}
4702
+        /**
4703
+         * Get the tool tip html.
4704
+         *
4705
+         * @param $tip
4706
+         * @param bool $allow_html
4707
+         *
4708
+         * @return string
4709
+         */
4710
+        function desc_tip( $tip, $allow_html = false ) {
4711
+            if ( $allow_html ) {
4712
+                $tip = $this->sanitize_tooltip( $tip );
4713
+            } else {
4714
+                $tip = esc_attr( $tip );
4715
+            }
4719 4716
 
4720
-		/**
4721
-		 * Sanitize a string destined to be a tooltip.
4722
-		 *
4723
-		 * @param string $var
4724
-		 *
4725
-		 * @return string
4726
-		 */
4727
-		public function sanitize_tooltip( $var ) {
4728
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4729
-				'br'     => array(),
4730
-				'em'     => array(),
4731
-				'strong' => array(),
4732
-				'small'  => array(),
4733
-				'span'   => array(),
4734
-				'ul'     => array(),
4735
-				'li'     => array(),
4736
-				'ol'     => array(),
4737
-				'p'      => array(),
4738
-			) ) );
4739
-		}
4717
+            return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
4718
+        }
4740 4719
 
4741
-		/**
4742
-		 * Processing widget options on save
4743
-		 *
4744
-		 * @param array $new_instance The new options
4745
-		 * @param array $old_instance The previous options
4746
-		 *
4747
-		 * @return array
4748
-		 * @todo we should add some sanitation here.
4749
-		 */
4750
-		public function update( $new_instance, $old_instance ) {
4751
-
4752
-			//save the widget
4753
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
4754
-
4755
-			// set widget instance
4756
-			$this->instance = $instance;
4757
-
4758
-			if ( empty( $this->arguments ) ) {
4759
-				$this->get_arguments();
4760
-			}
4720
+        /**
4721
+         * Sanitize a string destined to be a tooltip.
4722
+         *
4723
+         * @param string $var
4724
+         *
4725
+         * @return string
4726
+         */
4727
+        public function sanitize_tooltip( $var ) {
4728
+            return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4729
+                'br'     => array(),
4730
+                'em'     => array(),
4731
+                'strong' => array(),
4732
+                'small'  => array(),
4733
+                'span'   => array(),
4734
+                'ul'     => array(),
4735
+                'li'     => array(),
4736
+                'ol'     => array(),
4737
+                'p'      => array(),
4738
+            ) ) );
4739
+        }
4761 4740
 
4762
-			// check for checkboxes
4763
-			if ( ! empty( $this->arguments ) ) {
4764
-				foreach ( $this->arguments as $argument ) {
4765
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4766
-						$instance[ $argument['name'] ] = '0';
4767
-					}
4768
-				}
4769
-			}
4741
+        /**
4742
+         * Processing widget options on save
4743
+         *
4744
+         * @param array $new_instance The new options
4745
+         * @param array $old_instance The previous options
4746
+         *
4747
+         * @return array
4748
+         * @todo we should add some sanitation here.
4749
+         */
4750
+        public function update( $new_instance, $old_instance ) {
4770 4751
 
4771
-			return $instance;
4772
-		}
4752
+            //save the widget
4753
+            $instance = array_merge( (array) $old_instance, (array) $new_instance );
4773 4754
 
4774
-		/**
4775
-		 * Checks if the current call is a ajax call to get the block content.
4776
-		 *
4777
-		 * This can be used in your widget to return different content as the block content.
4778
-		 *
4779
-		 * @return bool
4780
-		 *@since 1.0.3
4781
-		 */
4782
-		public function is_block_content_call() {
4783
-			$result = false;
4784
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4785
-				$result = true;
4786
-			}
4755
+            // set widget instance
4756
+            $this->instance = $instance;
4787 4757
 
4788
-			return $result;
4789
-		}
4758
+            if ( empty( $this->arguments ) ) {
4759
+                $this->get_arguments();
4760
+            }
4790 4761
 
4791
-		/**
4792
-		 * Get an instance hash that will be unique to the type and settings.
4793
-		 *
4794
-		 * @return string
4795
-		 *@since 1.0.20
4796
-		 */
4797
-		public function get_instance_hash(){
4798
-			$instance_string = $this->base_id.serialize($this->instance);
4799
-			return hash('crc32b',$instance_string);
4800
-		}
4762
+            // check for checkboxes
4763
+            if ( ! empty( $this->arguments ) ) {
4764
+                foreach ( $this->arguments as $argument ) {
4765
+                    if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4766
+                        $instance[ $argument['name'] ] = '0';
4767
+                    }
4768
+                }
4769
+            }
4801 4770
 
4802
-		/**
4803
-		 * Generate and return inline styles from CSS rules that will match the unique class of the instance.
4804
-		 *
4805
-		 * @param array $rules
4806
-		 *
4807
-		 * @return string
4808
-		 *@since 1.0.20
4809
-		 */
4810
-		public function get_instance_style($rules = array()){
4811
-			$css = '';
4812
-
4813
-			if(!empty($rules)){
4814
-				$rules = array_unique($rules);
4815
-				$instance_hash = $this->get_instance_hash();
4816
-				$css .= "<style>";
4817
-				foreach($rules as $rule){
4818
-					$css .= ".sdel-$instance_hash $rule";
4819
-				}
4820
-				$css .= "</style>";
4821
-			}
4771
+            return $instance;
4772
+        }
4822 4773
 
4823
-			return $css;
4824
-		}
4774
+        /**
4775
+         * Checks if the current call is a ajax call to get the block content.
4776
+         *
4777
+         * This can be used in your widget to return different content as the block content.
4778
+         *
4779
+         * @return bool
4780
+         *@since 1.0.3
4781
+         */
4782
+        public function is_block_content_call() {
4783
+            $result = false;
4784
+            if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4785
+                $result = true;
4786
+            }
4825 4787
 
4826
-		/**
4827
-		 * Encode shortcodes tags.
4828
-		 *
4829
-		 * @param string $content Content to search for shortcode tags.
4830
-		 *
4788
+            return $result;
4789
+        }
4790
+
4791
+        /**
4792
+         * Get an instance hash that will be unique to the type and settings.
4793
+         *
4794
+         * @return string
4795
+         *@since 1.0.20
4796
+         */
4797
+        public function get_instance_hash(){
4798
+            $instance_string = $this->base_id.serialize($this->instance);
4799
+            return hash('crc32b',$instance_string);
4800
+        }
4801
+
4802
+        /**
4803
+         * Generate and return inline styles from CSS rules that will match the unique class of the instance.
4804
+         *
4805
+         * @param array $rules
4806
+         *
4807
+         * @return string
4808
+         *@since 1.0.20
4809
+         */
4810
+        public function get_instance_style($rules = array()){
4811
+            $css = '';
4812
+
4813
+            if(!empty($rules)){
4814
+                $rules = array_unique($rules);
4815
+                $instance_hash = $this->get_instance_hash();
4816
+                $css .= "<style>";
4817
+                foreach($rules as $rule){
4818
+                    $css .= ".sdel-$instance_hash $rule";
4819
+                }
4820
+                $css .= "</style>";
4821
+            }
4822
+
4823
+            return $css;
4824
+        }
4825
+
4826
+        /**
4827
+         * Encode shortcodes tags.
4828
+         *
4829
+         * @param string $content Content to search for shortcode tags.
4830
+         *
4831 4831
 *@return string Content with shortcode tags removed.
4832
-		 *@since 1.0.28
4833
-		 *
4834
-		 */
4835
-		public function encode_shortcodes( $content ) {
4836
-			// Avoids existing encoded tags.
4837
-			$trans   = array(
4838
-				'&#91;' => '&#091;',
4839
-				'&#93;' => '&#093;',
4840
-				'&amp;#91;' => '&#091;',
4841
-				'&amp;#93;' => '&#093;',
4842
-				'&lt;' => '&0lt;',
4843
-				'&gt;' => '&0gt;',
4844
-				'&amp;lt;' => '&0lt;',
4845
-				'&amp;gt;' => '&0gt;',
4846
-			);
4847
-
4848
-			$content = strtr( $content, $trans );
4849
-
4850
-			$trans   = array(
4851
-				'[' => '&#91;',
4852
-				']' => '&#93;',
4853
-				'<' => '&lt;',
4854
-				'>' => '&gt;',
4855
-				'"' => '&quot;',
4856
-				"'" => '&#39;',
4857
-			);
4858
-
4859
-			$content = strtr( $content, $trans );
4860
-
4861
-			return $content;
4862
-		}
4832
+         *@since 1.0.28
4833
+         *
4834
+         */
4835
+        public function encode_shortcodes( $content ) {
4836
+            // Avoids existing encoded tags.
4837
+            $trans   = array(
4838
+                '&#91;' => '&#091;',
4839
+                '&#93;' => '&#093;',
4840
+                '&amp;#91;' => '&#091;',
4841
+                '&amp;#93;' => '&#093;',
4842
+                '&lt;' => '&0lt;',
4843
+                '&gt;' => '&0gt;',
4844
+                '&amp;lt;' => '&0lt;',
4845
+                '&amp;gt;' => '&0gt;',
4846
+            );
4847
+
4848
+            $content = strtr( $content, $trans );
4849
+
4850
+            $trans   = array(
4851
+                '[' => '&#91;',
4852
+                ']' => '&#93;',
4853
+                '<' => '&lt;',
4854
+                '>' => '&gt;',
4855
+                '"' => '&quot;',
4856
+                "'" => '&#39;',
4857
+            );
4858
+
4859
+            $content = strtr( $content, $trans );
4860
+
4861
+            return $content;
4862
+        }
4863 4863
 
4864
-		/**
4865
-		 * Remove encoded shortcod tags.
4866
-		 *
4867
-		 * @param string $content Content to search for shortcode tags.
4868
-		 *
4864
+        /**
4865
+         * Remove encoded shortcod tags.
4866
+         *
4867
+         * @param string $content Content to search for shortcode tags.
4868
+         *
4869 4869
 *@return string Content with decoded shortcode tags.
4870
-		 *@since 1.0.28
4871
-		 *
4872
-		 */
4873
-		public function decode_shortcodes( $content ) {
4874
-			$trans   = array(
4875
-				'&#91;' => '[',
4876
-				'&#93;' => ']',
4877
-				'&amp;#91;' => '[',
4878
-				'&amp;#93;' => ']',
4879
-				'&lt;' => '<',
4880
-				'&gt;' => '>',
4881
-				'&amp;lt;' => '<',
4882
-				'&amp;gt;' => '>',
4883
-				'&quot;' => '"',
4884
-				'&apos;' => "'",
4885
-			);
4886
-
4887
-			$content = strtr( $content, $trans );
4888
-
4889
-			$trans   = array(
4890
-				'&#091;' => '&#91;',
4891
-				'&#093;' => '&#93;',
4892
-				'&amp;#091;' => '&#91;',
4893
-				'&amp;#093;' => '&#93;',
4894
-				'&0lt;' => '&lt;',
4895
-				'&0gt;' => '&gt;',
4896
-				'&amp;0lt;' => '&lt;',
4897
-				'&amp;0gt;' => '&gt;',
4898
-			);
4899
-
4900
-			$content = strtr( $content, $trans );
4901
-
4902
-			return $content;
4903
-		}
4904
-
4905
-		public function block_visibility_fields( $args ) {
4906
-			$value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
4907
-			$content = '<div class="bs-vc-rule-template d-none">';
4908
-				$content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
4909
-					$content .= '<div class="row">';
4910
-						$content .= '<div class="col-sm-12">';
4911
-							$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>';
4912
-							$content .= aui()->select(
4913
-								array(
4914
-									'id'          => 'bsvc_rule_BSVCINDEX',
4915
-									'name'        => 'bsvc_rule_BSVCINDEX',
4916
-									'label'       => __( 'Rule', 'ayecode-connect' ),
4917
-									'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
4918
-									'class'       => 'bsvc_rule form-select-sm no-select2',
4919
-									'options'     => sd_visibility_rules_options(),
4920
-									'default'     => '',
4921
-									'value'       => '',
4922
-									'label_type'  => '',
4923
-									'select2'     => false,
4924
-									'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
4925
-									'extra_attributes' => array(
4926
-										'data-minimum-results-for-search' => '-1'
4927
-									)
4928
-								)
4929
-							);
4930
-
4931
-						$content .= '</div>';
4932
-
4933
-						if ( class_exists( 'GeoDirectory' ) ) {
4934
-							$content .= '<div class="col-md-7 col-sm-12">';
4935
-
4936
-								$content .= aui()->select(
4937
-									array(
4938
-										'id'          => 'bsvc_gd_field_BSVCINDEX',
4939
-										'name'        => 'bsvc_gd_field_BSVCINDEX',
4940
-										'label'       => __( 'FIELD', 'ayecode-connect' ),
4941
-										'placeholder' => __( 'FIELD', 'ayecode-connect' ),
4942
-										'class'       => 'bsvc_gd_field form-select-sm no-select2',
4943
-										'options'     => sd_visibility_gd_field_options(),
4944
-										'default'     => '',
4945
-										'value'       => '',
4946
-										'label_type'  => '',
4947
-										'select2'     => false,
4948
-										'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
4949
-										'extra_attributes' => array(
4950
-											'data-minimum-results-for-search' => '-1'
4951
-										)
4952
-									)
4953
-								);
4954
-
4955
-							$content .= '</div>';
4956
-							$content .= '<div class="col-md-5 col-sm-12">';
4957
-
4958
-								$content .= aui()->select(
4959
-									array(
4960
-										'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
4961
-										'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
4962
-										'label'       => __( 'CONDITION', 'ayecode-connect' ),
4963
-										'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
4964
-										'class'       => 'bsvc_gd_field_condition form-select-sm no-select2',
4965
-										'options'     => sd_visibility_field_condition_options(),
4966
-										'default'     => '',
4967
-										'value'       => '',
4968
-										'label_type'  => '',
4969
-										'select2'     => false,
4970
-										'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
4971
-										'extra_attributes' => array(
4972
-											'data-minimum-results-for-search' => '-1'
4973
-										)
4974
-									)
4975
-								);
4976
-
4977
-							$content .= '</div>';
4978
-							$content .= '<div class="col-sm-12">';
4979
-
4980
-								$content .= aui()->input(
4981
-									array(
4982
-										'type'            => 'text',
4983
-										'id'              => 'bsvc_gd_field_search_BSVCINDEX',
4984
-										'name'            => 'bsvc_gd_field_search_BSVCINDEX',
4985
-										'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
4986
-										'class'           => 'bsvc_gd_field_search form-control-sm',
4987
-										'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
4988
-										'label_type'      => '',
4989
-										'value'           => '',
4990
-										'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")'
4991
-									)
4992
-								);
4870
+         *@since 1.0.28
4871
+         *
4872
+         */
4873
+        public function decode_shortcodes( $content ) {
4874
+            $trans   = array(
4875
+                '&#91;' => '[',
4876
+                '&#93;' => ']',
4877
+                '&amp;#91;' => '[',
4878
+                '&amp;#93;' => ']',
4879
+                '&lt;' => '<',
4880
+                '&gt;' => '>',
4881
+                '&amp;lt;' => '<',
4882
+                '&amp;gt;' => '>',
4883
+                '&quot;' => '"',
4884
+                '&apos;' => "'",
4885
+            );
4886
+
4887
+            $content = strtr( $content, $trans );
4888
+
4889
+            $trans   = array(
4890
+                '&#091;' => '&#91;',
4891
+                '&#093;' => '&#93;',
4892
+                '&amp;#091;' => '&#91;',
4893
+                '&amp;#093;' => '&#93;',
4894
+                '&0lt;' => '&lt;',
4895
+                '&0gt;' => '&gt;',
4896
+                '&amp;0lt;' => '&lt;',
4897
+                '&amp;0gt;' => '&gt;',
4898
+            );
4899
+
4900
+            $content = strtr( $content, $trans );
4901
+
4902
+            return $content;
4903
+        }
4993 4904
 
4994
-							$content .= '</div>';
4995
-						}
4905
+        public function block_visibility_fields( $args ) {
4906
+            $value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
4907
+            $content = '<div class="bs-vc-rule-template d-none">';
4908
+                $content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
4909
+                    $content .= '<div class="row">';
4910
+                        $content .= '<div class="col-sm-12">';
4911
+                            $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>';
4912
+                            $content .= aui()->select(
4913
+                                array(
4914
+                                    'id'          => 'bsvc_rule_BSVCINDEX',
4915
+                                    'name'        => 'bsvc_rule_BSVCINDEX',
4916
+                                    'label'       => __( 'Rule', 'ayecode-connect' ),
4917
+                                    'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
4918
+                                    'class'       => 'bsvc_rule form-select-sm no-select2',
4919
+                                    'options'     => sd_visibility_rules_options(),
4920
+                                    'default'     => '',
4921
+                                    'value'       => '',
4922
+                                    'label_type'  => '',
4923
+                                    'select2'     => false,
4924
+                                    'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
4925
+                                    'extra_attributes' => array(
4926
+                                        'data-minimum-results-for-search' => '-1'
4927
+                                    )
4928
+                                )
4929
+                            );
4930
+
4931
+                        $content .= '</div>';
4932
+
4933
+                        if ( class_exists( 'GeoDirectory' ) ) {
4934
+                            $content .= '<div class="col-md-7 col-sm-12">';
4935
+
4936
+                                $content .= aui()->select(
4937
+                                    array(
4938
+                                        'id'          => 'bsvc_gd_field_BSVCINDEX',
4939
+                                        'name'        => 'bsvc_gd_field_BSVCINDEX',
4940
+                                        'label'       => __( 'FIELD', 'ayecode-connect' ),
4941
+                                        'placeholder' => __( 'FIELD', 'ayecode-connect' ),
4942
+                                        'class'       => 'bsvc_gd_field form-select-sm no-select2',
4943
+                                        'options'     => sd_visibility_gd_field_options(),
4944
+                                        'default'     => '',
4945
+                                        'value'       => '',
4946
+                                        'label_type'  => '',
4947
+                                        'select2'     => false,
4948
+                                        'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
4949
+                                        'extra_attributes' => array(
4950
+                                            'data-minimum-results-for-search' => '-1'
4951
+                                        )
4952
+                                    )
4953
+                                );
4954
+
4955
+                            $content .= '</div>';
4956
+                            $content .= '<div class="col-md-5 col-sm-12">';
4957
+
4958
+                                $content .= aui()->select(
4959
+                                    array(
4960
+                                        'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
4961
+                                        'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
4962
+                                        'label'       => __( 'CONDITION', 'ayecode-connect' ),
4963
+                                        'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
4964
+                                        'class'       => 'bsvc_gd_field_condition form-select-sm no-select2',
4965
+                                        'options'     => sd_visibility_field_condition_options(),
4966
+                                        'default'     => '',
4967
+                                        'value'       => '',
4968
+                                        'label_type'  => '',
4969
+                                        'select2'     => false,
4970
+                                        'element_require'  => '[%bsvc_rule_BSVCINDEX%]=="gd_field"',
4971
+                                        'extra_attributes' => array(
4972
+                                            'data-minimum-results-for-search' => '-1'
4973
+                                        )
4974
+                                    )
4975
+                                );
4976
+
4977
+                            $content .= '</div>';
4978
+                            $content .= '<div class="col-sm-12">';
4979
+
4980
+                                $content .= aui()->input(
4981
+                                    array(
4982
+                                        'type'            => 'text',
4983
+                                        'id'              => 'bsvc_gd_field_search_BSVCINDEX',
4984
+                                        'name'            => 'bsvc_gd_field_search_BSVCINDEX',
4985
+                                        'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
4986
+                                        'class'           => 'bsvc_gd_field_search form-control-sm',
4987
+                                        'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
4988
+                                        'label_type'      => '',
4989
+                                        'value'           => '',
4990
+                                        '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")'
4991
+                                    )
4992
+                                );
4993
+
4994
+                            $content .= '</div>';
4995
+                        }
4996 4996
 
4997
-					$content .= '</div>';
4998
-
4999
-					$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>';
5000
-						$role_options = sd_user_roles_options();
5001
-
5002
-						$role_option_i = 0;
5003
-						foreach ( $role_options as $role_option_key => $role_option_name ) {
5004
-							$role_option_i++;
5005
-
5006
-							$content .= '<div class="col-sm-6">';
5007
-							$content .= aui()->input(
5008
-								array(
5009
-									'id'               => 'bsvc_user_roles_BSVCINDEX_' . $role_option_i,
5010
-									'name'             => 'bsvc_user_roles_BSVCINDEX[]',
5011
-									'type'             => 'checkbox',
5012
-									'label'            => $role_option_name,
5013
-									'label_type'       => 'hidden',
5014
-									'class'            => 'bsvc_user_roles',
5015
-									'value'            => $role_option_key,
5016
-									'switch'           => 'md',
5017
-									'no_wrap'          => true
5018
-								)
5019
-							);
5020
-							$content .= '</div>';
5021
-						}
5022
-					$content .= '</div>';
5023
-				$content .= '</div>';
5024
-			$content .= '</div>';
5025
-			$content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5026
-			$content .= '<div class="bs-vc-rule-sets"></div>';
5027
-			$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>';
5028
-			$content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5029
-			$content .= aui()->select(
5030
-				array(
5031
-					'id'          => 'bsvc_output',
5032
-					'name'        => 'bsvc_output',
5033
-					'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5034
-					'placeholder' => __( 'Default Output', 'ayecode-connect' ),
5035
-					'class'       => 'bsvc_output form-select-sm no-select2',
5036
-					'options'     => sd_visibility_output_options(),
5037
-					'default'     => '',
5038
-					'value'       => '',
5039
-					'label_type'  => 'top',
5040
-					'select2'     => false,
5041
-					'extra_attributes' => array(
5042
-						'data-minimum-results-for-search' => '-1'
5043
-					)
5044
-				)
5045
-			);
5046
-
5047
-			$content .= '</div><div class="col-md-6 col-sm-12">';
5048
-
5049
-			$content .= aui()->select(
5050
-				array(
5051
-					'id'              => 'bsvc_page',
5052
-					'name'            => 'bsvc_page',
5053
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5054
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5055
-					'class'           => 'bsvc_page form-select-sm no-select2',
5056
-					'options'         => sd_template_page_options(),
5057
-					'default'         => '',
5058
-					'value'           => '',
5059
-					'label_type'      => 'top',
5060
-					'select2'         => false,
5061
-					'element_require' => '[%bsvc_output%]=="page"'
5062
-				)
5063
-			);
5064
-
5065
-			$content .= aui()->select(
5066
-				array(
5067
-					'id'          => 'bsvc_tmpl_part',
5068
-					'name'        => 'bsvc_tmpl_part',
5069
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5070
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5071
-					'class'       => 'bsvc_tmpl_part form-select-sm no-select2',
5072
-					'options'     => sd_template_part_options(),
5073
-					'default'     => '',
5074
-					'value'       => '',
5075
-					'label_type'  => 'top',
5076
-					'select2'     => false,
5077
-					'element_require'  => '[%bsvc_output%]=="template_part"',
5078
-					'extra_attributes' => array(
5079
-						'data-minimum-results-for-search' => '-1'
5080
-					)
5081
-				)
5082
-			);
5083
-
5084
-			$content .= aui()->select(
5085
-				array(
5086
-					'id'               => 'bsvc_message_type',
5087
-					'name'             => 'bsvc_message_type',
5088
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5089
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5090
-					'class'            => 'bsvc_message_type form-select-sm no-select2',
5091
-					'options'          => sd_aui_colors(),
5092
-					'default'          => '',
5093
-					'value'            => '',
5094
-					'label_type'       => 'top',
5095
-					'select2'          => false,
5096
-					'element_require'  => '[%bsvc_output%]=="message"',
5097
-					'extra_attributes' => array(
5098
-						'data-minimum-results-for-search' => '-1'
5099
-					)
5100
-				)
5101
-			);
5102
-
5103
-			$content .= '</div><div class="col-sm-12">';
5104
-
5105
-			$content .= aui()->input(
5106
-				array(
5107
-					'type'            => 'text',
5108
-					'id'              => 'bsvc_message',
5109
-					'name'            => 'bsvc_message',
5110
-					'label'           => '',
5111
-					'class'           => 'bsvc_message form-control-sm',
5112
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5113
-					'label_type'      => '',
5114
-					'value'           => '',
5115
-					'form_group_class' => ' ',
5116
-					'element_require' => '[%bsvc_output%]=="message"',
5117
-				)
5118
-			);
5119
-
5120
-			$content .= '</div></div></form><input type="hidden" id="bsvc_raw_value" name="bsvc_raw_value" value="' . $value . '">';
5121
-
5122
-			return $content;
5123
-		}
5124
-	}
4997
+                    $content .= '</div>';
4998
+
4999
+                    $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>';
5000
+                        $role_options = sd_user_roles_options();
5001
+
5002
+                        $role_option_i = 0;
5003
+                        foreach ( $role_options as $role_option_key => $role_option_name ) {
5004
+                            $role_option_i++;
5005
+
5006
+                            $content .= '<div class="col-sm-6">';
5007
+                            $content .= aui()->input(
5008
+                                array(
5009
+                                    'id'               => 'bsvc_user_roles_BSVCINDEX_' . $role_option_i,
5010
+                                    'name'             => 'bsvc_user_roles_BSVCINDEX[]',
5011
+                                    'type'             => 'checkbox',
5012
+                                    'label'            => $role_option_name,
5013
+                                    'label_type'       => 'hidden',
5014
+                                    'class'            => 'bsvc_user_roles',
5015
+                                    'value'            => $role_option_key,
5016
+                                    'switch'           => 'md',
5017
+                                    'no_wrap'          => true
5018
+                                )
5019
+                            );
5020
+                            $content .= '</div>';
5021
+                        }
5022
+                    $content .= '</div>';
5023
+                $content .= '</div>';
5024
+            $content .= '</div>';
5025
+            $content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5026
+            $content .= '<div class="bs-vc-rule-sets"></div>';
5027
+            $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>';
5028
+            $content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5029
+            $content .= aui()->select(
5030
+                array(
5031
+                    'id'          => 'bsvc_output',
5032
+                    'name'        => 'bsvc_output',
5033
+                    'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5034
+                    'placeholder' => __( 'Default Output', 'ayecode-connect' ),
5035
+                    'class'       => 'bsvc_output form-select-sm no-select2',
5036
+                    'options'     => sd_visibility_output_options(),
5037
+                    'default'     => '',
5038
+                    'value'       => '',
5039
+                    'label_type'  => 'top',
5040
+                    'select2'     => false,
5041
+                    'extra_attributes' => array(
5042
+                        'data-minimum-results-for-search' => '-1'
5043
+                    )
5044
+                )
5045
+            );
5046
+
5047
+            $content .= '</div><div class="col-md-6 col-sm-12">';
5048
+
5049
+            $content .= aui()->select(
5050
+                array(
5051
+                    'id'              => 'bsvc_page',
5052
+                    'name'            => 'bsvc_page',
5053
+                    'label'           => __( 'Page Content', 'ayecode-connect' ),
5054
+                    'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5055
+                    'class'           => 'bsvc_page form-select-sm no-select2',
5056
+                    'options'         => sd_template_page_options(),
5057
+                    'default'         => '',
5058
+                    'value'           => '',
5059
+                    'label_type'      => 'top',
5060
+                    'select2'         => false,
5061
+                    'element_require' => '[%bsvc_output%]=="page"'
5062
+                )
5063
+            );
5064
+
5065
+            $content .= aui()->select(
5066
+                array(
5067
+                    'id'          => 'bsvc_tmpl_part',
5068
+                    'name'        => 'bsvc_tmpl_part',
5069
+                    'label'       => __( 'Template Part', 'ayecode-connect' ),
5070
+                    'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5071
+                    'class'       => 'bsvc_tmpl_part form-select-sm no-select2',
5072
+                    'options'     => sd_template_part_options(),
5073
+                    'default'     => '',
5074
+                    'value'       => '',
5075
+                    'label_type'  => 'top',
5076
+                    'select2'     => false,
5077
+                    'element_require'  => '[%bsvc_output%]=="template_part"',
5078
+                    'extra_attributes' => array(
5079
+                        'data-minimum-results-for-search' => '-1'
5080
+                    )
5081
+                )
5082
+            );
5083
+
5084
+            $content .= aui()->select(
5085
+                array(
5086
+                    'id'               => 'bsvc_message_type',
5087
+                    'name'             => 'bsvc_message_type',
5088
+                    'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5089
+                    'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5090
+                    'class'            => 'bsvc_message_type form-select-sm no-select2',
5091
+                    'options'          => sd_aui_colors(),
5092
+                    'default'          => '',
5093
+                    'value'            => '',
5094
+                    'label_type'       => 'top',
5095
+                    'select2'          => false,
5096
+                    'element_require'  => '[%bsvc_output%]=="message"',
5097
+                    'extra_attributes' => array(
5098
+                        'data-minimum-results-for-search' => '-1'
5099
+                    )
5100
+                )
5101
+            );
5102
+
5103
+            $content .= '</div><div class="col-sm-12">';
5104
+
5105
+            $content .= aui()->input(
5106
+                array(
5107
+                    'type'            => 'text',
5108
+                    'id'              => 'bsvc_message',
5109
+                    'name'            => 'bsvc_message',
5110
+                    'label'           => '',
5111
+                    'class'           => 'bsvc_message form-control-sm',
5112
+                    'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5113
+                    'label_type'      => '',
5114
+                    'value'           => '',
5115
+                    'form_group_class' => ' ',
5116
+                    'element_require' => '[%bsvc_output%]=="message"',
5117
+                )
5118
+            );
5119
+
5120
+            $content .= '</div></div></form><input type="hidden" id="bsvc_raw_value" name="bsvc_raw_value" value="' . $value . '">';
5121
+
5122
+            return $content;
5123
+        }
5124
+    }
5125 5125
 }
Please login to merge, or discard this patch.
Spacing   +775 added lines, -775 removed lines patch added patch discarded remove patch
@@ -1,11 +1,11 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) {
2
+if (!defined('ABSPATH')) {
3 3
 	exit;
4 4
 }
5 5
 
6
-if ( ! class_exists( 'WP_Super_Duper' ) ) {
6
+if (!class_exists('WP_Super_Duper')) {
7 7
 
8
-	define( 'SUPER_DUPER_VER', '1.1.35' );
8
+	define('SUPER_DUPER_VER', '1.1.35');
9 9
 
10 10
 	/**
11 11
 	 * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress.
@@ -38,40 +38,40 @@  discard block
 block discarded – undo
38 38
 		/**
39 39
 		 * Take the array options and use them to build.
40 40
 		 */
41
-		public function __construct( $options ) {
41
+		public function __construct($options) {
42 42
 			global $sd_widgets;
43 43
 
44
-			$sd_widgets[ $options['base_id'] ] = array(
44
+			$sd_widgets[$options['base_id']] = array(
45 45
 				'name'       => $options['name'],
46 46
 				'class_name' => $options['class_name'],
47 47
 				'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48 48
 			);
49
-			$this->base_id                     = $options['base_id'];
49
+			$this->base_id = $options['base_id'];
50 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 );
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 54
 			$this->options = $options;
55 55
 
56 56
 			$this->base_id   = $options['base_id'];
57
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
57
+			$this->arguments = isset($options['arguments']) ? $options['arguments'] : array();
58 58
 
59 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');
60
+            if (!empty($this->options['nested-block'])) {
61
+                if (empty($this->options['output_types'])) {
62
+                    $this->options['output_types'] = array('shortcode', 'block');
63 63
                 }elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64 64
                     unset($this->options['output_types'][$key]);
65 65
                 }
66 66
             }
67 67
 
68 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'] );
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 71
 			}
72 72
 
73 73
 
74
-			if ( isset( $options['class_name'] ) ) {
74
+			if (isset($options['class_name'])) {
75 75
 				// register widget
76 76
 				$this->class_name = $options['class_name'];
77 77
 
@@ -80,61 +80,61 @@  discard block
 block discarded – undo
80 80
 
81 81
 
82 82
 				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
83
+				if (function_exists('fusion_builder_map')) {
84
+					add_action('init', array($this, 'register_fusion_element'));
85 85
 				}
86 86
 
87 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' ) );
88
+				if (empty($this->options['output_types']) || in_array('block', $this->options['output_types'])) {
89
+				    add_action('admin_enqueue_scripts', array($this, 'register_block'));
90 90
                 }
91 91
 			}
92 92
 
93 93
 			// add the CSS and JS we need ONCE
94 94
 			global $sd_widget_scripts;
95 95
 
96
-			if ( ! $sd_widget_scripts ) {
97
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
98
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
99
-				wp_add_inline_style( 'widgets', $this->widget_css() );
96
+			if (!$sd_widget_scripts) {
97
+				wp_add_inline_script('admin-widgets', $this->widget_js());
98
+				wp_add_inline_script('customize-controls', $this->widget_js());
99
+				wp_add_inline_style('widgets', $this->widget_css());
100 100
 
101 101
 				// maybe add elementor editor styles
102
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
102
+				add_action('elementor/editor/after_enqueue_styles', array($this, 'elementor_editor_styles'));
103 103
 
104 104
 				$sd_widget_scripts = true;
105 105
 
106 106
 				// add shortcode insert button once
107
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
107
+				add_action('media_buttons', array($this, 'shortcode_insert_button'));
108 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' ) );
109
+				if (function_exists('generate_sections_sections_metabox')) {
110
+					add_action('generate_sections_metabox', array($this, 'shortcode_insert_button_script'));
111 111
 				}
112 112
 				/* Load script on Divi theme builder page */
113
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
113
+				if (function_exists('et_builder_is_tb_admin_screen') && et_builder_is_tb_admin_screen()) {
114 114
 					add_thickbox();
115
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
115
+					add_action('admin_footer', array($this, 'shortcode_insert_button_script'));
116 116
 				}
117 117
 
118
-				if ( $this->is_preview() ) {
119
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
118
+				if ($this->is_preview()) {
119
+					add_action('wp_footer', array($this, 'shortcode_insert_button_script'));
120 120
 					// this makes the insert button work for elementor
121
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
121
+					add_action('elementor/editor/after_enqueue_scripts', array(
122 122
 						$this,
123 123
 						'shortcode_insert_button_script'
124
-					) ); // for elementor
124
+					)); // for elementor
125 125
 				}
126 126
 				// this makes the insert button work for cornerstone
127
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
127
+				add_action('wp_print_footer_scripts', array(__CLASS__, 'maybe_cornerstone_builder'));
128 128
 
129
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
130
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
129
+				add_action('wp_ajax_super_duper_get_widget_settings', array(__CLASS__, 'get_widget_settings'));
130
+				add_action('wp_ajax_super_duper_get_picker', array(__CLASS__, 'get_picker'));
131 131
 
132 132
 				// add generator text to head
133
-				add_action( 'admin_head', array( $this, 'generator' ), 99 );
134
-				add_action( 'wp_head', array( $this, 'generator' ), 99 );
133
+				add_action('admin_head', array($this, 'generator'), 99);
134
+				add_action('wp_head', array($this, 'generator'), 99);
135 135
 			}
136 136
 
137
-			do_action( 'wp_super_duper_widget_init', $options, $this );
137
+			do_action('wp_super_duper_widget_init', $options, $this);
138 138
 		}
139 139
 
140 140
         /**
@@ -142,7 +142,7 @@  discard block
 block discarded – undo
142 142
          * @return void
143 143
          */
144 144
 		public function _register() {
145
-            if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
145
+            if (empty($this->options['output_types']) || in_array('widget', $this->options['output_types'])) {
146 146
                 parent::_register();
147 147
 			}
148 148
 		}
@@ -151,14 +151,14 @@  discard block
 block discarded – undo
151 151
 		 * Add our widget CSS to elementor editor.
152 152
 		 */
153 153
 		public function elementor_editor_styles() {
154
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
154
+			wp_add_inline_style('elementor-editor', $this->widget_css(false));
155 155
 		}
156 156
 
157 157
 		public function register_fusion_element() {
158 158
 
159 159
 			$options = $this->options;
160 160
 
161
-			if ( $this->base_id ) {
161
+			if ($this->base_id) {
162 162
 
163 163
 				$params = $this->get_fusion_params();
164 164
 
@@ -169,11 +169,11 @@  discard block
 block discarded – undo
169 169
 					'allow_generator' => true,
170 170
 				);
171 171
 
172
-				if ( ! empty( $params ) ) {
172
+				if (!empty($params)) {
173 173
 					$args['params'] = $params;
174 174
 				}
175 175
 
176
-				fusion_builder_map( $args );
176
+				fusion_builder_map($args);
177 177
 			}
178 178
 
179 179
 		}
@@ -182,8 +182,8 @@  discard block
 block discarded – undo
182 182
 			$params    = array();
183 183
 			$arguments = $this->get_arguments();
184 184
 
185
-			if ( ! empty( $arguments ) ) {
186
-				foreach ( $arguments as $key => $val ) {
185
+			if (!empty($arguments)) {
186
+				foreach ($arguments as $key => $val) {
187 187
 					$param = array();
188 188
 					// type
189 189
 					$param['type'] = str_replace(
@@ -205,38 +205,38 @@  discard block
 block discarded – undo
205 205
 						$val['type'] );
206 206
 
207 207
 					// multiselect
208
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
208
+					if ($val['type'] == 'multiselect' || (($param['type'] == 'select' || $val['type'] == 'select') && !empty($val['multiple']))) {
209 209
 						$param['type']     = 'multiple_select';
210 210
 						$param['multiple'] = true;
211 211
 					}
212 212
 
213 213
 					// heading
214
-					$param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
214
+					$param['heading'] = isset($val['title']) ? $val['title'] : '';
215 215
 
216 216
 					// description
217
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
217
+					$param['description'] = isset($val['desc']) ? $val['desc'] : '';
218 218
 
219 219
 					// param_name
220 220
 					$param['param_name'] = $key;
221 221
 
222 222
 					// Default
223
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
223
+					$param['default'] = isset($val['default']) ? $val['default'] : '';
224 224
 
225 225
 					// Group
226
-					if ( isset( $val['group'] ) ) {
226
+					if (isset($val['group'])) {
227 227
 						$param['group'] = $val['group'];
228 228
 					}
229 229
 
230 230
 					// value
231
-					if ( $val['type'] == 'checkbox' ) {
232
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
233
-							unset( $param['default'] );
231
+					if ($val['type'] == 'checkbox') {
232
+						if (isset($val['default']) && $val['default'] == '0') {
233
+							unset($param['default']);
234 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();
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 238
 					} else {
239
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
239
+						$param['value'] = isset($val['default']) ? $val['default'] : '';
240 240
 					}
241 241
 
242 242
 					// setup the param
@@ -253,7 +253,7 @@  discard block
 block discarded – undo
253 253
 		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
254 254
 		 */
255 255
 		public static function maybe_cornerstone_builder() {
256
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
256
+			if (did_action('cornerstone_before_boot_app')) {
257 257
 				self::shortcode_insert_button_script();
258 258
 			}
259 259
 		}
@@ -265,12 +265,12 @@  discard block
 block discarded – undo
265 265
 		 *
266 266
 		 * @return string
267 267
 		 */
268
-		public static function get_picker( $editor_id = '' ) {
268
+		public static function get_picker($editor_id = '') {
269 269
 
270 270
 			ob_start();
271
-			if ( isset( $_POST['editor_id'] ) ) {
272
-				$editor_id = esc_attr( $_POST['editor_id'] );
273
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
271
+			if (isset($_POST['editor_id'])) {
272
+				$editor_id = esc_attr($_POST['editor_id']);
273
+			} elseif (isset($_REQUEST['et_fb'])) {
274 274
 				$editor_id = 'main_content_content_vb_tiny_mce';
275 275
 			}
276 276
 
@@ -281,14 +281,14 @@  discard block
 block discarded – undo
281 281
 
282 282
 			<div class="sd-shortcode-left-wrap">
283 283
 				<?php
284
-				ksort( $sd_widgets );
284
+				ksort($sd_widgets);
285 285
 				//				print_r($sd_widgets);exit;
286
-				if ( ! empty( $sd_widgets ) ) {
286
+				if (!empty($sd_widgets)) {
287 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>";
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 292
 					}
293 293
 					echo "</select>";
294 294
 
@@ -301,37 +301,37 @@  discard block
 block discarded – undo
301 301
 			<div class="sd-shortcode-right-wrap">
302 302
 				<textarea id='sd-shortcode-output' disabled></textarea>
303 303
 				<div id='sd-shortcode-output-actions'>
304
-					<?php if ( $editor_id != '' ) { ?>
304
+					<?php if ($editor_id != '') { ?>
305 305
 						<button class="button sd-insert-shortcode-button"
306
-						        onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
306
+						        onclick="sd_insert_shortcode(<?php if (!empty($editor_id)) {
307 307
 							        echo "'" . $editor_id . "'";
308
-						        } ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
308
+						        } ?>)"><?php _e('Insert shortcode', 'ayecode-connect'); ?></button>
309 309
 					<?php } ?>
310 310
 					<button class="button"
311
-					        onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
311
+					        onclick="sd_copy_to_clipboard()"><?php _e('Copy shortcode'); ?></button>
312 312
 				</div>
313 313
 			</div>
314 314
 			<?php
315 315
 
316 316
 			$html = ob_get_clean();
317 317
 
318
-			if ( wp_doing_ajax() ) {
318
+			if (wp_doing_ajax()) {
319 319
 				echo $html;
320 320
 				$should_die = true;
321 321
 
322 322
 				// some builder get the editor via ajax so we should not die on those occasions
323 323
 				$dont_die = array(
324
-					'parent_tag',// WP Bakery
324
+					'parent_tag', // WP Bakery
325 325
 					'avia_request' // enfold
326 326
 				);
327 327
 
328
-				foreach ( $dont_die as $request ) {
329
-					if ( isset( $_REQUEST[ $request ] ) ) {
328
+				foreach ($dont_die as $request) {
329
+					if (isset($_REQUEST[$request])) {
330 330
 						$should_die = false;
331 331
 					}
332 332
 				}
333 333
 
334
-				if ( $should_die ) {
334
+				if ($should_die) {
335 335
 					wp_die();
336 336
 				}
337 337
 
@@ -347,22 +347,22 @@  discard block
 block discarded – undo
347 347
 		 * Output the version in the header.
348 348
 		 */
349 349
 		public function generator() {
350
-			$file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
351
-			$plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
350
+			$file = str_replace(array("/", "\\"), "/", realpath(__FILE__));
351
+			$plugins_dir = str_replace(array("/", "\\"), "/", realpath(WP_PLUGIN_DIR));
352 352
 
353 353
 			// Find source plugin/theme of SD
354 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() ) );
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 359
 
360
-				if ( strpos( $file, $themes_dir ) !== false ) {
361
-					$source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
360
+				if (strpos($file, $themes_dir) !== false) {
361
+					$source = explode("/", ltrim(str_replace($themes_dir, "", $file), "/"));
362 362
 				}
363 363
 			}
364 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] ) . '"' : '' ) . ' />';
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 366
 		}
367 367
 
368 368
 		/**
@@ -373,16 +373,16 @@  discard block
 block discarded – undo
373 373
 		public static function get_widget_settings() {
374 374
 			global $sd_widgets;
375 375
 
376
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
377
-			if ( ! $shortcode ) {
376
+			$shortcode = isset($_REQUEST['shortcode']) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes($_REQUEST['shortcode']) : '';
377
+			if (!$shortcode) {
378 378
 				wp_die();
379 379
 			}
380
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
381
-			if ( ! $widget_args ) {
380
+			$widget_args = isset($sd_widgets[$shortcode]) ? $sd_widgets[$shortcode] : '';
381
+			if (!$widget_args) {
382 382
 				wp_die();
383 383
 			}
384
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
385
-			if ( ! $class_name ) {
384
+			$class_name = isset($widget_args['class_name']) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
385
+			if (!$class_name) {
386 386
 				wp_die();
387 387
 			}
388 388
 
@@ -390,7 +390,7 @@  discard block
 block discarded – undo
390 390
 			$widget = new $class_name;
391 391
 
392 392
 			ob_start();
393
-			$widget->form( array() );
393
+			$widget->form(array());
394 394
 			$form = ob_get_clean();
395 395
 			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
396 396
 			echo "<style>" . $widget->widget_css() . "</style>";
@@ -409,9 +409,9 @@  discard block
 block discarded – undo
409 409
 		 *@since 1.0.0
410 410
 		 *
411 411
 		 */
412
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
412
+		public static function shortcode_insert_button($editor_id = '', $insert_shortcode_function = '') {
413 413
 			global $sd_widgets, $shortcode_insert_button_once;
414
-			if ( $shortcode_insert_button_once ) {
414
+			if ($shortcode_insert_button_once) {
415 415
 				return;
416 416
 			}
417 417
 			add_thickbox();
@@ -421,21 +421,21 @@  discard block
 block discarded – undo
421 421
 			 * Cornerstone makes us play dirty tricks :/
422 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 423
 			 */
424
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
424
+			if (function_exists('cornerstone_plugin_init') && !is_admin()) {
425 425
 				echo '<span id="insert-media-button">';
426 426
 			}
427 427
 
428
-			echo self::shortcode_button( 'this', 'true' );
428
+			echo self::shortcode_button('this', 'true');
429 429
 
430 430
 			// see opening note
431
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
431
+			if (function_exists('cornerstone_plugin_init') && !is_admin()) {
432 432
 				echo '</span>'; // end #insert-media-button
433 433
 			}
434 434
 
435 435
 			// Add separate script for generatepress theme sections
436
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
436
+			if (function_exists('generate_sections_sections_metabox') && did_action('generate_sections_metabox')) {
437 437
 			} else {
438
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
438
+				self::shortcode_insert_button_script($editor_id, $insert_shortcode_function);
439 439
 			}
440 440
 
441 441
 			$shortcode_insert_button_once = true;
@@ -449,12 +449,12 @@  discard block
 block discarded – undo
449 449
 		 *
450 450
 		 * @return mixed
451 451
 		 */
452
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
452
+		public static function shortcode_button($id = '', $search_for_id = '') {
453 453
 			ob_start();
454 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 ) {
457
+				if ($search_for_id) {
458 458
 					echo "," . $search_for_id;
459 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">
@@ -470,7 +470,7 @@  discard block
 block discarded – undo
470 470
 			$html = ob_get_clean();
471 471
 
472 472
 			// remove line breaks so we can use it in js
473
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
473
+			return preg_replace("/\r|\n/", "", trim($html));
474 474
 		}
475 475
 
476 476
 		/**
@@ -528,7 +528,7 @@  discard block
 block discarded – undo
528 528
 						jQuery($this).data('sd-widget-enabled', true);
529 529
 					}
530 530
 
531
-					var $button = '<button title="<?php _e( 'Advanced Settings', 'ayecode-connect' );?>" class="button button-primary right sd-advanced-button" onclick="sd_so_toggle_advanced(this);return false;"><i class="fas fa-sliders-h" aria-hidden="true"></i></button>';
531
+					var $button = '<button title="<?php _e('Advanced Settings', 'ayecode-connect'); ?>" class="button button-primary right sd-advanced-button" onclick="sd_so_toggle_advanced(this);return false;"><i class="fas fa-sliders-h" aria-hidden="true"></i></button>';
532 532
 					var form = jQuery($this).parents('' + $selector + '');
533 533
 
534 534
 					if (jQuery($this).val() == '1' && jQuery(form).find('.sd-advanced-button').length == 0) {
@@ -563,10 +563,10 @@  discard block
 block discarded – undo
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(
566
+			return str_replace(array(
567 567
 				'<script>',
568 568
 				'</script>'
569
-			), '', $output );
569
+			), '', $output);
570 570
 		}
571 571
 
572 572
 		/**
@@ -578,7 +578,7 @@  discard block
 block discarded – undo
578 578
 		 *@since 1.0.6
579 579
 		 *
580 580
 		 */
581
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
581
+		public static function shortcode_insert_button_script($editor_id = '', $insert_shortcode_function = '') {
582 582
 			?>
583 583
 			<style>
584 584
 				.sd-shortcode-left-wrap {
@@ -697,25 +697,25 @@  discard block
 block discarded – undo
697 697
 					width: 100%;
698 698
 				}
699 699
 
700
-				<?php if ( function_exists( 'generate_sections_sections_metabox' ) ) { ?>
700
+				<?php if (function_exists('generate_sections_sections_metabox')) { ?>
701 701
 				.generate-sections-modal #custom-media-buttons > .sd-lable-shortcode-inserter {
702 702
 					display: inline;
703 703
 				}
704 704
 				<?php } ?>
705
-				<?php if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) { ?>
705
+				<?php if (function_exists('et_builder_is_tb_admin_screen') && et_builder_is_tb_admin_screen()) { ?>
706 706
 				body.divi_page_et_theme_builder div#TB_window.gd-tb-window{z-index:9999999}
707 707
 				<?php } ?>
708 708
 			</style>
709 709
 			<?php
710
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
710
+			if (class_exists('SiteOrigin_Panels')) {
711 711
 				echo "<script>" . self::siteorigin_js() . "</script>";
712 712
 			}
713 713
 			?>
714 714
 			<script>
715 715
 				<?php
716
-				if(! empty( $insert_shortcode_function )){
716
+				if (!empty($insert_shortcode_function)) {
717 717
 					echo $insert_shortcode_function;
718
-				}else{
718
+				} else {
719 719
 
720 720
 				/**
721 721
 				 * Function for super duper insert shortcode.
@@ -728,9 +728,9 @@  discard block
 block discarded – undo
728 728
 					if ($shortcode) {
729 729
 						if (!$editor_id) {
730 730
 							<?php
731
-							if ( isset( $_REQUEST['et_fb'] ) ) {
731
+							if (isset($_REQUEST['et_fb'])) {
732 732
 								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
733
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
733
+							} elseif (isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor') {
734 734
 								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
735 735
 							} else {
736 736
 								echo '$editor_id = "#wp-content-editor-container textarea";';
@@ -813,11 +813,11 @@  discard block
 block discarded – undo
813 813
 							'shortcode': $short_code,
814 814
 							'attributes': 123,
815 815
 							'post_id': 321,
816
-							'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
816
+							'_ajax_nonce': '<?php echo wp_create_nonce('super_duper_output_shortcode'); ?>'
817 817
 						};
818 818
 
819 819
 						if (typeof ajaxurl === 'undefined') {
820
-							var ajaxurl = "<?php echo admin_url( 'admin-ajax.php' );?>";
820
+							var ajaxurl = "<?php echo admin_url('admin-ajax.php'); ?>";
821 821
 						}
822 822
 
823 823
 						jQuery.post(ajaxurl, data, function (response) {
@@ -1016,11 +1016,11 @@  discard block
 block discarded – undo
1016 1016
 					var data = {
1017 1017
 						'action': 'super_duper_get_picker',
1018 1018
 						'editor_id': $id,
1019
-						'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_picker' );?>'
1019
+						'_ajax_nonce': '<?php echo wp_create_nonce('super_duper_picker'); ?>'
1020 1020
 					};
1021 1021
 
1022 1022
 					if (!ajaxurl) {
1023
-						var ajaxurl = "<?php echo admin_url( 'admin-ajax.php' ); ?>";
1023
+						var ajaxurl = "<?php echo admin_url('admin-ajax.php'); ?>";
1024 1024
 					}
1025 1025
 
1026 1026
 					jQuery.post(ajaxurl, data, function (response) {
@@ -1042,9 +1042,9 @@  discard block
 block discarded – undo
1042 1042
 				 */
1043 1043
 				function sd_shortcode_button($id) {
1044 1044
 					if ($id) {
1045
-						return '<?php echo self::shortcode_button( "\\''+\$id+'\\'" );?>';
1045
+						return '<?php echo self::shortcode_button("\\''+\$id+'\\'"); ?>';
1046 1046
 					} else {
1047
-						return '<?php echo self::shortcode_button();?>';
1047
+						return '<?php echo self::shortcode_button(); ?>';
1048 1048
 					}
1049 1049
 				}
1050 1050
 			</script>
@@ -1058,11 +1058,11 @@  discard block
 block discarded – undo
1058 1058
 		 *
1059 1059
 		 * @return mixed
1060 1060
 		 */
1061
-		public function widget_css( $advanced = true ) {
1061
+		public function widget_css($advanced = true) {
1062 1062
 			ob_start();
1063 1063
 			?>
1064 1064
 			<style>
1065
-				<?php if( $advanced ){ ?>
1065
+				<?php if ($advanced) { ?>
1066 1066
 				.sd-advanced-setting {
1067 1067
 					display: none;
1068 1068
 				}
@@ -1106,10 +1106,10 @@  discard block
 block discarded – undo
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(
1109
+			return str_replace(array(
1110 1110
 				'<style>',
1111 1111
 				'</style>'
1112
-			), '', $output );
1112
+			), '', $output);
1113 1113
 		}
1114 1114
 
1115 1115
 		/**
@@ -1176,7 +1176,7 @@  discard block
 block discarded – undo
1176 1176
 						jQuery($this).data('sd-widget-enabled', true);
1177 1177
 					}
1178 1178
 
1179
-					var $button = '<button title="<?php _e( 'Advanced Settings', 'ayecode-connect' );?>" style="line-height: 28px;" class="button button-primary right sd-advanced-button" onclick="sd_toggle_advanced(this);return false;"><span class="dashicons dashicons-admin-settings" style="width: 28px;font-size: 28px;"></span></button>';
1179
+					var $button = '<button title="<?php _e('Advanced Settings', 'ayecode-connect'); ?>" style="line-height: 28px;" class="button button-primary right sd-advanced-button" onclick="sd_toggle_advanced(this);return false;"><span class="dashicons dashicons-admin-settings" style="width: 28px;font-size: 28px;"></span></button>';
1180 1180
 					var form = $form ? $form : jQuery($this).parents('' + $selector + '');
1181 1181
 
1182 1182
 					if (jQuery($this).val() == '1' && jQuery(form).find('.sd-advanced-button').length == 0) {
@@ -1267,7 +1267,7 @@  discard block
 block discarded – undo
1267 1267
 					});
1268 1268
 
1269 1269
 				}
1270
-				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1270
+				<?php do_action('wp_super_duper_widget_js', $this); ?>
1271 1271
 			</script>
1272 1272
 			<?php
1273 1273
 			$output = ob_get_clean();
@@ -1276,10 +1276,10 @@  discard block
 block discarded – undo
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(
1279
+			return str_replace(array(
1280 1280
 				'<script>',
1281 1281
 				'</script>'
1282
-			), '', $output );
1282
+			), '', $output);
1283 1283
 		}
1284 1284
 
1285 1285
 
@@ -1290,14 +1290,14 @@  discard block
 block discarded – undo
1290 1290
 		 *
1291 1291
 		 * @return mixed
1292 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;
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 1297
 				}
1298
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1299
-				foreach ( $options as $key => $val ) {
1300
-					$options[ $key ]['name'] = $key;
1298
+			} elseif ($arguments && is_array($options) && !empty($options)) {
1299
+				foreach ($options as $key => $val) {
1300
+					$options[$key]['name'] = $key;
1301 1301
 				}
1302 1302
 			}
1303 1303
 
@@ -1310,8 +1310,8 @@  discard block
 block discarded – undo
1310 1310
 		 * @since 1.0.0
1311 1311
 		 */
1312 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' ) );
1313
+			add_shortcode($this->base_id, array($this, 'shortcode_output'));
1314
+			add_action('wp_ajax_super_duper_output_shortcode', array($this, 'render_shortcode'));
1315 1315
 		}
1316 1316
 
1317 1317
 		/**
@@ -1320,50 +1320,50 @@  discard block
 block discarded – undo
1320 1320
 		 * @since 1.0.0
1321 1321
 		 */
1322 1322
 		public function render_shortcode() {
1323
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1324
-			if ( ! current_user_can( 'manage_options' ) ) {
1323
+			check_ajax_referer('super_duper_output_shortcode', '_ajax_nonce', true);
1324
+			if (!current_user_can('manage_options')) {
1325 1325
 				wp_die();
1326 1326
 			}
1327 1327
 
1328 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 ) ) {
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 1332
 					global $post;
1333 1333
 					$post = $post_obj;
1334 1334
 				}
1335 1335
 			}
1336 1336
 
1337
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1337
+			if (isset($_POST['shortcode']) && $_POST['shortcode']) {
1338 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();
1339
+				$shortcode_name   = sanitize_title_with_dashes($_POST['shortcode']);
1340
+				$attributes_array = isset($_POST['attributes']) && $_POST['attributes'] ? $_POST['attributes'] : array();
1341 1341
 				$attributes       = '';
1342
-				if ( ! empty( $attributes_array ) ) {
1343
-					foreach ( $attributes_array as $key => $value ) {
1344
-						if ( is_array( $value ) ) {
1345
-							$value = implode( ",", $value );
1342
+				if (!empty($attributes_array)) {
1343
+					foreach ($attributes_array as $key => $value) {
1344
+						if (is_array($value)) {
1345
+							$value = implode(",", $value);
1346 1346
 						}
1347 1347
 
1348
-						if ( ! empty( $value ) ) {
1349
-							$value = wp_unslash( $value );
1348
+						if (!empty($value)) {
1349
+							$value = wp_unslash($value);
1350 1350
 
1351 1351
 							// Encode [ and ].
1352
-							if ( $is_preview ) {
1353
-								$value = $this->encode_shortcodes( $value );
1352
+							if ($is_preview) {
1353
+								$value = $this->encode_shortcodes($value);
1354 1354
 							}
1355 1355
 						}
1356
-						$attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . esc_attr( $value ) . "' ";
1356
+						$attributes .= " " . sanitize_title_with_dashes($key) . "='" . esc_attr($value) . "' ";
1357 1357
 					}
1358 1358
 				}
1359 1359
 
1360 1360
 				$shortcode = "[" . $shortcode_name . " " . $attributes . "]";
1361 1361
 
1362
-				$content = do_shortcode( $shortcode );
1362
+				$content = do_shortcode($shortcode);
1363 1363
 
1364 1364
 				// Decode [ and ].
1365
-				if ( ! empty( $content ) && $is_preview ) {
1366
-					$content = $this->decode_shortcodes( $content );
1365
+				if (!empty($content) && $is_preview) {
1366
+					$content = $this->decode_shortcodes($content);
1367 1367
 				}
1368 1368
 
1369 1369
 				echo $content;
@@ -1379,21 +1379,21 @@  discard block
 block discarded – undo
1379 1379
 		 *
1380 1380
 		 * @return string
1381 1381
 		 */
1382
-		public function shortcode_output( $args = array(), $content = '' ) {
1382
+		public function shortcode_output($args = array(), $content = '') {
1383 1383
 			$_instance = $args;
1384 1384
 
1385
-			$args = $this->argument_values( $args );
1385
+			$args = $this->argument_values($args);
1386 1386
 
1387 1387
 			// add extra argument so we know its a output to gutenberg
1388 1388
 			//$args
1389
-			$args = $this->string_to_bool( $args );
1389
+			$args = $this->string_to_bool($args);
1390 1390
 
1391 1391
 			// if we have a enclosed shortcode we add it to the special `html` argument
1392
-			if ( ! empty( $content ) ) {
1392
+			if (!empty($content)) {
1393 1393
 				$args['html'] = $content;
1394 1394
 			}
1395 1395
 
1396
-			if ( ! $this->is_preview() ) {
1396
+			if (!$this->is_preview()) {
1397 1397
 				/**
1398 1398
 				 * Filters the settings for a particular widget args.
1399 1399
 				 *
@@ -1404,40 +1404,40 @@  discard block
 block discarded – undo
1404 1404
 				 *@since 1.0.28
1405 1405
 				 *
1406 1406
 				 */
1407
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1407
+				$args = apply_filters('wp_super_duper_widget_display_callback', $args, $this, $_instance);
1408 1408
 
1409
-				if ( ! is_array( $args ) ) {
1409
+				if (!is_array($args)) {
1410 1410
 					return $args;
1411 1411
 				}
1412 1412
 			}
1413 1413
 
1414
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1415
-			$class .= " sdel-".$this->get_instance_hash();
1414
+			$class = isset($this->options['widget_ops']['classname']) ? esc_attr($this->options['widget_ops']['classname']) : '';
1415
+			$class .= " sdel-" . $this->get_instance_hash();
1416 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 );
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 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 );
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 1422
 
1423 1423
 			$shortcode_args = array();
1424 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'] ) {
1425
+			$no_wrap        = isset($this->options['no_wrap']) && $this->options['no_wrap'] ? true : false;
1426
+			if (isset($args['no_wrap']) && $args['no_wrap']) {
1427 1427
 				$no_wrap = true;
1428 1428
 			}
1429
-			$main_content = $this->output( $args, $shortcode_args, $content );
1430
-			if ( $main_content && ! $no_wrap ) {
1429
+			$main_content = $this->output($args, $shortcode_args, $content);
1430
+			if ($main_content && !$no_wrap) {
1431 1431
 				// wrap the shortcode in a div with the same class as the widget
1432 1432
 				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1433
-				if ( ! empty( $args['title'] ) ) {
1433
+				if (!empty($args['title'])) {
1434 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 ) ) {
1435
+					$shortcode_args = array('before_title' => '', 'after_title' => '');
1436
+					if (empty($instance)) {
1437 1437
 						global $wp_registered_sidebars;
1438
-						if ( ! empty( $wp_registered_sidebars ) ) {
1439
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1440
-								if ( ! empty( $sidebar['before_title'] ) ) {
1438
+						if (!empty($wp_registered_sidebars)) {
1439
+							foreach ($wp_registered_sidebars as $sidebar) {
1440
+								if (!empty($sidebar['before_title'])) {
1441 1441
 									$shortcode_args['before_title'] = $sidebar['before_title'];
1442 1442
 									$shortcode_args['after_title']  = $sidebar['after_title'];
1443 1443
 									break;
@@ -1445,20 +1445,20 @@  discard block
 block discarded – undo
1445 1445
 							}
1446 1446
 						}
1447 1447
 					}
1448
-					$output .= $this->output_title( $shortcode_args, $args );
1448
+					$output .= $this->output_title($shortcode_args, $args);
1449 1449
 				}
1450 1450
 				$output .= $main_content;
1451 1451
 				$output .= '</div>';
1452
-			} elseif ( $main_content && $no_wrap ) {
1452
+			} elseif ($main_content && $no_wrap) {
1453 1453
 				$output .= $main_content;
1454 1454
 			}
1455 1455
 
1456 1456
 			// if preview show a placeholder if empty
1457
-			if ( $this->is_preview() && $output == '' ) {
1458
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1457
+			if ($this->is_preview() && $output == '') {
1458
+				$output = $this->preview_placeholder_text("{{" . $this->base_id . "}}");
1459 1459
 			}
1460 1460
 
1461
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1461
+			return apply_filters('wp_super_duper_widget_output', $output, $args, $shortcode_args, $this);
1462 1462
 		}
1463 1463
 
1464 1464
 		/**
@@ -1468,8 +1468,8 @@  discard block
 block discarded – undo
1468 1468
 		 *
1469 1469
 		 * @return string
1470 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>";
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 1473
 		}
1474 1474
 
1475 1475
 		/**
@@ -1479,13 +1479,13 @@  discard block
 block discarded – undo
1479 1479
 		 *
1480 1480
 		 * @return mixed
1481 1481
 		 */
1482
-		public function string_to_bool( $options ) {
1482
+		public function string_to_bool($options) {
1483 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;
1484
+			foreach ($options as $key => $val) {
1485
+				if ($val == 'false') {
1486
+					$options[$key] = false;
1487
+				} elseif ($val == 'true') {
1488
+					$options[$key] = true;
1489 1489
 				}
1490 1490
 			}
1491 1491
 
@@ -1501,26 +1501,26 @@  discard block
 block discarded – undo
1501 1501
 		 *@since 1.0.12 Don't set checkbox default value if the value is empty.
1502 1502
 		 *
1503 1503
 		 */
1504
-		public function argument_values( $instance ) {
1504
+		public function argument_values($instance) {
1505 1505
 			$argument_values = array();
1506 1506
 
1507 1507
 			// set widget instance
1508 1508
 			$this->instance = $instance;
1509 1509
 
1510
-			if ( empty( $this->arguments ) ) {
1510
+			if (empty($this->arguments)) {
1511 1511
 				$this->arguments = $this->get_arguments();
1512 1512
 			}
1513 1513
 
1514
-			if ( ! empty( $this->arguments ) ) {
1515
-				foreach ( $this->arguments as $key => $args ) {
1514
+			if (!empty($this->arguments)) {
1515
+				foreach ($this->arguments as $key => $args) {
1516 1516
 					// set the input name from the key
1517 1517
 					$args['name'] = $key;
1518 1518
 					//
1519
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1520
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1519
+					$argument_values[$key] = isset($instance[$key]) ? $instance[$key] : '';
1520
+					if ($args['type'] == 'checkbox' && $argument_values[$key] == '') {
1521 1521
 						// don't set default for an empty checkbox
1522
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1523
-						$argument_values[ $key ] = $args['default'];
1522
+					} elseif ($argument_values[$key] == '' && isset($args['default'])) {
1523
+						$argument_values[$key] = $args['default'];
1524 1524
 					}
1525 1525
 				}
1526 1526
 			}
@@ -1547,12 +1547,12 @@  discard block
 block discarded – undo
1547 1547
 		 *
1548 1548
 		 */
1549 1549
 		public function get_arguments() {
1550
-			if ( empty( $this->arguments ) ) {
1550
+			if (empty($this->arguments)) {
1551 1551
 				$this->arguments = $this->set_arguments();
1552 1552
 			}
1553 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 );
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 1556
 
1557 1557
 			return $this->arguments;
1558 1558
 		}
@@ -1564,7 +1564,7 @@  discard block
 block discarded – undo
1564 1564
 		 * @param array $widget_args
1565 1565
 		 * @param string $content
1566 1566
 		 */
1567
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1567
+		public function output($args = array(), $widget_args = array(), $content = '') {
1568 1568
 
1569 1569
 		}
1570 1570
 
@@ -1572,9 +1572,9 @@  discard block
 block discarded – undo
1572 1572
 		 * Add the dynamic block code inline when the wp-block in enqueued.
1573 1573
 		 */
1574 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() );
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 1578
 			}
1579 1579
 		}
1580 1580
 
@@ -1588,9 +1588,9 @@  discard block
 block discarded – undo
1588 1588
 			$show      = false;
1589 1589
 			$arguments = $this->get_arguments();
1590 1590
 
1591
-			if ( ! empty( $arguments ) ) {
1592
-				foreach ( $arguments as $argument ) {
1593
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1591
+			if (!empty($arguments)) {
1592
+				foreach ($arguments as $argument) {
1593
+					if (isset($argument['advanced']) && $argument['advanced']) {
1594 1594
 						$show = true;
1595 1595
 						break; // no need to continue if we know we have it
1596 1596
 					}
@@ -1608,19 +1608,19 @@  discard block
 block discarded – undo
1608 1608
 		public function get_url() {
1609 1609
 			$url = $this->url;
1610 1610
 
1611
-			if ( ! $url ) {
1612
-				$content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1613
-				$content_url = untrailingslashit( WP_CONTENT_URL );
1611
+			if (!$url) {
1612
+				$content_dir = wp_normalize_path(untrailingslashit(WP_CONTENT_DIR));
1613
+				$content_url = untrailingslashit(WP_CONTENT_URL);
1614 1614
 
1615 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 );
1616
+				if (strpos($content_url, 'http://') === 0 && strpos(plugins_url(), 'https://') === 0) {
1617
+					$content_url = str_replace('http://', 'https://', $content_url);
1618 1618
 				}
1619 1619
 
1620 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 );
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 1624
 				$this->url = $url;
1625 1625
 			}
1626 1626
 
@@ -1636,15 +1636,15 @@  discard block
 block discarded – undo
1636 1636
 
1637 1637
 			$url = $this->url;
1638 1638
 
1639
-			if ( ! $url ) {
1639
+			if (!$url) {
1640 1640
 				// check if we are inside a plugin
1641
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1641
+				$file_dir = str_replace("/includes", "", dirname(__FILE__));
1642 1642
 
1643
-				$dir_parts = explode( "/wp-content/", $file_dir );
1644
-				$url_parts = explode( "/wp-content/", plugins_url() );
1643
+				$dir_parts = explode("/wp-content/", $file_dir);
1644
+				$url_parts = explode("/wp-content/", plugins_url());
1645 1645
 
1646
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1647
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1646
+				if (!empty($url_parts[0]) && !empty($dir_parts[1])) {
1647
+					$url       = trailingslashit($url_parts[0] . "/wp-content/" . $dir_parts[1]);
1648 1648
 					$this->url = $url;
1649 1649
 				}
1650 1650
 			}
@@ -1665,45 +1665,45 @@  discard block
 block discarded – undo
1665 1665
 		 * @return string
1666 1666
 		 *@since 1.1.0
1667 1667
 		 */
1668
-		public function get_block_icon( $icon ) {
1668
+		public function get_block_icon($icon) {
1669 1669
 
1670 1670
 			// check if we have a Font Awesome icon
1671 1671
 			$fa_type = '';
1672
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1672
+			if (substr($icon, 0, 7) === "fas fa-") {
1673 1673
 				$fa_type = 'solid';
1674
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1674
+			} elseif (substr($icon, 0, 7) === "far fa-") {
1675 1675
 				$fa_type = 'regular';
1676
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1676
+			} elseif (substr($icon, 0, 7) === "fab fa-") {
1677 1677
 				$fa_type = 'brands';
1678 1678
 			} else {
1679 1679
 				$icon = "'" . $icon . "'";
1680 1680
 			}
1681 1681
 
1682 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 );
1683
+			if ($fa_type) {
1684
+				$fa_icon = str_replace(array("fas fa-", "far fa-", "fab fa-"), "", $icon);
1685 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 1686
 			}
1687 1687
 
1688 1688
 			return $icon;
1689 1689
 		}
1690 1690
 
1691
-		public function group_arguments( $arguments ) {
1692
-			if ( ! empty( $arguments ) ) {
1691
+		public function group_arguments($arguments) {
1692
+			if (!empty($arguments)) {
1693 1693
 				$temp_arguments = array();
1694
-				$general        = __( "General", 'ayecode-connect' );
1694
+				$general        = __("General", 'ayecode-connect');
1695 1695
 				$add_sections   = false;
1696
-				foreach ( $arguments as $key => $args ) {
1697
-					if ( isset( $args['group'] ) ) {
1698
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1696
+				foreach ($arguments as $key => $args) {
1697
+					if (isset($args['group'])) {
1698
+						$temp_arguments[$args['group']][$key] = $args;
1699 1699
 						$add_sections                             = true;
1700 1700
 					} else {
1701
-						$temp_arguments[ $general ][ $key ] = $args;
1701
+						$temp_arguments[$general][$key] = $args;
1702 1702
 					}
1703 1703
 				}
1704 1704
 
1705 1705
 				// only add sections if more than one
1706
-				if ( $add_sections ) {
1706
+				if ($add_sections) {
1707 1707
 					$arguments = $temp_arguments;
1708 1708
 				}
1709 1709
 			}
@@ -1716,38 +1716,38 @@  discard block
 block discarded – undo
1716 1716
 		 *
1717 1717
 		 * @since 1.1.17
1718 1718
 		 */
1719
-		public function group_block_tabs( $tabs, $arguments ) {
1720
-			if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1719
+		public function group_block_tabs($tabs, $arguments) {
1720
+			if (!empty($tabs) && !empty($arguments)) {
1721 1721
 				$has_sections = false;
1722 1722
 
1723
-				foreach ( $this->arguments as $key => $args ) {
1724
-					if ( isset( $args['group'] ) ) {
1723
+				foreach ($this->arguments as $key => $args) {
1724
+					if (isset($args['group'])) {
1725 1725
 						$has_sections = true;
1726 1726
 						break;
1727 1727
 					}
1728 1728
 				}
1729 1729
 
1730
-				if ( ! $has_sections ) {
1730
+				if (!$has_sections) {
1731 1731
 					return $tabs;
1732 1732
 				}
1733 1733
 
1734 1734
 				$new_tabs = array();
1735 1735
 
1736
-				foreach ( $tabs as $tab_key => $tab ) {
1736
+				foreach ($tabs as $tab_key => $tab) {
1737 1737
 					$new_groups = array();
1738 1738
 
1739
-					if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1740
-						foreach ( $tab['groups'] as $group ) {
1741
-							if ( isset( $arguments[ $group ] ) ) {
1739
+					if (!empty($tab['groups']) && is_array($tab['groups'])) {
1740
+						foreach ($tab['groups'] as $group) {
1741
+							if (isset($arguments[$group])) {
1742 1742
 								$new_groups[] = $group;
1743 1743
 							}
1744 1744
 						}
1745 1745
 					}
1746 1746
 
1747
-					if ( ! empty( $new_groups ) ) {
1747
+					if (!empty($new_groups)) {
1748 1748
 						$tab['groups'] = $new_groups;
1749 1749
 
1750
-						$new_tabs[ $tab_key ] = $tab;
1750
+						$new_tabs[$tab_key] = $tab;
1751 1751
 					}
1752 1752
 				}
1753 1753
 
@@ -1774,7 +1774,7 @@  discard block
 block discarded – undo
1774 1774
 			?>
1775 1775
 			<script>
1776 1776
 			<?php
1777
-			if ( ! $sd_is_js_functions_loaded ) {
1777
+			if (!$sd_is_js_functions_loaded) {
1778 1778
 				$sd_is_js_functions_loaded = true;
1779 1779
 			?>
1780 1780
 function sd_show_view_options($this){
@@ -2151,7 +2151,7 @@  discard block
 block discarded – undo
2151 2151
 
2152 2152
 				// maybe use featured image.
2153 2153
 				if( $args['bg_image_use_featured'] !== undefined && $args['bg_image_use_featured'] ){
2154
-					$bg_image = '<?php echo $this->get_url();?>icons/placeholder.png';
2154
+					$bg_image = '<?php echo $this->get_url(); ?>icons/placeholder.png';
2155 2155
 				}
2156 2156
 
2157 2157
                 if( $bg_image !== undefined && $bg_image !== '' ){
@@ -2226,7 +2226,7 @@  discard block
 block discarded – undo
2226 2226
                 $classes = [];
2227 2227
 
2228 2228
 				<?php
2229
-				if($aui_bs5){
2229
+				if ($aui_bs5) {
2230 2230
 					?>
2231 2231
 				$aui_bs5 = true;
2232 2232
 				$p_ml = 'ms-';
@@ -2235,7 +2235,7 @@  discard block
 block discarded – undo
2235 2235
 				$p_pl = 'ps-';
2236 2236
 				$p_pr = 'pe-';
2237 2237
 					<?php
2238
-				}else{
2238
+				} else {
2239 2239
 						?>
2240 2240
 				$aui_bs5 = false;
2241 2241
 				$p_ml = 'ml-';
@@ -2420,7 +2420,7 @@  discard block
 block discarded – undo
2420 2420
             }
2421 2421
 
2422 2422
 			function sd_get_class_build_keys(){
2423
-				return <?php echo json_encode(sd_get_class_build_keys());?>;
2423
+				return <?php echo json_encode(sd_get_class_build_keys()); ?>;
2424 2424
 			}
2425 2425
 
2426 2426
             <?php
@@ -2428,7 +2428,7 @@  discard block
 block discarded – undo
2428 2428
 
2429 2429
             }
2430 2430
 
2431
-			if(method_exists($this,'block_global_js')){
2431
+			if (method_exists($this, 'block_global_js')) {
2432 2432
 					echo $this->block_global_js();
2433 2433
 			}
2434 2434
 			?>
@@ -2457,9 +2457,9 @@  discard block
 block discarded – undo
2457 2457
                     var InnerBlocks = blockEditor.InnerBlocks;
2458 2458
 
2459 2459
 					var term_query_type = '';
2460
-					var post_type_rest_slugs = <?php if(! empty( $this->arguments ) && isset($this->arguments['post_type']['onchange_rest']['values'])){echo "[".json_encode($this->arguments['post_type']['onchange_rest']['values'])."]";}else{echo "[]";} ?>;
2461
-					const taxonomies_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2462
-					const sort_by_<?php echo str_replace("-","_", $this->id);?> = [{label: "Please wait", value: 0}];
2460
+					var post_type_rest_slugs = <?php if (!empty($this->arguments) && isset($this->arguments['post_type']['onchange_rest']['values'])) {echo "[" . json_encode($this->arguments['post_type']['onchange_rest']['values']) . "]"; } else {echo "[]"; } ?>;
2461
+					const taxonomies_<?php echo str_replace("-", "_", $this->id); ?> = [{label: "Please wait", value: 0}];
2462
+					const sort_by_<?php echo str_replace("-", "_", $this->id); ?> = [{label: "Please wait", value: 0}];
2463 2463
                     const MediaUpload = wp.blockEditor.MediaUpload;
2464 2464
 
2465 2465
 					/**
@@ -2474,20 +2474,20 @@  discard block
 block discarded – undo
2474 2474
 					 * @return {?WPBlock}          The block, if it has been successfully
2475 2475
 					 *                             registered; otherwise `undefined`.
2476 2476
 					 */
2477
-					registerBlockType('<?php echo str_replace( "_", "-", sanitize_title_with_dashes( $this->options['textdomain'] ) . '/' . sanitize_title_with_dashes( $this->options['class_name'] ) );  ?>', { // Block name. Block names must be string that contains a namespace prefix. Example: my-plugin/my-custom-block.
2478
-						apiVersion: <?php echo isset($this->options['block-api-version']) ? absint($this->options['block-api-version']) : 2 ; ?>,
2479
-                        title: '<?php echo addslashes( $this->options['name'] ); ?>', // Block title.
2480
-						description: '<?php echo addslashes( $this->options['widget_ops']['description'] )?>', // Block title.
2481
-						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/.
2477
+					registerBlockType('<?php echo str_replace("_", "-", sanitize_title_with_dashes($this->options['textdomain']) . '/' . sanitize_title_with_dashes($this->options['class_name'])); ?>', { // Block name. Block names must be string that contains a namespace prefix. Example: my-plugin/my-custom-block.
2478
+						apiVersion: <?php echo isset($this->options['block-api-version']) ? absint($this->options['block-api-version']) : 2; ?>,
2479
+                        title: '<?php echo addslashes($this->options['name']); ?>', // Block title.
2480
+						description: '<?php echo addslashes($this->options['widget_ops']['description'])?>', // Block title.
2481
+						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/.
2482 2482
 						supports: {
2483 2483
 							<?php
2484
-							if ( isset( $this->options['block-supports'] ) ) {
2485
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2484
+							if (isset($this->options['block-supports'])) {
2485
+								echo $this->array_to_attributes($this->options['block-supports']);
2486 2486
 							}
2487 2487
 							?>
2488 2488
 						},
2489 2489
 						<?php
2490
-						if ( isset( $this->options['block-label'] ) ) {
2490
+						if (isset($this->options['block-label'])) {
2491 2491
 						?>
2492 2492
 						__experimentalLabel( attributes, { context } ) {
2493 2493
                             return <?php echo $this->options['block-label']; ?>;
@@ -2495,8 +2495,8 @@  discard block
 block discarded – undo
2495 2495
                         <?php
2496 2496
                         }
2497 2497
                         ?>
2498
-						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.
2499
-						<?php if ( isset( $this->options['block-keywords'] ) ) {
2498
+						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.
2499
+						<?php if (isset($this->options['block-keywords'])) {
2500 2500
 						echo "keywords : " . $this->options['block-keywords'] . ",";
2501 2501
 
2502 2502
 //						// block hover preview.
@@ -2523,11 +2523,11 @@  discard block
 block discarded – undo
2523 2523
                         }
2524 2524
 
2525 2525
 						// maybe set no_wrap
2526
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2527
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2526
+						$no_wrap = isset($this->options['no_wrap']) && $this->options['no_wrap'] ? true : false;
2527
+						if (isset($this->arguments['no_wrap']) && $this->arguments['no_wrap']) {
2528 2528
 							$no_wrap = true;
2529 2529
 						}
2530
-						if ( $no_wrap ) {
2530
+						if ($no_wrap) {
2531 2531
 							$this->options['block-wrap'] = '';
2532 2532
 						}
2533 2533
 
@@ -2541,10 +2541,10 @@  discard block
 block discarded – undo
2541 2541
 						echo "  html: false";
2542 2542
 						echo "},";*/
2543 2543
 
2544
-						if ( ! empty( $this->arguments ) ) {
2544
+						if (!empty($this->arguments)) {
2545 2545
 							echo "attributes : {";
2546 2546
 
2547
-							if ( $show_advanced ) {
2547
+							if ($show_advanced) {
2548 2548
 								echo "show_advanced: {";
2549 2549
 								echo "	type: 'boolean',";
2550 2550
 								echo "  default: false,";
@@ -2552,56 +2552,56 @@  discard block
 block discarded – undo
2552 2552
 							}
2553 2553
 
2554 2554
 							// block wrap element
2555
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2555
+							if (!empty($this->options['block-wrap'])) { //@todo we should validate this?
2556 2556
 								echo "block_wrap: {";
2557 2557
 								echo "	type: 'string',";
2558
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2558
+								echo "  default: '" . esc_attr($this->options['block-wrap']) . "',";
2559 2559
 								echo "},";
2560 2560
 							}
2561 2561
 
2562 2562
 
2563 2563
 
2564
-							foreach ( $this->arguments as $key => $args ) {
2564
+							foreach ($this->arguments as $key => $args) {
2565 2565
 
2566
-								if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2566
+								if ($args['type'] == 'image' || $args['type'] == 'images') {
2567 2567
 									$img_drag_drop = true;
2568 2568
 								}
2569 2569
 
2570 2570
 								// set if we should show alignment
2571
-								if ( $key == 'alignment' ) {
2571
+								if ($key == 'alignment') {
2572 2572
 									$show_alignment = true;
2573 2573
 								}
2574 2574
 
2575 2575
 								$extra = '';
2576 2576
 
2577
-								if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2577
+								if ($args['type'] == 'notice' || $args['type'] == 'tab') {
2578 2578
 									continue;
2579 2579
 								}
2580
-								elseif ( $args['type'] == 'checkbox' ) {
2580
+								elseif ($args['type'] == 'checkbox') {
2581 2581
 									$type    = 'boolean';
2582
-									$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2583
-								} elseif ( $args['type'] == 'number' ) {
2582
+									$default = isset($args['default']) && $args['default'] ? 'true' : 'false';
2583
+								} elseif ($args['type'] == 'number') {
2584 2584
 									$type    = 'number';
2585
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2586
-								} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2585
+									$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2586
+								} elseif ($args['type'] == 'select' && !empty($args['multiple'])) {
2587 2587
 									$type = 'array';
2588
-									if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2589
-										$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2588
+									if (isset($args['default']) && is_array($args['default'])) {
2589
+										$default = !empty($args['default']) ? "['" . implode("','", $args['default']) . "']" : "[]";
2590 2590
 									} else {
2591
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2591
+										$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2592 2592
 									}
2593
-								} elseif ( $args['type'] == 'tagselect' ) {
2593
+								} elseif ($args['type'] == 'tagselect') {
2594 2594
 									$type    = 'array';
2595
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2596
-								} elseif ( $args['type'] == 'multiselect' ) {
2595
+									$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2596
+								} elseif ($args['type'] == 'multiselect') {
2597 2597
 									$type    = 'array';
2598
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2599
-								} elseif ( $args['type'] == 'image_xy' ) {
2598
+									$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2599
+								} elseif ($args['type'] == 'image_xy') {
2600 2600
 									$type    = 'object';
2601
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2602
-								} elseif ( $args['type'] == 'image' ) {
2601
+									$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2602
+								} elseif ($args['type'] == 'image') {
2603 2603
 									$type    = 'string';
2604
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2604
+									$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2605 2605
 
2606 2606
                                     // add a field for ID
2607 2607
 //                                    echo $key . "_id : {";
@@ -2613,7 +2613,7 @@  discard block
 block discarded – undo
2613 2613
 
2614 2614
 								} else {
2615 2615
 									$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2616
-									$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2616
+									$default = isset($args['default']) ? "'" . $args['default'] . "'" : "''";
2617 2617
 
2618 2618
 								}
2619 2619
 								echo $key . " : {";
@@ -2637,7 +2637,7 @@  discard block
 block discarded – undo
2637 2637
 
2638 2638
 <?php
2639 2639
 // only include the drag/drop functions if required.
2640
-if( $img_drag_drop ){
2640
+if ($img_drag_drop) {
2641 2641
 
2642 2642
 ?>
2643 2643
 
@@ -2703,9 +2703,9 @@  discard block
 block discarded – undo
2703 2703
 							}
2704 2704
 
2705 2705
                             <?php
2706
-                            if(!empty($this->options['block-edit-raw'])) {
2706
+                            if (!empty($this->options['block-edit-raw'])) {
2707 2707
                                 echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2708
-                            }else{
2708
+                            } else {
2709 2709
                             ?>
2710 2710
 
2711 2711
 function hasSelectedInnerBlock(props) {
@@ -2729,7 +2729,7 @@  discard block
 block discarded – undo
2729 2729
 	var $value = '';
2730 2730
 	<?php
2731 2731
 	// if we have a post_type and a category then link them
2732
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2732
+	if (isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked'])) {
2733 2733
 	?>
2734 2734
 	if(typeof(prev_attributes[props.clientId]) != 'undefined'){
2735 2735
 		$pt = props.attributes.post_type;
@@ -2744,9 +2744,9 @@  discard block
 block discarded – undo
2744 2744
 		}
2745 2745
 <?php
2746 2746
 	$cat_path = '';
2747
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2748
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2749
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2747
+	if (!empty($this->arguments['post_type']['onchange_rest']['path'])) {
2748
+		$cat_path = esc_js(strip_tags($this->arguments['post_type']['onchange_rest']['path']));
2749
+		$cat_path = str_replace(array('&quot;', '&#039;'), array('"', "'"), $cat_path);
2750 2750
 	}
2751 2751
 ?>
2752 2752
 		/* taxonomies */
@@ -2754,15 +2754,15 @@  discard block
 block discarded – undo
2754 2754
 			if (!window.gdCPTCats) {
2755 2755
 				window.gdCPTCats = [];
2756 2756
 			}
2757
-			var gdCatPath = "<?php echo ( ! empty( $cat_path ) ? $cat_path : "/wp/v2/" + $value + "/categories/?per_page=100" ); ?>";
2757
+			var gdCatPath = "<?php echo (!empty($cat_path) ? $cat_path : "/wp/v2/" +$value + "/categories/?per_page=100"); ?>";
2758 2758
 			if (window.gdCPTCats[gdCatPath]) {
2759 2759
 				terms = window.gdCPTCats[gdCatPath];
2760
-				while (taxonomies_<?php echo str_replace("-","_", $this->id);?>.length) {
2761
-					taxonomies_<?php echo str_replace("-","_", $this->id);?>.pop();
2760
+				while (taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2761
+					taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2762 2762
 				}
2763
-				taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: "All", value: 0});
2763
+				taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: "All", value: 0});
2764 2764
 				jQuery.each( terms, function( key, val ) {
2765
-					taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: val.name, value: val.id});
2765
+					taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val.name, value: val.id});
2766 2766
 				});
2767 2767
 
2768 2768
 				/* Setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options. */
@@ -2772,12 +2772,12 @@  discard block
 block discarded – undo
2772 2772
 			} else {
2773 2773
 				wp.apiFetch({path: gdCatPath}).then(terms => {
2774 2774
 					window.gdCPTCats[gdCatPath] = terms;
2775
-					while (taxonomies_<?php echo str_replace("-","_", $this->id);?>.length) {
2776
-						taxonomies_<?php echo str_replace("-","_", $this->id);?>.pop();
2775
+					while (taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2776
+						taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2777 2777
 					}
2778
-					taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: "All", value: 0});
2778
+					taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: "All", value: 0});
2779 2779
 					jQuery.each( terms, function( key, val ) {
2780
-						taxonomies_<?php echo str_replace("-","_", $this->id);?>.push({label: val.name, value: val.id});
2780
+						taxonomies_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val.name, value: val.id});
2781 2781
 					});
2782 2782
 
2783 2783
 					/* Setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options. */
@@ -2785,7 +2785,7 @@  discard block
 block discarded – undo
2785 2785
 					props.setAttributes({category: [0] });
2786 2786
 					props.setAttributes({category: $old_cat_value });
2787 2787
 
2788
-					return taxonomies_<?php echo str_replace("-","_", $this->id);?>;
2788
+					return taxonomies_<?php echo str_replace("-", "_", $this->id); ?>;
2789 2789
 				});
2790 2790
 			}
2791 2791
 		}
@@ -2797,12 +2797,12 @@  discard block
 block discarded – undo
2797 2797
 			}
2798 2798
 			if (window.gdCPTSort[$pt]) {
2799 2799
 				response = window.gdCPTSort[$pt];
2800
-				while (sort_by_<?php echo str_replace("-","_", $this->id);?>.length) {
2801
-					sort_by_<?php echo str_replace("-","_", $this->id);?>.pop();
2800
+				while (sort_by_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2801
+					sort_by_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2802 2802
 				}
2803 2803
 
2804 2804
 				jQuery.each( response, function( key, val ) {
2805
-					sort_by_<?php echo str_replace("-","_", $this->id);?>.push({label: val, value: key});
2805
+					sort_by_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val, value: key});
2806 2806
 				});
2807 2807
 
2808 2808
 				// setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options.
@@ -2817,12 +2817,12 @@  discard block
 block discarded – undo
2817 2817
 				jQuery.post(ajaxurl, data, function(response) {
2818 2818
 					response = JSON.parse(response);
2819 2819
 					window.gdCPTSort[$pt] = response;
2820
-					while (sort_by_<?php echo str_replace("-","_", $this->id);?>.length) {
2821
-						sort_by_<?php echo str_replace("-","_", $this->id);?>.pop();
2820
+					while (sort_by_<?php echo str_replace("-", "_", $this->id); ?>.length) {
2821
+						sort_by_<?php echo str_replace("-", "_", $this->id); ?>.pop();
2822 2822
 					}
2823 2823
 
2824 2824
 					jQuery.each( response, function( key, val ) {
2825
-						sort_by_<?php echo str_replace("-","_", $this->id);?>.push({label: val, value: key});
2825
+						sort_by_<?php echo str_replace("-", "_", $this->id); ?>.push({label: val, value: key});
2826 2826
 					});
2827 2827
 
2828 2828
 					// setting the value back and fourth fixes the no update issue that sometimes happens where it won't update the options.
@@ -2830,7 +2830,7 @@  discard block
 block discarded – undo
2830 2830
 					props.setAttributes({sort_by: [0] });
2831 2831
 					props.setAttributes({sort_by: $old_sort_by_value });
2832 2832
 
2833
-					return sort_by_<?php echo str_replace("-","_", $this->id);?>;
2833
+					return sort_by_<?php echo str_replace("-", "_", $this->id); ?>;
2834 2834
 				});
2835 2835
 			}
2836 2836
 		}
@@ -2838,9 +2838,9 @@  discard block
 block discarded – undo
2838 2838
 	<?php } ?>
2839 2839
 <?php
2840 2840
 $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2841
-if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2841
+if (!empty($current_screen->base) && $current_screen->base === 'widgets') {
2842 2842
 	echo 'const { deviceType } = "";';
2843
-}else{
2843
+} else {
2844 2844
 ?>
2845 2845
 /** Get device type const. */
2846 2846
 const { deviceType } = wp.data.useSelect != 'undefined' ?  wp.data.useSelect(select => {
@@ -2869,13 +2869,13 @@  discard block
 block discarded – undo
2869 2869
 
2870 2870
 									var data = {
2871 2871
 										'action': 'super_duper_output_shortcode',
2872
-										'shortcode': '<?php echo $this->options['base_id'];?>',
2872
+										'shortcode': '<?php echo $this->options['base_id']; ?>',
2873 2873
 										'attributes': props.attributes,
2874 2874
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
2875
-										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
2875
+										'post_id': <?php global $post; if (isset($post->ID)) {
2876 2876
 										echo $post->ID;
2877
-									}else{echo '0';}?>,
2878
-										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
2877
+									} else {echo '0'; }?>,
2878
+										'_ajax_nonce': '<?php echo wp_create_nonce('super_duper_output_shortcode'); ?>'
2879 2879
 									};
2880 2880
 
2881 2881
 									jQuery.post(ajaxurl, data, function (response) {
@@ -2884,17 +2884,17 @@  discard block
 block discarded – undo
2884 2884
 
2885 2885
 										// if the content is empty then we place some placeholder text
2886 2886
 										if (env == '') {
2887
-											env = "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" + "<?php _e( 'Placeholder for:', 'ayecode-connect' );?> " + props.name + "</div>";
2887
+											env = "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" + "<?php _e('Placeholder for:', 'ayecode-connect'); ?> " + props.name + "</div>";
2888 2888
 										}
2889 2889
 
2890 2890
                                          <?php
2891
-                                        if(!empty($this->options['nested-block'])){
2891
+                                        if (!empty($this->options['nested-block'])) {
2892 2892
                                             ?>
2893 2893
                                             // props.setAttributes({content: env});
2894 2894
 										is_fetching = false;
2895 2895
 										prev_attributes[props.clientId] = props.attributes;
2896 2896
                                              <?php
2897
-                                        }else{
2897
+                                        } else {
2898 2898
                                         ?>
2899 2899
                                         props.setAttributes({content: env});
2900 2900
 										is_fetching = false;
@@ -2919,8 +2919,8 @@  discard block
 block discarded – undo
2919 2919
 							}
2920 2920
 
2921 2921
                             <?php
2922
-                            if(!empty($this->options['block-edit-js'])) {
2923
-                                echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
2922
+                            if (!empty($this->options['block-edit-js'])) {
2923
+                                echo  $this->options['block-edit-js']; // strings have to be in single quotes, may cause issues
2924 2924
                             }
2925 2925
 
2926 2926
 
@@ -2933,7 +2933,7 @@  discard block
 block discarded – undo
2933 2933
 
2934 2934
 								el(wp.blockEditor.BlockControls, {key: 'controls'},
2935 2935
 
2936
-									<?php if($show_alignment){?>
2936
+									<?php if ($show_alignment) {?>
2937 2937
 									el(
2938 2938
 										wp.blockEditor.AlignmentToolbar,
2939 2939
 										{
@@ -2951,9 +2951,9 @@  discard block
 block discarded – undo
2951 2951
 
2952 2952
 									<?php
2953 2953
 
2954
-									if(! empty( $this->arguments )){
2954
+									if (!empty($this->arguments)) {
2955 2955
 
2956
-									if ( $show_advanced ) {
2956
+									if ($show_advanced) {
2957 2957
 									?>
2958 2958
 									el('div', {
2959 2959
 											style: {'padding-left': '16px','padding-right': '16px'}
@@ -2973,42 +2973,42 @@  discard block
 block discarded – undo
2973 2973
 									<?php
2974 2974
 									}
2975 2975
 
2976
-									$arguments = $this->group_arguments( $this->arguments );
2977
-									$block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
2976
+									$arguments = $this->group_arguments($this->arguments);
2977
+									$block_group_tabs = !empty($this->options['block_group_tabs']) ? $this->group_block_tabs($this->options['block_group_tabs'], $arguments) : array();
2978 2978
 
2979 2979
 									// Do we have sections?
2980 2980
 									$has_sections = $arguments == $this->arguments ? false : true;
2981 2981
 
2982
-									if($has_sections){
2982
+									if ($has_sections) {
2983 2983
 									$panel_count = 0;
2984 2984
 									$open_tab = '';
2985 2985
 
2986 2986
 									$open_tab_groups = array();
2987 2987
 									$used_tabs = array();
2988 2988
 
2989
-									foreach ( $arguments as $key => $args ) {
2989
+									foreach ($arguments as $key => $args) {
2990 2990
 										$close_tab = false;
2991 2991
 										$close_tabs = false;
2992 2992
 
2993
-										 if ( ! empty( $block_group_tabs ) ) {
2994
-											foreach ( $block_group_tabs as $tab_name => $tab_args ) {
2995
-												if ( in_array( $key, $tab_args['groups'] ) ) {
2993
+										 if (!empty($block_group_tabs)) {
2994
+											foreach ($block_group_tabs as $tab_name => $tab_args) {
2995
+												if (in_array($key, $tab_args['groups'])) {
2996 2996
 													$open_tab_groups[] = $key;
2997 2997
 
2998
-													if ( $open_tab != $tab_name ) {
2998
+													if ($open_tab != $tab_name) {
2999 2999
 														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3000 3000
 														$tab_args['tab']['open'] = true;
3001 3001
 
3002
-														$this->block_tab_start( '', $tab_args );
3002
+														$this->block_tab_start('', $tab_args);
3003 3003
 														$open_tab = $tab_name;
3004 3004
 														$used_tabs[] = $tab_name;
3005 3005
 													}
3006 3006
 
3007
-													if ( $open_tab_groups == $tab_args['groups'] ) {
3007
+													if ($open_tab_groups == $tab_args['groups']) {
3008 3008
 														$close_tab = true;
3009 3009
 														$open_tab_groups = array();
3010 3010
 
3011
-														if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3011
+														if ($used_tabs == array_keys($block_group_tabs)) {
3012 3012
 															$close_tabs = true;
3013 3013
 														}
3014 3014
 													}
@@ -3017,27 +3017,27 @@  discard block
 block discarded – undo
3017 3017
 										}
3018 3018
 										?>
3019 3019
 										el(wp.components.PanelBody, {
3020
-												title: '<?php esc_attr_e( $key ); ?>',
3021
-												initialOpen: <?php if ( $panel_count ) {
3020
+												title: '<?php esc_attr_e($key); ?>',
3021
+												initialOpen: <?php if ($panel_count) {
3022 3022
 												echo "false";
3023 3023
 											} else {
3024 3024
 												echo "true";
3025 3025
 											}?>
3026 3026
 											},
3027 3027
 											<?php
3028
-											foreach ( $args as $k => $a ) {
3029
-												$this->block_tab_start( $k, $a );
3030
-												$this->block_row_start( $k, $a );
3031
-												$this->build_block_arguments( $k, $a );
3032
-												$this->block_row_end( $k, $a );
3033
-												$this->block_tab_end( $k, $a );
3028
+											foreach ($args as $k => $a) {
3029
+												$this->block_tab_start($k, $a);
3030
+												$this->block_row_start($k, $a);
3031
+												$this->build_block_arguments($k, $a);
3032
+												$this->block_row_end($k, $a);
3033
+												$this->block_tab_end($k, $a);
3034 3034
 											}
3035 3035
 											?>
3036 3036
 										),
3037 3037
 										<?php
3038
-										$panel_count ++;
3038
+										$panel_count++;
3039 3039
 
3040
-										if($close_tab || $close_tabs){
3040
+										if ($close_tab || $close_tabs) {
3041 3041
 											$tab_args = array(
3042 3042
 												'tab'	=> array(
3043 3043
 													'tabs_close' => $close_tabs,
@@ -3045,24 +3045,24 @@  discard block
 block discarded – undo
3045 3045
 												)
3046 3046
 
3047 3047
 											);
3048
-											$this->block_tab_end( '', $tab_args );
3048
+											$this->block_tab_end('', $tab_args);
3049 3049
 //											echo '###close'; print_r($tab_args);
3050 3050
 											$panel_count = 0;
3051 3051
 										}
3052 3052
 //
3053 3053
 
3054 3054
 									}
3055
-									}else {
3055
+									} else {
3056 3056
 									?>
3057 3057
 									el(wp.components.PanelBody, {
3058
-											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
3058
+											title: '<?php esc_attr_e("Settings", 'ayecode-connect'); ?>',
3059 3059
 											initialOpen: true
3060 3060
 										},
3061 3061
 										<?php
3062
-										foreach ( $this->arguments as $key => $args ) {
3063
-											$this->block_row_start( $key, $args );
3064
-											$this->build_block_arguments( $key, $args );
3065
-											$this->block_row_end( $key, $args );
3062
+										foreach ($this->arguments as $key => $args) {
3063
+											$this->block_row_start($key, $args);
3064
+											$this->build_block_arguments($key, $args);
3065
+											$this->block_row_end($key, $args);
3066 3066
 										}
3067 3067
 										?>
3068 3068
 									),
@@ -3076,11 +3076,11 @@  discard block
 block discarded – undo
3076 3076
 
3077 3077
 								<?php
3078 3078
 								// If the user sets block-output array then build it
3079
-								if ( ! empty( $this->options['block-output'] ) ) {
3080
-								$this->block_element( $this->options['block-output'] );
3081
-							}elseif(!empty($this->options['block-edit-return'])){
3079
+								if (!empty($this->options['block-output'])) {
3080
+								$this->block_element($this->options['block-output']);
3081
+							}elseif (!empty($this->options['block-edit-return'])) {
3082 3082
                                    echo $this->options['block-edit-return'];
3083
-							}else{
3083
+							} else {
3084 3084
 								// if no block-output is set then we try and get the shortcode html output via ajax.
3085 3085
 								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3086 3086
 								?>
@@ -3106,22 +3106,22 @@  discard block
 block discarded – undo
3106 3106
 							var align = '';
3107 3107
 
3108 3108
 							// build the shortcode.
3109
-							var content = "[<?php echo $this->options['base_id'];?>";
3109
+							var content = "[<?php echo $this->options['base_id']; ?>";
3110 3110
 							$html = '';
3111 3111
 							<?php
3112 3112
 
3113
-							if(! empty( $this->arguments )){
3113
+							if (!empty($this->arguments)) {
3114 3114
 
3115
-							foreach($this->arguments as $key => $args){
3115
+							foreach ($this->arguments as $key => $args) {
3116 3116
                                // if($args['type']=='tabs'){continue;}
3117 3117
 							?>
3118
-							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3119
-								if ('<?php echo esc_attr( $key );?>' == 'html') {
3120
-									$html = attr.<?php echo esc_attr( $key );?>;
3121
-								} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
3122
-									content += " <?php echo esc_attr( $key );?>='{x:" + attr.<?php echo esc_attr( $key );?>.x + ",y:"+attr.<?php echo esc_attr( $key );?>.y +"}' ";
3118
+							if (attr.hasOwnProperty("<?php echo esc_attr($key); ?>")) {
3119
+								if ('<?php echo esc_attr($key); ?>' == 'html') {
3120
+									$html = attr.<?php echo esc_attr($key); ?>;
3121
+								} else if ('<?php echo esc_attr($args['type']); ?>' == 'image_xy') {
3122
+									content += " <?php echo esc_attr($key); ?>='{x:" + attr.<?php echo esc_attr($key); ?>.x + ",y:"+attr.<?php echo esc_attr($key); ?>.y +"}' ";
3123 3123
 								} else {
3124
-									content += " <?php echo esc_attr( $key );?>='" + attr.<?php echo esc_attr( $key );?>.toString().replace('\'','&#39;') + "' ";
3124
+									content += " <?php echo esc_attr($key); ?>='" + attr.<?php echo esc_attr($key); ?>.toString().replace('\'','&#39;') + "' ";
3125 3125
 								}
3126 3126
 							}
3127 3127
 							<?php
@@ -3140,7 +3140,7 @@  discard block
 block discarded – undo
3140 3140
                             ?>
3141 3141
 							// if has html element
3142 3142
 							if ($html) {
3143
-								content += $html + "[/<?php echo $this->options['base_id'];?>]";
3143
+								content += $html + "[/<?php echo $this->options['base_id']; ?>]";
3144 3144
 							}
3145 3145
 
3146 3146
 							// @todo should we add inline style here or just css classes?
@@ -3170,7 +3170,7 @@  discard block
 block discarded – undo
3170 3170
 //                                <x?php
3171 3171
 //							}else
3172 3172
 
3173
-                            if(!empty($this->options['block-output'])){
3173
+                            if (!empty($this->options['block-output'])) {
3174 3174
 //                               echo "return";
3175 3175
 //                               $this->block_element( $this->options['block-output'], true );
3176 3176
 //                               echo ";";
@@ -3180,30 +3180,30 @@  discard block
 block discarded – undo
3180 3180
                                    '',
3181 3181
                                    {},
3182 3182
                                    el('', {dangerouslySetInnerHTML: {__html: content}}),
3183
-                                   <?php $this->block_element( $this->options['block-output'], true ); ?>
3184
-                                   el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3183
+                                   <?php $this->block_element($this->options['block-output'], true); ?>
3184
+                                   el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id']; ?>]"}})
3185 3185
                                );
3186 3186
                                 <?php
3187 3187
 
3188
-							}elseif(!empty($this->options['block-save-return'])){
3188
+							}elseif (!empty($this->options['block-save-return'])) {
3189 3189
                                    echo 'return ' . $this->options['block-save-return'];
3190
-							}elseif(!empty($this->options['nested-block'])){
3190
+							}elseif (!empty($this->options['nested-block'])) {
3191 3191
                                 ?>
3192 3192
                               return el(
3193 3193
                                    '',
3194 3194
                                    {},
3195 3195
                                    el('', {dangerouslySetInnerHTML: {__html: content+"\n"}}),
3196 3196
                                    InnerBlocks.Content ? el( InnerBlocks.Content ) : '', // @todo i think we need a comma here
3197
-                                   el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3197
+                                   el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id']; ?>]"}})
3198 3198
                                );
3199 3199
                                 <?php
3200
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3201
-                                echo "return ". $this->options['block-edit-return'].";";
3202
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3200
+							}elseif (!empty($this->options['block-save-return'])) {
3201
+                                echo "return " . $this->options['block-edit-return'] . ";";
3202
+							}elseif (isset($this->options['block-wrap']) && $this->options['block-wrap'] == '') {
3203 3203
 							?>
3204 3204
 							return content;
3205 3205
 							<?php
3206
-							}else{
3206
+							} else {
3207 3207
 							?>
3208 3208
 							var block_wrap = 'div';
3209 3209
 							if (attr.hasOwnProperty("block_wrap")) {
@@ -3232,48 +3232,48 @@  discard block
 block discarded – undo
3232 3232
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
3233 3233
 			 */
3234 3234
 
3235
-			return str_replace( array(
3235
+			return str_replace(array(
3236 3236
 				'<script>',
3237 3237
 				'</script>'
3238
-			), '', $output );
3238
+			), '', $output);
3239 3239
 		}
3240 3240
 
3241 3241
 
3242 3242
 
3243
-		public function block_row_start($key, $args){
3243
+		public function block_row_start($key, $args) {
3244 3244
 
3245 3245
 			// check for row
3246
-			if(!empty($args['row'])){
3246
+			if (!empty($args['row'])) {
3247 3247
 
3248
-				if(!empty($args['row']['open'])){
3248
+				if (!empty($args['row']['open'])) {
3249 3249
 
3250 3250
 				// element require
3251
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3252
-                $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3253
-                $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3251
+				$element_require = !empty($args['element_require']) ? $this->block_props_replace($args['element_require'], true) . " && " : "";
3252
+                $device_type = !empty($args['device_type']) ? esc_attr($args['device_type']) : '';
3253
+                $device_type_require = !empty($args['device_type']) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3254 3254
                 $device_type_icon = '';
3255
-                if($device_type=='Desktop'){
3255
+                if ($device_type == 'Desktop') {
3256 3256
                     $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3257
-                }elseif($device_type=='Tablet'){
3257
+                }elseif ($device_type == 'Tablet') {
3258 3258
                     $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3259
-                }elseif($device_type=='Mobile'){
3259
+                }elseif ($device_type == 'Mobile') {
3260 3260
                     $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3261 3261
                 }
3262 3262
 				echo $element_require;
3263 3263
                 echo $device_type_require;
3264 3264
 
3265
-					if(false){?><script><?php }?>
3265
+					if (false) {?><script><?php }?>
3266 3266
 						el('div', {
3267 3267
 								className: 'bsui components-base-control',
3268 3268
 							},
3269
-							<?php if(!empty($args['row']['title'])){ ?>
3269
+							<?php if (!empty($args['row']['title'])) { ?>
3270 3270
 							el('label', {
3271 3271
 									className: 'components-base-control__label position-relative',
3272 3272
 									style: {width:"100%"}
3273 3273
 								},
3274
-								el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes( $args['row']['title'] ) ?>'}}),
3275
-								<?php if($device_type_icon){ ?>
3276
-                                    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)"}})
3274
+								el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes($args['row']['title']) ?>'}}),
3275
+								<?php if ($device_type_icon) { ?>
3276
+                                    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)"}})
3277 3277
 								<?php
3278 3278
                                 }
3279 3279
                                 ?>
@@ -3281,17 +3281,17 @@  discard block
 block discarded – undo
3281 3281
 
3282 3282
 							),
3283 3283
 							<?php }?>
3284
-							<?php if(!empty($args['row']['desc'])){ ?>
3284
+							<?php if (!empty($args['row']['desc'])) { ?>
3285 3285
 							el('p', {
3286 3286
 									className: 'components-base-control__help mb-0',
3287 3287
 								},
3288
-								'<?php echo addslashes( $args['row']['desc'] ); ?>'
3288
+								'<?php echo addslashes($args['row']['desc']); ?>'
3289 3289
 							),
3290 3290
 							<?php }?>
3291 3291
 							el(
3292 3292
 								'div',
3293 3293
 								{
3294
-									className: 'row mb-n2 <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>',
3294
+									className: 'row mb-n2 <?php if (!empty($args['row']['class'])) { echo esc_attr($args['row']['class']); } ?>',
3295 3295
 								},
3296 3296
 								el(
3297 3297
 									'div',
@@ -3300,36 +3300,36 @@  discard block
 block discarded – undo
3300 3300
 									},
3301 3301
 
3302 3302
 					<?php
3303
-					if(false){?></script><?php }
3304
-				}elseif(!empty($args['row']['close'])){
3305
-					if(false){?><script><?php }?>
3303
+					if (false) {?></script><?php }
3304
+				}elseif (!empty($args['row']['close'])) {
3305
+					if (false) {?><script><?php }?>
3306 3306
 						el(
3307 3307
 							'div',
3308 3308
 							{
3309 3309
 								className: 'col pl-0 ps-0',
3310 3310
 							},
3311 3311
 					<?php
3312
-					if(false){?></script><?php }
3313
-				}else{
3314
-					if(false){?><script><?php }?>
3312
+					if (false) {?></script><?php }
3313
+				} else {
3314
+					if (false) {?><script><?php }?>
3315 3315
 						el(
3316 3316
 							'div',
3317 3317
 							{
3318 3318
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3319 3319
 							},
3320 3320
 					<?php
3321
-					if(false){?></script><?php }
3321
+					if (false) {?></script><?php }
3322 3322
 				}
3323 3323
 
3324 3324
 			}
3325 3325
 
3326 3326
 		}
3327 3327
 
3328
-		public function block_row_end($key, $args){
3328
+		public function block_row_end($key, $args) {
3329 3329
 
3330
-			if(!empty($args['row'])){
3330
+			if (!empty($args['row'])) {
3331 3331
 				// maybe close
3332
-				if(!empty($args['row']['close'])){
3332
+				if (!empty($args['row']['close'])) {
3333 3333
 					echo "))";
3334 3334
 				}
3335 3335
 
@@ -3337,14 +3337,14 @@  discard block
 block discarded – undo
3337 3337
 			}
3338 3338
 		}
3339 3339
 
3340
-		public function block_tab_start($key, $args){
3340
+		public function block_tab_start($key, $args) {
3341 3341
 
3342 3342
 			// check for row
3343
-			if(!empty($args['tab'])){
3343
+			if (!empty($args['tab'])) {
3344 3344
 
3345
-				if(!empty($args['tab']['tabs_open'])){
3345
+				if (!empty($args['tab']['tabs_open'])) {
3346 3346
 
3347
-					if(false){?><script><?php }?>
3347
+					if (false) {?><script><?php }?>
3348 3348
 
3349 3349
 el('div',{className: 'bsui'},
3350 3350
 
@@ -3353,81 +3353,81 @@  discard block
 block discarded – undo
3353 3353
 									{
3354 3354
                                         activeClass: 'is-active',
3355 3355
                                         className: 'btn-groupx',
3356
-                                        initialTabName: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3356
+                                        initialTabName: '<?php echo addslashes(esc_attr($args['tab']['key'])); ?>',
3357 3357
 										tabs: [
3358 3358
 
3359 3359
 					<?php
3360
-					if(false){?></script><?php }
3360
+					if (false) {?></script><?php }
3361 3361
 				}
3362 3362
 
3363
-				if(!empty($args['tab']['open'])){
3363
+				if (!empty($args['tab']['open'])) {
3364 3364
 
3365
-					if(false){?><script><?php }?>
3365
+					if (false) {?><script><?php }?>
3366 3366
 							{
3367
-												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3368
-												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
3369
-												className: '<?php echo addslashes( esc_attr( $args['tab']['class']) ); ?>',
3370
-												content: el('div',{}, <?php if(!empty($args['tab']['desc'])){ ?>el('p', {
3367
+												name: '<?php echo addslashes(esc_attr($args['tab']['key'])); ?>',
3368
+												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes(esc_attr($args['tab']['title'])); ?>'}}),
3369
+												className: '<?php echo addslashes(esc_attr($args['tab']['class'])); ?>',
3370
+												content: el('div',{}, <?php if (!empty($args['tab']['desc'])) { ?>el('p', {
3371 3371
 									className: 'components-base-control__help mb-0',
3372
-									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3372
+									dangerouslySetInnerHTML: {__html:'<?php echo addslashes($args['tab']['desc']); ?>'}
3373 3373
 								}),<?php }
3374
-					if(false){?></script><?php }
3374
+					if (false) {?></script><?php }
3375 3375
 				}
3376 3376
 
3377 3377
 			}
3378 3378
 
3379 3379
 		}
3380 3380
 
3381
-		public function block_tab_end($key, $args){
3381
+		public function block_tab_end($key, $args) {
3382 3382
 
3383
-			if(!empty($args['tab'])){
3383
+			if (!empty($args['tab'])) {
3384 3384
 				// maybe close
3385
-				if(!empty($args['tab']['close'])){
3385
+				if (!empty($args['tab']['close'])) {
3386 3386
 					echo ")}, /* tab close */";
3387 3387
 				}
3388 3388
 
3389
-				if(!empty($args['tab']['tabs_close'])){
3390
-					if(false){?><script><?php }?>
3389
+				if (!empty($args['tab']['tabs_close'])) {
3390
+					if (false) {?><script><?php }?>
3391 3391
 						]}, ( tab ) => {
3392 3392
 								return tab.content;
3393 3393
 							}
3394 3394
 						)), /* tabs close */
3395
-					<?php if(false){ ?></script><?php }
3395
+					<?php if (false) { ?></script><?php }
3396 3396
 				}
3397 3397
 			}
3398 3398
 		}
3399 3399
 
3400
-		public function build_block_arguments( $key, $args ) {
3401
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3400
+		public function build_block_arguments($key, $args) {
3401
+			$custom_attributes = !empty($args['custom_attributes']) ? $this->array_to_attributes($args['custom_attributes']) : '';
3402 3402
 			$options           = '';
3403 3403
 			$extra             = '';
3404 3404
 			$require           = '';
3405
-            $inside_elements   = '';
3405
+            $inside_elements = '';
3406 3406
 			$after_elements	   = '';
3407 3407
 
3408 3408
 			// `content` is a protected and special argument
3409
-			if ( $key == 'content' ) {
3409
+			if ($key == 'content') {
3410 3410
 				return;
3411 3411
 			}
3412 3412
 
3413
-            $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3414
-            $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3413
+            $device_type = !empty($args['device_type']) ? esc_attr($args['device_type']) : '';
3414
+            $device_type_require = !empty($args['device_type']) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3415 3415
             $device_type_icon = '';
3416
-            if($device_type=='Desktop'){
3416
+            if ($device_type == 'Desktop') {
3417 3417
                 $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3418
-            }elseif($device_type=='Tablet'){
3418
+            }elseif ($device_type == 'Tablet') {
3419 3419
                 $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3420
-            }elseif($device_type=='Mobile'){
3420
+            }elseif ($device_type == 'Mobile') {
3421 3421
                 $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3422 3422
             }
3423 3423
 
3424 3424
 			// icon
3425 3425
 			$icon = '';
3426
-			if( !empty( $args['icon'] ) ){
3426
+			if (!empty($args['icon'])) {
3427 3427
 				$icon .= "el('div', {";
3428
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3428
+									$icon .= "dangerouslySetInnerHTML: {__html: '" . self::get_widget_icon(esc_attr($args['icon'])) . "'},";
3429 3429
 									$icon .= "className: 'text-center',";
3430
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3430
+									$icon .= "title: '" . addslashes($args['title']) . "',";
3431 3431
 								$icon .= "}),";
3432 3432
 
3433 3433
 				// blank title as its added to the icon.
@@ -3435,20 +3435,20 @@  discard block
 block discarded – undo
3435 3435
 			}
3436 3436
 
3437 3437
 			// require advanced
3438
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3438
+			$require_advanced = !empty($args['advanced']) ? "props.attributes.show_advanced && " : "";
3439 3439
 
3440 3440
 			// element require
3441
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3441
+			$element_require = !empty($args['element_require']) ? $this->block_props_replace($args['element_require'], true) . " && " : "";
3442 3442
 
3443 3443
 
3444 3444
 			$onchange  = "props.setAttributes({ $key: $key } )";
3445
-			$onchangecomplete  = "";
3445
+			$onchangecomplete = "";
3446 3446
 			$value     = "props.attributes.$key";
3447
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3448
-			if ( in_array( $args['type'], $text_type ) ) {
3447
+			$text_type = array('text', 'password', 'number', 'email', 'tel', 'url', 'colorx', 'range');
3448
+			if (in_array($args['type'], $text_type)) {
3449 3449
 				$type = 'TextControl';
3450 3450
 				// Save numbers as numbers and not strings
3451
-				if ( $args['type'] == 'number' ) {
3451
+				if ($args['type'] == 'number') {
3452 3452
 					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3453 3453
 				}
3454 3454
 			}
@@ -3469,12 +3469,12 @@  discard block
 block discarded – undo
3469 3469
 //
3470 3470
 //				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3471 3471
 //			}
3472
-			else if ( $args['type'] == 'styleid' ) {
3472
+			else if ($args['type'] == 'styleid') {
3473 3473
 				$type = 'TextControl';
3474 3474
 				$args['type'] == 'text';
3475 3475
 				// Save numbers as numbers and not strings
3476
-				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3477
-			}else if ( $args['type'] == 'notice' ) {
3476
+				$value = "props.attributes.$key ? props.attributes.$key : ''";
3477
+			} else if ($args['type'] == 'notice') {
3478 3478
 
3479 3479
 				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3480 3480
 				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
@@ -3536,11 +3536,11 @@  discard block
 block discarded – undo
3536 3536
 							return;
3537 3537
 						}
3538 3538
 */
3539
-			elseif ( $args['type'] == 'color' ) {
3539
+			elseif ($args['type'] == 'color') {
3540 3540
 				$type = 'ColorPicker';
3541 3541
 				$onchange = "";
3542 3542
 				$extra = "color: $value,";
3543
-				if(!empty($args['disable_alpha'])){
3543
+				if (!empty($args['disable_alpha'])) {
3544 3544
 					$extra .= "disableAlpha: true,";
3545 3545
 				}
3546 3546
 				$onchangecomplete = "onChangeComplete: function($key) {
@@ -3549,7 +3549,7 @@  discard block
 block discarded – undo
3549 3549
                             $key: value
3550 3550
                         });
3551 3551
                     },";
3552
-			}elseif ( $args['type'] == 'gradient' ) {
3552
+			}elseif ($args['type'] == 'gradient') {
3553 3553
 				$type = 'GradientPicker';
3554 3554
 				$extra .= "gradients: [{
3555 3555
 			name: 'Vivid cyan blue to vivid purple',
@@ -3588,11 +3588,11 @@  discard block
 block discarded – undo
3588 3588
 			slug: 'cool-to-warm-spectrum',
3589 3589
 		}],";
3590 3590
 
3591
-			}elseif ( $args['type'] == 'image' ) {
3591
+			}elseif ($args['type'] == 'image') {
3592 3592
 //                print_r($args);
3593 3593
 
3594 3594
                 $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,{
3595
-                            url:  props.attributes.{$key}_use_featured === true ? '".$this->get_url()."icons/placeholder.png'  : props.attributes.$key,
3595
+                            url:  props.attributes.{$key}_use_featured === true ? '" . $this->get_url() . "icons/placeholder.png'  : props.attributes.$key,
3596 3596
                             value: props.attributes.{$key}_xy.x !== undefined && props.attributes.{$key}_xy.x >= 0 ? props.attributes.{$key}_xy  : {x: 0.5,y: 0.5,},
3597 3597
 //                            value: props.attributes.{$key}_xy,
3598 3598
                             onChange: function(focalPoint){
@@ -3650,7 +3650,7 @@  discard block
 block discarded – undo
3650 3650
                 $onchange = "";
3651 3651
 
3652 3652
                 //$inside_elements = ",el('div',{},'file upload')";
3653
-			} else if ( $args['type'] == 'images' ) {
3653
+			} else if ($args['type'] == 'images') {
3654 3654
 				$img_preview = "props.attributes.$key && (function() {
3655 3655
 	let uploads = JSON.parse('['+props.attributes.$key+']');
3656 3656
 	let images = [];
@@ -3663,7 +3663,7 @@  discard block
 block discarded – undo
3663 3663
 			el('i',{
3664 3664
 				className: 'fas fa-times-circle text-danger position-absolute  ml-n2 mt-n1 bg-white rounded-circle c-pointer',
3665 3665
 				onClick: function() {
3666
-					aui_confirm('".esc_attr__('Are you sure?')."', '".esc_attr__('Delete')."', '".esc_attr__('Cancel')."', true).then(function(confirmed) {
3666
+					aui_confirm('" . esc_attr__('Are you sure?') . "', '" . esc_attr__('Delete') . "', '" . esc_attr__('Cancel') . "', true).then(function(confirmed) {
3667 3667
 						if (confirmed) {
3668 3668
 							let new_uploads = JSON.parse('['+props.attributes.$key+']');
3669 3669
 							new_uploads.splice(index, 1);
@@ -3726,36 +3726,36 @@  discard block
 block discarded – undo
3726 3726
 
3727 3727
                 //$inside_elements = ",el('div',{},'file upload')";
3728 3728
 			}
3729
-			elseif ( $args['type'] == 'checkbox' ) {
3729
+			elseif ($args['type'] == 'checkbox') {
3730 3730
 				$type = 'CheckboxControl';
3731 3731
 				$extra .= "checked: props.attributes.$key,";
3732 3732
 				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3733
-			} elseif ( $args['type'] == 'textarea' ) {
3733
+			} elseif ($args['type'] == 'textarea') {
3734 3734
 				$type = 'TextareaControl';
3735 3735
 
3736
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3736
+			} elseif ($args['type'] == 'select' || $args['type'] == 'multiselect') {
3737 3737
 				$type = 'SelectControl';
3738 3738
 
3739
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3740
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3741
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3742
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3743
-				}else {
3739
+				if ($args['name'] == 'category' && !empty($args['post_type_linked'])) {
3740
+					$options .= "options: taxonomies_" . str_replace("-", "_", $this->id) . ",";
3741
+				}elseif ($args['name'] == 'sort_by' && !empty($args['post_type_linked'])) {
3742
+					$options .= "options: sort_by_" . str_replace("-", "_", $this->id) . ",";
3743
+				} else {
3744 3744
 
3745
-					if ( ! empty( $args['options'] ) ) {
3745
+					if (!empty($args['options'])) {
3746 3746
 						$options .= "options: [";
3747
-						foreach ( $args['options'] as $option_val => $option_label ) {
3748
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3747
+						foreach ($args['options'] as $option_val => $option_label) {
3748
+							$options .= "{ value: '" . esc_attr($option_val) . "', label: '" . esc_js(addslashes($option_label)) . "' },";
3749 3749
 						}
3750 3750
 						$options .= "],";
3751 3751
 					}
3752 3752
 				}
3753
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3753
+				if (isset($args['multiple']) && $args['multiple']) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3754 3754
 					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3755 3755
 				}
3756 3756
 
3757
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3758
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3757
+				if ($args['type'] == 'multiselect' || (isset($args['multiple']) && $args['multiple'])) {
3758
+					$after_elements .= "props.attributes.$key && el( wp.components.Button, {
3759 3759
                                       className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3760 3760
                                       style: {margin:'-8px 0 8px 0',display: 'block'},
3761 3761
                                       onClick: function(){
@@ -3767,7 +3767,7 @@  discard block
 block discarded – undo
3767 3767
                                     'Clear'
3768 3768
                             ),";
3769 3769
 				}
3770
-			} elseif ( $args['type'] == 'tagselect' ) {
3770
+			} elseif ($args['type'] == 'tagselect') {
3771 3771
 //				$type = 'FormTokenField';
3772 3772
 //
3773 3773
 //				if ( ! empty( $args['options'] ) ) {
@@ -3802,19 +3802,19 @@  discard block
 block discarded – undo
3802 3802
 //				$value     = "[]";
3803 3803
 //				$extra .= ' __experimentalExpandOnFocus: true,';
3804 3804
 
3805
-			} else if ( $args['type'] == 'alignment' ) {
3805
+			} else if ($args['type'] == 'alignment') {
3806 3806
 				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
3807
-			} else if ( $args['type'] == 'margins' ) {
3807
+			} else if ($args['type'] == 'margins') {
3808 3808
 
3809
-			} else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
3809
+			} else if ($args['type'] == 'visibility_conditions' && (function_exists('wp_is_block_theme') && wp_is_block_theme())) {
3810 3810
 				$type = 'TextControl';
3811 3811
 				$value = "(props.attributes.$key ? props.attributes.$key : '')";
3812 3812
 				$args['type'] = 'text';
3813 3813
 				$options .= 'disabled:true,';
3814
-				$bsvc_title = esc_attr( addslashes( $args['title'] ) );
3815
-				$bsvc_body = $this->block_visibility_fields( $args );
3814
+				$bsvc_title = esc_attr(addslashes($args['title']));
3815
+				$bsvc_body = $this->block_visibility_fields($args);
3816 3816
 				// @TODO reset button
3817
-				$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>';
3817
+				$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>';
3818 3818
 				$after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
3819 3819
 						className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
3820 3820
 						onClick: function() {
@@ -3833,25 +3833,25 @@  discard block
 block discarded – undo
3833 3833
 									jQuery('.bs-vc-modal-form').trigger('change');
3834 3834
 								}
3835 3835
 							});
3836
-							aui_modal('" . $bsvc_title . "', '" . addslashes( $bsvc_body ) . "', '" . $bsvc_footer . "', true, 'bs-vc-modal', 'modal-lg', '');
3836
+							aui_modal('" . $bsvc_title . "', '" . addslashes($bsvc_body) . "', '" . $bsvc_footer . "', true, 'bs-vc-modal', 'modal-lg', '');
3837 3837
 							jQuery(document).off('change', '#bsvc_raw_value').on('change', '#bsvc_raw_value', function(e) {
3838 3838
 								props.setAttributes({" . $key . ": e.target.value});
3839 3839
 							});
3840 3840
 						}
3841 3841
 					},
3842
-					'" . addslashes( ! empty( $args['button_title'] ) ? $args['button_title'] : $args['title'] ) . "'
3842
+					'" . addslashes(!empty($args['button_title']) ? $args['button_title'] : $args['title']) . "'
3843 3843
 				) ),";
3844 3844
 			} else {
3845
-				return;// if we have not implemented the control then don't break the JS.
3845
+				return; // if we have not implemented the control then don't break the JS.
3846 3846
 			}
3847 3847
 
3848 3848
 			// color input does not show the labels so we add them
3849
-			if($args['type']=='color'){
3849
+			if ($args['type'] == 'color') {
3850 3850
 				// add show only if advanced
3851 3851
 				echo $require_advanced;
3852 3852
 				// add setting require if defined
3853 3853
 				echo $element_require;
3854
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
3854
+				echo "el('div', {style: {'marginBottom': '8px'}}, '" . addslashes($args['title']) . "'),";
3855 3855
 			}
3856 3856
 
3857 3857
 			// add show only if advanced
@@ -3863,22 +3863,22 @@  discard block
 block discarded – undo
3863 3863
 			// icon
3864 3864
 			echo $icon;
3865 3865
 			?>
3866
-			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
3867
-			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
3868
-			} else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
3869
-			help: <?php echo ( isset( $args['desc'] ) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim( wp_kses_post( addslashes( $args['desc'] ) ) ) . "'}})" : "''" ); ?>,
3866
+			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type : "wp.components." . $type; ?>, {
3867
+			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
3868
+			} else { ?>'<?php echo addslashes(trim(esc_html($args['title']))); ?>'<?php } ?>,
3869
+			help: <?php echo (isset($args['desc']) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim(wp_kses_post(addslashes($args['desc']))) . "'}})" : "''"); ?>,
3870 3870
 			value: <?php echo $value; ?>,
3871
-			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
3872
-				echo "type: '" . addslashes( $args['type'] ) . "',";
3871
+			<?php if ($type == 'TextControl' && $args['type'] != 'text') {
3872
+				echo "type: '" . addslashes($args['type']) . "',";
3873 3873
 			} ?>
3874
-			<?php if ( ! empty( $args['placeholder'] ) ) {
3875
-				echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
3874
+			<?php if (!empty($args['placeholder'])) {
3875
+				echo "placeholder: '" . esc_js(addslashes(trim(esc_html($args['placeholder'])))) . "',";
3876 3876
 			} ?>
3877 3877
 			<?php echo $options; ?>
3878 3878
 			<?php echo $extra; ?>
3879 3879
 			<?php echo $custom_attributes; ?>
3880 3880
 			<?php echo $onchangecomplete; ?>
3881
-			<?php if ( $onchange ) { ?>
3881
+			<?php if ($onchange) { ?>
3882 3882
 			onChange: function ( <?php echo $key; ?> ) {
3883 3883
 				<?php echo $onchange; ?>
3884 3884
 			}
@@ -3897,15 +3897,15 @@  discard block
 block discarded – undo
3897 3897
 		 *@todo there is prob a faster way to do this, also we could add some validation here.
3898 3898
 		 *
3899 3899
 		 */
3900
-		public function array_to_attributes( $custom_attributes, $html = false ) {
3900
+		public function array_to_attributes($custom_attributes, $html = false) {
3901 3901
 			$attributes = '';
3902
-			if ( ! empty( $custom_attributes ) ) {
3902
+			if (!empty($custom_attributes)) {
3903 3903
 
3904
-				foreach ( $custom_attributes as $key => $val ) {
3905
-					if(is_array($val)){
3906
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
3907
-					}else{
3908
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
3904
+				foreach ($custom_attributes as $key => $val) {
3905
+					if (is_array($val)) {
3906
+						$attributes .= $key . ': {' . $this->array_to_attributes($val, $html) . '},';
3907
+					} else {
3908
+						$attributes .= $html ? " $key='$val' " : "'$key': '$val',";
3909 3909
 					}
3910 3910
 				}
3911 3911
 
@@ -3923,112 +3923,112 @@  discard block
 block discarded – undo
3923 3923
 		 *
3924 3924
 		 * @param $args
3925 3925
 		 */
3926
-		public function block_element( $args, $save = false ) {
3926
+		public function block_element($args, $save = false) {
3927 3927
 
3928 3928
 
3929
-			if ( ! empty( $args ) ) {
3930
-				foreach ( $args as $element => $new_args ) {
3929
+			if (!empty($args)) {
3930
+				foreach ($args as $element => $new_args) {
3931 3931
 
3932
-					if ( is_array( $new_args ) ) { // its an element
3932
+					if (is_array($new_args)) { // its an element
3933 3933
 
3934 3934
 
3935
-						if ( isset( $new_args['element'] ) ) {
3935
+						if (isset($new_args['element'])) {
3936 3936
 
3937
-							if ( isset( $new_args['element_require'] ) ) {
3938
-								echo str_replace( array(
3937
+							if (isset($new_args['element_require'])) {
3938
+								echo str_replace(array(
3939 3939
 										"'+",
3940 3940
 										"+'"
3941
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
3942
-								unset( $new_args['element_require'] );
3941
+									), '', $this->block_props_replace($new_args['element_require'])) . " &&  ";
3942
+								unset($new_args['element_require']);
3943 3943
 							}
3944 3944
 
3945
-                            if($new_args['element']=='InnerBlocks'){
3945
+                            if ($new_args['element'] == 'InnerBlocks') {
3946 3946
                                 echo "\n el( InnerBlocks, {";
3947
-                            }elseif($new_args['element']=='innerBlocksProps'){
3947
+                            }elseif ($new_args['element'] == 'innerBlocksProps') {
3948 3948
                                 $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
3949 3949
                               //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
3950 3950
 //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
3951 3951
                                 echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
3952 3952
                                 echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
3953
-                                echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
3953
+                                echo !empty($new_args['blockProps']) ? $this->block_element($new_args['blockProps'], $save) : '';
3954 3954
 
3955 3955
                                 echo "} ), {";
3956
-                                echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
3956
+                                echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element($new_args['innerBlocksProps'], $save) : '';
3957 3957
                             //    echo '###';
3958 3958
 
3959 3959
                               //  echo '###';
3960
-                            }elseif($new_args['element']=='BlocksProps'){
3960
+                            }elseif ($new_args['element'] == 'BlocksProps') {
3961 3961
 
3962
-								if ( isset($new_args['if_inner_element']) ) {
3962
+								if (isset($new_args['if_inner_element'])) {
3963 3963
 									$element = $new_args['if_inner_element'];
3964
-								}else {
3965
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
3964
+								} else {
3965
+									$element = isset($new_args['inner_element']) ? "'" . esc_attr($new_args['inner_element']) . "'" : "'div'";
3966 3966
 								}
3967 3967
 
3968 3968
 								unset($new_args['inner_element']);
3969 3969
                                 echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
3970
-                                echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
3970
+                                echo !empty($new_args['blockProps']) ? $this->block_element($new_args['blockProps'], $save) : '';
3971 3971
 
3972 3972
 
3973 3973
                                // echo "} ),";
3974 3974
 
3975
-                            }else{
3975
+                            } else {
3976 3976
                                 echo "\n el( '" . $new_args['element'] . "', {";
3977 3977
                             }
3978 3978
 
3979 3979
 
3980 3980
 							// get the attributes
3981
-							foreach ( $new_args as $new_key => $new_value ) {
3981
+							foreach ($new_args as $new_key => $new_value) {
3982 3982
 
3983 3983
 
3984
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
3984
+								if ($new_key == 'element' || $new_key == 'content' || $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array($new_value)) {
3985 3985
 									// do nothing
3986 3986
 								} else {
3987
-									echo $this->block_element( array( $new_key => $new_value ),$save );
3987
+									echo $this->block_element(array($new_key => $new_value), $save);
3988 3988
 								}
3989 3989
 							}
3990 3990
 
3991
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
3991
+							echo $new_args['element'] == 'BlocksProps' ? '} ),' : "},"; // end attributes
3992 3992
 
3993 3993
 							// get the content
3994 3994
 							$first_item = 0;
3995
-							foreach ( $new_args as $new_key => $new_value ) {
3996
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
3995
+							foreach ($new_args as $new_key => $new_value) {
3996
+								if ($new_key === 'content' || $new_key === 'if_content' || is_array($new_value)) {
3997 3997
 
3998
-									if ( $new_key === 'content' ) {
3999
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4000
-									}else if ( $new_key === 'if_content' ) {
4001
-										echo  $this->block_props_replace(  $new_value  );
3998
+									if ($new_key === 'content') {
3999
+										echo "'" . $this->block_props_replace(wp_slash($new_value)) . "'";
4000
+									} else if ($new_key === 'if_content') {
4001
+										echo  $this->block_props_replace($new_value);
4002 4002
 									}
4003 4003
 
4004
-									if ( is_array( $new_value ) ) {
4004
+									if (is_array($new_value)) {
4005 4005
 
4006
-										if ( isset( $new_value['element_require'] ) ) {
4007
-											echo str_replace( array(
4006
+										if (isset($new_value['element_require'])) {
4007
+											echo str_replace(array(
4008 4008
 													"'+",
4009 4009
 													"+'"
4010
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4011
-											unset( $new_value['element_require'] );
4010
+												), '', $this->block_props_replace($new_value['element_require'])) . " &&  ";
4011
+											unset($new_value['element_require']);
4012 4012
 										}
4013 4013
 
4014
-										if ( isset( $new_value['element_repeat'] ) ) {
4014
+										if (isset($new_value['element_repeat'])) {
4015 4015
 											$x = 1;
4016
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
4017
-												$this->block_element( array( '' => $new_value ),$save );
4018
-												$x ++;
4016
+											while ($x <= absint($new_value['element_repeat'])) {
4017
+												$this->block_element(array('' => $new_value), $save);
4018
+												$x++;
4019 4019
 											}
4020 4020
 										} else {
4021
-											$this->block_element( array( '' => $new_value ),$save );
4021
+											$this->block_element(array('' => $new_value), $save);
4022 4022
 										}
4023 4023
 									}
4024
-									$first_item ++;
4024
+									$first_item++;
4025 4025
 								}
4026 4026
 							}
4027 4027
 
4028
-                            if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4029
-                                echo "))";// end content
4030
-                            }else{
4031
-                                echo ")";// end content
4028
+                            if ($new_args['element'] == 'innerBlocksProps' || $new_args['element'] == 'xBlocksProps') {
4029
+                                echo "))"; // end content
4030
+                            } else {
4031
+                                echo ")"; // end content
4032 4032
                             }
4033 4033
 
4034 4034
 
@@ -4037,26 +4037,26 @@  discard block
 block discarded – undo
4037 4037
 						}
4038 4038
 					} else {
4039 4039
 
4040
-						if ( substr( $element, 0, 3 ) === "if_" ) {
4040
+						if (substr($element, 0, 3) === "if_") {
4041 4041
 							$extra = '';
4042
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
4043
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4044
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4042
+							if (strpos($new_args, '[%WrapClass%]') !== false) {
4043
+								$new_args = str_replace('[%WrapClass%]"', '" + sd_build_aui_class(props.attributes)', $new_args);
4044
+								$new_args = str_replace('[%WrapClass%]', '+ sd_build_aui_class(props.attributes)', $new_args);
4045 4045
 							}
4046
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4047
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4048
-                            $new_args = str_replace('[%WrapStyle%]','',$new_args);
4049
-                            echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4046
+							echo str_replace("if_", "", $element) . ": " . $this->block_props_replace($new_args, true) . ",";
4047
+						} elseif ($element == 'style' && strpos($new_args, '[%WrapStyle%]') !== false) {
4048
+                            $new_args = str_replace('[%WrapStyle%]', '', $new_args);
4049
+                            echo $element . ": {..." . $this->block_props_replace($new_args) . " , ...sd_build_aui_styles(props.attributes) },";
4050 4050
 //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4051
-						} elseif ( $element == 'style' ) {
4052
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4053
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4054
-                            $new_args = str_replace('[%WrapClass%]','',$new_args);
4055
-                            echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4056
-						} elseif ( $element == 'template' && $new_args ) {
4051
+						} elseif ($element == 'style') {
4052
+							echo $element . ": " . $this->block_props_replace($new_args) . ",";
4053
+						} elseif (($element == 'class' || $element == 'className') && strpos($new_args, '[%WrapClass%]') !== false) {
4054
+                            $new_args = str_replace('[%WrapClass%]', '', $new_args);
4055
+                            echo $element . ": '" . $this->block_props_replace($new_args) . "' + sd_build_aui_class(props.attributes),";
4056
+						} elseif ($element == 'template' && $new_args) {
4057 4057
 							echo $element . ": $new_args,";
4058 4058
 						} else {
4059
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4059
+							echo $element . ": '" . $this->block_props_replace($new_args) . "',";
4060 4060
 						}
4061 4061
 
4062 4062
 					}
@@ -4071,11 +4071,11 @@  discard block
 block discarded – undo
4071 4071
 		 *
4072 4072
 		 * @return mixed
4073 4073
 		 */
4074
-		public function block_props_replace( $string, $no_wrap = false ) {
4075
-			if ( $no_wrap ) {
4076
-				$string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4074
+		public function block_props_replace($string, $no_wrap = false) {
4075
+			if ($no_wrap) {
4076
+				$string = str_replace(array("[%", "%]", "%:checked]"), array("props.attributes.", "", ""), $string);
4077 4077
 			} else {
4078
-				$string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4078
+				$string = str_replace(array("![%", "[%", "%]", "%:checked]"), array("'+!props.attributes.", "'+props.attributes.", "+'", "+'"), $string);
4079 4079
 			}
4080 4080
 
4081 4081
 			return $string;
@@ -4087,65 +4087,65 @@  discard block
 block discarded – undo
4087 4087
 		 * @param array $args
4088 4088
 		 * @param array $instance
4089 4089
 		 */
4090
-		public function widget( $args, $instance ) {
4091
-			if ( ! is_array( $args ) ) {
4090
+		public function widget($args, $instance) {
4091
+			if (!is_array($args)) {
4092 4092
 				$args = array();
4093 4093
 			}
4094 4094
 
4095 4095
 			// Get the filtered values
4096
-			$argument_values = $this->argument_values( $instance );
4097
-			$argument_values = $this->string_to_bool( $argument_values );
4098
-			$output          = $this->output( $argument_values, $args );
4096
+			$argument_values = $this->argument_values($instance);
4097
+			$argument_values = $this->string_to_bool($argument_values);
4098
+			$output          = $this->output($argument_values, $args);
4099 4099
 
4100 4100
 			$no_wrap = false;
4101
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4101
+			if (isset($argument_values['no_wrap']) && $argument_values['no_wrap']) {
4102 4102
 				$no_wrap = true;
4103 4103
 			}
4104 4104
 
4105 4105
 			ob_start();
4106
-			if ( $output && ! $no_wrap ) {
4106
+			if ($output && !$no_wrap) {
4107 4107
 
4108 4108
 				$class_original = $this->options['widget_ops']['classname'];
4109
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4109
+				$class = $this->options['widget_ops']['classname'] . " sdel-" . $this->get_instance_hash();
4110 4110
 
4111 4111
 				// Before widget
4112
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4113
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4114
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4115
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4112
+				$before_widget = !empty($args['before_widget']) ? $args['before_widget'] : '';
4113
+				$before_widget = $before_widget ? str_replace($class_original, $class, $before_widget) : $before_widget;
4114
+				$before_widget = apply_filters('wp_super_duper_before_widget', $before_widget, $args, $instance, $this);
4115
+				$before_widget = apply_filters('wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this);
4116 4116
 
4117 4117
 				// After widget
4118
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4119
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4120
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4118
+				$after_widget = !empty($args['after_widget']) ? $args['after_widget'] : '';
4119
+				$after_widget = apply_filters('wp_super_duper_after_widget', $after_widget, $args, $instance, $this);
4120
+				$after_widget = apply_filters('wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this);
4121 4121
 
4122 4122
 				echo $before_widget;
4123 4123
 				// elementor strips the widget wrapping div so we check for and add it back if needed
4124
-				if ( $this->is_elementor_widget_output() ) {
4124
+				if ($this->is_elementor_widget_output()) {
4125 4125
 					// Filter class & attrs for elementor widget output.
4126
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4127
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4126
+					$class = apply_filters('wp_super_duper_div_classname', $class, $args, $this);
4127
+					$class = apply_filters('wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this);
4128 4128
 
4129
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4130
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4129
+					$attrs = apply_filters('wp_super_duper_div_attrs', '', $args, $this);
4130
+					$attrs = apply_filters('wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this);
4131 4131
 
4132
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4132
+					echo "<span class='" . esc_attr($class) . "' " . $attrs . ">";
4133 4133
 				}
4134
-				echo $this->output_title( $args, $instance );
4134
+				echo $this->output_title($args, $instance);
4135 4135
 				echo $output;
4136
-				if ( $this->is_elementor_widget_output() ) {
4136
+				if ($this->is_elementor_widget_output()) {
4137 4137
 					echo "</span>";
4138 4138
 				}
4139 4139
 				echo $after_widget;
4140
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4141
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4140
+			} elseif ($this->is_preview() && $output == '') {// if preview show a placeholder if empty
4141
+				$output = $this->preview_placeholder_text("{{" . $this->base_id . "}}");
4142 4142
 				echo $output;
4143
-			} elseif ( $output && $no_wrap ) {
4143
+			} elseif ($output && $no_wrap) {
4144 4144
 				echo $output;
4145 4145
 			}
4146 4146
 			$output = ob_get_clean();
4147 4147
 
4148
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4148
+			$output = apply_filters('wp_super_duper_widget_output', $output, $instance, $args, $this);
4149 4149
 
4150 4150
 			echo $output;
4151 4151
 		}
@@ -4158,7 +4158,7 @@  discard block
 block discarded – undo
4158 4158
 		 */
4159 4159
 		public function is_elementor_widget_output() {
4160 4160
 			$result = false;
4161
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4161
+			if (defined('ELEMENTOR_VERSION') && isset($this->number) && $this->number == 'REPLACE_TO_ID') {
4162 4162
 				$result = true;
4163 4163
 			}
4164 4164
 
@@ -4173,7 +4173,7 @@  discard block
 block discarded – undo
4173 4173
 		 */
4174 4174
 		public function is_elementor_preview() {
4175 4175
 			$result = false;
4176
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4176
+			if (isset($_REQUEST['elementor-preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor') || (isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor_ajax')) {
4177 4177
 				$result = true;
4178 4178
 			}
4179 4179
 
@@ -4188,7 +4188,7 @@  discard block
 block discarded – undo
4188 4188
 		 */
4189 4189
 		public function is_divi_preview() {
4190 4190
 			$result = false;
4191
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4191
+			if (isset($_REQUEST['et_fb']) || isset($_REQUEST['et_pb_preview']) || (is_admin() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'elementor')) {
4192 4192
 				$result = true;
4193 4193
 			}
4194 4194
 
@@ -4203,7 +4203,7 @@  discard block
 block discarded – undo
4203 4203
 		 */
4204 4204
 		public function is_beaver_preview() {
4205 4205
 			$result = false;
4206
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
4206
+			if (isset($_REQUEST['fl_builder'])) {
4207 4207
 				$result = true;
4208 4208
 			}
4209 4209
 
@@ -4218,7 +4218,7 @@  discard block
 block discarded – undo
4218 4218
 		 */
4219 4219
 		public function is_siteorigin_preview() {
4220 4220
 			$result = false;
4221
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4221
+			if (!empty($_REQUEST['siteorigin_panels_live_editor'])) {
4222 4222
 				$result = true;
4223 4223
 			}
4224 4224
 
@@ -4233,7 +4233,7 @@  discard block
 block discarded – undo
4233 4233
 		 */
4234 4234
 		public function is_cornerstone_preview() {
4235 4235
 			$result = false;
4236
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4236
+			if (!empty($_REQUEST['cornerstone_preview']) || basename($_SERVER['REQUEST_URI']) == 'cornerstone-endpoint') {
4237 4237
 				$result = true;
4238 4238
 			}
4239 4239
 
@@ -4248,7 +4248,7 @@  discard block
 block discarded – undo
4248 4248
 		 */
4249 4249
 		public function is_fusion_preview() {
4250 4250
 			$result = false;
4251
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4251
+			if (!empty($_REQUEST['fb-edit']) || !empty($_REQUEST['fusion_load_nonce'])) {
4252 4252
 				$result = true;
4253 4253
 			}
4254 4254
 
@@ -4263,7 +4263,7 @@  discard block
 block discarded – undo
4263 4263
 		 */
4264 4264
 		public function is_oxygen_preview() {
4265 4265
 			$result = false;
4266
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4266
+			if (!empty($_REQUEST['ct_builder']) || (!empty($_REQUEST['action']) && (substr($_REQUEST['action'], 0, 11) === "oxy_render_" || substr($_REQUEST['action'], 0, 10) === "ct_render_"))) {
4267 4267
 				$result = true;
4268 4268
 			}
4269 4269
 
@@ -4280,7 +4280,7 @@  discard block
 block discarded – undo
4280 4280
 		public function is_kallyas_zion_preview() {
4281 4281
 			$result = false;
4282 4282
 
4283
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4283
+			if (function_exists('znhg_kallyas_theme_config') && !empty($_REQUEST['zn_pb_edit'])) {
4284 4284
 				$result = true;
4285 4285
 			}
4286 4286
 
@@ -4297,7 +4297,7 @@  discard block
 block discarded – undo
4297 4297
 		public function is_bricks_preview() {
4298 4298
 			$result = false;
4299 4299
 
4300
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4300
+			if (function_exists('bricks_is_builder') && (bricks_is_builder() || bricks_is_builder_call())) {
4301 4301
 				$result = true;
4302 4302
 			}
4303 4303
 
@@ -4312,25 +4312,25 @@  discard block
 block discarded – undo
4312 4312
 		 */
4313 4313
 		public function is_preview() {
4314 4314
 			$preview = false;
4315
-			if ( $this->is_divi_preview() ) {
4315
+			if ($this->is_divi_preview()) {
4316 4316
 				$preview = true;
4317
-			} elseif ( $this->is_elementor_preview() ) {
4317
+			} elseif ($this->is_elementor_preview()) {
4318 4318
 				$preview = true;
4319
-			} elseif ( $this->is_beaver_preview() ) {
4319
+			} elseif ($this->is_beaver_preview()) {
4320 4320
 				$preview = true;
4321
-			} elseif ( $this->is_siteorigin_preview() ) {
4321
+			} elseif ($this->is_siteorigin_preview()) {
4322 4322
 				$preview = true;
4323
-			} elseif ( $this->is_cornerstone_preview() ) {
4323
+			} elseif ($this->is_cornerstone_preview()) {
4324 4324
 				$preview = true;
4325
-			} elseif ( $this->is_fusion_preview() ) {
4325
+			} elseif ($this->is_fusion_preview()) {
4326 4326
 				$preview = true;
4327
-			} elseif ( $this->is_oxygen_preview() ) {
4327
+			} elseif ($this->is_oxygen_preview()) {
4328 4328
 				$preview = true;
4329
-			} elseif( $this->is_kallyas_zion_preview() ) {
4329
+			} elseif ($this->is_kallyas_zion_preview()) {
4330 4330
 				$preview = true;
4331
-			} elseif( $this->is_block_content_call() ) {
4331
+			} elseif ($this->is_block_content_call()) {
4332 4332
 				$preview = true;
4333
-			} elseif( $this->is_bricks_preview() ) {
4333
+			} elseif ($this->is_bricks_preview()) {
4334 4334
 				$preview = true;
4335 4335
 			}
4336 4336
 
@@ -4345,34 +4345,34 @@  discard block
 block discarded – undo
4345 4345
 		 *
4346 4346
 		 * @return string
4347 4347
 		 */
4348
-		public function output_title( $args, $instance = array() ) {
4348
+		public function output_title($args, $instance = array()) {
4349 4349
 			$output = '';
4350
-			if ( ! empty( $instance['title'] ) ) {
4350
+			if (!empty($instance['title'])) {
4351 4351
 				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4352
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4352
+				$title = apply_filters('widget_title', $instance['title'], $instance, $this->id_base);
4353 4353
 
4354
-				if(empty($instance['widget_title_tag'])){
4354
+				if (empty($instance['widget_title_tag'])) {
4355 4355
 					$output = $args['before_title'] . $title . $args['after_title'];
4356
-				}else{
4357
-					$title_tag = esc_attr( $instance['widget_title_tag'] );
4356
+				} else {
4357
+					$title_tag = esc_attr($instance['widget_title_tag']);
4358 4358
 
4359 4359
 					// classes
4360 4360
 					$title_classes = array();
4361
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4362
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4363
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4364
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4365
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4366
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4367
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4368
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4369
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4370
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4371
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4372
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4373
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4374
-
4375
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4361
+					$title_classes[] = !empty($instance['widget_title_size_class']) ? sanitize_html_class($instance['widget_title_size_class']) : '';
4362
+					$title_classes[] = !empty($instance['widget_title_align_class']) ? sanitize_html_class($instance['widget_title_align_class']) : '';
4363
+					$title_classes[] = !empty($instance['widget_title_color_class']) ? "text-" . sanitize_html_class($instance['widget_title_color_class']) : '';
4364
+					$title_classes[] = !empty($instance['widget_title_border_class']) ? sanitize_html_class($instance['widget_title_border_class']) : '';
4365
+					$title_classes[] = !empty($instance['widget_title_border_color_class']) ? "border-" . sanitize_html_class($instance['widget_title_border_color_class']) : '';
4366
+					$title_classes[] = !empty($instance['widget_title_mt_class']) ? "mt-" . absint($instance['widget_title_mt_class']) : '';
4367
+					$title_classes[] = !empty($instance['widget_title_mr_class']) ? "mr-" . absint($instance['widget_title_mr_class']) : '';
4368
+					$title_classes[] = !empty($instance['widget_title_mb_class']) ? "mb-" . absint($instance['widget_title_mb_class']) : '';
4369
+					$title_classes[] = !empty($instance['widget_title_ml_class']) ? "ml-" . absint($instance['widget_title_ml_class']) : '';
4370
+					$title_classes[] = !empty($instance['widget_title_pt_class']) ? "pt-" . absint($instance['widget_title_pt_class']) : '';
4371
+					$title_classes[] = !empty($instance['widget_title_pr_class']) ? "pr-" . absint($instance['widget_title_pr_class']) : '';
4372
+					$title_classes[] = !empty($instance['widget_title_pb_class']) ? "pb-" . absint($instance['widget_title_pb_class']) : '';
4373
+					$title_classes[] = !empty($instance['widget_title_pl_class']) ? "pl-" . absint($instance['widget_title_pl_class']) : '';
4374
+
4375
+					$class = !empty($title_classes) ? implode(" ", $title_classes) : '';
4376 4376
 					$output = "<$title_tag class='$class' >$title</$title_tag>";
4377 4377
 				}
4378 4378
 
@@ -4386,7 +4386,7 @@  discard block
 block discarded – undo
4386 4386
 		 *
4387 4387
 		 * @param array $instance The widget options.
4388 4388
 		 */
4389
-		public function form( $instance ) {
4389
+		public function form($instance) {
4390 4390
 
4391 4391
 			// set widget instance
4392 4392
 			$this->instance = $instance;
@@ -4394,20 +4394,20 @@  discard block
 block discarded – undo
4394 4394
 			// set it as a SD widget
4395 4395
 			echo $this->widget_advanced_toggle();
4396 4396
 
4397
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4397
+			echo "<p>" . esc_attr($this->options['widget_ops']['description']) . "</p>";
4398 4398
 			$arguments_raw = $this->get_arguments();
4399 4399
 
4400
-			if ( is_array( $arguments_raw ) ) {
4400
+			if (is_array($arguments_raw)) {
4401 4401
 
4402
-				$arguments = $this->group_arguments( $arguments_raw );
4402
+				$arguments = $this->group_arguments($arguments_raw);
4403 4403
 
4404 4404
 				// Do we have sections?
4405 4405
 				$has_sections = $arguments == $arguments_raw ? false : true;
4406 4406
 
4407 4407
 
4408
-				if ( $has_sections ) {
4408
+				if ($has_sections) {
4409 4409
 					$panel_count = 0;
4410
-					foreach ( $arguments as $key => $args ) {
4410
+					foreach ($arguments as $key => $args) {
4411 4411
 
4412 4412
 						?>
4413 4413
 						<script>
@@ -4417,26 +4417,26 @@  discard block
 block discarded – undo
4417 4417
 
4418 4418
 						$hide       = $panel_count ? ' style="display:none;" ' : '';
4419 4419
 						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4420
-						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>";
4421
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4420
+						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>";
4421
+						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes($key) . "' $hide>";
4422 4422
 
4423
-						foreach ( $args as $k => $a ) {
4423
+						foreach ($args as $k => $a) {
4424 4424
 
4425 4425
 							$this->widget_inputs_row_start($k, $a);
4426
-							$this->widget_inputs( $a, $instance );
4426
+							$this->widget_inputs($a, $instance);
4427 4427
 							$this->widget_inputs_row_end($k, $a);
4428 4428
 
4429 4429
 						}
4430 4430
 
4431 4431
 						echo "</div>";
4432 4432
 
4433
-						$panel_count ++;
4433
+						$panel_count++;
4434 4434
 
4435 4435
 					}
4436 4436
 				} else {
4437
-					foreach ( $arguments as $key => $args ) {
4437
+					foreach ($arguments as $key => $args) {
4438 4438
 						$this->widget_inputs_row_start($key, $args);
4439
-						$this->widget_inputs( $args, $instance );
4439
+						$this->widget_inputs($args, $instance);
4440 4440
 						$this->widget_inputs_row_end($key, $args);
4441 4441
 					}
4442 4442
 				}
@@ -4444,28 +4444,28 @@  discard block
 block discarded – undo
4444 4444
 			}
4445 4445
 		}
4446 4446
 
4447
-		public function widget_inputs_row_start( $key, $args ) {
4448
-			if ( ! empty( $args['row'] ) ) {
4447
+		public function widget_inputs_row_start($key, $args) {
4448
+			if (!empty($args['row'])) {
4449 4449
 				// Maybe open
4450
-				if ( ! empty( $args['row']['open'] ) ) {
4450
+				if (!empty($args['row']['open'])) {
4451 4451
 					?>
4452
-					<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'] ) : '' ); ?>'>
4453
-					<?php if ( ! empty( $args['row']['title'] ) ) { ?>
4452
+					<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']) : ''); ?>'>
4453
+					<?php if (!empty($args['row']['title'])) { ?>
4454 4454
 					<?php 
4455
-						if ( isset( $args['row']['icon'] ) ) {
4455
+						if (isset($args['row']['icon'])) {
4456 4456
 							$args['row']['icon'] = '';
4457 4457
 						}
4458 4458
 
4459
-						if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4459
+						if (!isset($args['row']['device_type']) && isset($args['device_type'])) {
4460 4460
 							$args['row']['device_type'] = $args['device_type'];
4461 4461
 						}
4462 4462
 					?>
4463
-					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4463
+					<label class="mb-0"><?php echo $this->widget_field_title($args['row']); ?><?php echo $this->widget_field_desc($args['row']); ?></label>
4464 4464
 					<?php } ?>
4465
-					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4465
+					<div class='row<?php echo (!empty($args['row']['class']) ? ' ' . esc_attr($args['row']['class']) : ''); ?>'>
4466 4466
 					<div class='col pr-2'>
4467 4467
 					<?php
4468
-				} else if ( ! empty( $args['row']['close'] ) ) {
4468
+				} else if (!empty($args['row']['close'])) {
4469 4469
 					echo "<div class='col pl-0 ps-0'>";
4470 4470
 				} else {
4471 4471
 					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
@@ -4473,10 +4473,10 @@  discard block
 block discarded – undo
4473 4473
 			}
4474 4474
 		}
4475 4475
 
4476
-		public function widget_inputs_row_end( $key, $args ) {
4477
-			if ( ! empty( $args['row'] ) ) {
4476
+		public function widget_inputs_row_end($key, $args) {
4477
+			if (!empty($args['row'])) {
4478 4478
 				// Maybe close
4479
-				if ( ! empty( $args['row']['close'] ) ) {
4479
+				if (!empty($args['row']['close'])) {
4480 4480
 					echo "</div></div>";
4481 4481
 				}
4482 4482
 				echo "</div>";
@@ -4491,7 +4491,7 @@  discard block
 block discarded – undo
4491 4491
 		public function widget_advanced_toggle() {
4492 4492
 
4493 4493
 			$output = '';
4494
-			if ( $this->block_show_advanced() ) {
4494
+			if ($this->block_show_advanced()) {
4495 4495
 				$val = 1;
4496 4496
 			} else {
4497 4497
 				$val = 0;
@@ -4511,14 +4511,14 @@  discard block
 block discarded – undo
4511 4511
 		 *@since 1.0.0
4512 4512
 		 *
4513 4513
 		 */
4514
-		public function convert_element_require( $input ) {
4515
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4514
+		public function convert_element_require($input) {
4515
+			$input = str_replace("'", '"', $input); // we only want double quotes
4516 4516
 
4517
-			$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4517
+			$output = esc_attr(str_replace(array("[%", "%]", "%:checked]"), array(
4518 4518
 				"jQuery(form).find('[data-argument=\"",
4519 4519
 				"\"]').find('input,select,textarea').val()",
4520 4520
 				"\"]').find('input:checked').val()"
4521
-			), $input ) );
4521
+			), $input));
4522 4522
 
4523 4523
 			return $output;
4524 4524
 		}
@@ -4529,48 +4529,48 @@  discard block
 block discarded – undo
4529 4529
 		 * @param $args
4530 4530
 		 * @param $instance
4531 4531
 		 */
4532
-		public function widget_inputs( $args, $instance ) {
4532
+		public function widget_inputs($args, $instance) {
4533 4533
 
4534 4534
 			$class             = "";
4535 4535
 			$element_require   = "";
4536 4536
 			$custom_attributes = "";
4537 4537
 
4538 4538
 			// get value
4539
-			if ( isset( $instance[ $args['name'] ] ) ) {
4540
-				$value = $instance[ $args['name'] ];
4541
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4542
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4539
+			if (isset($instance[$args['name']])) {
4540
+				$value = $instance[$args['name']];
4541
+			} elseif (!isset($instance[$args['name']]) && !empty($args['default'])) {
4542
+				$value = is_array($args['default']) ? array_map("esc_html", $args['default']) : esc_html($args['default']);
4543 4543
 			} else {
4544 4544
 				$value = '';
4545 4545
 			}
4546 4546
 
4547 4547
 			// get placeholder
4548
-			if ( ! empty( $args['placeholder'] ) ) {
4549
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4548
+			if (!empty($args['placeholder'])) {
4549
+				$placeholder = "placeholder='" . esc_html($args['placeholder']) . "'";
4550 4550
 			} else {
4551 4551
 				$placeholder = '';
4552 4552
 			}
4553 4553
 
4554 4554
 			// get if advanced
4555
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4555
+			if (isset($args['advanced']) && $args['advanced']) {
4556 4556
 				$class .= " sd-advanced-setting ";
4557 4557
 			}
4558 4558
 
4559 4559
 			// element_require
4560
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4560
+			if (isset($args['element_require']) && $args['element_require']) {
4561 4561
 				$element_require = $args['element_require'];
4562 4562
 			}
4563 4563
 
4564 4564
 			// custom_attributes
4565
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4566
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4565
+			if (isset($args['custom_attributes']) && $args['custom_attributes']) {
4566
+				$custom_attributes = $this->array_to_attributes($args['custom_attributes'], true);
4567 4567
 			}
4568 4568
 
4569 4569
 			// before wrapper
4570 4570
 			?>
4571
-			<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 );} ?>'>
4571
+			<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); } ?>'>
4572 4572
 			<?php
4573
-			switch ( $args['type'] ) {
4573
+			switch ($args['type']) {
4574 4574
 				//array('text','password','number','email','tel','url','color')
4575 4575
 				case "text":
4576 4576
 				case "password":
@@ -4580,33 +4580,33 @@  discard block
 block discarded – undo
4580 4580
 				case "url":
4581 4581
 				case "color":
4582 4582
 					?>
4583
-					<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>
4584
-					<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 ); ?>">
4583
+					<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>
4584
+					<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); ?>">
4585 4585
 					<?php
4586 4586
 
4587 4587
 					break;
4588 4588
 				case "select":
4589
-					$multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false;
4590
-					if ( $multiple ) {
4591
-						if ( empty( $value ) ) {
4589
+					$multiple = isset($args['multiple']) && $args['multiple'] ? true : false;
4590
+					if ($multiple) {
4591
+						if (empty($value)) {
4592 4592
 							$value = array();
4593 4593
 						}
4594 4594
 					}
4595 4595
 					?>
4596
-					<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>
4597
-					<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 "[]"; } ?>"
4598
-						<?php if ( $multiple ) {
4596
+					<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>
4597
+					<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 "[]"; } ?>"
4598
+						<?php if ($multiple) {
4599 4599
 							echo "multiple";
4600 4600
 						} //@todo not implemented yet due to gutenberg not supporting it
4601 4601
 						?>>
4602 4602
 						<?php
4603 4603
 
4604
-						if ( ! empty( $args['options'] ) ) {
4605
-							foreach ( $args['options'] as $val => $label ) {
4606
-								if ( $multiple ) {
4607
-									$selected = in_array( $val, $value ) ? 'selected="selected"' : '';
4604
+						if (!empty($args['options'])) {
4605
+							foreach ($args['options'] as $val => $label) {
4606
+								if ($multiple) {
4607
+									$selected = in_array($val, $value) ? 'selected="selected"' : '';
4608 4608
 								} else {
4609
-									$selected = selected( $value, $val, false );
4609
+									$selected = selected($value, $val, false);
4610 4610
 								}
4611 4611
 								echo "<option value='$val' " . $selected . ">$label</option>";
4612 4612
 							}
@@ -4617,20 +4617,20 @@  discard block
 block discarded – undo
4617 4617
 					break;
4618 4618
 				case "checkbox":
4619 4619
 					?>
4620
-					<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">
4621
-					<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>
4620
+					<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">
4621
+					<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>
4622 4622
 					<?php
4623 4623
 					break;
4624 4624
 				case "textarea":
4625 4625
 					?>
4626
-					<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>
4627
-					<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>
4626
+					<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>
4627
+					<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>
4628 4628
 					<?php
4629 4629
 
4630 4630
 					break;
4631 4631
 				case "hidden":
4632 4632
 					?>
4633
-					<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 ); ?>">
4633
+					<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); ?>">
4634 4634
 					<?php
4635 4635
 					break;
4636 4636
 				default:
@@ -4640,15 +4640,15 @@  discard block
 block discarded – undo
4640 4640
 			?></p><?php
4641 4641
 		}
4642 4642
 
4643
-		public function get_widget_icon($icon = 'box-top', $title = ''){
4644
-			if($icon=='box-top'){
4645
-				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>';
4646
-			}elseif($icon=='box-right'){
4647
-				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>';
4648
-			}elseif($icon=='box-bottom'){
4649
-				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>';
4650
-			}elseif($icon=='box-left'){
4651
-				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>';
4643
+		public function get_widget_icon($icon = 'box-top', $title = '') {
4644
+			if ($icon == 'box-top') {
4645
+				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>';
4646
+			}elseif ($icon == 'box-right') {
4647
+				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>';
4648
+			}elseif ($icon == 'box-bottom') {
4649
+				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>';
4650
+			}elseif ($icon == 'box-left') {
4651
+				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>';
4652 4652
 			}
4653 4653
 		}
4654 4654
 
@@ -4660,14 +4660,14 @@  discard block
 block discarded – undo
4660 4660
 		 * @return string
4661 4661
 		 * @todo, need to make its own tooltip script
4662 4662
 		 */
4663
-		public function widget_field_desc( $args ) {
4663
+		public function widget_field_desc($args) {
4664 4664
 
4665 4665
 			$description = '';
4666
-			if ( isset( $args['desc'] ) && $args['desc'] ) {
4667
-				if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) {
4668
-					$description = $this->desc_tip( $args['desc'] );
4666
+			if (isset($args['desc']) && $args['desc']) {
4667
+				if (isset($args['desc_tip']) && $args['desc_tip']) {
4668
+					$description = $this->desc_tip($args['desc']);
4669 4669
 				} else {
4670
-					$description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>';
4670
+					$description = '<span class="description">' . wp_kses_post($args['desc']) . '</span>';
4671 4671
 				}
4672 4672
 			}
4673 4673
 
@@ -4681,18 +4681,18 @@  discard block
 block discarded – undo
4681 4681
 		 *
4682 4682
 		 * @return string
4683 4683
 		 */
4684
-		public function widget_field_title( $args ) {
4684
+		public function widget_field_title($args) {
4685 4685
 			$title = '';
4686 4686
 
4687
-			if ( isset( $args['title'] ) && $args['title'] ) {
4688
-				if ( ! empty( $args['device_type'] ) ) {
4687
+			if (isset($args['title']) && $args['title']) {
4688
+				if (!empty($args['device_type'])) {
4689 4689
 					$args['title'] .= ' (' . $args['device_type'] . ')'; // Append device type to title.
4690 4690
 				}
4691 4691
 
4692
-				if ( isset( $args['icon'] ) && $args['icon'] ) {
4693
-					$title = self::get_widget_icon( $args['icon'], $args['title']  );
4692
+				if (isset($args['icon']) && $args['icon']) {
4693
+					$title = self::get_widget_icon($args['icon'], $args['title']);
4694 4694
 				} else {
4695
-					$title = esc_attr( $args['title'] );
4695
+					$title = esc_attr($args['title']);
4696 4696
 				}
4697 4697
 			}
4698 4698
 
@@ -4707,11 +4707,11 @@  discard block
 block discarded – undo
4707 4707
 		 *
4708 4708
 		 * @return string
4709 4709
 		 */
4710
-		function desc_tip( $tip, $allow_html = false ) {
4711
-			if ( $allow_html ) {
4712
-				$tip = $this->sanitize_tooltip( $tip );
4710
+		function desc_tip($tip, $allow_html = false) {
4711
+			if ($allow_html) {
4712
+				$tip = $this->sanitize_tooltip($tip);
4713 4713
 			} else {
4714
-				$tip = esc_attr( $tip );
4714
+				$tip = esc_attr($tip);
4715 4715
 			}
4716 4716
 
4717 4717
 			return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>';
@@ -4724,8 +4724,8 @@  discard block
 block discarded – undo
4724 4724
 		 *
4725 4725
 		 * @return string
4726 4726
 		 */
4727
-		public function sanitize_tooltip( $var ) {
4728
-			return htmlspecialchars( wp_kses( html_entity_decode( $var ), array(
4727
+		public function sanitize_tooltip($var) {
4728
+			return htmlspecialchars(wp_kses(html_entity_decode($var), array(
4729 4729
 				'br'     => array(),
4730 4730
 				'em'     => array(),
4731 4731
 				'strong' => array(),
@@ -4735,7 +4735,7 @@  discard block
 block discarded – undo
4735 4735
 				'li'     => array(),
4736 4736
 				'ol'     => array(),
4737 4737
 				'p'      => array(),
4738
-			) ) );
4738
+			)));
4739 4739
 		}
4740 4740
 
4741 4741
 		/**
@@ -4747,23 +4747,23 @@  discard block
 block discarded – undo
4747 4747
 		 * @return array
4748 4748
 		 * @todo we should add some sanitation here.
4749 4749
 		 */
4750
-		public function update( $new_instance, $old_instance ) {
4750
+		public function update($new_instance, $old_instance) {
4751 4751
 
4752 4752
 			//save the widget
4753
-			$instance = array_merge( (array) $old_instance, (array) $new_instance );
4753
+			$instance = array_merge((array) $old_instance, (array) $new_instance);
4754 4754
 
4755 4755
 			// set widget instance
4756 4756
 			$this->instance = $instance;
4757 4757
 
4758
-			if ( empty( $this->arguments ) ) {
4758
+			if (empty($this->arguments)) {
4759 4759
 				$this->get_arguments();
4760 4760
 			}
4761 4761
 
4762 4762
 			// check for checkboxes
4763
-			if ( ! empty( $this->arguments ) ) {
4764
-				foreach ( $this->arguments as $argument ) {
4765
-					if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) {
4766
-						$instance[ $argument['name'] ] = '0';
4763
+			if (!empty($this->arguments)) {
4764
+				foreach ($this->arguments as $argument) {
4765
+					if (isset($argument['type']) && $argument['type'] == 'checkbox' && !isset($new_instance[$argument['name']])) {
4766
+						$instance[$argument['name']] = '0';
4767 4767
 					}
4768 4768
 				}
4769 4769
 			}
@@ -4781,7 +4781,7 @@  discard block
 block discarded – undo
4781 4781
 		 */
4782 4782
 		public function is_block_content_call() {
4783 4783
 			$result = false;
4784
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
4784
+			if (wp_doing_ajax() && isset($_REQUEST['action']) && $_REQUEST['action'] == 'super_duper_output_shortcode') {
4785 4785
 				$result = true;
4786 4786
 			}
4787 4787
 
@@ -4794,9 +4794,9 @@  discard block
 block discarded – undo
4794 4794
 		 * @return string
4795 4795
 		 *@since 1.0.20
4796 4796
 		 */
4797
-		public function get_instance_hash(){
4798
-			$instance_string = $this->base_id.serialize($this->instance);
4799
-			return hash('crc32b',$instance_string);
4797
+		public function get_instance_hash() {
4798
+			$instance_string = $this->base_id . serialize($this->instance);
4799
+			return hash('crc32b', $instance_string);
4800 4800
 		}
4801 4801
 
4802 4802
 		/**
@@ -4807,14 +4807,14 @@  discard block
 block discarded – undo
4807 4807
 		 * @return string
4808 4808
 		 *@since 1.0.20
4809 4809
 		 */
4810
-		public function get_instance_style($rules = array()){
4810
+		public function get_instance_style($rules = array()) {
4811 4811
 			$css = '';
4812 4812
 
4813
-			if(!empty($rules)){
4813
+			if (!empty($rules)) {
4814 4814
 				$rules = array_unique($rules);
4815 4815
 				$instance_hash = $this->get_instance_hash();
4816 4816
 				$css .= "<style>";
4817
-				foreach($rules as $rule){
4817
+				foreach ($rules as $rule) {
4818 4818
 					$css .= ".sdel-$instance_hash $rule";
4819 4819
 				}
4820 4820
 				$css .= "</style>";
@@ -4832,9 +4832,9 @@  discard block
 block discarded – undo
4832 4832
 		 *@since 1.0.28
4833 4833
 		 *
4834 4834
 		 */
4835
-		public function encode_shortcodes( $content ) {
4835
+		public function encode_shortcodes($content) {
4836 4836
 			// Avoids existing encoded tags.
4837
-			$trans   = array(
4837
+			$trans = array(
4838 4838
 				'&#91;' => '&#091;',
4839 4839
 				'&#93;' => '&#093;',
4840 4840
 				'&amp;#91;' => '&#091;',
@@ -4845,7 +4845,7 @@  discard block
 block discarded – undo
4845 4845
 				'&amp;gt;' => '&0gt;',
4846 4846
 			);
4847 4847
 
4848
-			$content = strtr( $content, $trans );
4848
+			$content = strtr($content, $trans);
4849 4849
 
4850 4850
 			$trans   = array(
4851 4851
 				'[' => '&#91;',
@@ -4856,7 +4856,7 @@  discard block
 block discarded – undo
4856 4856
 				"'" => '&#39;',
4857 4857
 			);
4858 4858
 
4859
-			$content = strtr( $content, $trans );
4859
+			$content = strtr($content, $trans);
4860 4860
 
4861 4861
 			return $content;
4862 4862
 		}
@@ -4870,8 +4870,8 @@  discard block
 block discarded – undo
4870 4870
 		 *@since 1.0.28
4871 4871
 		 *
4872 4872
 		 */
4873
-		public function decode_shortcodes( $content ) {
4874
-			$trans   = array(
4873
+		public function decode_shortcodes($content) {
4874
+			$trans = array(
4875 4875
 				'&#91;' => '[',
4876 4876
 				'&#93;' => ']',
4877 4877
 				'&amp;#91;' => '[',
@@ -4884,7 +4884,7 @@  discard block
 block discarded – undo
4884 4884
 				'&apos;' => "'",
4885 4885
 			);
4886 4886
 
4887
-			$content = strtr( $content, $trans );
4887
+			$content = strtr($content, $trans);
4888 4888
 
4889 4889
 			$trans   = array(
4890 4890
 				'&#091;' => '&#91;',
@@ -4897,31 +4897,31 @@  discard block
 block discarded – undo
4897 4897
 				'&amp;0gt;' => '&gt;',
4898 4898
 			);
4899 4899
 
4900
-			$content = strtr( $content, $trans );
4900
+			$content = strtr($content, $trans);
4901 4901
 
4902 4902
 			return $content;
4903 4903
 		}
4904 4904
 
4905
-		public function block_visibility_fields( $args ) {
4906
-			$value = ! empty( $args['value'] ) ? esc_attr( $args['value'] ) : '';
4905
+		public function block_visibility_fields($args) {
4906
+			$value = !empty($args['value']) ? esc_attr($args['value']) : '';
4907 4907
 			$content = '<div class="bs-vc-rule-template d-none">';
4908 4908
 				$content .= '<div class="p-3 pb-0 mb-3 border border-1 rounded-1 position-relative bs-vc-rule" data-bs-index="BSVCINDEX" >';
4909 4909
 					$content .= '<div class="row">';
4910 4910
 						$content .= '<div class="col-sm-12">';
4911
-							$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>';
4911
+							$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>';
4912 4912
 							$content .= aui()->select(
4913 4913
 								array(
4914 4914
 									'id'          => 'bsvc_rule_BSVCINDEX',
4915 4915
 									'name'        => 'bsvc_rule_BSVCINDEX',
4916
-									'label'       => __( 'Rule', 'ayecode-connect' ),
4917
-									'placeholder' => __( 'Select Rule...', 'ayecode-connect' ),
4916
+									'label'       => __('Rule', 'ayecode-connect'),
4917
+									'placeholder' => __('Select Rule...', 'ayecode-connect'),
4918 4918
 									'class'       => 'bsvc_rule form-select-sm no-select2',
4919 4919
 									'options'     => sd_visibility_rules_options(),
4920 4920
 									'default'     => '',
4921 4921
 									'value'       => '',
4922 4922
 									'label_type'  => '',
4923 4923
 									'select2'     => false,
4924
-									'input_group_left' => __( 'Rule:', 'ayecode-connect' ),
4924
+									'input_group_left' => __('Rule:', 'ayecode-connect'),
4925 4925
 									'extra_attributes' => array(
4926 4926
 										'data-minimum-results-for-search' => '-1'
4927 4927
 									)
@@ -4930,15 +4930,15 @@  discard block
 block discarded – undo
4930 4930
 
4931 4931
 						$content .= '</div>';
4932 4932
 
4933
-						if ( class_exists( 'GeoDirectory' ) ) {
4933
+						if (class_exists('GeoDirectory')) {
4934 4934
 							$content .= '<div class="col-md-7 col-sm-12">';
4935 4935
 
4936 4936
 								$content .= aui()->select(
4937 4937
 									array(
4938 4938
 										'id'          => 'bsvc_gd_field_BSVCINDEX',
4939 4939
 										'name'        => 'bsvc_gd_field_BSVCINDEX',
4940
-										'label'       => __( 'FIELD', 'ayecode-connect' ),
4941
-										'placeholder' => __( 'FIELD', 'ayecode-connect' ),
4940
+										'label'       => __('FIELD', 'ayecode-connect'),
4941
+										'placeholder' => __('FIELD', 'ayecode-connect'),
4942 4942
 										'class'       => 'bsvc_gd_field form-select-sm no-select2',
4943 4943
 										'options'     => sd_visibility_gd_field_options(),
4944 4944
 										'default'     => '',
@@ -4959,8 +4959,8 @@  discard block
 block discarded – undo
4959 4959
 									array(
4960 4960
 										'id'          => 'bsvc_gd_field_condition_BSVCINDEX',
4961 4961
 										'name'        => 'bsvc_gd_field_condition_BSVCINDEX',
4962
-										'label'       => __( 'CONDITION', 'ayecode-connect' ),
4963
-										'placeholder' => __( 'CONDITION', 'ayecode-connect' ),
4962
+										'label'       => __('CONDITION', 'ayecode-connect'),
4963
+										'placeholder' => __('CONDITION', 'ayecode-connect'),
4964 4964
 										'class'       => 'bsvc_gd_field_condition form-select-sm no-select2',
4965 4965
 										'options'     => sd_visibility_field_condition_options(),
4966 4966
 										'default'     => '',
@@ -4982,9 +4982,9 @@  discard block
 block discarded – undo
4982 4982
 										'type'            => 'text',
4983 4983
 										'id'              => 'bsvc_gd_field_search_BSVCINDEX',
4984 4984
 										'name'            => 'bsvc_gd_field_search_BSVCINDEX',
4985
-										'label'           => __( 'VALUE TO MATCH', 'ayecode-connect' ),
4985
+										'label'           => __('VALUE TO MATCH', 'ayecode-connect'),
4986 4986
 										'class'           => 'bsvc_gd_field_search form-control-sm',
4987
-										'placeholder'     => __( 'VALUE TO MATCH', 'ayecode-connect' ),
4987
+										'placeholder'     => __('VALUE TO MATCH', 'ayecode-connect'),
4988 4988
 										'label_type'      => '',
4989 4989
 										'value'           => '',
4990 4990
 										'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")'
@@ -4996,11 +4996,11 @@  discard block
 block discarded – undo
4996 4996
 
4997 4997
 					$content .= '</div>';
4998 4998
 
4999
-					$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>';
4999
+					$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>';
5000 5000
 						$role_options = sd_user_roles_options();
5001 5001
 
5002 5002
 						$role_option_i = 0;
5003
-						foreach ( $role_options as $role_option_key => $role_option_name ) {
5003
+						foreach ($role_options as $role_option_key => $role_option_name) {
5004 5004
 							$role_option_i++;
5005 5005
 
5006 5006
 							$content .= '<div class="col-sm-6">';
@@ -5024,14 +5024,14 @@  discard block
 block discarded – undo
5024 5024
 			$content .= '</div>';
5025 5025
 			$content .= '<form id="bs-vc-modal-form" class="bs-vc-modal-form">';
5026 5026
 			$content .= '<div class="bs-vc-rule-sets"></div>';
5027
-			$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>';
5027
+			$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>';
5028 5028
 			$content .= '<div class="row"><div class="col-md-6 col-sm-12">';
5029 5029
 			$content .= aui()->select(
5030 5030
 				array(
5031 5031
 					'id'          => 'bsvc_output',
5032 5032
 					'name'        => 'bsvc_output',
5033
-					'label'       => __( 'What should happen if rules met.', 'ayecode-connect' ),
5034
-					'placeholder' => __( 'Default Output', 'ayecode-connect' ),
5033
+					'label'       => __('What should happen if rules met.', 'ayecode-connect'),
5034
+					'placeholder' => __('Default Output', 'ayecode-connect'),
5035 5035
 					'class'       => 'bsvc_output form-select-sm no-select2',
5036 5036
 					'options'     => sd_visibility_output_options(),
5037 5037
 					'default'     => '',
@@ -5050,8 +5050,8 @@  discard block
 block discarded – undo
5050 5050
 				array(
5051 5051
 					'id'              => 'bsvc_page',
5052 5052
 					'name'            => 'bsvc_page',
5053
-					'label'           => __( 'Page Content', 'ayecode-connect' ),
5054
-					'placeholder'     => __( 'Select Page ID...', 'ayecode-connect' ),
5053
+					'label'           => __('Page Content', 'ayecode-connect'),
5054
+					'placeholder'     => __('Select Page ID...', 'ayecode-connect'),
5055 5055
 					'class'           => 'bsvc_page form-select-sm no-select2',
5056 5056
 					'options'         => sd_template_page_options(),
5057 5057
 					'default'         => '',
@@ -5066,8 +5066,8 @@  discard block
 block discarded – undo
5066 5066
 				array(
5067 5067
 					'id'          => 'bsvc_tmpl_part',
5068 5068
 					'name'        => 'bsvc_tmpl_part',
5069
-					'label'       => __( 'Template Part', 'ayecode-connect' ),
5070
-					'placeholder' => __( 'Select Template Part...', 'ayecode-connect' ),
5069
+					'label'       => __('Template Part', 'ayecode-connect'),
5070
+					'placeholder' => __('Select Template Part...', 'ayecode-connect'),
5071 5071
 					'class'       => 'bsvc_tmpl_part form-select-sm no-select2',
5072 5072
 					'options'     => sd_template_part_options(),
5073 5073
 					'default'     => '',
@@ -5085,8 +5085,8 @@  discard block
 block discarded – undo
5085 5085
 				array(
5086 5086
 					'id'               => 'bsvc_message_type',
5087 5087
 					'name'             => 'bsvc_message_type',
5088
-					'label'            => __( 'Custom Message Type', 'ayecode-connect' ),
5089
-					'placeholder'      => __( 'Default (none)', 'ayecode-connect' ),
5088
+					'label'            => __('Custom Message Type', 'ayecode-connect'),
5089
+					'placeholder'      => __('Default (none)', 'ayecode-connect'),
5090 5090
 					'class'            => 'bsvc_message_type form-select-sm no-select2',
5091 5091
 					'options'          => sd_aui_colors(),
5092 5092
 					'default'          => '',
@@ -5109,7 +5109,7 @@  discard block
 block discarded – undo
5109 5109
 					'name'            => 'bsvc_message',
5110 5110
 					'label'           => '',
5111 5111
 					'class'           => 'bsvc_message form-control-sm',
5112
-					'placeholder'     => __( 'CUSTOM MESSAGE TO SHOW', 'ayecode-connect' ),
5112
+					'placeholder'     => __('CUSTOM MESSAGE TO SHOW', 'ayecode-connect'),
5113 5113
 					'label_type'      => '',
5114 5114
 					'value'           => '',
5115 5115
 					'form_group_class' => ' ',
Please login to merge, or discard this patch.
includes/api/class-getpaid-rest-date-based-controller.php 2 patches
Spacing   +84 added lines, -84 removed lines patch added patch discarded remove patch
@@ -7,7 +7,7 @@  discard block
 block discarded – undo
7 7
  * @since   2.0.0
8 8
  */
9 9
 
10
-defined( 'ABSPATH' ) || exit;
10
+defined('ABSPATH') || exit;
11 11
 
12 12
 /**
13 13
  * GetPaid REST date based controller class.
@@ -43,26 +43,26 @@  discard block
 block discarded – undo
43 43
 	 * @param WP_REST_Request $request Request object.
44 44
 	 * @return array The appropriate date range.
45 45
 	 */
46
-	public function get_date_range( $request ) {
46
+	public function get_date_range($request) {
47 47
 
48 48
 		// Check if the period is x_days.
49
-		if ( preg_match( '/^(\d+)_days$/', $request['period'], $matches ) ) {
50
-			$date_range = $this->get_x_days_date_range( absint( $matches[1] ) );
51
-		} elseif ( is_callable( array( $this, 'get_' . $request['period'] . '_date_range' ) ) ) {
52
-			$date_range = call_user_func( array( $this, 'get_' . $request['period'] . '_date_range' ), $request );
49
+		if (preg_match('/^(\d+)_days$/', $request['period'], $matches)) {
50
+			$date_range = $this->get_x_days_date_range(absint($matches[1]));
51
+		} elseif (is_callable(array($this, 'get_' . $request['period'] . '_date_range'))) {
52
+			$date_range = call_user_func(array($this, 'get_' . $request['period'] . '_date_range'), $request);
53 53
 		} else {
54 54
 			$request['period'] = '7_days';
55 55
 			$date_range        = $this->get_x_days_date_range();
56 56
 		}
57 57
 
58 58
 		// 3 months max for day view.
59
-		$before = strtotime( $date_range['before'] );
60
-		$after  = strtotime( $date_range['after'] );
61
-		if ( floor( ( $before - $after ) / MONTH_IN_SECONDS ) > 2 ) {
59
+		$before = strtotime($date_range['before']);
60
+		$after  = strtotime($date_range['after']);
61
+		if (floor(($before - $after) / MONTH_IN_SECONDS) > 2) {
62 62
 			$this->groupby = 'month';
63 63
 		}
64 64
 
65
-		$this->prepare_interval( $date_range );
65
+		$this->prepare_interval($date_range);
66 66
 
67 67
 		return $date_range;
68 68
 
@@ -74,25 +74,25 @@  discard block
 block discarded – undo
74 74
 	 * @param array $range Date range.
75 75
 	 * @return array The appropriate date range.
76 76
 	 */
77
-	public function prepare_interval( $range ) {
77
+	public function prepare_interval($range) {
78 78
 
79
-		$before = strtotime( $range['before'] );
80
-		$after  = strtotime( $range['after'] );
81
-		if ( 'day' === $this->groupby ) {
82
-			$difference     = max( DAY_IN_SECONDS, ( DAY_IN_SECONDS + $before - $after ) ); // Prevent division by 0;
83
-			$this->interval = absint( ceil( max( 1, $difference / DAY_IN_SECONDS ) ) );
79
+		$before = strtotime($range['before']);
80
+		$after  = strtotime($range['after']);
81
+		if ('day' === $this->groupby) {
82
+			$difference     = max(DAY_IN_SECONDS, (DAY_IN_SECONDS + $before - $after)); // Prevent division by 0;
83
+			$this->interval = absint(ceil(max(1, $difference / DAY_IN_SECONDS)));
84 84
 			return;
85 85
 		}
86 86
 
87 87
 		$this->interval = 0;
88
-		$min_date       = strtotime( gmdate( 'Y-m-01', $after ) );
88
+		$min_date       = strtotime(gmdate('Y-m-01', $after));
89 89
 
90
-		while ( $min_date <= $before ) {
91
-			$this->interval ++;
92
-			$min_date = strtotime( '+1 MONTH', $min_date );
90
+		while ($min_date <= $before) {
91
+			$this->interval++;
92
+			$min_date = strtotime('+1 MONTH', $min_date);
93 93
 		}
94 94
 
95
-		$this->interval = max( 1, $this->interval );
95
+		$this->interval = max(1, $this->interval);
96 96
 
97 97
 	}
98 98
 
@@ -102,27 +102,27 @@  discard block
 block discarded – undo
102 102
 	 * @param WP_REST_Request $request Request object.
103 103
 	 * @return array The appropriate date range.
104 104
 	 */
105
-	public function get_custom_date_range( $request ) {
105
+	public function get_custom_date_range($request) {
106 106
 
107
-		$after  = max( strtotime( '-20 years' ), strtotime( sanitize_text_field( $request['after'] ) ) );
108
-		$before = gmdate( 'Y-m-d' );
107
+		$after  = max(strtotime('-20 years'), strtotime(sanitize_text_field($request['after'])));
108
+		$before = gmdate('Y-m-d');
109 109
 
110
-		if ( ! empty( $request['before'] ) ) {
111
-			$before  = min( strtotime( $before ), strtotime( sanitize_text_field( $request['before'] ) ) );
110
+		if (!empty($request['before'])) {
111
+			$before = min(strtotime($before), strtotime(sanitize_text_field($request['before'])));
112 112
 		}
113 113
 
114 114
 		// Set the previous date range.
115 115
 		$difference           = $before - $after;
116 116
 		$this->previous_range = array(
117 117
 			'period' => 'custom',
118
-			'before' => gmdate( 'Y-m-d', $before - $difference - DAY_IN_SECONDS ),
119
-			'after'  => gmdate( 'Y-m-d', $after - $difference - DAY_IN_SECONDS ),
118
+			'before' => gmdate('Y-m-d', $before - $difference - DAY_IN_SECONDS),
119
+			'after'  => gmdate('Y-m-d', $after - $difference - DAY_IN_SECONDS),
120 120
 		);
121 121
 
122 122
 		// Generate the report.
123 123
 		return array(
124
-			'before' => gmdate( 'Y-m-d', $before ),
125
-			'after'  => gmdate( 'Y-m-d', $after ),
124
+			'before' => gmdate('Y-m-d', $before),
125
+			'after'  => gmdate('Y-m-d', $after),
126 126
 		);
127 127
 
128 128
 	}
@@ -141,8 +141,8 @@  discard block
 block discarded – undo
141 141
 
142 142
 		// Generate the report.
143 143
 		return array(
144
-			'before' => gmdate( 'Y-m-d' ),
145
-			'after'  => gmdate( 'Y-m-d' ),
144
+			'before' => gmdate('Y-m-d'),
145
+			'after'  => gmdate('Y-m-d'),
146 146
 		);
147 147
 
148 148
 	}
@@ -157,14 +157,14 @@  discard block
 block discarded – undo
157 157
 		// Set the previous date range.
158 158
 		$this->previous_range = array(
159 159
 			'period' => 'custom',
160
-			'before' => gmdate( 'Y-m-d', strtotime( '-2 days' ) ),
161
-			'after'  => gmdate( 'Y-m-d', strtotime( '-2 days' ) ),
160
+			'before' => gmdate('Y-m-d', strtotime('-2 days')),
161
+			'after'  => gmdate('Y-m-d', strtotime('-2 days')),
162 162
 		);
163 163
 
164 164
 		// Generate the report.
165 165
 		return array(
166
-			'before' => gmdate( 'Y-m-d', strtotime( '-1 day' ) ),
167
-			'after'  => gmdate( 'Y-m-d', strtotime( '-1 day' ) ),
166
+			'before' => gmdate('Y-m-d', strtotime('-1 day')),
167
+			'after'  => gmdate('Y-m-d', strtotime('-1 day')),
168 168
 		);
169 169
 
170 170
 	}
@@ -182,10 +182,10 @@  discard block
 block discarded – undo
182 182
 		);
183 183
 
184 184
 		// Generate the report.
185
-		$week_starts = absint( get_option( 'start_of_week' ) );
185
+		$week_starts = absint(get_option('start_of_week'));
186 186
 		return array(
187
-			'before' => gmdate( 'Y-m-d' ),
188
-			'after'  => gmdate( 'Y-m-d', strtotime( 'next Sunday -' . ( 7 - $week_starts ) . ' days' ) ),
187
+			'before' => gmdate('Y-m-d'),
188
+			'after'  => gmdate('Y-m-d', strtotime('next Sunday -' . (7 - $week_starts) . ' days')),
189 189
 		);
190 190
 	}
191 191
 
@@ -196,19 +196,19 @@  discard block
 block discarded – undo
196 196
 	 */
197 197
 	public function get_last_week_date_range() {
198 198
 
199
-		$week_starts = absint( get_option( 'start_of_week' ) );
200
-		$week_starts = strtotime( 'last Sunday -' . ( 7 - $week_starts ) . ' days' );
199
+		$week_starts = absint(get_option('start_of_week'));
200
+		$week_starts = strtotime('last Sunday -' . (7 - $week_starts) . ' days');
201 201
 		$date_range  = array(
202
-			'before' => gmdate( 'Y-m-d', $week_starts + 6 * DAY_IN_SECONDS ),
203
-			'after'  => gmdate( 'Y-m-d', $week_starts ),
202
+			'before' => gmdate('Y-m-d', $week_starts + 6 * DAY_IN_SECONDS),
203
+			'after'  => gmdate('Y-m-d', $week_starts),
204 204
 		);
205 205
 
206 206
 		// Set the previous date range.
207 207
 		$week_starts          = $week_starts - 7 * DAY_IN_SECONDS;
208 208
 		$this->previous_range = array(
209 209
 			'period' => 'custom',
210
-			'before' => gmdate( 'Y-m-d', $week_starts + 6 * DAY_IN_SECONDS ),
211
-			'after'  => gmdate( 'Y-m-d', $week_starts ),
210
+			'before' => gmdate('Y-m-d', $week_starts + 6 * DAY_IN_SECONDS),
211
+			'after'  => gmdate('Y-m-d', $week_starts),
212 212
 		);
213 213
 
214 214
 		// Generate the report.
@@ -220,13 +220,13 @@  discard block
 block discarded – undo
220 220
 	 *
221 221
 	 * @return array The appropriate date range.
222 222
 	 */
223
-	public function get_x_days_date_range( $days = 7 ) {
223
+	public function get_x_days_date_range($days = 7) {
224 224
 
225 225
 		$days--;
226 226
 
227
-		$date_range  = array(
228
-			'before' => gmdate( 'Y-m-d' ),
229
-			'after'  => gmdate( 'Y-m-d', strtotime( "-$days days" ) ),
227
+		$date_range = array(
228
+			'before' => gmdate('Y-m-d'),
229
+			'after'  => gmdate('Y-m-d', strtotime("-$days days")),
230 230
 		);
231 231
 
232 232
 		$days++;
@@ -234,8 +234,8 @@  discard block
 block discarded – undo
234 234
 		// Set the previous date range.
235 235
 		$this->previous_range = array(
236 236
 			'period' => 'custom',
237
-			'before' => gmdate( 'Y-m-d', strtotime( $date_range['before'] ) - $days * DAY_IN_SECONDS ),
238
-			'after'  => gmdate( 'Y-m-d', strtotime( $date_range['after'] ) - $days * DAY_IN_SECONDS ),
237
+			'before' => gmdate('Y-m-d', strtotime($date_range['before']) - $days * DAY_IN_SECONDS),
238
+			'after'  => gmdate('Y-m-d', strtotime($date_range['after']) - $days * DAY_IN_SECONDS),
239 239
 		);
240 240
 
241 241
 		// Generate the report.
@@ -256,8 +256,8 @@  discard block
 block discarded – undo
256 256
 
257 257
 		// Generate the report.
258 258
 		return array(
259
-			'after'  => gmdate( 'Y-m-01' ),
260
-			'before' => gmdate( 'Y-m-t' ),
259
+			'after'  => gmdate('Y-m-01'),
260
+			'before' => gmdate('Y-m-t'),
261 261
 		);
262 262
 
263 263
 	}
@@ -272,14 +272,14 @@  discard block
 block discarded – undo
272 272
 		// Set the previous date range.
273 273
 		$this->previous_range = array(
274 274
 			'period' => 'custom',
275
-			'after'  => gmdate( 'Y-m-01', strtotime( '-2 months' ) ),
276
-			'before' => gmdate( 'Y-m-t', strtotime( '-2 months' ) ),
275
+			'after'  => gmdate('Y-m-01', strtotime('-2 months')),
276
+			'before' => gmdate('Y-m-t', strtotime('-2 months')),
277 277
 		);
278 278
 
279 279
 		// Generate the report.
280 280
 		return array(
281
-			'after'  => gmdate( 'Y-m-01', strtotime( 'last month' ) ),
282
-			'before' => gmdate( 'Y-m-t', strtotime( 'last month' ) ),
281
+			'after'  => gmdate('Y-m-01', strtotime('last month')),
282
+			'before' => gmdate('Y-m-t', strtotime('last month')),
283 283
 		);
284 284
 
285 285
 	}
@@ -291,7 +291,7 @@  discard block
 block discarded – undo
291 291
 	 */
292 292
 	public function get_quarters() {
293 293
 
294
-		$year      = (int) gmdate( 'Y' );
294
+		$year      = (int) gmdate('Y');
295 295
 		$last_year = (int) $year - 1;
296 296
 		return array(
297 297
 
@@ -340,9 +340,9 @@  discard block
 block discarded – undo
340 340
 	 */
341 341
 	public function get_quarter() {
342 342
 
343
-		$month    = (int) gmdate( 'n' );
344
-		$quarters = array( 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4 );
345
-		return $quarters[ $month - 1 ];
343
+		$month    = (int) gmdate('n');
344
+		$quarters = array(1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4);
345
+		return $quarters[$month - 1];
346 346
 
347 347
 	}
348 348
 
@@ -361,7 +361,7 @@  discard block
 block discarded – undo
361 361
 		// Generate the report.
362 362
 		$quarter  = $this->get_quarter();
363 363
 		$quarters = $this->get_quarters();
364
-		return $quarters[ $quarter + 1 ];
364
+		return $quarters[$quarter + 1];
365 365
 
366 366
 	}
367 367
 
@@ -377,12 +377,12 @@  discard block
 block discarded – undo
377 377
 
378 378
 		// Set the previous date range.
379 379
 		$this->previous_range = array_merge(
380
-			$quarters[ $quarter - 1 ],
381
-			array( 'period' => 'custom' )
380
+			$quarters[$quarter - 1],
381
+			array('period' => 'custom')
382 382
 		);
383 383
 
384 384
 		// Generate the report.
385
-		return $quarters[ $quarter ];
385
+		return $quarters[$quarter];
386 386
 
387 387
 	}
388 388
 
@@ -400,8 +400,8 @@  discard block
 block discarded – undo
400 400
 
401 401
 		// Generate the report.
402 402
 		return array(
403
-			'after'  => gmdate( 'Y-01-01' ),
404
-			'before' => gmdate( 'Y-12-31' ),
403
+			'after'  => gmdate('Y-01-01'),
404
+			'before' => gmdate('Y-12-31'),
405 405
 		);
406 406
 
407 407
 	}
@@ -416,14 +416,14 @@  discard block
 block discarded – undo
416 416
 		// Set the previous date range.
417 417
 		$this->previous_range = array(
418 418
 			'period' => 'custom',
419
-			'after'  => gmdate( 'Y-01-01', strtotime( '-2 years' ) ),
420
-			'before' => gmdate( 'Y-12-31', strtotime( '-2 years' ) ),
419
+			'after'  => gmdate('Y-01-01', strtotime('-2 years')),
420
+			'before' => gmdate('Y-12-31', strtotime('-2 years')),
421 421
 		);
422 422
 
423 423
 		// Generate the report.
424 424
 		return array(
425
-			'after'  => gmdate( 'Y-01-01', strtotime( 'last year' ) ),
426
-			'before' => gmdate( 'Y-12-31', strtotime( 'last year' ) ),
425
+			'after'  => gmdate('Y-01-01', strtotime('last year')),
426
+			'before' => gmdate('Y-12-31', strtotime('last year')),
427 427
 		);
428 428
 
429 429
 	}
@@ -435,20 +435,20 @@  discard block
 block discarded – undo
435 435
 	 * @param string $date_field The date field.
436 436
 	 * @return string The appropriate SQL.
437 437
 	 */
438
-	public function get_date_range_sql( $request, $date_field ) {
438
+	public function get_date_range_sql($request, $date_field) {
439 439
 		global $wpdb;
440 440
 
441 441
 		$sql = '1=1';
442
-		$range = $this->get_date_range( $request );
442
+		$range = $this->get_date_range($request);
443 443
 
444
-		if ( ! empty( $range['after'] ) ) {
444
+		if (!empty($range['after'])) {
445 445
 			$sql .= ' AND ' . $wpdb->prepare(
446 446
 				"$date_field >= %s",
447 447
 				$range['after']
448 448
 			);
449 449
 		}
450 450
 
451
-		if ( ! empty( $range['before'] ) ) {
451
+		if (!empty($range['before'])) {
452 452
 			$sql .= ' AND ' . $wpdb->prepare(
453 453
 				"$date_field <= %s",
454 454
 				$range['before']
@@ -465,9 +465,9 @@  discard block
 block discarded – undo
465 465
 	 * @param string $date_field The date field.
466 466
 	 * @return string The appropriate SQL.
467 467
 	 */
468
-	public function get_group_by_sql( $date_field ) {
468
+	public function get_group_by_sql($date_field) {
469 469
 
470
-		if ( 'day' === $this->groupby ) {
470
+		if ('day' === $this->groupby) {
471 471
 			return "YEAR($date_field), MONTH($date_field), DAY($date_field)";
472 472
 		}
473 473
 
@@ -481,30 +481,30 @@  discard block
 block discarded – undo
481 481
 	 */
482 482
 	public function get_collection_params() {
483 483
 		return array(
484
-			'context' => $this->get_context_param( array( 'default' => 'view' ) ),
484
+			'context' => $this->get_context_param(array('default' => 'view')),
485 485
 			'period'  => array(
486
-				'description'       => __( 'Limit to results of a specific period.', 'invoicing' ),
486
+				'description'       => __('Limit to results of a specific period.', 'invoicing'),
487 487
 				'type'              => 'string',
488
-				'enum'              => array( 'custom', 'today', 'yesterday', 'week', 'last_week', '7_days', '30_days', '60_days', '90_days', '180_days', 'month', 'last_month', 'quarter', 'last_quarter', 'year', 'last_year', 'quarter', 'last_quarter' ),
488
+				'enum'              => array('custom', 'today', 'yesterday', 'week', 'last_week', '7_days', '30_days', '60_days', '90_days', '180_days', 'month', 'last_month', 'quarter', 'last_quarter', 'year', 'last_year', 'quarter', 'last_quarter'),
489 489
 				'validate_callback' => 'rest_validate_request_arg',
490 490
 				'sanitize_callback' => 'sanitize_text_field',
491 491
 				'default'           => '7_days',
492 492
 			),
493 493
 			'after'   => array(
494 494
 				/* translators: %s: date format */
495
-				'description'       => sprintf( __( 'Limit to results after a specific date, the date needs to be in the %s format.', 'invoicing' ), 'YYYY-MM-DD' ),
495
+				'description'       => sprintf(__('Limit to results after a specific date, the date needs to be in the %s format.', 'invoicing'), 'YYYY-MM-DD'),
496 496
 				'type'              => 'string',
497 497
 				'validate_callback' => 'rest_validate_request_arg',
498 498
 				'sanitize_callback' => 'sanitize_text_field',
499
-				'default'           => gmdate( 'Y-m-d', strtotime( '-7 days' ) ),
499
+				'default'           => gmdate('Y-m-d', strtotime('-7 days')),
500 500
 			),
501 501
 			'before'  => array(
502 502
 				/* translators: %s: date format */
503
-				'description'       => sprintf( __( 'Limit to results before a specific date, the date needs to be in the %s format.', 'invoicing' ), 'YYYY-MM-DD' ),
503
+				'description'       => sprintf(__('Limit to results before a specific date, the date needs to be in the %s format.', 'invoicing'), 'YYYY-MM-DD'),
504 504
 				'type'              => 'string',
505 505
 				'validate_callback' => 'rest_validate_request_arg',
506 506
 				'sanitize_callback' => 'sanitize_text_field',
507
-				'default'           => gmdate( 'Y-m-d' ),
507
+				'default'           => gmdate('Y-m-d'),
508 508
 			),
509 509
 		);
510 510
 	}
Please login to merge, or discard this patch.
Indentation   +491 added lines, -491 removed lines patch added patch discarded remove patch
@@ -16,496 +16,496 @@
 block discarded – undo
16 16
  */
17 17
 class GetPaid_REST_Date_Based_Controller extends GetPaid_REST_Controller {
18 18
 
19
-	/**
20
-	 * Group response items by day or month.
21
-	 *
22
-	 * @var string
23
-	 */
24
-	public $groupby = 'day';
25
-
26
-	/**
27
-	 * Returns an array with arguments to request the previous report.
28
-	 *
29
-	 * @var array
30
-	 */
31
-	public $previous_range = array();
32
-
33
-	/**
34
-	 * The period interval.
35
-	 *
36
-	 * @var int
37
-	 */
38
-	public $interval;
39
-
40
-	/**
41
-	 * Retrieves the before and after dates.
42
-	 *
43
-	 * @param WP_REST_Request $request Request object.
44
-	 * @return array The appropriate date range.
45
-	 */
46
-	public function get_date_range( $request ) {
47
-
48
-		// Check if the period is x_days.
49
-		if ( preg_match( '/^(\d+)_days$/', $request['period'], $matches ) ) {
50
-			$date_range = $this->get_x_days_date_range( absint( $matches[1] ) );
51
-		} elseif ( is_callable( array( $this, 'get_' . $request['period'] . '_date_range' ) ) ) {
52
-			$date_range = call_user_func( array( $this, 'get_' . $request['period'] . '_date_range' ), $request );
53
-		} else {
54
-			$request['period'] = '7_days';
55
-			$date_range        = $this->get_x_days_date_range();
56
-		}
57
-
58
-		// 3 months max for day view.
59
-		$before = strtotime( $date_range['before'] );
60
-		$after  = strtotime( $date_range['after'] );
61
-		if ( floor( ( $before - $after ) / MONTH_IN_SECONDS ) > 2 ) {
62
-			$this->groupby = 'month';
63
-		}
64
-
65
-		$this->prepare_interval( $date_range );
66
-
67
-		return $date_range;
68
-
69
-	}
70
-
71
-	/**
72
-	 * Groups by month or days.
73
-	 *
74
-	 * @param array $range Date range.
75
-	 * @return array The appropriate date range.
76
-	 */
77
-	public function prepare_interval( $range ) {
78
-
79
-		$before = strtotime( $range['before'] );
80
-		$after  = strtotime( $range['after'] );
81
-		if ( 'day' === $this->groupby ) {
82
-			$difference     = max( DAY_IN_SECONDS, ( DAY_IN_SECONDS + $before - $after ) ); // Prevent division by 0;
83
-			$this->interval = absint( ceil( max( 1, $difference / DAY_IN_SECONDS ) ) );
84
-			return;
85
-		}
86
-
87
-		$this->interval = 0;
88
-		$min_date       = strtotime( gmdate( 'Y-m-01', $after ) );
89
-
90
-		while ( $min_date <= $before ) {
91
-			$this->interval ++;
92
-			$min_date = strtotime( '+1 MONTH', $min_date );
93
-		}
94
-
95
-		$this->interval = max( 1, $this->interval );
96
-
97
-	}
98
-
99
-	/**
100
-	 * Retrieves a custom date range.
101
-	 *
102
-	 * @param WP_REST_Request $request Request object.
103
-	 * @return array The appropriate date range.
104
-	 */
105
-	public function get_custom_date_range( $request ) {
106
-
107
-		$after  = max( strtotime( '-20 years' ), strtotime( sanitize_text_field( $request['after'] ) ) );
108
-		$before = gmdate( 'Y-m-d' );
19
+    /**
20
+     * Group response items by day or month.
21
+     *
22
+     * @var string
23
+     */
24
+    public $groupby = 'day';
25
+
26
+    /**
27
+     * Returns an array with arguments to request the previous report.
28
+     *
29
+     * @var array
30
+     */
31
+    public $previous_range = array();
32
+
33
+    /**
34
+     * The period interval.
35
+     *
36
+     * @var int
37
+     */
38
+    public $interval;
39
+
40
+    /**
41
+     * Retrieves the before and after dates.
42
+     *
43
+     * @param WP_REST_Request $request Request object.
44
+     * @return array The appropriate date range.
45
+     */
46
+    public function get_date_range( $request ) {
47
+
48
+        // Check if the period is x_days.
49
+        if ( preg_match( '/^(\d+)_days$/', $request['period'], $matches ) ) {
50
+            $date_range = $this->get_x_days_date_range( absint( $matches[1] ) );
51
+        } elseif ( is_callable( array( $this, 'get_' . $request['period'] . '_date_range' ) ) ) {
52
+            $date_range = call_user_func( array( $this, 'get_' . $request['period'] . '_date_range' ), $request );
53
+        } else {
54
+            $request['period'] = '7_days';
55
+            $date_range        = $this->get_x_days_date_range();
56
+        }
57
+
58
+        // 3 months max for day view.
59
+        $before = strtotime( $date_range['before'] );
60
+        $after  = strtotime( $date_range['after'] );
61
+        if ( floor( ( $before - $after ) / MONTH_IN_SECONDS ) > 2 ) {
62
+            $this->groupby = 'month';
63
+        }
64
+
65
+        $this->prepare_interval( $date_range );
66
+
67
+        return $date_range;
68
+
69
+    }
70
+
71
+    /**
72
+     * Groups by month or days.
73
+     *
74
+     * @param array $range Date range.
75
+     * @return array The appropriate date range.
76
+     */
77
+    public function prepare_interval( $range ) {
78
+
79
+        $before = strtotime( $range['before'] );
80
+        $after  = strtotime( $range['after'] );
81
+        if ( 'day' === $this->groupby ) {
82
+            $difference     = max( DAY_IN_SECONDS, ( DAY_IN_SECONDS + $before - $after ) ); // Prevent division by 0;
83
+            $this->interval = absint( ceil( max( 1, $difference / DAY_IN_SECONDS ) ) );
84
+            return;
85
+        }
86
+
87
+        $this->interval = 0;
88
+        $min_date       = strtotime( gmdate( 'Y-m-01', $after ) );
89
+
90
+        while ( $min_date <= $before ) {
91
+            $this->interval ++;
92
+            $min_date = strtotime( '+1 MONTH', $min_date );
93
+        }
94
+
95
+        $this->interval = max( 1, $this->interval );
96
+
97
+    }
98
+
99
+    /**
100
+     * Retrieves a custom date range.
101
+     *
102
+     * @param WP_REST_Request $request Request object.
103
+     * @return array The appropriate date range.
104
+     */
105
+    public function get_custom_date_range( $request ) {
106
+
107
+        $after  = max( strtotime( '-20 years' ), strtotime( sanitize_text_field( $request['after'] ) ) );
108
+        $before = gmdate( 'Y-m-d' );
109 109
 		
110
-		if ( ! empty( $request['before'] ) ) {
111
-			$before  = min( strtotime( $before ), strtotime( sanitize_text_field( $request['before'] ) ) );
112
-		}
113
-
114
-		// Set the previous date range.
115
-		$difference           = $before - $after;
116
-		$this->previous_range = array(
117
-			'period' => 'custom',
118
-			'before' => gmdate( 'Y-m-d', $before - $difference - DAY_IN_SECONDS ),
119
-			'after'  => gmdate( 'Y-m-d', $after - $difference - DAY_IN_SECONDS ),
120
-		);
121
-
122
-		// Generate the report.
123
-		return array(
124
-			'before' => gmdate( 'Y-m-d', $before ),
125
-			'after'  => gmdate( 'Y-m-d', $after ),
126
-		);
127
-
128
-	}
129
-
130
-	/**
131
-	 * Retrieves todays date range.
132
-	 *
133
-	 * @return array The appropriate date range.
134
-	 */
135
-	public function get_today_date_range() {
136
-
137
-		// Set the previous date range.
138
-		$this->previous_range = array(
139
-			'period' => 'yesterday',
140
-		);
141
-
142
-		// Generate the report.
143
-		return array(
144
-			'before' => gmdate( 'Y-m-d' ),
145
-			'after'  => gmdate( 'Y-m-d' ),
146
-		);
147
-
148
-	}
149
-
150
-	/**
151
-	 * Retrieves yesterdays date range.
152
-	 *
153
-	 * @return array The appropriate date range.
154
-	 */
155
-	public function get_yesterday_date_range() {
156
-
157
-		// Set the previous date range.
158
-		$this->previous_range = array(
159
-			'period' => 'custom',
160
-			'before' => gmdate( 'Y-m-d', strtotime( '-2 days' ) ),
161
-			'after'  => gmdate( 'Y-m-d', strtotime( '-2 days' ) ),
162
-		);
163
-
164
-		// Generate the report.
165
-		return array(
166
-			'before' => gmdate( 'Y-m-d', strtotime( '-1 day' ) ),
167
-			'after'  => gmdate( 'Y-m-d', strtotime( '-1 day' ) ),
168
-		);
169
-
170
-	}
171
-
172
-	/**
173
-	 * Retrieves this week's date range.
174
-	 *
175
-	 * @return array The appropriate date range.
176
-	 */
177
-	public function get_week_date_range() {
178
-
179
-		// Set the previous date range.
180
-		$this->previous_range = array(
181
-			'period' => 'last_week',
182
-		);
183
-
184
-		// Generate the report.
185
-		$week_starts = absint( get_option( 'start_of_week' ) );
186
-		return array(
187
-			'before' => gmdate( 'Y-m-d' ),
188
-			'after'  => gmdate( 'Y-m-d', strtotime( 'next Sunday -' . ( 7 - $week_starts ) . ' days' ) ),
189
-		);
190
-	}
191
-
192
-	/**
193
-	 * Retrieves last week's date range.
194
-	 *
195
-	 * @return array The appropriate date range.
196
-	 */
197
-	public function get_last_week_date_range() {
198
-
199
-		$week_starts = absint( get_option( 'start_of_week' ) );
200
-		$week_starts = strtotime( 'last Sunday -' . ( 7 - $week_starts ) . ' days' );
201
-		$date_range  = array(
202
-			'before' => gmdate( 'Y-m-d', $week_starts + 6 * DAY_IN_SECONDS ),
203
-			'after'  => gmdate( 'Y-m-d', $week_starts ),
204
-		);
205
-
206
-		// Set the previous date range.
207
-		$week_starts          = $week_starts - 7 * DAY_IN_SECONDS;
208
-		$this->previous_range = array(
209
-			'period' => 'custom',
210
-			'before' => gmdate( 'Y-m-d', $week_starts + 6 * DAY_IN_SECONDS ),
211
-			'after'  => gmdate( 'Y-m-d', $week_starts ),
212
-		);
213
-
214
-		// Generate the report.
215
-		return $date_range;
216
-	}
217
-
218
-	/**
219
-	 * Retrieves last x days date range.
220
-	 *
221
-	 * @return array The appropriate date range.
222
-	 */
223
-	public function get_x_days_date_range( $days = 7 ) {
224
-
225
-		$days--;
226
-
227
-		$date_range  = array(
228
-			'before' => gmdate( 'Y-m-d' ),
229
-			'after'  => gmdate( 'Y-m-d', strtotime( "-$days days" ) ),
230
-		);
231
-
232
-		$days++;
233
-
234
-		// Set the previous date range.
235
-		$this->previous_range = array(
236
-			'period' => 'custom',
237
-			'before' => gmdate( 'Y-m-d', strtotime( $date_range['before'] ) - $days * DAY_IN_SECONDS ),
238
-			'after'  => gmdate( 'Y-m-d', strtotime( $date_range['after'] ) - $days * DAY_IN_SECONDS ),
239
-		);
240
-
241
-		// Generate the report.
242
-		return $date_range;
243
-	}
244
-
245
-	/**
246
-	 * Retrieves this month date range.
247
-	 *
248
-	 * @return array The appropriate date range.
249
-	 */
250
-	public function get_month_date_range() {
251
-
252
-		// Set the previous date range.
253
-		$this->previous_range = array(
254
-			'period' => 'last_month',
255
-		);
256
-
257
-		// Generate the report.
258
-		return array(
259
-			'after'  => gmdate( 'Y-m-01' ),
260
-			'before' => gmdate( 'Y-m-t' ),
261
-		);
262
-
263
-	}
264
-
265
-	/**
266
-	 * Retrieves last month's date range.
267
-	 *
268
-	 * @return array The appropriate date range.
269
-	 */
270
-	public function get_last_month_date_range() {
271
-
272
-		// Set the previous date range.
273
-		$this->previous_range = array(
274
-			'period' => 'custom',
275
-			'after'  => gmdate( 'Y-m-01', strtotime( '-2 months' ) ),
276
-			'before' => gmdate( 'Y-m-t', strtotime( '-2 months' ) ),
277
-		);
278
-
279
-		// Generate the report.
280
-		return array(
281
-			'after'  => gmdate( 'Y-m-01', strtotime( 'last month' ) ),
282
-			'before' => gmdate( 'Y-m-t', strtotime( 'last month' ) ),
283
-		);
284
-
285
-	}
286
-
287
-	/**
288
-	 * Retrieves this quarter date range.
289
-	 *
290
-	 * @return array The available quarters.
291
-	 */
292
-	public function get_quarters() {
293
-
294
-		$year      = (int) gmdate( 'Y' );
295
-		$last_year = (int) $year - 1;
296
-		return array(
297
-
298
-			// Third quarter of previous year: July 1st to September 30th
299
-			array(
300
-				'before' => "{$last_year}-09-30",
301
-				'after'  => "{$last_year}-07-01",
302
-			),
303
-
304
-			// Last quarter of previous year: October 1st to December 31st
305
-			array(
306
-				'before' => "{$last_year}-12-31",
307
-        		'after'  => "{$last_year}-10-01",
308
-			),
309
-
310
-			// First quarter: January 1st to March 31st
311
-			array(
312
-				'before' => "{$year}-03-31",
313
-				'after'  => "{$year}-01-01",
314
-			),
315
-
316
-			// Second quarter: April 1st to June 30th
317
-			array(
318
-				'before' => "{$year}-06-30",
319
-				'after'  => "{$year}-04-01",
320
-			),
321
-
322
-			// Third quarter: July 1st to September 30th
323
-			array(
324
-				'before' => "{$year}-09-30",
325
-				'after'  => "{$year}-07-01",
326
-			),
327
-
328
-			// Fourth quarter: October 1st to December 31st
329
-			array(
330
-				'before' => "{$year}-12-31",
331
-				'after'  => "{$year}-10-01",
332
-			),
333
-		);
334
-	}
335
-
336
-	/**
337
-	 * Retrieves the current quater.
338
-	 *
339
-	 * @return int The current quarter.
340
-	 */
341
-	public function get_quarter() {
342
-
343
-		$month    = (int) gmdate( 'n' );
344
-		$quarters = array( 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4 );
345
-		return $quarters[ $month - 1 ];
346
-
347
-	}
348
-
349
-	/**
350
-	 * Retrieves this quarter date range.
351
-	 *
352
-	 * @return array The appropriate date range.
353
-	 */
354
-	public function get_quarter_date_range() {
355
-
356
-		// Set the previous date range.
357
-		$this->previous_range = array(
358
-			'period' => 'last_quarter',
359
-		);
360
-
361
-		// Generate the report.
362
-		$quarter  = $this->get_quarter();
363
-		$quarters = $this->get_quarters();
364
-		return $quarters[ $quarter + 1 ];
365
-
366
-	}
367
-
368
-	/**
369
-	 * Retrieves last quarter's date range.
370
-	 *
371
-	 * @return array The appropriate date range.
372
-	 */
373
-	public function get_last_quarter_date_range() {
374
-
375
-		$quarters = $this->get_quarters();
376
-		$quarter  = $this->get_quarter();
377
-
378
-		// Set the previous date range.
379
-		$this->previous_range = array_merge(
380
-			$quarters[ $quarter - 1 ],
381
-			array( 'period' => 'custom' )
382
-		);
383
-
384
-		// Generate the report.
385
-		return $quarters[ $quarter ];
386
-
387
-	}
388
-
389
-	/**
390
-	 * Retrieves this year date range.
391
-	 *
392
-	 * @return array The appropriate date range.
393
-	 */
394
-	public function get_year_date_range() {
395
-
396
-		// Set the previous date range.
397
-		$this->previous_range = array(
398
-			'period' => 'last_year',
399
-		);
400
-
401
-		// Generate the report.
402
-		return array(
403
-			'after'  => gmdate( 'Y-01-01' ),
404
-			'before' => gmdate( 'Y-12-31' ),
405
-		);
406
-
407
-	}
408
-
409
-	/**
410
-	 * Retrieves last year date range.
411
-	 *
412
-	 * @return array The appropriate date range.
413
-	 */
414
-	public function get_last_year_date_range() {
415
-
416
-		// Set the previous date range.
417
-		$this->previous_range = array(
418
-			'period' => 'custom',
419
-			'after'  => gmdate( 'Y-01-01', strtotime( '-2 years' ) ),
420
-			'before' => gmdate( 'Y-12-31', strtotime( '-2 years' ) ),
421
-		);
422
-
423
-		// Generate the report.
424
-		return array(
425
-			'after'  => gmdate( 'Y-01-01', strtotime( 'last year' ) ),
426
-			'before' => gmdate( 'Y-12-31', strtotime( 'last year' ) ),
427
-		);
428
-
429
-	}
430
-
431
-	/**
432
-	 * Prepare a the request date for SQL usage.
433
-	 *
434
-	 * @param WP_REST_Request $request Request object.
435
-	 * @param string $date_field The date field.
436
-	 * @return string The appropriate SQL.
437
-	 */
438
-	public function get_date_range_sql( $request, $date_field ) {
439
-		global $wpdb;
440
-
441
-		$sql = '1=1';
442
-		$range = $this->get_date_range( $request );
443
-
444
-		if ( ! empty( $range['after'] ) ) {
445
-			$sql .= ' AND ' . $wpdb->prepare(
446
-				"$date_field >= %s",
447
-				$range['after']
448
-			);
449
-		}
450
-
451
-		if ( ! empty( $range['before'] ) ) {
452
-			$sql .= ' AND ' . $wpdb->prepare(
453
-				"$date_field <= %s",
454
-				$range['before']
455
-			);
456
-		}
457
-
458
-		return $sql;
459
-
460
-	}
461
-
462
-	/**
463
-	 * Prepares a group by query.
464
-	 *
465
-	 * @param string $date_field The date field.
466
-	 * @return string The appropriate SQL.
467
-	 */
468
-	public function get_group_by_sql( $date_field ) {
469
-
470
-		if ( 'day' === $this->groupby ) {
471
-			return "YEAR($date_field), MONTH($date_field), DAY($date_field)";
472
-		}
473
-
474
-		return "YEAR($date_field), MONTH($date_field)";
475
-	}
476
-
477
-	/**
478
-	 * Get the query params for collections.
479
-	 *
480
-	 * @return array
481
-	 */
482
-	public function get_collection_params() {
483
-		return array(
484
-			'context' => $this->get_context_param( array( 'default' => 'view' ) ),
485
-			'period'  => array(
486
-				'description'       => __( 'Limit to results of a specific period.', 'invoicing' ),
487
-				'type'              => 'string',
488
-				'enum'              => array( 'custom', 'today', 'yesterday', 'week', 'last_week', '7_days', '30_days', '60_days', '90_days', '180_days', 'month', 'last_month', 'quarter', 'last_quarter', 'year', 'last_year', 'quarter', 'last_quarter' ),
489
-				'validate_callback' => 'rest_validate_request_arg',
490
-				'sanitize_callback' => 'sanitize_text_field',
491
-				'default'           => '7_days',
492
-			),
493
-			'after'   => array(
494
-				/* translators: %s: date format */
495
-				'description'       => sprintf( __( 'Limit to results after a specific date, the date needs to be in the %s format.', 'invoicing' ), 'YYYY-MM-DD' ),
496
-				'type'              => 'string',
497
-				'validate_callback' => 'rest_validate_request_arg',
498
-				'sanitize_callback' => 'sanitize_text_field',
499
-				'default'           => gmdate( 'Y-m-d', strtotime( '-7 days' ) ),
500
-			),
501
-			'before'  => array(
502
-				/* translators: %s: date format */
503
-				'description'       => sprintf( __( 'Limit to results before a specific date, the date needs to be in the %s format.', 'invoicing' ), 'YYYY-MM-DD' ),
504
-				'type'              => 'string',
505
-				'validate_callback' => 'rest_validate_request_arg',
506
-				'sanitize_callback' => 'sanitize_text_field',
507
-				'default'           => gmdate( 'Y-m-d' ),
508
-			),
509
-		);
510
-	}
110
+        if ( ! empty( $request['before'] ) ) {
111
+            $before  = min( strtotime( $before ), strtotime( sanitize_text_field( $request['before'] ) ) );
112
+        }
113
+
114
+        // Set the previous date range.
115
+        $difference           = $before - $after;
116
+        $this->previous_range = array(
117
+            'period' => 'custom',
118
+            'before' => gmdate( 'Y-m-d', $before - $difference - DAY_IN_SECONDS ),
119
+            'after'  => gmdate( 'Y-m-d', $after - $difference - DAY_IN_SECONDS ),
120
+        );
121
+
122
+        // Generate the report.
123
+        return array(
124
+            'before' => gmdate( 'Y-m-d', $before ),
125
+            'after'  => gmdate( 'Y-m-d', $after ),
126
+        );
127
+
128
+    }
129
+
130
+    /**
131
+     * Retrieves todays date range.
132
+     *
133
+     * @return array The appropriate date range.
134
+     */
135
+    public function get_today_date_range() {
136
+
137
+        // Set the previous date range.
138
+        $this->previous_range = array(
139
+            'period' => 'yesterday',
140
+        );
141
+
142
+        // Generate the report.
143
+        return array(
144
+            'before' => gmdate( 'Y-m-d' ),
145
+            'after'  => gmdate( 'Y-m-d' ),
146
+        );
147
+
148
+    }
149
+
150
+    /**
151
+     * Retrieves yesterdays date range.
152
+     *
153
+     * @return array The appropriate date range.
154
+     */
155
+    public function get_yesterday_date_range() {
156
+
157
+        // Set the previous date range.
158
+        $this->previous_range = array(
159
+            'period' => 'custom',
160
+            'before' => gmdate( 'Y-m-d', strtotime( '-2 days' ) ),
161
+            'after'  => gmdate( 'Y-m-d', strtotime( '-2 days' ) ),
162
+        );
163
+
164
+        // Generate the report.
165
+        return array(
166
+            'before' => gmdate( 'Y-m-d', strtotime( '-1 day' ) ),
167
+            'after'  => gmdate( 'Y-m-d', strtotime( '-1 day' ) ),
168
+        );
169
+
170
+    }
171
+
172
+    /**
173
+     * Retrieves this week's date range.
174
+     *
175
+     * @return array The appropriate date range.
176
+     */
177
+    public function get_week_date_range() {
178
+
179
+        // Set the previous date range.
180
+        $this->previous_range = array(
181
+            'period' => 'last_week',
182
+        );
183
+
184
+        // Generate the report.
185
+        $week_starts = absint( get_option( 'start_of_week' ) );
186
+        return array(
187
+            'before' => gmdate( 'Y-m-d' ),
188
+            'after'  => gmdate( 'Y-m-d', strtotime( 'next Sunday -' . ( 7 - $week_starts ) . ' days' ) ),
189
+        );
190
+    }
191
+
192
+    /**
193
+     * Retrieves last week's date range.
194
+     *
195
+     * @return array The appropriate date range.
196
+     */
197
+    public function get_last_week_date_range() {
198
+
199
+        $week_starts = absint( get_option( 'start_of_week' ) );
200
+        $week_starts = strtotime( 'last Sunday -' . ( 7 - $week_starts ) . ' days' );
201
+        $date_range  = array(
202
+            'before' => gmdate( 'Y-m-d', $week_starts + 6 * DAY_IN_SECONDS ),
203
+            'after'  => gmdate( 'Y-m-d', $week_starts ),
204
+        );
205
+
206
+        // Set the previous date range.
207
+        $week_starts          = $week_starts - 7 * DAY_IN_SECONDS;
208
+        $this->previous_range = array(
209
+            'period' => 'custom',
210
+            'before' => gmdate( 'Y-m-d', $week_starts + 6 * DAY_IN_SECONDS ),
211
+            'after'  => gmdate( 'Y-m-d', $week_starts ),
212
+        );
213
+
214
+        // Generate the report.
215
+        return $date_range;
216
+    }
217
+
218
+    /**
219
+     * Retrieves last x days date range.
220
+     *
221
+     * @return array The appropriate date range.
222
+     */
223
+    public function get_x_days_date_range( $days = 7 ) {
224
+
225
+        $days--;
226
+
227
+        $date_range  = array(
228
+            'before' => gmdate( 'Y-m-d' ),
229
+            'after'  => gmdate( 'Y-m-d', strtotime( "-$days days" ) ),
230
+        );
231
+
232
+        $days++;
233
+
234
+        // Set the previous date range.
235
+        $this->previous_range = array(
236
+            'period' => 'custom',
237
+            'before' => gmdate( 'Y-m-d', strtotime( $date_range['before'] ) - $days * DAY_IN_SECONDS ),
238
+            'after'  => gmdate( 'Y-m-d', strtotime( $date_range['after'] ) - $days * DAY_IN_SECONDS ),
239
+        );
240
+
241
+        // Generate the report.
242
+        return $date_range;
243
+    }
244
+
245
+    /**
246
+     * Retrieves this month date range.
247
+     *
248
+     * @return array The appropriate date range.
249
+     */
250
+    public function get_month_date_range() {
251
+
252
+        // Set the previous date range.
253
+        $this->previous_range = array(
254
+            'period' => 'last_month',
255
+        );
256
+
257
+        // Generate the report.
258
+        return array(
259
+            'after'  => gmdate( 'Y-m-01' ),
260
+            'before' => gmdate( 'Y-m-t' ),
261
+        );
262
+
263
+    }
264
+
265
+    /**
266
+     * Retrieves last month's date range.
267
+     *
268
+     * @return array The appropriate date range.
269
+     */
270
+    public function get_last_month_date_range() {
271
+
272
+        // Set the previous date range.
273
+        $this->previous_range = array(
274
+            'period' => 'custom',
275
+            'after'  => gmdate( 'Y-m-01', strtotime( '-2 months' ) ),
276
+            'before' => gmdate( 'Y-m-t', strtotime( '-2 months' ) ),
277
+        );
278
+
279
+        // Generate the report.
280
+        return array(
281
+            'after'  => gmdate( 'Y-m-01', strtotime( 'last month' ) ),
282
+            'before' => gmdate( 'Y-m-t', strtotime( 'last month' ) ),
283
+        );
284
+
285
+    }
286
+
287
+    /**
288
+     * Retrieves this quarter date range.
289
+     *
290
+     * @return array The available quarters.
291
+     */
292
+    public function get_quarters() {
293
+
294
+        $year      = (int) gmdate( 'Y' );
295
+        $last_year = (int) $year - 1;
296
+        return array(
297
+
298
+            // Third quarter of previous year: July 1st to September 30th
299
+            array(
300
+                'before' => "{$last_year}-09-30",
301
+                'after'  => "{$last_year}-07-01",
302
+            ),
303
+
304
+            // Last quarter of previous year: October 1st to December 31st
305
+            array(
306
+                'before' => "{$last_year}-12-31",
307
+                'after'  => "{$last_year}-10-01",
308
+            ),
309
+
310
+            // First quarter: January 1st to March 31st
311
+            array(
312
+                'before' => "{$year}-03-31",
313
+                'after'  => "{$year}-01-01",
314
+            ),
315
+
316
+            // Second quarter: April 1st to June 30th
317
+            array(
318
+                'before' => "{$year}-06-30",
319
+                'after'  => "{$year}-04-01",
320
+            ),
321
+
322
+            // Third quarter: July 1st to September 30th
323
+            array(
324
+                'before' => "{$year}-09-30",
325
+                'after'  => "{$year}-07-01",
326
+            ),
327
+
328
+            // Fourth quarter: October 1st to December 31st
329
+            array(
330
+                'before' => "{$year}-12-31",
331
+                'after'  => "{$year}-10-01",
332
+            ),
333
+        );
334
+    }
335
+
336
+    /**
337
+     * Retrieves the current quater.
338
+     *
339
+     * @return int The current quarter.
340
+     */
341
+    public function get_quarter() {
342
+
343
+        $month    = (int) gmdate( 'n' );
344
+        $quarters = array( 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4 );
345
+        return $quarters[ $month - 1 ];
346
+
347
+    }
348
+
349
+    /**
350
+     * Retrieves this quarter date range.
351
+     *
352
+     * @return array The appropriate date range.
353
+     */
354
+    public function get_quarter_date_range() {
355
+
356
+        // Set the previous date range.
357
+        $this->previous_range = array(
358
+            'period' => 'last_quarter',
359
+        );
360
+
361
+        // Generate the report.
362
+        $quarter  = $this->get_quarter();
363
+        $quarters = $this->get_quarters();
364
+        return $quarters[ $quarter + 1 ];
365
+
366
+    }
367
+
368
+    /**
369
+     * Retrieves last quarter's date range.
370
+     *
371
+     * @return array The appropriate date range.
372
+     */
373
+    public function get_last_quarter_date_range() {
374
+
375
+        $quarters = $this->get_quarters();
376
+        $quarter  = $this->get_quarter();
377
+
378
+        // Set the previous date range.
379
+        $this->previous_range = array_merge(
380
+            $quarters[ $quarter - 1 ],
381
+            array( 'period' => 'custom' )
382
+        );
383
+
384
+        // Generate the report.
385
+        return $quarters[ $quarter ];
386
+
387
+    }
388
+
389
+    /**
390
+     * Retrieves this year date range.
391
+     *
392
+     * @return array The appropriate date range.
393
+     */
394
+    public function get_year_date_range() {
395
+
396
+        // Set the previous date range.
397
+        $this->previous_range = array(
398
+            'period' => 'last_year',
399
+        );
400
+
401
+        // Generate the report.
402
+        return array(
403
+            'after'  => gmdate( 'Y-01-01' ),
404
+            'before' => gmdate( 'Y-12-31' ),
405
+        );
406
+
407
+    }
408
+
409
+    /**
410
+     * Retrieves last year date range.
411
+     *
412
+     * @return array The appropriate date range.
413
+     */
414
+    public function get_last_year_date_range() {
415
+
416
+        // Set the previous date range.
417
+        $this->previous_range = array(
418
+            'period' => 'custom',
419
+            'after'  => gmdate( 'Y-01-01', strtotime( '-2 years' ) ),
420
+            'before' => gmdate( 'Y-12-31', strtotime( '-2 years' ) ),
421
+        );
422
+
423
+        // Generate the report.
424
+        return array(
425
+            'after'  => gmdate( 'Y-01-01', strtotime( 'last year' ) ),
426
+            'before' => gmdate( 'Y-12-31', strtotime( 'last year' ) ),
427
+        );
428
+
429
+    }
430
+
431
+    /**
432
+     * Prepare a the request date for SQL usage.
433
+     *
434
+     * @param WP_REST_Request $request Request object.
435
+     * @param string $date_field The date field.
436
+     * @return string The appropriate SQL.
437
+     */
438
+    public function get_date_range_sql( $request, $date_field ) {
439
+        global $wpdb;
440
+
441
+        $sql = '1=1';
442
+        $range = $this->get_date_range( $request );
443
+
444
+        if ( ! empty( $range['after'] ) ) {
445
+            $sql .= ' AND ' . $wpdb->prepare(
446
+                "$date_field >= %s",
447
+                $range['after']
448
+            );
449
+        }
450
+
451
+        if ( ! empty( $range['before'] ) ) {
452
+            $sql .= ' AND ' . $wpdb->prepare(
453
+                "$date_field <= %s",
454
+                $range['before']
455
+            );
456
+        }
457
+
458
+        return $sql;
459
+
460
+    }
461
+
462
+    /**
463
+     * Prepares a group by query.
464
+     *
465
+     * @param string $date_field The date field.
466
+     * @return string The appropriate SQL.
467
+     */
468
+    public function get_group_by_sql( $date_field ) {
469
+
470
+        if ( 'day' === $this->groupby ) {
471
+            return "YEAR($date_field), MONTH($date_field), DAY($date_field)";
472
+        }
473
+
474
+        return "YEAR($date_field), MONTH($date_field)";
475
+    }
476
+
477
+    /**
478
+     * Get the query params for collections.
479
+     *
480
+     * @return array
481
+     */
482
+    public function get_collection_params() {
483
+        return array(
484
+            'context' => $this->get_context_param( array( 'default' => 'view' ) ),
485
+            'period'  => array(
486
+                'description'       => __( 'Limit to results of a specific period.', 'invoicing' ),
487
+                'type'              => 'string',
488
+                'enum'              => array( 'custom', 'today', 'yesterday', 'week', 'last_week', '7_days', '30_days', '60_days', '90_days', '180_days', 'month', 'last_month', 'quarter', 'last_quarter', 'year', 'last_year', 'quarter', 'last_quarter' ),
489
+                'validate_callback' => 'rest_validate_request_arg',
490
+                'sanitize_callback' => 'sanitize_text_field',
491
+                'default'           => '7_days',
492
+            ),
493
+            'after'   => array(
494
+                /* translators: %s: date format */
495
+                'description'       => sprintf( __( 'Limit to results after a specific date, the date needs to be in the %s format.', 'invoicing' ), 'YYYY-MM-DD' ),
496
+                'type'              => 'string',
497
+                'validate_callback' => 'rest_validate_request_arg',
498
+                'sanitize_callback' => 'sanitize_text_field',
499
+                'default'           => gmdate( 'Y-m-d', strtotime( '-7 days' ) ),
500
+            ),
501
+            'before'  => array(
502
+                /* translators: %s: date format */
503
+                'description'       => sprintf( __( 'Limit to results before a specific date, the date needs to be in the %s format.', 'invoicing' ), 'YYYY-MM-DD' ),
504
+                'type'              => 'string',
505
+                'validate_callback' => 'rest_validate_request_arg',
506
+                'sanitize_callback' => 'sanitize_text_field',
507
+                'default'           => gmdate( 'Y-m-d' ),
508
+            ),
509
+        );
510
+    }
511 511
 }
Please login to merge, or discard this patch.
includes/payments/class-getpaid-checkout.php 2 patches
Indentation   +310 added lines, -310 removed lines patch added patch discarded remove patch
@@ -12,185 +12,185 @@  discard block
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Checkout {
14 14
 
15
-	/**
16
-	 * @var GetPaid_Payment_Form_Submission
17
-	 */
18
-	protected $payment_form_submission;
19
-
20
-	/**
21
-	 * Class constructor.
22
-	 *
23
-	 * @param GetPaid_Payment_Form_Submission $submission
24
-	 */
25
-	public function __construct( $submission ) {
26
-		$this->payment_form_submission = $submission;
27
-	}
28
-
29
-	/**
30
-	 * Processes the checkout.
31
-	 *
32
-	 */
33
-	public function process_checkout() {
34
-
35
-		// Validate the submission.
36
-		$this->validate_submission();
37
-
38
-		// Prepare the invoice.
39
-		$items    = $this->get_submission_items();
40
-		$invoice  = $this->get_submission_invoice();
41
-		$invoice  = $this->process_submission_invoice( $invoice, $items );
42
-		$prepared = $this->prepare_submission_data_for_saving();
43
-
44
-		$this->prepare_billing_info( $invoice );
45
-
46
-		$shipping   = $this->prepare_shipping_info( $invoice );
47
-
48
-		// Save the invoice.
49
-		$invoice->set_is_viewed( true );
50
-		$invoice->recalculate_total();
15
+    /**
16
+     * @var GetPaid_Payment_Form_Submission
17
+     */
18
+    protected $payment_form_submission;
19
+
20
+    /**
21
+     * Class constructor.
22
+     *
23
+     * @param GetPaid_Payment_Form_Submission $submission
24
+     */
25
+    public function __construct( $submission ) {
26
+        $this->payment_form_submission = $submission;
27
+    }
28
+
29
+    /**
30
+     * Processes the checkout.
31
+     *
32
+     */
33
+    public function process_checkout() {
34
+
35
+        // Validate the submission.
36
+        $this->validate_submission();
37
+
38
+        // Prepare the invoice.
39
+        $items    = $this->get_submission_items();
40
+        $invoice  = $this->get_submission_invoice();
41
+        $invoice  = $this->process_submission_invoice( $invoice, $items );
42
+        $prepared = $this->prepare_submission_data_for_saving();
43
+
44
+        $this->prepare_billing_info( $invoice );
45
+
46
+        $shipping   = $this->prepare_shipping_info( $invoice );
47
+
48
+        // Save the invoice.
49
+        $invoice->set_is_viewed( true );
50
+        $invoice->recalculate_total();
51 51
         $invoice->save();
52 52
 
53
-		do_action( 'getpaid_checkout_invoice_updated', $invoice );
53
+        do_action( 'getpaid_checkout_invoice_updated', $invoice );
54 54
 
55
-		// Send to the gateway.
56
-		$this->post_process_submission( $invoice, $prepared, $shipping );
57
-	}
55
+        // Send to the gateway.
56
+        $this->post_process_submission( $invoice, $prepared, $shipping );
57
+    }
58 58
 
59
-	/**
60
-	 * Validates the submission.
61
-	 *
62
-	 */
63
-	protected function validate_submission() {
59
+    /**
60
+     * Validates the submission.
61
+     *
62
+     */
63
+    protected function validate_submission() {
64 64
 
65
-		$submission = $this->payment_form_submission;
66
-		$data       = $submission->get_data();
65
+        $submission = $this->payment_form_submission;
66
+        $data       = $submission->get_data();
67 67
 
68
-		// Do we have an error?
68
+        // Do we have an error?
69 69
         if ( ! empty( $submission->last_error ) ) {
70
-			wp_send_json_error( $submission->last_error );
70
+            wp_send_json_error( $submission->last_error );
71 71
         }
72 72
 
73
-		// We need a billing email.
73
+        // We need a billing email.
74 74
         if ( ! $submission->has_billing_email() ) {
75 75
             wp_send_json_error( __( 'Provide a valid billing email.', 'invoicing' ) );
76
-		}
76
+        }
77 77
 
78
-		// Non-recurring gateways should not be allowed to process recurring invoices.
79
-		if ( $submission->should_collect_payment_details() && $submission->has_recurring && ! wpinv_gateway_support_subscription( $data['wpi-gateway'] ) ) {
80
-			wp_send_json_error( __( 'The selected payment gateway does not support subscription payments.', 'invoicing' ) );
81
-		}
78
+        // Non-recurring gateways should not be allowed to process recurring invoices.
79
+        if ( $submission->should_collect_payment_details() && $submission->has_recurring && ! wpinv_gateway_support_subscription( $data['wpi-gateway'] ) ) {
80
+            wp_send_json_error( __( 'The selected payment gateway does not support subscription payments.', 'invoicing' ) );
81
+        }
82 82
 
83
-		// Ensure the gateway is active.
84
-		if ( $submission->should_collect_payment_details() && ! wpinv_is_gateway_active( $data['wpi-gateway'] ) ) {
85
-			wp_send_json_error( __( 'The selected payment gateway is not active', 'invoicing' ) );
86
-		}
83
+        // Ensure the gateway is active.
84
+        if ( $submission->should_collect_payment_details() && ! wpinv_is_gateway_active( $data['wpi-gateway'] ) ) {
85
+            wp_send_json_error( __( 'The selected payment gateway is not active', 'invoicing' ) );
86
+        }
87 87
 
88
-		// Clear any existing errors.
89
-		wpinv_clear_errors();
88
+        // Clear any existing errors.
89
+        wpinv_clear_errors();
90 90
 
91
-		// Allow themes and plugins to hook to errors
92
-		do_action( 'getpaid_checkout_error_checks', $submission );
91
+        // Allow themes and plugins to hook to errors
92
+        do_action( 'getpaid_checkout_error_checks', $submission );
93 93
 
94
-		// Do we have any errors?
94
+        // Do we have any errors?
95 95
         if ( wpinv_get_errors() ) {
96 96
             wp_send_json_error( getpaid_get_errors_html() );
97
-		}
97
+        }
98 98
 
99
-	}
99
+    }
100 100
 
101
-	/**
102
-	 * Retrieves submission items.
103
-	 *
104
-	 * @return GetPaid_Form_Item[]
105
-	 */
106
-	protected function get_submission_items() {
101
+    /**
102
+     * Retrieves submission items.
103
+     *
104
+     * @return GetPaid_Form_Item[]
105
+     */
106
+    protected function get_submission_items() {
107 107
 
108
-		$items = $this->payment_form_submission->get_items();
108
+        $items = $this->payment_form_submission->get_items();
109 109
 
110 110
         // Ensure that we have items.
111 111
         if ( empty( $items ) && ! $this->payment_form_submission->has_fees() ) {
112 112
             wp_send_json_error( __( 'Please provide at least one item or amount.', 'invoicing' ) );
113
-		}
114
-
115
-		return $items;
116
-	}
117
-
118
-	/**
119
-	 * Retrieves submission invoice.
120
-	 *
121
-	 * @return WPInv_Invoice
122
-	 */
123
-	protected function get_submission_invoice() {
124
-		$submission = $this->payment_form_submission;
125
-
126
-		if ( ! $submission->has_invoice() ) {
127
-			$invoice = new WPInv_Invoice();
128
-			$invoice->set_created_via( 'payment_form' );
129
-			return $invoice;
130 113
         }
131 114
 
132
-		$invoice = $submission->get_invoice();
115
+        return $items;
116
+    }
117
+
118
+    /**
119
+     * Retrieves submission invoice.
120
+     *
121
+     * @return WPInv_Invoice
122
+     */
123
+    protected function get_submission_invoice() {
124
+        $submission = $this->payment_form_submission;
133 125
 
134
-		// Make sure that it is neither paid or refunded.
135
-		if ( $invoice->is_paid() || $invoice->is_refunded() ) {
136
-			wp_send_json_error( __( 'This invoice has already been paid for.', 'invoicing' ) );
137
-		}
126
+        if ( ! $submission->has_invoice() ) {
127
+            $invoice = new WPInv_Invoice();
128
+            $invoice->set_created_via( 'payment_form' );
129
+            return $invoice;
130
+        }
138 131
 
139
-		return $invoice;
140
-	}
132
+        $invoice = $submission->get_invoice();
141 133
 
142
-	/**
143
-	 * Processes the submission invoice.
144
-	 *
145
-	 * @param WPInv_Invoice $invoice
146
-	 * @param GetPaid_Form_Item[] $items
147
-	 * @return WPInv_Invoice
148
-	 */
149
-	protected function process_submission_invoice( $invoice, $items ) {
134
+        // Make sure that it is neither paid or refunded.
135
+        if ( $invoice->is_paid() || $invoice->is_refunded() ) {
136
+            wp_send_json_error( __( 'This invoice has already been paid for.', 'invoicing' ) );
137
+        }
150 138
 
151
-		$submission = $this->payment_form_submission;
139
+        return $invoice;
140
+    }
152 141
 
153
-		// Set-up the invoice details.
154
-		$invoice->set_email( sanitize_email( $submission->get_billing_email() ) );
155
-		$invoice->set_user_id( $this->get_submission_customer() );
156
-		$invoice->set_submission_id( $submission->id );
157
-		$invoice->set_payment_form( absint( $submission->get_payment_form()->get_id() ) );
142
+    /**
143
+     * Processes the submission invoice.
144
+     *
145
+     * @param WPInv_Invoice $invoice
146
+     * @param GetPaid_Form_Item[] $items
147
+     * @return WPInv_Invoice
148
+     */
149
+    protected function process_submission_invoice( $invoice, $items ) {
150
+
151
+        $submission = $this->payment_form_submission;
152
+
153
+        // Set-up the invoice details.
154
+        $invoice->set_email( sanitize_email( $submission->get_billing_email() ) );
155
+        $invoice->set_user_id( $this->get_submission_customer() );
156
+        $invoice->set_submission_id( $submission->id );
157
+        $invoice->set_payment_form( absint( $submission->get_payment_form()->get_id() ) );
158 158
         $invoice->set_items( $items );
159 159
         $invoice->set_fees( $submission->get_fees() );
160 160
         $invoice->set_taxes( $submission->get_taxes() );
161
-		$invoice->set_discounts( $submission->get_discounts() );
162
-		$invoice->set_gateway( $submission->get_field( 'wpi-gateway' ) );
163
-		$invoice->set_currency( $submission->get_currency() );
161
+        $invoice->set_discounts( $submission->get_discounts() );
162
+        $invoice->set_gateway( $submission->get_field( 'wpi-gateway' ) );
163
+        $invoice->set_currency( $submission->get_currency() );
164 164
 
165
-		if ( $submission->has_shipping() ) {
166
-			$invoice->set_shipping( $submission->get_shipping() );
167
-		}
165
+        if ( $submission->has_shipping() ) {
166
+            $invoice->set_shipping( $submission->get_shipping() );
167
+        }
168 168
 
169
-		$address_confirmed = $submission->get_field( 'confirm-address' );
170
-		$invoice->set_address_confirmed( ! empty( $address_confirmed ) );
169
+        $address_confirmed = $submission->get_field( 'confirm-address' );
170
+        $invoice->set_address_confirmed( ! empty( $address_confirmed ) );
171 171
 
172
-		if ( $submission->has_discount_code() ) {
172
+        if ( $submission->has_discount_code() ) {
173 173
             $invoice->set_discount_code( $submission->get_discount_code() );
174
-		}
175
-
176
-		getpaid_maybe_add_default_address( $invoice );
177
-		return $invoice;
178
-	}
179
-
180
-	/**
181
-	 * Retrieves the submission's customer.
182
-	 *
183
-	 * @return int The customer id.
184
-	 */
185
-	protected function get_submission_customer() {
186
-		$submission = $this->payment_form_submission;
187
-
188
-		// If this is an existing invoice...
189
-		if ( $submission->has_invoice() ) {
190
-			return $submission->get_invoice()->get_user_id();
191
-		}
192
-
193
-		// (Maybe) create the user.
174
+        }
175
+
176
+        getpaid_maybe_add_default_address( $invoice );
177
+        return $invoice;
178
+    }
179
+
180
+    /**
181
+     * Retrieves the submission's customer.
182
+     *
183
+     * @return int The customer id.
184
+     */
185
+    protected function get_submission_customer() {
186
+        $submission = $this->payment_form_submission;
187
+
188
+        // If this is an existing invoice...
189
+        if ( $submission->has_invoice() ) {
190
+            return $submission->get_invoice()->get_user_id();
191
+        }
192
+
193
+        // (Maybe) create the user.
194 194
         $user = get_current_user_id();
195 195
 
196 196
         if ( empty( $user ) ) {
@@ -198,16 +198,16 @@  discard block
 block discarded – undo
198 198
         }
199 199
 
200 200
         if ( empty( $user ) ) {
201
-			$name = array( $submission->get_field( 'wpinv_first_name', 'billing' ), $submission->get_field( 'wpinv_last_name', 'billing' ) );
202
-			$name = implode( '', array_filter( $name ) );
201
+            $name = array( $submission->get_field( 'wpinv_first_name', 'billing' ), $submission->get_field( 'wpinv_last_name', 'billing' ) );
202
+            $name = implode( '', array_filter( $name ) );
203 203
             $user = wpinv_create_user( $submission->get_billing_email(), $name );
204 204
 
205
-			// (Maybe) send new user notification.
206
-			$should_send_notification = wpinv_get_option( 'disable_new_user_emails' );
207
-			if ( ! empty( $user ) && is_numeric( $user ) && apply_filters( 'getpaid_send_new_user_notification', empty( $should_send_notification ), $user ) ) {
208
-				wp_send_new_user_notifications( $user, 'user' );
209
-			}
210
-		}
205
+            // (Maybe) send new user notification.
206
+            $should_send_notification = wpinv_get_option( 'disable_new_user_emails' );
207
+            if ( ! empty( $user ) && is_numeric( $user ) && apply_filters( 'getpaid_send_new_user_notification', empty( $should_send_notification ), $user ) ) {
208
+                wp_send_new_user_notifications( $user, 'user' );
209
+            }
210
+        }
211 211
 
212 212
         if ( is_wp_error( $user ) ) {
213 213
             wp_send_json_error( $user->get_error_message() );
@@ -215,49 +215,49 @@  discard block
 block discarded – undo
215 215
 
216 216
         if ( is_numeric( $user ) ) {
217 217
             return $user;
218
-		}
218
+        }
219 219
 
220
-		return $user->ID;
220
+        return $user->ID;
221 221
 
222
-	}
222
+    }
223 223
 
224
-	/**
224
+    /**
225 225
      * Prepares submission data for saving to the database.
226 226
      *
227
-	 * @return array
227
+     * @return array
228 228
      */
229 229
     public function prepare_submission_data_for_saving() {
230 230
 
231
-		$submission = $this->payment_form_submission;
231
+        $submission = $this->payment_form_submission;
232 232
 
233
-		// Prepared submission details.
233
+        // Prepared submission details.
234 234
         $prepared = array(
235
-			'all'  => array(),
236
-			'meta' => array(),
237
-		);
235
+            'all'  => array(),
236
+            'meta' => array(),
237
+        );
238 238
 
239 239
         // Raw submission details.
240
-		$data     = $submission->get_data();
240
+        $data     = $submission->get_data();
241 241
 
242
-		// Loop through the submitted details.
242
+        // Loop through the submitted details.
243 243
         foreach ( $submission->get_payment_form()->get_elements() as $field ) {
244 244
 
245
-			// Skip premade fields.
245
+            // Skip premade fields.
246 246
             if ( ! empty( $field['premade'] ) ) {
247 247
                 continue;
248 248
             }
249 249
 
250
-			// Ensure address is provided.
251
-			if ( 'address' === $field['type'] ) {
250
+            // Ensure address is provided.
251
+            if ( 'address' === $field['type'] ) {
252 252
                 $address_type = isset( $field['address_type'] ) && 'shipping' === $field['address_type'] ? 'shipping' : 'billing';
253 253
 
254
-				foreach ( $field['fields'] as $address_field ) {
254
+                foreach ( $field['fields'] as $address_field ) {
255 255
 
256
-					if ( ! empty( $address_field['visible'] ) && ! empty( $address_field['required'] ) && '' === trim( $_POST[ $address_type ][ $address_field['name'] ] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Missing
257
-						wp_send_json_error( __( 'Please fill all required fields.', 'invoicing' ) );
258
-					}
259
-			}
260
-		}
256
+                    if ( ! empty( $address_field['visible'] ) && ! empty( $address_field['required'] ) && '' === trim( $_POST[ $address_type ][ $address_field['name'] ] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Missing
257
+                        wp_send_json_error( __( 'Please fill all required fields.', 'invoicing' ) );
258
+                    }
259
+            }
260
+        }
261 261
 
262 262
             // If it is required and not set, abort.
263 263
             if ( ! $submission->is_required_field_set( $field ) ) {
@@ -267,31 +267,31 @@  discard block
 block discarded – undo
267 267
             // Handle misc fields.
268 268
             if ( isset( $data[ $field['id'] ] ) ) {
269 269
 
270
-				// Uploads.
271
-				if ( 'file_upload' === $field['type'] ) {
272
-					$max_file_num = empty( $field['max_file_num'] ) ? 1 : absint( $field['max_file_num'] );
270
+                // Uploads.
271
+                if ( 'file_upload' === $field['type'] ) {
272
+                    $max_file_num = empty( $field['max_file_num'] ) ? 1 : absint( $field['max_file_num'] );
273 273
 
274
-					if ( count( $data[ $field['id'] ] ) > $max_file_num ) {
275
-						wp_send_json_error( __( 'Maximum number of allowed files exceeded.', 'invoicing' ) );
276
-					}
274
+                    if ( count( $data[ $field['id'] ] ) > $max_file_num ) {
275
+                        wp_send_json_error( __( 'Maximum number of allowed files exceeded.', 'invoicing' ) );
276
+                    }
277 277
 
278
-					$value = array();
278
+                    $value = array();
279 279
 
280
-					foreach ( $data[ $field['id'] ] as $url => $name ) {
281
-						$value[] = sprintf(
282
-							'<a href="%s" target="_blank">%s</a>',
283
-							esc_url_raw( $url ),
284
-							esc_html( $name )
285
-						);
286
-					}
280
+                    foreach ( $data[ $field['id'] ] as $url => $name ) {
281
+                        $value[] = sprintf(
282
+                            '<a href="%s" target="_blank">%s</a>',
283
+                            esc_url_raw( $url ),
284
+                            esc_html( $name )
285
+                        );
286
+                    }
287 287
 
288
-					$value = implode( ' | ', $value );
288
+                    $value = implode( ' | ', $value );
289 289
 
290
-				} elseif ( 'checkbox' === $field['type'] ) {
291
-					$value = ! empty( $data[ $field['id'] ] ) ? __( 'Yes', 'invoicing' ) : __( 'No', 'invoicing' );
292
-				} else {
293
-					$value = wp_kses_post( $data[ $field['id'] ] );
294
-				}
290
+                } elseif ( 'checkbox' === $field['type'] ) {
291
+                    $value = ! empty( $data[ $field['id'] ] ) ? __( 'Yes', 'invoicing' ) : __( 'No', 'invoicing' );
292
+                } else {
293
+                    $value = wp_kses_post( $data[ $field['id'] ] );
294
+                }
295 295
 
296 296
                 $label = $field['id'];
297 297
 
@@ -299,192 +299,192 @@  discard block
 block discarded – undo
299 299
                     $label = $field['label'];
300 300
                 }
301 301
 
302
-				if ( ! empty( $field['add_meta'] ) ) {
303
-					$prepared['meta'][ wpinv_clean( $label ) ] = wp_kses_post_deep( $value );
304
-				}
305
-				$prepared['all'][ wpinv_clean( $label ) ] = wp_kses_post_deep( $value );
302
+                if ( ! empty( $field['add_meta'] ) ) {
303
+                    $prepared['meta'][ wpinv_clean( $label ) ] = wp_kses_post_deep( $value );
304
+                }
305
+                $prepared['all'][ wpinv_clean( $label ) ] = wp_kses_post_deep( $value );
306 306
 
307 307
             }
308
-		}
308
+        }
309 309
 
310
-		return $prepared;
310
+        return $prepared;
311 311
 
312
-	}
312
+    }
313 313
 
314
-	/**
314
+    /**
315 315
      * Retrieves address details.
316 316
      *
317
-	 * @return array
318
-	 * @param WPInv_Invoice $invoice
319
-	 * @param string $type
317
+     * @return array
318
+     * @param WPInv_Invoice $invoice
319
+     * @param string $type
320 320
      */
321 321
     public function prepare_address_details( $invoice, $type = 'billing' ) {
322 322
 
323
-		$data     = $this->payment_form_submission->get_data();
324
-		$type     = sanitize_key( $type );
325
-		$address  = array();
326
-		$prepared = array();
323
+        $data     = $this->payment_form_submission->get_data();
324
+        $type     = sanitize_key( $type );
325
+        $address  = array();
326
+        $prepared = array();
327 327
 
328
-		if ( ! empty( $data[ $type ] ) ) {
329
-			$address = $data[ $type ];
330
-		}
328
+        if ( ! empty( $data[ $type ] ) ) {
329
+            $address = $data[ $type ];
330
+        }
331 331
 
332
-		// Clean address details.
333
-		foreach ( $address as $key => $value ) {
334
-			$key             = sanitize_key( $key );
335
-			$key             = str_replace( 'wpinv_', '', $key );
336
-			$value           = wpinv_clean( $value );
337
-			$prepared[ $key ] = apply_filters( "getpaid_checkout_{$type}_address_$key", $value, $this->payment_form_submission, $invoice );
338
-		}
332
+        // Clean address details.
333
+        foreach ( $address as $key => $value ) {
334
+            $key             = sanitize_key( $key );
335
+            $key             = str_replace( 'wpinv_', '', $key );
336
+            $value           = wpinv_clean( $value );
337
+            $prepared[ $key ] = apply_filters( "getpaid_checkout_{$type}_address_$key", $value, $this->payment_form_submission, $invoice );
338
+        }
339 339
 
340
-		// Filter address details.
341
-		$prepared = apply_filters( "getpaid_checkout_{$type}_address", $prepared, $this->payment_form_submission, $invoice );
340
+        // Filter address details.
341
+        $prepared = apply_filters( "getpaid_checkout_{$type}_address", $prepared, $this->payment_form_submission, $invoice );
342 342
 
343
-		// Remove non-whitelisted values.
344
-		return array_filter( $prepared, 'getpaid_is_address_field_whitelisted', ARRAY_FILTER_USE_KEY );
343
+        // Remove non-whitelisted values.
344
+        return array_filter( $prepared, 'getpaid_is_address_field_whitelisted', ARRAY_FILTER_USE_KEY );
345 345
 
346
-	}
346
+    }
347 347
 
348
-	/**
348
+    /**
349 349
      * Prepares the billing details.
350 350
      *
351
-	 * @return array
352
-	 * @param WPInv_Invoice $invoice
351
+     * @return array
352
+     * @param WPInv_Invoice $invoice
353 353
      */
354 354
     protected function prepare_billing_info( &$invoice ) {
355 355
 
356
-		$billing_address = $this->prepare_address_details( $invoice, 'billing' );
356
+        $billing_address = $this->prepare_address_details( $invoice, 'billing' );
357 357
 
358
-		// Update the invoice with the billing details.
359
-		$invoice->set_props( $billing_address );
358
+        // Update the invoice with the billing details.
359
+        $invoice->set_props( $billing_address );
360 360
 
361
-	}
361
+    }
362 362
 
363
-	/**
363
+    /**
364 364
      * Prepares the shipping details.
365 365
      *
366
-	 * @return array
367
-	 * @param WPInv_Invoice $invoice
366
+     * @return array
367
+     * @param WPInv_Invoice $invoice
368 368
      */
369 369
     protected function prepare_shipping_info( $invoice ) {
370 370
 
371
-		$data = $this->payment_form_submission->get_data();
371
+        $data = $this->payment_form_submission->get_data();
372 372
 
373
-		if ( empty( $data['same-shipping-address'] ) ) {
374
-			return $this->prepare_address_details( $invoice, 'shipping' );
375
-		}
373
+        if ( empty( $data['same-shipping-address'] ) ) {
374
+            return $this->prepare_address_details( $invoice, 'shipping' );
375
+        }
376 376
 
377
-		return $this->prepare_address_details( $invoice, 'billing' );
377
+        return $this->prepare_address_details( $invoice, 'billing' );
378 378
 
379
-	}
379
+    }
380 380
 
381
-	/**
382
-	 * Confirms the submission is valid and send users to the gateway.
383
-	 *
384
-	 * @param WPInv_Invoice $invoice
385
-	 * @param array $prepared_payment_form_data
386
-	 * @param array $shipping
387
-	 */
388
-	protected function post_process_submission( $invoice, $prepared_payment_form_data, $shipping ) {
381
+    /**
382
+     * Confirms the submission is valid and send users to the gateway.
383
+     *
384
+     * @param WPInv_Invoice $invoice
385
+     * @param array $prepared_payment_form_data
386
+     * @param array $shipping
387
+     */
388
+    protected function post_process_submission( $invoice, $prepared_payment_form_data, $shipping ) {
389 389
 
390
-		// Ensure the invoice exists.
390
+        // Ensure the invoice exists.
391 391
         if ( ! $invoice->exists() ) {
392 392
             wp_send_json_error( __( 'An error occured while saving your invoice. Please try again.', 'invoicing' ) );
393 393
         }
394 394
 
395
-		// Save payment form data.
396
-		$prepared_payment_form_data = apply_filters( 'getpaid_prepared_payment_form_data', $prepared_payment_form_data, $invoice );
395
+        // Save payment form data.
396
+        $prepared_payment_form_data = apply_filters( 'getpaid_prepared_payment_form_data', $prepared_payment_form_data, $invoice );
397 397
         delete_post_meta( $invoice->get_id(), 'payment_form_data' );
398
-		delete_post_meta( $invoice->get_id(), 'additional_meta_data' );
399
-		if ( ! empty( $prepared_payment_form_data ) ) {
398
+        delete_post_meta( $invoice->get_id(), 'additional_meta_data' );
399
+        if ( ! empty( $prepared_payment_form_data ) ) {
400 400
 
401
-			if ( ! empty( $prepared_payment_form_data['all'] ) ) {
402
-				update_post_meta( $invoice->get_id(), 'payment_form_data', $prepared_payment_form_data['all'] );
403
-			}
401
+            if ( ! empty( $prepared_payment_form_data['all'] ) ) {
402
+                update_post_meta( $invoice->get_id(), 'payment_form_data', $prepared_payment_form_data['all'] );
403
+            }
404 404
 
405
-			if ( ! empty( $prepared_payment_form_data['meta'] ) ) {
406
-				update_post_meta( $invoice->get_id(), 'additional_meta_data', $prepared_payment_form_data['meta'] );
407
-			}
408
-		}
405
+            if ( ! empty( $prepared_payment_form_data['meta'] ) ) {
406
+                update_post_meta( $invoice->get_id(), 'additional_meta_data', $prepared_payment_form_data['meta'] );
407
+            }
408
+        }
409 409
 
410
-		// Save payment form data.
411
-		$shipping = apply_filters( 'getpaid_checkout_shipping_details', $shipping, $this->payment_form_submission );
410
+        // Save payment form data.
411
+        $shipping = apply_filters( 'getpaid_checkout_shipping_details', $shipping, $this->payment_form_submission );
412 412
         if ( ! empty( $shipping ) ) {
413 413
             update_post_meta( $invoice->get_id(), 'shipping_address', $shipping );
414
-		}
414
+        }
415 415
 
416
-		// Backwards compatibility.
416
+        // Backwards compatibility.
417 417
         add_filter( 'wp_redirect', array( $this, 'send_redirect_response' ) );
418 418
 
419
-		try {
420
-			$this->process_payment( $invoice );
421
-		} catch ( Exception $e ) {
422
-			wpinv_set_error( 'payment_error', $e->getMessage() );
423
-		}
419
+        try {
420
+            $this->process_payment( $invoice );
421
+        } catch ( Exception $e ) {
422
+            wpinv_set_error( 'payment_error', $e->getMessage() );
423
+        }
424 424
 
425 425
         // If we are here, there was an error.
426
-		wpinv_send_back_to_checkout( $invoice );
426
+        wpinv_send_back_to_checkout( $invoice );
427 427
 
428
-	}
428
+    }
429 429
 
430
-	/**
431
-	 * Processes the actual payment.
432
-	 *
433
-	 * @param WPInv_Invoice $invoice
434
-	 */
435
-	protected function process_payment( $invoice ) {
430
+    /**
431
+     * Processes the actual payment.
432
+     *
433
+     * @param WPInv_Invoice $invoice
434
+     */
435
+    protected function process_payment( $invoice ) {
436 436
 
437
-		// Clear any checkout errors.
438
-		wpinv_clear_errors();
437
+        // Clear any checkout errors.
438
+        wpinv_clear_errors();
439 439
 
440
-		// No need to send free invoices to the gateway.
441
-		if ( $invoice->is_free() ) {
442
-			$this->process_free_payment( $invoice );
443
-		}
440
+        // No need to send free invoices to the gateway.
441
+        if ( $invoice->is_free() ) {
442
+            $this->process_free_payment( $invoice );
443
+        }
444 444
 
445
-		$submission = $this->payment_form_submission;
445
+        $submission = $this->payment_form_submission;
446 446
 
447
-		// Fires before sending to the gateway.
448
-		do_action( 'getpaid_checkout_before_gateway', $invoice, $submission );
447
+        // Fires before sending to the gateway.
448
+        do_action( 'getpaid_checkout_before_gateway', $invoice, $submission );
449 449
 
450
-		// Allow the sumission data to be modified before it is sent to the gateway.
451
-		$submission_data    = $submission->get_data();
452
-		$submission_gateway = apply_filters( 'getpaid_gateway_submission_gateway', $invoice->get_gateway(), $submission, $invoice );
453
-		$submission_data    = apply_filters( 'getpaid_gateway_submission_data', $submission_data, $submission, $invoice );
450
+        // Allow the sumission data to be modified before it is sent to the gateway.
451
+        $submission_data    = $submission->get_data();
452
+        $submission_gateway = apply_filters( 'getpaid_gateway_submission_gateway', $invoice->get_gateway(), $submission, $invoice );
453
+        $submission_data    = apply_filters( 'getpaid_gateway_submission_data', $submission_data, $submission, $invoice );
454 454
 
455
-		// Validate the currency.
456
-		if ( ! apply_filters( "getpaid_gateway_{$submission_gateway}_is_valid_for_currency", true, $invoice->get_currency() ) ) {
457
-			wpinv_set_error( 'invalid_currency' );
458
-		}
455
+        // Validate the currency.
456
+        if ( ! apply_filters( "getpaid_gateway_{$submission_gateway}_is_valid_for_currency", true, $invoice->get_currency() ) ) {
457
+            wpinv_set_error( 'invalid_currency' );
458
+        }
459 459
 
460
-		// Check to see if we have any errors.
461
-		if ( wpinv_get_errors() ) {
462
-			wpinv_send_back_to_checkout( $invoice );
463
-		}
460
+        // Check to see if we have any errors.
461
+        if ( wpinv_get_errors() ) {
462
+            wpinv_send_back_to_checkout( $invoice );
463
+        }
464 464
 
465
-		// Send info to the gateway for payment processing
466
-		do_action( "getpaid_gateway_$submission_gateway", $invoice, $submission_data, $submission );
465
+        // Send info to the gateway for payment processing
466
+        do_action( "getpaid_gateway_$submission_gateway", $invoice, $submission_data, $submission );
467 467
 
468
-		// Backwards compatibility.
469
-		wpinv_send_to_gateway( $submission_gateway, $invoice );
468
+        // Backwards compatibility.
469
+        wpinv_send_to_gateway( $submission_gateway, $invoice );
470 470
 
471
-	}
471
+    }
472 472
 
473
-	/**
474
-	 * Marks the invoice as paid in case the checkout is free.
475
-	 *
476
-	 * @param WPInv_Invoice $invoice
477
-	 */
478
-	protected function process_free_payment( $invoice ) {
473
+    /**
474
+     * Marks the invoice as paid in case the checkout is free.
475
+     *
476
+     * @param WPInv_Invoice $invoice
477
+     */
478
+    protected function process_free_payment( $invoice ) {
479 479
 
480
-		$invoice->set_gateway( 'none' );
481
-		$invoice->add_note( __( "This is a free invoice and won't be sent to the payment gateway", 'invoicing' ), false, false, true );
482
-		$invoice->mark_paid();
483
-		wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
480
+        $invoice->set_gateway( 'none' );
481
+        $invoice->add_note( __( "This is a free invoice and won't be sent to the payment gateway", 'invoicing' ), false, false, true );
482
+        $invoice->mark_paid();
483
+        wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
484 484
 
485
-	}
485
+    }
486 486
 
487
-	/**
487
+    /**
488 488
      * Sends a redrect response to payment details.
489 489
      *
490 490
      */
Please login to merge, or discard this patch.
Spacing   +139 added lines, -139 removed lines patch added patch discarded remove patch
@@ -4,7 +4,7 @@  discard block
 block discarded – undo
4 4
  *
5 5
  */
6 6
 
7
-defined( 'ABSPATH' ) || exit;
7
+defined('ABSPATH') || exit;
8 8
 
9 9
 /**
10 10
  * Main Checkout Class.
@@ -22,7 +22,7 @@  discard block
 block discarded – undo
22 22
 	 *
23 23
 	 * @param GetPaid_Payment_Form_Submission $submission
24 24
 	 */
25
-	public function __construct( $submission ) {
25
+	public function __construct($submission) {
26 26
 		$this->payment_form_submission = $submission;
27 27
 	}
28 28
 
@@ -38,22 +38,22 @@  discard block
 block discarded – undo
38 38
 		// Prepare the invoice.
39 39
 		$items    = $this->get_submission_items();
40 40
 		$invoice  = $this->get_submission_invoice();
41
-		$invoice  = $this->process_submission_invoice( $invoice, $items );
41
+		$invoice  = $this->process_submission_invoice($invoice, $items);
42 42
 		$prepared = $this->prepare_submission_data_for_saving();
43 43
 
44
-		$this->prepare_billing_info( $invoice );
44
+		$this->prepare_billing_info($invoice);
45 45
 
46
-		$shipping   = $this->prepare_shipping_info( $invoice );
46
+		$shipping = $this->prepare_shipping_info($invoice);
47 47
 
48 48
 		// Save the invoice.
49
-		$invoice->set_is_viewed( true );
49
+		$invoice->set_is_viewed(true);
50 50
 		$invoice->recalculate_total();
51 51
         $invoice->save();
52 52
 
53
-		do_action( 'getpaid_checkout_invoice_updated', $invoice );
53
+		do_action('getpaid_checkout_invoice_updated', $invoice);
54 54
 
55 55
 		// Send to the gateway.
56
-		$this->post_process_submission( $invoice, $prepared, $shipping );
56
+		$this->post_process_submission($invoice, $prepared, $shipping);
57 57
 	}
58 58
 
59 59
 	/**
@@ -66,34 +66,34 @@  discard block
 block discarded – undo
66 66
 		$data       = $submission->get_data();
67 67
 
68 68
 		// Do we have an error?
69
-        if ( ! empty( $submission->last_error ) ) {
70
-			wp_send_json_error( $submission->last_error );
69
+        if (!empty($submission->last_error)) {
70
+			wp_send_json_error($submission->last_error);
71 71
         }
72 72
 
73 73
 		// We need a billing email.
74
-        if ( ! $submission->has_billing_email() ) {
75
-            wp_send_json_error( __( 'Provide a valid billing email.', 'invoicing' ) );
74
+        if (!$submission->has_billing_email()) {
75
+            wp_send_json_error(__('Provide a valid billing email.', 'invoicing'));
76 76
 		}
77 77
 
78 78
 		// Non-recurring gateways should not be allowed to process recurring invoices.
79
-		if ( $submission->should_collect_payment_details() && $submission->has_recurring && ! wpinv_gateway_support_subscription( $data['wpi-gateway'] ) ) {
80
-			wp_send_json_error( __( 'The selected payment gateway does not support subscription payments.', 'invoicing' ) );
79
+		if ($submission->should_collect_payment_details() && $submission->has_recurring && !wpinv_gateway_support_subscription($data['wpi-gateway'])) {
80
+			wp_send_json_error(__('The selected payment gateway does not support subscription payments.', 'invoicing'));
81 81
 		}
82 82
 
83 83
 		// Ensure the gateway is active.
84
-		if ( $submission->should_collect_payment_details() && ! wpinv_is_gateway_active( $data['wpi-gateway'] ) ) {
85
-			wp_send_json_error( __( 'The selected payment gateway is not active', 'invoicing' ) );
84
+		if ($submission->should_collect_payment_details() && !wpinv_is_gateway_active($data['wpi-gateway'])) {
85
+			wp_send_json_error(__('The selected payment gateway is not active', 'invoicing'));
86 86
 		}
87 87
 
88 88
 		// Clear any existing errors.
89 89
 		wpinv_clear_errors();
90 90
 
91 91
 		// Allow themes and plugins to hook to errors
92
-		do_action( 'getpaid_checkout_error_checks', $submission );
92
+		do_action('getpaid_checkout_error_checks', $submission);
93 93
 
94 94
 		// Do we have any errors?
95
-        if ( wpinv_get_errors() ) {
96
-            wp_send_json_error( getpaid_get_errors_html() );
95
+        if (wpinv_get_errors()) {
96
+            wp_send_json_error(getpaid_get_errors_html());
97 97
 		}
98 98
 
99 99
 	}
@@ -108,8 +108,8 @@  discard block
 block discarded – undo
108 108
 		$items = $this->payment_form_submission->get_items();
109 109
 
110 110
         // Ensure that we have items.
111
-        if ( empty( $items ) && ! $this->payment_form_submission->has_fees() ) {
112
-            wp_send_json_error( __( 'Please provide at least one item or amount.', 'invoicing' ) );
111
+        if (empty($items) && !$this->payment_form_submission->has_fees()) {
112
+            wp_send_json_error(__('Please provide at least one item or amount.', 'invoicing'));
113 113
 		}
114 114
 
115 115
 		return $items;
@@ -123,17 +123,17 @@  discard block
 block discarded – undo
123 123
 	protected function get_submission_invoice() {
124 124
 		$submission = $this->payment_form_submission;
125 125
 
126
-		if ( ! $submission->has_invoice() ) {
126
+		if (!$submission->has_invoice()) {
127 127
 			$invoice = new WPInv_Invoice();
128
-			$invoice->set_created_via( 'payment_form' );
128
+			$invoice->set_created_via('payment_form');
129 129
 			return $invoice;
130 130
         }
131 131
 
132 132
 		$invoice = $submission->get_invoice();
133 133
 
134 134
 		// Make sure that it is neither paid or refunded.
135
-		if ( $invoice->is_paid() || $invoice->is_refunded() ) {
136
-			wp_send_json_error( __( 'This invoice has already been paid for.', 'invoicing' ) );
135
+		if ($invoice->is_paid() || $invoice->is_refunded()) {
136
+			wp_send_json_error(__('This invoice has already been paid for.', 'invoicing'));
137 137
 		}
138 138
 
139 139
 		return $invoice;
@@ -146,34 +146,34 @@  discard block
 block discarded – undo
146 146
 	 * @param GetPaid_Form_Item[] $items
147 147
 	 * @return WPInv_Invoice
148 148
 	 */
149
-	protected function process_submission_invoice( $invoice, $items ) {
149
+	protected function process_submission_invoice($invoice, $items) {
150 150
 
151 151
 		$submission = $this->payment_form_submission;
152 152
 
153 153
 		// Set-up the invoice details.
154
-		$invoice->set_email( sanitize_email( $submission->get_billing_email() ) );
155
-		$invoice->set_user_id( $this->get_submission_customer() );
156
-		$invoice->set_submission_id( $submission->id );
157
-		$invoice->set_payment_form( absint( $submission->get_payment_form()->get_id() ) );
158
-        $invoice->set_items( $items );
159
-        $invoice->set_fees( $submission->get_fees() );
160
-        $invoice->set_taxes( $submission->get_taxes() );
161
-		$invoice->set_discounts( $submission->get_discounts() );
162
-		$invoice->set_gateway( $submission->get_field( 'wpi-gateway' ) );
163
-		$invoice->set_currency( $submission->get_currency() );
164
-
165
-		if ( $submission->has_shipping() ) {
166
-			$invoice->set_shipping( $submission->get_shipping() );
154
+		$invoice->set_email(sanitize_email($submission->get_billing_email()));
155
+		$invoice->set_user_id($this->get_submission_customer());
156
+		$invoice->set_submission_id($submission->id);
157
+		$invoice->set_payment_form(absint($submission->get_payment_form()->get_id()));
158
+        $invoice->set_items($items);
159
+        $invoice->set_fees($submission->get_fees());
160
+        $invoice->set_taxes($submission->get_taxes());
161
+		$invoice->set_discounts($submission->get_discounts());
162
+		$invoice->set_gateway($submission->get_field('wpi-gateway'));
163
+		$invoice->set_currency($submission->get_currency());
164
+
165
+		if ($submission->has_shipping()) {
166
+			$invoice->set_shipping($submission->get_shipping());
167 167
 		}
168 168
 
169
-		$address_confirmed = $submission->get_field( 'confirm-address' );
170
-		$invoice->set_address_confirmed( ! empty( $address_confirmed ) );
169
+		$address_confirmed = $submission->get_field('confirm-address');
170
+		$invoice->set_address_confirmed(!empty($address_confirmed));
171 171
 
172
-		if ( $submission->has_discount_code() ) {
173
-            $invoice->set_discount_code( $submission->get_discount_code() );
172
+		if ($submission->has_discount_code()) {
173
+            $invoice->set_discount_code($submission->get_discount_code());
174 174
 		}
175 175
 
176
-		getpaid_maybe_add_default_address( $invoice );
176
+		getpaid_maybe_add_default_address($invoice);
177 177
 		return $invoice;
178 178
 	}
179 179
 
@@ -186,34 +186,34 @@  discard block
 block discarded – undo
186 186
 		$submission = $this->payment_form_submission;
187 187
 
188 188
 		// If this is an existing invoice...
189
-		if ( $submission->has_invoice() ) {
189
+		if ($submission->has_invoice()) {
190 190
 			return $submission->get_invoice()->get_user_id();
191 191
 		}
192 192
 
193 193
 		// (Maybe) create the user.
194 194
         $user = get_current_user_id();
195 195
 
196
-        if ( empty( $user ) ) {
197
-            $user = get_user_by( 'email', $submission->get_billing_email() );
196
+        if (empty($user)) {
197
+            $user = get_user_by('email', $submission->get_billing_email());
198 198
         }
199 199
 
200
-        if ( empty( $user ) ) {
201
-			$name = array( $submission->get_field( 'wpinv_first_name', 'billing' ), $submission->get_field( 'wpinv_last_name', 'billing' ) );
202
-			$name = implode( '', array_filter( $name ) );
203
-            $user = wpinv_create_user( $submission->get_billing_email(), $name );
200
+        if (empty($user)) {
201
+			$name = array($submission->get_field('wpinv_first_name', 'billing'), $submission->get_field('wpinv_last_name', 'billing'));
202
+			$name = implode('', array_filter($name));
203
+            $user = wpinv_create_user($submission->get_billing_email(), $name);
204 204
 
205 205
 			// (Maybe) send new user notification.
206
-			$should_send_notification = wpinv_get_option( 'disable_new_user_emails' );
207
-			if ( ! empty( $user ) && is_numeric( $user ) && apply_filters( 'getpaid_send_new_user_notification', empty( $should_send_notification ), $user ) ) {
208
-				wp_send_new_user_notifications( $user, 'user' );
206
+			$should_send_notification = wpinv_get_option('disable_new_user_emails');
207
+			if (!empty($user) && is_numeric($user) && apply_filters('getpaid_send_new_user_notification', empty($should_send_notification), $user)) {
208
+				wp_send_new_user_notifications($user, 'user');
209 209
 			}
210 210
 		}
211 211
 
212
-        if ( is_wp_error( $user ) ) {
213
-            wp_send_json_error( $user->get_error_message() );
212
+        if (is_wp_error($user)) {
213
+            wp_send_json_error($user->get_error_message());
214 214
         }
215 215
 
216
-        if ( is_numeric( $user ) ) {
216
+        if (is_numeric($user)) {
217 217
             return $user;
218 218
 		}
219 219
 
@@ -237,72 +237,72 @@  discard block
 block discarded – undo
237 237
 		);
238 238
 
239 239
         // Raw submission details.
240
-		$data     = $submission->get_data();
240
+		$data = $submission->get_data();
241 241
 
242 242
 		// Loop through the submitted details.
243
-        foreach ( $submission->get_payment_form()->get_elements() as $field ) {
243
+        foreach ($submission->get_payment_form()->get_elements() as $field) {
244 244
 
245 245
 			// Skip premade fields.
246
-            if ( ! empty( $field['premade'] ) ) {
246
+            if (!empty($field['premade'])) {
247 247
                 continue;
248 248
             }
249 249
 
250 250
 			// Ensure address is provided.
251
-			if ( 'address' === $field['type'] ) {
252
-                $address_type = isset( $field['address_type'] ) && 'shipping' === $field['address_type'] ? 'shipping' : 'billing';
251
+			if ('address' === $field['type']) {
252
+                $address_type = isset($field['address_type']) && 'shipping' === $field['address_type'] ? 'shipping' : 'billing';
253 253
 
254
-				foreach ( $field['fields'] as $address_field ) {
254
+				foreach ($field['fields'] as $address_field) {
255 255
 
256
-					if ( ! empty( $address_field['visible'] ) && ! empty( $address_field['required'] ) && '' === trim( $_POST[ $address_type ][ $address_field['name'] ] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Missing
257
-						wp_send_json_error( __( 'Please fill all required fields.', 'invoicing' ) );
256
+					if (!empty($address_field['visible']) && !empty($address_field['required']) && '' === trim($_POST[$address_type][$address_field['name']])) { // phpcs:ignore WordPress.Security.NonceVerification.Missing
257
+						wp_send_json_error(__('Please fill all required fields.', 'invoicing'));
258 258
 					}
259 259
 			}
260 260
 		}
261 261
 
262 262
             // If it is required and not set, abort.
263
-            if ( ! $submission->is_required_field_set( $field ) ) {
264
-                wp_send_json_error( __( 'Please fill all required fields.', 'invoicing' ) );
263
+            if (!$submission->is_required_field_set($field)) {
264
+                wp_send_json_error(__('Please fill all required fields.', 'invoicing'));
265 265
             }
266 266
 
267 267
             // Handle misc fields.
268
-            if ( isset( $data[ $field['id'] ] ) ) {
268
+            if (isset($data[$field['id']])) {
269 269
 
270 270
 				// Uploads.
271
-				if ( 'file_upload' === $field['type'] ) {
272
-					$max_file_num = empty( $field['max_file_num'] ) ? 1 : absint( $field['max_file_num'] );
271
+				if ('file_upload' === $field['type']) {
272
+					$max_file_num = empty($field['max_file_num']) ? 1 : absint($field['max_file_num']);
273 273
 
274
-					if ( count( $data[ $field['id'] ] ) > $max_file_num ) {
275
-						wp_send_json_error( __( 'Maximum number of allowed files exceeded.', 'invoicing' ) );
274
+					if (count($data[$field['id']]) > $max_file_num) {
275
+						wp_send_json_error(__('Maximum number of allowed files exceeded.', 'invoicing'));
276 276
 					}
277 277
 
278 278
 					$value = array();
279 279
 
280
-					foreach ( $data[ $field['id'] ] as $url => $name ) {
280
+					foreach ($data[$field['id']] as $url => $name) {
281 281
 						$value[] = sprintf(
282 282
 							'<a href="%s" target="_blank">%s</a>',
283
-							esc_url_raw( $url ),
284
-							esc_html( $name )
283
+							esc_url_raw($url),
284
+							esc_html($name)
285 285
 						);
286 286
 					}
287 287
 
288
-					$value = implode( ' | ', $value );
288
+					$value = implode(' | ', $value);
289 289
 
290
-				} elseif ( 'checkbox' === $field['type'] ) {
291
-					$value = ! empty( $data[ $field['id'] ] ) ? __( 'Yes', 'invoicing' ) : __( 'No', 'invoicing' );
290
+				} elseif ('checkbox' === $field['type']) {
291
+					$value = !empty($data[$field['id']]) ? __('Yes', 'invoicing') : __('No', 'invoicing');
292 292
 				} else {
293
-					$value = wp_kses_post( $data[ $field['id'] ] );
293
+					$value = wp_kses_post($data[$field['id']]);
294 294
 				}
295 295
 
296 296
                 $label = $field['id'];
297 297
 
298
-                if ( isset( $field['label'] ) ) {
298
+                if (isset($field['label'])) {
299 299
                     $label = $field['label'];
300 300
                 }
301 301
 
302
-				if ( ! empty( $field['add_meta'] ) ) {
303
-					$prepared['meta'][ wpinv_clean( $label ) ] = wp_kses_post_deep( $value );
302
+				if (!empty($field['add_meta'])) {
303
+					$prepared['meta'][wpinv_clean($label)] = wp_kses_post_deep($value);
304 304
 				}
305
-				$prepared['all'][ wpinv_clean( $label ) ] = wp_kses_post_deep( $value );
305
+				$prepared['all'][wpinv_clean($label)] = wp_kses_post_deep($value);
306 306
 
307 307
             }
308 308
 		}
@@ -318,30 +318,30 @@  discard block
 block discarded – undo
318 318
 	 * @param WPInv_Invoice $invoice
319 319
 	 * @param string $type
320 320
      */
321
-    public function prepare_address_details( $invoice, $type = 'billing' ) {
321
+    public function prepare_address_details($invoice, $type = 'billing') {
322 322
 
323 323
 		$data     = $this->payment_form_submission->get_data();
324
-		$type     = sanitize_key( $type );
324
+		$type     = sanitize_key($type);
325 325
 		$address  = array();
326 326
 		$prepared = array();
327 327
 
328
-		if ( ! empty( $data[ $type ] ) ) {
329
-			$address = $data[ $type ];
328
+		if (!empty($data[$type])) {
329
+			$address = $data[$type];
330 330
 		}
331 331
 
332 332
 		// Clean address details.
333
-		foreach ( $address as $key => $value ) {
334
-			$key             = sanitize_key( $key );
335
-			$key             = str_replace( 'wpinv_', '', $key );
336
-			$value           = wpinv_clean( $value );
337
-			$prepared[ $key ] = apply_filters( "getpaid_checkout_{$type}_address_$key", $value, $this->payment_form_submission, $invoice );
333
+		foreach ($address as $key => $value) {
334
+			$key             = sanitize_key($key);
335
+			$key             = str_replace('wpinv_', '', $key);
336
+			$value           = wpinv_clean($value);
337
+			$prepared[$key] = apply_filters("getpaid_checkout_{$type}_address_$key", $value, $this->payment_form_submission, $invoice);
338 338
 		}
339 339
 
340 340
 		// Filter address details.
341
-		$prepared = apply_filters( "getpaid_checkout_{$type}_address", $prepared, $this->payment_form_submission, $invoice );
341
+		$prepared = apply_filters("getpaid_checkout_{$type}_address", $prepared, $this->payment_form_submission, $invoice);
342 342
 
343 343
 		// Remove non-whitelisted values.
344
-		return array_filter( $prepared, 'getpaid_is_address_field_whitelisted', ARRAY_FILTER_USE_KEY );
344
+		return array_filter($prepared, 'getpaid_is_address_field_whitelisted', ARRAY_FILTER_USE_KEY);
345 345
 
346 346
 	}
347 347
 
@@ -351,12 +351,12 @@  discard block
 block discarded – undo
351 351
 	 * @return array
352 352
 	 * @param WPInv_Invoice $invoice
353 353
      */
354
-    protected function prepare_billing_info( &$invoice ) {
354
+    protected function prepare_billing_info(&$invoice) {
355 355
 
356
-		$billing_address = $this->prepare_address_details( $invoice, 'billing' );
356
+		$billing_address = $this->prepare_address_details($invoice, 'billing');
357 357
 
358 358
 		// Update the invoice with the billing details.
359
-		$invoice->set_props( $billing_address );
359
+		$invoice->set_props($billing_address);
360 360
 
361 361
 	}
362 362
 
@@ -366,15 +366,15 @@  discard block
 block discarded – undo
366 366
 	 * @return array
367 367
 	 * @param WPInv_Invoice $invoice
368 368
      */
369
-    protected function prepare_shipping_info( $invoice ) {
369
+    protected function prepare_shipping_info($invoice) {
370 370
 
371 371
 		$data = $this->payment_form_submission->get_data();
372 372
 
373
-		if ( empty( $data['same-shipping-address'] ) ) {
374
-			return $this->prepare_address_details( $invoice, 'shipping' );
373
+		if (empty($data['same-shipping-address'])) {
374
+			return $this->prepare_address_details($invoice, 'shipping');
375 375
 		}
376 376
 
377
-		return $this->prepare_address_details( $invoice, 'billing' );
377
+		return $this->prepare_address_details($invoice, 'billing');
378 378
 
379 379
 	}
380 380
 
@@ -385,45 +385,45 @@  discard block
 block discarded – undo
385 385
 	 * @param array $prepared_payment_form_data
386 386
 	 * @param array $shipping
387 387
 	 */
388
-	protected function post_process_submission( $invoice, $prepared_payment_form_data, $shipping ) {
388
+	protected function post_process_submission($invoice, $prepared_payment_form_data, $shipping) {
389 389
 
390 390
 		// Ensure the invoice exists.
391
-        if ( ! $invoice->exists() ) {
392
-            wp_send_json_error( __( 'An error occured while saving your invoice. Please try again.', 'invoicing' ) );
391
+        if (!$invoice->exists()) {
392
+            wp_send_json_error(__('An error occured while saving your invoice. Please try again.', 'invoicing'));
393 393
         }
394 394
 
395 395
 		// Save payment form data.
396
-		$prepared_payment_form_data = apply_filters( 'getpaid_prepared_payment_form_data', $prepared_payment_form_data, $invoice );
397
-        delete_post_meta( $invoice->get_id(), 'payment_form_data' );
398
-		delete_post_meta( $invoice->get_id(), 'additional_meta_data' );
399
-		if ( ! empty( $prepared_payment_form_data ) ) {
396
+		$prepared_payment_form_data = apply_filters('getpaid_prepared_payment_form_data', $prepared_payment_form_data, $invoice);
397
+        delete_post_meta($invoice->get_id(), 'payment_form_data');
398
+		delete_post_meta($invoice->get_id(), 'additional_meta_data');
399
+		if (!empty($prepared_payment_form_data)) {
400 400
 
401
-			if ( ! empty( $prepared_payment_form_data['all'] ) ) {
402
-				update_post_meta( $invoice->get_id(), 'payment_form_data', $prepared_payment_form_data['all'] );
401
+			if (!empty($prepared_payment_form_data['all'])) {
402
+				update_post_meta($invoice->get_id(), 'payment_form_data', $prepared_payment_form_data['all']);
403 403
 			}
404 404
 
405
-			if ( ! empty( $prepared_payment_form_data['meta'] ) ) {
406
-				update_post_meta( $invoice->get_id(), 'additional_meta_data', $prepared_payment_form_data['meta'] );
405
+			if (!empty($prepared_payment_form_data['meta'])) {
406
+				update_post_meta($invoice->get_id(), 'additional_meta_data', $prepared_payment_form_data['meta']);
407 407
 			}
408 408
 		}
409 409
 
410 410
 		// Save payment form data.
411
-		$shipping = apply_filters( 'getpaid_checkout_shipping_details', $shipping, $this->payment_form_submission );
412
-        if ( ! empty( $shipping ) ) {
413
-            update_post_meta( $invoice->get_id(), 'shipping_address', $shipping );
411
+		$shipping = apply_filters('getpaid_checkout_shipping_details', $shipping, $this->payment_form_submission);
412
+        if (!empty($shipping)) {
413
+            update_post_meta($invoice->get_id(), 'shipping_address', $shipping);
414 414
 		}
415 415
 
416 416
 		// Backwards compatibility.
417
-        add_filter( 'wp_redirect', array( $this, 'send_redirect_response' ) );
417
+        add_filter('wp_redirect', array($this, 'send_redirect_response'));
418 418
 
419 419
 		try {
420
-			$this->process_payment( $invoice );
421
-		} catch ( Exception $e ) {
422
-			wpinv_set_error( 'payment_error', $e->getMessage() );
420
+			$this->process_payment($invoice);
421
+		} catch (Exception $e) {
422
+			wpinv_set_error('payment_error', $e->getMessage());
423 423
 		}
424 424
 
425 425
         // If we are here, there was an error.
426
-		wpinv_send_back_to_checkout( $invoice );
426
+		wpinv_send_back_to_checkout($invoice);
427 427
 
428 428
 	}
429 429
 
@@ -432,41 +432,41 @@  discard block
 block discarded – undo
432 432
 	 *
433 433
 	 * @param WPInv_Invoice $invoice
434 434
 	 */
435
-	protected function process_payment( $invoice ) {
435
+	protected function process_payment($invoice) {
436 436
 
437 437
 		// Clear any checkout errors.
438 438
 		wpinv_clear_errors();
439 439
 
440 440
 		// No need to send free invoices to the gateway.
441
-		if ( $invoice->is_free() ) {
442
-			$this->process_free_payment( $invoice );
441
+		if ($invoice->is_free()) {
442
+			$this->process_free_payment($invoice);
443 443
 		}
444 444
 
445 445
 		$submission = $this->payment_form_submission;
446 446
 
447 447
 		// Fires before sending to the gateway.
448
-		do_action( 'getpaid_checkout_before_gateway', $invoice, $submission );
448
+		do_action('getpaid_checkout_before_gateway', $invoice, $submission);
449 449
 
450 450
 		// Allow the sumission data to be modified before it is sent to the gateway.
451 451
 		$submission_data    = $submission->get_data();
452
-		$submission_gateway = apply_filters( 'getpaid_gateway_submission_gateway', $invoice->get_gateway(), $submission, $invoice );
453
-		$submission_data    = apply_filters( 'getpaid_gateway_submission_data', $submission_data, $submission, $invoice );
452
+		$submission_gateway = apply_filters('getpaid_gateway_submission_gateway', $invoice->get_gateway(), $submission, $invoice);
453
+		$submission_data    = apply_filters('getpaid_gateway_submission_data', $submission_data, $submission, $invoice);
454 454
 
455 455
 		// Validate the currency.
456
-		if ( ! apply_filters( "getpaid_gateway_{$submission_gateway}_is_valid_for_currency", true, $invoice->get_currency() ) ) {
457
-			wpinv_set_error( 'invalid_currency' );
456
+		if (!apply_filters("getpaid_gateway_{$submission_gateway}_is_valid_for_currency", true, $invoice->get_currency())) {
457
+			wpinv_set_error('invalid_currency');
458 458
 		}
459 459
 
460 460
 		// Check to see if we have any errors.
461
-		if ( wpinv_get_errors() ) {
462
-			wpinv_send_back_to_checkout( $invoice );
461
+		if (wpinv_get_errors()) {
462
+			wpinv_send_back_to_checkout($invoice);
463 463
 		}
464 464
 
465 465
 		// Send info to the gateway for payment processing
466
-		do_action( "getpaid_gateway_$submission_gateway", $invoice, $submission_data, $submission );
466
+		do_action("getpaid_gateway_$submission_gateway", $invoice, $submission_data, $submission);
467 467
 
468 468
 		// Backwards compatibility.
469
-		wpinv_send_to_gateway( $submission_gateway, $invoice );
469
+		wpinv_send_to_gateway($submission_gateway, $invoice);
470 470
 
471 471
 	}
472 472
 
@@ -475,12 +475,12 @@  discard block
 block discarded – undo
475 475
 	 *
476 476
 	 * @param WPInv_Invoice $invoice
477 477
 	 */
478
-	protected function process_free_payment( $invoice ) {
478
+	protected function process_free_payment($invoice) {
479 479
 
480
-		$invoice->set_gateway( 'none' );
481
-		$invoice->add_note( __( "This is a free invoice and won't be sent to the payment gateway", 'invoicing' ), false, false, true );
480
+		$invoice->set_gateway('none');
481
+		$invoice->add_note(__("This is a free invoice and won't be sent to the payment gateway", 'invoicing'), false, false, true);
482 482
 		$invoice->mark_paid();
483
-		wpinv_send_to_success_page( array( 'invoice_key' => $invoice->get_key() ) );
483
+		wpinv_send_to_success_page(array('invoice_key' => $invoice->get_key()));
484 484
 
485 485
 	}
486 486
 
@@ -488,9 +488,9 @@  discard block
 block discarded – undo
488 488
      * Sends a redrect response to payment details.
489 489
      *
490 490
      */
491
-    public function send_redirect_response( $url ) {
492
-        $url = rawurlencode( $url );
493
-        wp_send_json_success( $url );
491
+    public function send_redirect_response($url) {
492
+        $url = rawurlencode($url);
493
+        wp_send_json_success($url);
494 494
     }
495 495
 
496 496
 }
Please login to merge, or discard this patch.
includes/admin/register-settings.php 2 patches
Indentation   +369 added lines, -369 removed lines patch added patch discarded remove patch
@@ -25,8 +25,8 @@  discard block
 block discarded – undo
25 25
                     $defaults[ $key ] = $setting['std'];
26 26
                 }
27 27
             }
28
-		}
29
-	}
28
+        }
29
+    }
30 30
 
31 31
     return $defaults;
32 32
 
@@ -144,7 +144,7 @@  discard block
 block discarded – undo
144 144
  *
145 145
  */
146 146
 function wpinv_register_settings() {
147
-	do_action( 'getpaid_before_register_settings' );
147
+    do_action( 'getpaid_before_register_settings' );
148 148
 
149 149
     // Loop through all tabs.
150 150
     foreach ( wpinv_get_registered_settings() as $tab => $sections ) {
@@ -159,7 +159,7 @@  discard block
 block discarded – undo
159 159
                 $settings = $sections;
160 160
             }
161 161
 
162
-			do_action( "getpaid_register_{$tab}_{$section}" );
162
+            do_action( "getpaid_register_{$tab}_{$section}" );
163 163
 
164 164
             // Register the setting section.
165 165
             add_settings_section(
@@ -180,7 +180,7 @@  discard block
 block discarded – undo
180 180
     // Creates our settings in the options table.
181 181
     register_setting( 'wpinv_settings', 'wpinv_settings', 'wpinv_settings_sanitize' );
182 182
 
183
-	do_action( 'getpaid_after_register_settings' );
183
+    do_action( 'getpaid_after_register_settings' );
184 184
 }
185 185
 add_action( 'admin_init', 'wpinv_register_settings' );
186 186
 
@@ -197,13 +197,13 @@  discard block
 block discarded – undo
197 197
     $name       = isset( $option['name'] ) ? $option['name'] : '';
198 198
     $cb         = "wpinv_{$option['type']}_callback";
199 199
     $section    = "wpinv_settings_{$tab}_$section";
200
-	$is_wizzard = is_admin() && isset( $_GET['page'] ) && 'gp-setup' == $_GET['page'];
200
+    $is_wizzard = is_admin() && isset( $_GET['page'] ) && 'gp-setup' == $_GET['page'];
201 201
 
202
-	if ( isset( $option['desc'] ) && ( ! $is_wizzard && ! empty( $option['help-tip'] ) ) ) {
203
-		$tip   = wpinv_clean( $option['desc'] );
204
-		$name .= "<span class='dashicons dashicons-editor-help wpi-help-tip' title='$tip'></span>";
205
-		unset( $option['desc'] );
206
-	}
202
+    if ( isset( $option['desc'] ) && ( ! $is_wizzard && ! empty( $option['help-tip'] ) ) ) {
203
+        $tip   = wpinv_clean( $option['desc'] );
204
+        $name .= "<span class='dashicons dashicons-editor-help wpi-help-tip' title='$tip'></span>";
205
+        unset( $option['desc'] );
206
+    }
207 207
 
208 208
     // Loop through all tabs.
209 209
     add_settings_field(
@@ -230,9 +230,9 @@  discard block
 block discarded – undo
230 230
             'faux'            => isset( $option['faux'] ) ? $option['faux'] : false,
231 231
             'onchange'        => isset( $option['onchange'] ) ? $option['onchange'] : '',
232 232
             'custom'          => isset( $option['custom'] ) ? $option['custom'] : '',
233
-			'default_content' => isset( $option['default_content'] ) ? $option['default_content'] : '',
234
-			'class'           => isset( $option['class'] ) ? $option['class'] : '',
235
-			'style'           => isset( $option['style'] ) ? $option['style'] : '',
233
+            'default_content' => isset( $option['default_content'] ) ? $option['default_content'] : '',
234
+            'class'           => isset( $option['class'] ) ? $option['class'] : '',
235
+            'style'           => isset( $option['style'] ) ? $option['style'] : '',
236 236
             'cols'            => isset( $option['cols'] ) && (int) $option['cols'] > 0 ? (int) $option['cols'] : 50,
237 237
             'rows'            => isset( $option['rows'] ) && (int) $option['rows'] > 0 ? (int) $option['rows'] : 5,
238 238
         )
@@ -246,7 +246,7 @@  discard block
 block discarded – undo
246 246
  * @return array
247 247
  */
248 248
 function wpinv_get_registered_settings() {
249
-	return array_filter( apply_filters( 'wpinv_registered_settings', wpinv_get_data( 'admin-settings' ) ) );
249
+    return array_filter( apply_filters( 'wpinv_registered_settings', wpinv_get_data( 'admin-settings' ) ) );
250 250
 }
251 251
 
252 252
 /**
@@ -265,18 +265,18 @@  discard block
 block discarded – undo
265 265
  */
266 266
 function wpinv_settings_sanitize( $input = array() ) {
267 267
 
268
-	$wpinv_options = wpinv_get_options();
269
-	$raw_referrer  = wp_get_raw_referer();
268
+    $wpinv_options = wpinv_get_options();
269
+    $raw_referrer  = wp_get_raw_referer();
270 270
 
271 271
     if ( empty( $raw_referrer ) ) {
272
-		return array_merge( $wpinv_options, $input );
272
+        return array_merge( $wpinv_options, $input );
273 273
     }
274 274
 
275 275
     wp_parse_str( $raw_referrer, $referrer );
276 276
 
277
-	if ( in_array( 'gp-setup', $referrer ) ) {
278
-		return array_merge( $wpinv_options, $input );
279
-	}
277
+    if ( in_array( 'gp-setup', $referrer ) ) {
278
+        return array_merge( $wpinv_options, $input );
279
+    }
280 280
 
281 281
     $settings = wpinv_get_registered_settings();
282 282
     $tab      = isset( $referrer['tab'] ) ? $referrer['tab'] : 'general';
@@ -298,10 +298,10 @@  discard block
 block discarded – undo
298 298
         }
299 299
 
300 300
         // General filter
301
-		$input[ $key ] = apply_filters( 'wpinv_settings_sanitize', $input[ $key ], $key );
301
+        $input[ $key ] = apply_filters( 'wpinv_settings_sanitize', $input[ $key ], $key );
302 302
 
303
-		// Key specific filter.
304
-		$input[ $key ] = apply_filters( "wpinv_settings_sanitize_$key", $input[ $key ] );
303
+        // Key specific filter.
304
+        $input[ $key ] = apply_filters( "wpinv_settings_sanitize_$key", $input[ $key ] );
305 305
     }
306 306
 
307 307
     // Loop through the whitelist and unset any that are empty for the tab being saved
@@ -344,14 +344,14 @@  discard block
 block discarded – undo
344 344
 
345 345
     foreach ( $new_rates as $rate ) {
346 346
 
347
-		$rate['rate']    = wpinv_sanitize_amount( $rate['rate'] );
348
-		$rate['name']    = sanitize_text_field( $rate['name'] );
349
-		$rate['state']   = sanitize_text_field( $rate['state'] );
350
-		$rate['country'] = sanitize_text_field( $rate['country'] );
351
-		$rate['global']  = empty( $rate['state'] );
352
-		$tax_rates[]     = $rate;
347
+        $rate['rate']    = wpinv_sanitize_amount( $rate['rate'] );
348
+        $rate['name']    = sanitize_text_field( $rate['name'] );
349
+        $rate['state']   = sanitize_text_field( $rate['state'] );
350
+        $rate['country'] = sanitize_text_field( $rate['country'] );
351
+        $rate['global']  = empty( $rate['state'] );
352
+        $tax_rates[]     = $rate;
353 353
 
354
-	}
354
+    }
355 355
 
356 356
     update_option( 'wpinv_tax_rates', $tax_rates );
357 357
 
@@ -364,21 +364,21 @@  discard block
 block discarded – undo
364 364
         return $input;
365 365
     }
366 366
 
367
-	if ( empty( $_POST['wpinv_tax_rules_nonce'] ) || ! wp_verify_nonce( $_POST['wpinv_tax_rules_nonce'], 'wpinv_tax_rules' ) ) {
368
-		return $input;
369
-	}
367
+    if ( empty( $_POST['wpinv_tax_rules_nonce'] ) || ! wp_verify_nonce( $_POST['wpinv_tax_rules_nonce'], 'wpinv_tax_rules' ) ) {
368
+        return $input;
369
+    }
370 370
 
371 371
     $new_rules = ! empty( $_POST['tax_rules'] ) ? wp_kses_post_deep( array_values( $_POST['tax_rules'] ) ) : array();
372 372
     $tax_rules = array();
373 373
 
374 374
     foreach ( $new_rules as $rule ) {
375 375
 
376
-		$rule['key']      = sanitize_title_with_dashes( $rule['key'] );
377
-		$rule['label']    = sanitize_text_field( $rule['label'] );
378
-		$rule['tax_base'] = sanitize_text_field( $rule['tax_base'] );
379
-		$tax_rules[]      = $rule;
376
+        $rule['key']      = sanitize_title_with_dashes( $rule['key'] );
377
+        $rule['label']    = sanitize_text_field( $rule['label'] );
378
+        $rule['tax_base'] = sanitize_text_field( $rule['tax_base'] );
379
+        $tax_rules[]      = $rule;
380 380
 
381
-	}
381
+    }
382 382
 
383 383
     update_option( 'wpinv_tax_rules', $tax_rules );
384 384
 
@@ -391,11 +391,11 @@  discard block
 block discarded – undo
391 391
     $tabs['general']  = __( 'General', 'invoicing' );
392 392
     $tabs['gateways'] = __( 'Payment Gateways', 'invoicing' );
393 393
     $tabs['taxes']    = __( 'Taxes', 'invoicing' );
394
-	$tabs['emails']   = __( 'Emails', 'invoicing' );
394
+    $tabs['emails']   = __( 'Emails', 'invoicing' );
395 395
 
396
-	if ( count( getpaid_get_integration_settings() ) > 0 ) {
397
-		$tabs['integrations'] = __( 'Integrations', 'invoicing' );
398
-	}
396
+    if ( count( getpaid_get_integration_settings() ) > 0 ) {
397
+        $tabs['integrations'] = __( 'Integrations', 'invoicing' );
398
+    }
399 399
 
400 400
     $tabs['privacy']  = __( 'Privacy', 'invoicing' );
401 401
     $tabs['misc']     = __( 'Misc', 'invoicing' );
@@ -426,53 +426,53 @@  discard block
 block discarded – undo
426 426
         'general'      => apply_filters(
427 427
             'wpinv_settings_sections_general',
428 428
             array(
429
-				'main'             => __( 'General Settings', 'invoicing' ),
430
-				'page_section'     => __( 'Page Settings', 'invoicing' ),
431
-				'currency_section' => __( 'Currency Settings', 'invoicing' ),
432
-				'labels'           => __( 'Label Texts', 'invoicing' ),
429
+                'main'             => __( 'General Settings', 'invoicing' ),
430
+                'page_section'     => __( 'Page Settings', 'invoicing' ),
431
+                'currency_section' => __( 'Currency Settings', 'invoicing' ),
432
+                'labels'           => __( 'Label Texts', 'invoicing' ),
433 433
             )
434 434
         ),
435 435
         'gateways'     => apply_filters(
436 436
             'wpinv_settings_sections_gateways',
437 437
             array(
438
-				'main' => __( 'Gateway Settings', 'invoicing' ),
438
+                'main' => __( 'Gateway Settings', 'invoicing' ),
439 439
             )
440 440
         ),
441 441
         'taxes'        => apply_filters(
442 442
             'wpinv_settings_sections_taxes',
443 443
             array(
444
-				'main'  => __( 'Tax Settings', 'invoicing' ),
445
-				'rules' => __( 'Tax Rules', 'invoicing' ),
446
-				'rates' => __( 'Tax Rates', 'invoicing' ),
447
-				'vat'   => __( 'EU VAT Settings', 'invoicing' ),
444
+                'main'  => __( 'Tax Settings', 'invoicing' ),
445
+                'rules' => __( 'Tax Rules', 'invoicing' ),
446
+                'rates' => __( 'Tax Rates', 'invoicing' ),
447
+                'vat'   => __( 'EU VAT Settings', 'invoicing' ),
448 448
             )
449 449
         ),
450 450
         'emails'       => apply_filters(
451 451
             'wpinv_settings_sections_emails',
452 452
             array(
453
-				'main' => __( 'Email Settings', 'invoicing' ),
453
+                'main' => __( 'Email Settings', 'invoicing' ),
454 454
             )
455 455
         ),
456 456
 
457
-		'integrations' => wp_list_pluck( getpaid_get_integration_settings(), 'label', 'id' ),
457
+        'integrations' => wp_list_pluck( getpaid_get_integration_settings(), 'label', 'id' ),
458 458
 
459 459
         'privacy'      => apply_filters(
460 460
             'wpinv_settings_sections_privacy',
461 461
             array(
462
-				'main' => __( 'Privacy policy', 'invoicing' ),
462
+                'main' => __( 'Privacy policy', 'invoicing' ),
463 463
             )
464 464
         ),
465 465
         'misc'         => apply_filters(
466 466
             'wpinv_settings_sections_misc',
467 467
             array(
468
-				'main'       => __( 'Miscellaneous', 'invoicing' ),
469
-				'custom-css' => __( 'Custom CSS', 'invoicing' ),
468
+                'main'       => __( 'Miscellaneous', 'invoicing' ),
469
+                'custom-css' => __( 'Custom CSS', 'invoicing' ),
470 470
             )
471 471
         ),
472 472
         'tools'        => apply_filters(
473 473
             'wpinv_settings_sections_tools',
474 474
             array(
475
-				'main' => __( 'Diagnostic Tools', 'invoicing' ),
475
+                'main' => __( 'Diagnostic Tools', 'invoicing' ),
476 476
             )
477 477
         ),
478 478
     );
@@ -483,46 +483,46 @@  discard block
 block discarded – undo
483 483
 }
484 484
 
485 485
 function wpinv_get_pages( $with_slug = false, $default_label = null ) {
486
-	$pages_options = array();
486
+    $pages_options = array();
487 487
 
488
-	if ( $default_label !== null && $default_label !== false ) {
489
-		$pages_options = array( '' => $default_label ); // Blank option
490
-	}
488
+    if ( $default_label !== null && $default_label !== false ) {
489
+        $pages_options = array( '' => $default_label ); // Blank option
490
+    }
491 491
 
492
-	$pages = get_pages();
493
-	if ( $pages ) {
494
-		foreach ( $pages as $page ) {
495
-			$title = $with_slug ? $page->post_title . ' (' . $page->post_name . ')' : $page->post_title;
492
+    $pages = get_pages();
493
+    if ( $pages ) {
494
+        foreach ( $pages as $page ) {
495
+            $title = $with_slug ? $page->post_title . ' (' . $page->post_name . ')' : $page->post_title;
496 496
             $pages_options[ $page->ID ] = $title;
497
-		}
498
-	}
497
+        }
498
+    }
499 499
 
500
-	return $pages_options;
500
+    return $pages_options;
501 501
 }
502 502
 
503 503
 function wpinv_header_callback( $args ) {
504
-	if ( ! empty( $args['desc'] ) ) {
504
+    if ( ! empty( $args['desc'] ) ) {
505 505
         echo wp_kses_post( $args['desc'] );
506 506
     }
507 507
 }
508 508
 
509 509
 function wpinv_hidden_callback( $args ) {
510 510
 
511
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
512
-	$value   = wpinv_get_option( $args['id'], $std );
511
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
512
+    $value   = wpinv_get_option( $args['id'], $std );
513 513
 
514
-	if ( isset( $args['set_value'] ) ) {
515
-		$value = $args['set_value'];
516
-	}
514
+    if ( isset( $args['set_value'] ) ) {
515
+        $value = $args['set_value'];
516
+    }
517 517
 
518
-	if ( isset( $args['faux'] ) && true === $args['faux'] ) {
519
-		$args['readonly'] = true;
520
-		$name  = '';
521
-	} else {
522
-		$name = 'wpinv_settings[' . esc_attr( $args['id'] ) . ']';
523
-	}
518
+    if ( isset( $args['faux'] ) && true === $args['faux'] ) {
519
+        $args['readonly'] = true;
520
+        $name  = '';
521
+    } else {
522
+        $name = 'wpinv_settings[' . esc_attr( $args['id'] ) . ']';
523
+    }
524 524
 
525
-	echo '<input type="hidden" id="wpinv_settings[' . esc_attr( $args['id'] ) . ']" name="' . esc_attr( $name ) . '" value="' . esc_attr( stripslashes( $value ) ) . '" />';
525
+    echo '<input type="hidden" id="wpinv_settings[' . esc_attr( $args['id'] ) . ']" name="' . esc_attr( $name ) . '" value="' . esc_attr( stripslashes( $value ) ) . '" />';
526 526
 
527 527
 }
528 528
 
@@ -531,12 +531,12 @@  discard block
 block discarded – undo
531 531
  */
532 532
 function wpinv_checkbox_callback( $args ) {
533 533
 
534
-	$std = isset( $args['std'] ) ? $args['std'] : '';
535
-	$std = wpinv_get_option( $args['id'], $std );
536
-	$id  = esc_attr( $args['id'] );
534
+    $std = isset( $args['std'] ) ? $args['std'] : '';
535
+    $std = wpinv_get_option( $args['id'], $std );
536
+    $id  = esc_attr( $args['id'] );
537 537
 
538
-	getpaid_hidden_field( "wpinv_settings[$id]", '0' );
539
-	?>
538
+    getpaid_hidden_field( "wpinv_settings[$id]", '0' );
539
+    ?>
540 540
 		<label>
541 541
 			<input id="wpinv-settings-<?php echo esc_attr( $id ); ?>" name="wpinv_settings[<?php echo esc_attr( $id ); ?>]" <?php checked( empty( $std ), false ); ?> value="1" type="checkbox" />
542 542
 			<?php echo wp_kses_post( $args['desc'] ); ?>
@@ -546,75 +546,75 @@  discard block
 block discarded – undo
546 546
 
547 547
 function wpinv_multicheck_callback( $args ) {
548 548
 
549
-	$sanitize_id = wpinv_sanitize_key( $args['id'] );
550
-	$class = ! empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
549
+    $sanitize_id = wpinv_sanitize_key( $args['id'] );
550
+    $class = ! empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
551 551
 
552
-	if ( ! empty( $args['options'] ) ) {
552
+    if ( ! empty( $args['options'] ) ) {
553 553
 
554
-		$std     = isset( $args['std'] ) ? $args['std'] : array();
555
-		$value   = wpinv_get_option( $args['id'], $std );
554
+        $std     = isset( $args['std'] ) ? $args['std'] : array();
555
+        $value   = wpinv_get_option( $args['id'], $std );
556 556
 
557
-		echo '<div class="wpi-mcheck-rows wpi-mcheck-' . esc_attr( $sanitize_id . $class ) . '">';
557
+        echo '<div class="wpi-mcheck-rows wpi-mcheck-' . esc_attr( $sanitize_id . $class ) . '">';
558 558
         foreach ( $args['options'] as $key => $option ) :
559
-			$sanitize_key = esc_attr( wpinv_sanitize_key( $key ) );
560
-			if ( in_array( $sanitize_key, $value ) ) {
561
-				$enabled = $sanitize_key;
562
-			} else {
563
-				$enabled = null;
564
-			}
565
-			echo '<div class="wpi-mcheck-row"><input name="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" id="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" type="checkbox" value="' . esc_attr( $sanitize_key ) . '" ' . checked( $sanitize_key, $enabled, false ) . '/>&nbsp;';
566
-			echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']">' . wp_kses_post( $option ) . '</label></div>';
567
-		endforeach;
568
-		echo '</div>';
569
-		echo '<p class="description">' . wp_kses_post( $args['desc'] ) . '</p>';
570
-	}
559
+            $sanitize_key = esc_attr( wpinv_sanitize_key( $key ) );
560
+            if ( in_array( $sanitize_key, $value ) ) {
561
+                $enabled = $sanitize_key;
562
+            } else {
563
+                $enabled = null;
564
+            }
565
+            echo '<div class="wpi-mcheck-row"><input name="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" id="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" type="checkbox" value="' . esc_attr( $sanitize_key ) . '" ' . checked( $sanitize_key, $enabled, false ) . '/>&nbsp;';
566
+            echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']">' . wp_kses_post( $option ) . '</label></div>';
567
+        endforeach;
568
+        echo '</div>';
569
+        echo '<p class="description">' . wp_kses_post( $args['desc'] ) . '</p>';
570
+    }
571 571
 }
572 572
 
573 573
 function wpinv_payment_icons_callback( $args ) {
574 574
 
575 575
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
576
-	$value   = wpinv_get_option( $args['id'], false );
576
+    $value   = wpinv_get_option( $args['id'], false );
577 577
 
578
-	if ( ! empty( $args['options'] ) ) {
579
-		foreach ( $args['options'] as $key => $option ) {
578
+    if ( ! empty( $args['options'] ) ) {
579
+        foreach ( $args['options'] as $key => $option ) {
580 580
             $sanitize_key = wpinv_sanitize_key( $key );
581 581
 
582
-			if ( empty( $value ) ) {
583
-				$enabled = $option;
584
-			} else {
585
-				$enabled = null;
586
-			}
587
-
588
-			echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" style="margin-right:10px;line-height:16px;height:16px;display:inline-block;">';
589
-
590
-				echo '<input name="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" id="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" type="checkbox" value="' . esc_attr( $option ) . '" ' . checked( $option, $enabled, false ) . '/>&nbsp;';
591
-
592
-				if ( wpinv_string_is_image_url( $key ) ) {
593
-				echo '<img class="payment-icon" src="' . esc_url( $key ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
594
-				} else {
595
-				$card = strtolower( str_replace( ' ', '', $option ) );
596
-
597
-				if ( has_filter( 'wpinv_accepted_payment_' . $card . '_image' ) ) {
598
-					$image = apply_filters( 'wpinv_accepted_payment_' . $card . '_image', '' );
599
-					} else {
600
-					$image       = wpinv_locate_template( 'images' . DIRECTORY_SEPARATOR . 'icons' . DIRECTORY_SEPARATOR . $card . '.gif', false );
601
-					$content_dir = WP_CONTENT_DIR;
602
-
603
-					if ( function_exists( 'wp_normalize_path' ) ) {
604
-						// Replaces backslashes with forward slashes for Windows systems
605
-						$image = wp_normalize_path( $image );
606
-						$content_dir = wp_normalize_path( $content_dir );
607
-						}
608
-
609
-					$image = str_replace( $content_dir, content_url(), $image );
610
-					}
611
-
612
-				echo '<img class="payment-icon" src="' . esc_url( $image ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
613
-				}
614
-			echo wp_kses_post( $option ) . '</label>';
615
-		}
616
-		echo '<p class="description" style="margin-top:16px;">' . wp_kses_post( $args['desc'] ) . '</p>';
617
-	}
582
+            if ( empty( $value ) ) {
583
+                $enabled = $option;
584
+            } else {
585
+                $enabled = null;
586
+            }
587
+
588
+            echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" style="margin-right:10px;line-height:16px;height:16px;display:inline-block;">';
589
+
590
+                echo '<input name="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" id="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" type="checkbox" value="' . esc_attr( $option ) . '" ' . checked( $option, $enabled, false ) . '/>&nbsp;';
591
+
592
+                if ( wpinv_string_is_image_url( $key ) ) {
593
+                echo '<img class="payment-icon" src="' . esc_url( $key ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
594
+                } else {
595
+                $card = strtolower( str_replace( ' ', '', $option ) );
596
+
597
+                if ( has_filter( 'wpinv_accepted_payment_' . $card . '_image' ) ) {
598
+                    $image = apply_filters( 'wpinv_accepted_payment_' . $card . '_image', '' );
599
+                    } else {
600
+                    $image       = wpinv_locate_template( 'images' . DIRECTORY_SEPARATOR . 'icons' . DIRECTORY_SEPARATOR . $card . '.gif', false );
601
+                    $content_dir = WP_CONTENT_DIR;
602
+
603
+                    if ( function_exists( 'wp_normalize_path' ) ) {
604
+                        // Replaces backslashes with forward slashes for Windows systems
605
+                        $image = wp_normalize_path( $image );
606
+                        $content_dir = wp_normalize_path( $content_dir );
607
+                        }
608
+
609
+                    $image = str_replace( $content_dir, content_url(), $image );
610
+                    }
611
+
612
+                echo '<img class="payment-icon" src="' . esc_url( $image ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
613
+                }
614
+            echo wp_kses_post( $option ) . '</label>';
615
+        }
616
+        echo '<p class="description" style="margin-top:16px;">' . wp_kses_post( $args['desc'] ) . '</p>';
617
+    }
618 618
 }
619 619
 
620 620
 /**
@@ -622,9 +622,9 @@  discard block
 block discarded – undo
622 622
  */
623 623
 function wpinv_radio_callback( $args ) {
624 624
 
625
-	$std = isset( $args['std'] ) ? $args['std'] : '';
626
-	$std = wpinv_get_option( $args['id'], $std );
627
-	?>
625
+    $std = isset( $args['std'] ) ? $args['std'] : '';
626
+    $std = wpinv_get_option( $args['id'], $std );
627
+    ?>
628 628
 		<fieldset>
629 629
 			<ul id="wpinv-settings-<?php echo esc_attr( $args['id'] ); ?>" style="margin-top: 0;">
630 630
 				<?php foreach ( $args['options'] as $key => $option ) : ?>
@@ -638,7 +638,7 @@  discard block
 block discarded – undo
638 638
 			</ul>
639 639
 		</fieldset>
640 640
 	<?php
641
-	getpaid_settings_description_callback( $args );
641
+    getpaid_settings_description_callback( $args );
642 642
 }
643 643
 
644 644
 /**
@@ -646,10 +646,10 @@  discard block
 block discarded – undo
646 646
  */
647 647
 function getpaid_settings_description_callback( $args ) {
648 648
 
649
-	if ( ! empty( $args['desc'] ) ) {
650
-		$description = $args['desc'];
651
-		echo wp_kses_post( "<p class='description'>$description</p>" );
652
-	}
649
+    if ( ! empty( $args['desc'] ) ) {
650
+        $description = $args['desc'];
651
+        echo wp_kses_post( "<p class='description'>$description</p>" );
652
+    }
653 653
 
654 654
 }
655 655
 
@@ -658,7 +658,7 @@  discard block
 block discarded – undo
658 658
  */
659 659
 function wpinv_gateways_callback() {
660 660
 
661
-	?>
661
+    ?>
662 662
 		</td>
663 663
 	</tr>
664 664
 	<tr class="bsui">
@@ -672,26 +672,26 @@  discard block
 block discarded – undo
672 672
 
673 673
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
674 674
     $class = ! empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
675
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
676
-	$value   = wpinv_get_option( $args['id'], $std );
675
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
676
+    $value   = wpinv_get_option( $args['id'], $std );
677 677
 
678
-	echo '<select name="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" class="' . esc_attr( $class ) . '" >';
678
+    echo '<select name="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" class="' . esc_attr( $class ) . '" >';
679 679
 
680
-	foreach ( $args['options'] as $key => $option ) :
680
+    foreach ( $args['options'] as $key => $option ) :
681 681
 
682
-		echo '<option value="' . esc_attr( $key ) . '" ';
682
+        echo '<option value="' . esc_attr( $key ) . '" ';
683 683
 
684
-		if ( isset( $args['selected'] ) && $args['selected'] !== null && $args['selected'] !== false ) {
684
+        if ( isset( $args['selected'] ) && $args['selected'] !== null && $args['selected'] !== false ) {
685 685
             selected( $key, $args['selected'] );
686 686
         } else {
687 687
             selected( $key, $value );
688 688
         }
689 689
 
690
-		echo '>' . esc_html( $option['admin_label'] ) . '</option>';
691
-	endforeach;
690
+        echo '>' . esc_html( $option['admin_label'] ) . '</option>';
691
+    endforeach;
692 692
 
693
-	echo '</select>';
694
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
693
+    echo '</select>';
694
+    echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
695 695
 }
696 696
 
697 697
 /**
@@ -702,38 +702,38 @@  discard block
 block discarded – undo
702 702
  */
703 703
 function wpinv_settings_attrs_helper( $args ) {
704 704
 
705
-	$value = isset( $args['std'] ) ? $args['std'] : '';
706
-	$id    = esc_attr( $args['id'] );
707
-	$value = is_scalar( $value ) ? $value : '';
708
-
709
-	$attrs = array(
710
-		'name'     => ! empty( $args['faux'] ) ? false : "wpinv_settings[$id]",
711
-		'readonly' => ! empty( $args['faux'] ),
712
-		'value'    => ! empty( $args['faux'] ) ? $value : wpinv_get_option( $args['id'], $value ),
713
-		'id'       => 'wpinv-settings-' . $args['id'],
714
-		'style'    => $args['style'],
715
-		'class'    => $args['class'],
716
-		'placeholder' => $args['placeholder'],
717
-		'data-placeholder' => $args['placeholder'],
718
-	);
705
+    $value = isset( $args['std'] ) ? $args['std'] : '';
706
+    $id    = esc_attr( $args['id'] );
707
+    $value = is_scalar( $value ) ? $value : '';
708
+
709
+    $attrs = array(
710
+        'name'     => ! empty( $args['faux'] ) ? false : "wpinv_settings[$id]",
711
+        'readonly' => ! empty( $args['faux'] ),
712
+        'value'    => ! empty( $args['faux'] ) ? $value : wpinv_get_option( $args['id'], $value ),
713
+        'id'       => 'wpinv-settings-' . $args['id'],
714
+        'style'    => $args['style'],
715
+        'class'    => $args['class'],
716
+        'placeholder' => $args['placeholder'],
717
+        'data-placeholder' => $args['placeholder'],
718
+    );
719 719
 
720
-	if ( ! empty( $args['onchange'] ) ) {
721
-		$attrs['onchange'] = $args['onchange'];
722
-	}
720
+    if ( ! empty( $args['onchange'] ) ) {
721
+        $attrs['onchange'] = $args['onchange'];
722
+    }
723 723
 
724
-	foreach ( $attrs as $key => $value ) {
724
+    foreach ( $attrs as $key => $value ) {
725 725
 
726
-		if ( false === $value ) {
727
-			continue;
728
-		}
726
+        if ( false === $value ) {
727
+            continue;
728
+        }
729 729
 
730
-		if ( true === $value ) {
731
-			echo ' ' . esc_attr( $key );
732
-		} else {
733
-			echo ' ' . esc_attr( $key ) . '="' . esc_attr( $value ) . '"';
734
-		}
730
+        if ( true === $value ) {
731
+            echo ' ' . esc_attr( $key );
732
+        } else {
733
+            echo ' ' . esc_attr( $key ) . '="' . esc_attr( $value ) . '"';
734
+        }
735 735
 
736
-	}
736
+    }
737 737
 
738 738
 }
739 739
 
@@ -742,7 +742,7 @@  discard block
 block discarded – undo
742 742
  */
743 743
 function wpinv_text_callback( $args ) {
744 744
 
745
-	?>
745
+    ?>
746 746
 		<label style="width: 100%;">
747 747
 			<input type="text" <?php wpinv_settings_attrs_helper( $args ); ?>>
748 748
 			<?php getpaid_settings_description_callback( $args ); ?>
@@ -756,7 +756,7 @@  discard block
 block discarded – undo
756 756
  */
757 757
 function wpinv_number_callback( $args ) {
758 758
 
759
-	?>
759
+    ?>
760 760
 		<label style="width: 100%;">
761 761
 			<input type="number" step="<?php echo esc_attr( $args['step'] ); ?>" max="<?php echo intval( $args['max'] ); ?>" min="<?php echo intval( $args['min'] ); ?>" <?php wpinv_settings_attrs_helper( $args ); ?>>
762 762
 			<?php getpaid_settings_description_callback( $args ); ?>
@@ -768,34 +768,34 @@  discard block
 block discarded – undo
768 768
 function wpinv_textarea_callback( $args ) {
769 769
 
770 770
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
771
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
772
-	$value   = wpinv_get_option( $args['id'], $std );
771
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
772
+    $value   = wpinv_get_option( $args['id'], $std );
773 773
 
774 774
     $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
775 775
     $class = ( isset( $args['class'] ) && ! is_null( $args['class'] ) ) ? $args['class'] : 'large-text';
776 776
 
777
-	echo '<textarea class="' . esc_attr( $class ) . ' txtarea-' . esc_attr( $size ) . ' wpi-' . esc_attr( sanitize_html_class( $sanitize_id ) ) . ' " cols="' . esc_attr( $args['cols'] ) . '" rows="' . esc_attr( $args['rows'] ) . '" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
778
-	echo '<br /><label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
777
+    echo '<textarea class="' . esc_attr( $class ) . ' txtarea-' . esc_attr( $size ) . ' wpi-' . esc_attr( sanitize_html_class( $sanitize_id ) ) . ' " cols="' . esc_attr( $args['cols'] ) . '" rows="' . esc_attr( $args['rows'] ) . '" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
778
+    echo '<br /><label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
779 779
 
780 780
 }
781 781
 
782 782
 function wpinv_password_callback( $args ) {
783 783
 
784 784
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
785
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
786
-	$value   = wpinv_get_option( $args['id'], $std );
785
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
786
+    $value   = wpinv_get_option( $args['id'], $std );
787 787
 
788
-	$size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
789
-	echo '<input type="password" class="' . esc_attr( $size ) . '-text" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '"/>';
790
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
788
+    $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
789
+    echo '<input type="password" class="' . esc_attr( $size ) . '-text" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '"/>';
790
+    echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
791 791
 
792 792
 }
793 793
 
794 794
 function wpinv_missing_callback( $args ) {
795
-	printf(
796
-		esc_html__( 'The callback function used for the %s setting is missing.', 'invoicing' ),
797
-		'<strong>' . esc_html( $args['id'] ) . '</strong>'
798
-	);
795
+    printf(
796
+        esc_html__( 'The callback function used for the %s setting is missing.', 'invoicing' ),
797
+        '<strong>' . esc_html( $args['id'] ) . '</strong>'
798
+    );
799 799
 }
800 800
 
801 801
 /**
@@ -803,13 +803,13 @@  discard block
 block discarded – undo
803 803
  */
804 804
 function wpinv_select_callback( $args ) {
805 805
 
806
-	$desc   = wp_kses_post( $args['desc'] );
807
-	$desc   = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
808
-	$value  = isset( $args['std'] ) ? $args['std'] : '';
809
-	$value  = wpinv_get_option( $args['id'], $value );
810
-	$rand   = uniqid( 'random_id' );
806
+    $desc   = wp_kses_post( $args['desc'] );
807
+    $desc   = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
808
+    $value  = isset( $args['std'] ) ? $args['std'] : '';
809
+    $value  = wpinv_get_option( $args['id'], $value );
810
+    $rand   = uniqid( 'random_id' );
811 811
 
812
-	?>
812
+    ?>
813 813
 		<label style="width: 100%;">
814 814
 			<select <?php wpinv_settings_attrs_helper( $args ); ?> data-allow-clear="true">
815 815
 				<?php foreach ( $args['options'] as $option => $name ) : ?>
@@ -842,50 +842,50 @@  discard block
 block discarded – undo
842 842
 function wpinv_color_select_callback( $args ) {
843 843
 
844 844
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
845
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
846
-	$value   = wpinv_get_option( $args['id'], $std );
845
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
846
+    $value   = wpinv_get_option( $args['id'], $std );
847 847
 
848
-	echo '<select id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"/>';
848
+    echo '<select id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"/>';
849 849
 
850
-	foreach ( $args['options'] as $option => $color ) {
851
-		echo '<option value="' . esc_attr( $option ) . '" ' . selected( $option, $value ) . '>' . esc_html( $color['label'] ) . '</option>';
852
-	}
850
+    foreach ( $args['options'] as $option => $color ) {
851
+        echo '<option value="' . esc_attr( $option ) . '" ' . selected( $option, $value ) . '>' . esc_html( $color['label'] ) . '</option>';
852
+    }
853 853
 
854
-	echo '</select>';
855
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
854
+    echo '</select>';
855
+    echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
856 856
 
857 857
 }
858 858
 
859 859
 function wpinv_rich_editor_callback( $args ) {
860
-	global $wp_version;
860
+    global $wp_version;
861 861
 
862 862
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
863 863
 
864
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
865
-	$value   = wpinv_get_option( $args['id'], $std );
864
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
865
+    $value   = wpinv_get_option( $args['id'], $std );
866 866
 
867
-	if ( ! empty( $args['allow_blank'] ) && empty( $value ) ) {
868
-		$value = $std;
869
-	}
867
+    if ( ! empty( $args['allow_blank'] ) && empty( $value ) ) {
868
+        $value = $std;
869
+    }
870 870
 
871
-	$rows = isset( $args['size'] ) ? $args['size'] : 20;
871
+    $rows = isset( $args['size'] ) ? $args['size'] : 20;
872 872
 
873
-	echo '<div class="getpaid-settings-editor-input">';
874
-	if ( $wp_version >= 3.3 && function_exists( 'wp_editor' ) ) {
875
-		wp_editor(
873
+    echo '<div class="getpaid-settings-editor-input">';
874
+    if ( $wp_version >= 3.3 && function_exists( 'wp_editor' ) ) {
875
+        wp_editor(
876 876
             stripslashes( $value ),
877 877
             'wpinv_settings_' . esc_attr( $args['id'] ),
878 878
             array(
879
-				'textarea_name' => 'wpinv_settings[' . esc_attr( $args['id'] ) . ']',
880
-				'textarea_rows' => absint( $rows ),
881
-				'media_buttons' => false,
879
+                'textarea_name' => 'wpinv_settings[' . esc_attr( $args['id'] ) . ']',
880
+                'textarea_rows' => absint( $rows ),
881
+                'media_buttons' => false,
882 882
             )
883 883
         );
884
-	} else {
885
-		echo '<textarea class="large-text" rows="10" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="wpi-' . esc_attr( sanitize_html_class( $args['id'] ) ) . '">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
886
-	}
884
+    } else {
885
+        echo '<textarea class="large-text" rows="10" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="wpi-' . esc_attr( sanitize_html_class( $args['id'] ) ) . '">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
886
+    }
887 887
 
888
-	echo '</div><br/><label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
888
+    echo '</div><br/><label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
889 889
 
890 890
 }
891 891
 
@@ -893,51 +893,51 @@  discard block
 block discarded – undo
893 893
 
894 894
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
895 895
 
896
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
897
-	$value   = wpinv_get_option( $args['id'], $std );
896
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
897
+    $value   = wpinv_get_option( $args['id'], $std );
898 898
 
899
-	$size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
900
-	echo '<input type="text" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( stripslashes( $value ) ) . '"/>';
901
-	echo '<span>&nbsp;<input type="button" class="wpinv_settings_upload_button button-secondary" value="' . esc_attr__( 'Upload File', 'invoicing' ) . '"/></span>';
902
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
899
+    $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
900
+    echo '<input type="text" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( stripslashes( $value ) ) . '"/>';
901
+    echo '<span>&nbsp;<input type="button" class="wpinv_settings_upload_button button-secondary" value="' . esc_attr__( 'Upload File', 'invoicing' ) . '"/></span>';
902
+    echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
903 903
 
904 904
 }
905 905
 
906 906
 function wpinv_color_callback( $args ) {
907 907
 
908
-	$std         = isset( $args['std'] ) ? $args['std'] : '';
909
-	$value       = wpinv_get_option( $args['id'], $std );
908
+    $std         = isset( $args['std'] ) ? $args['std'] : '';
909
+    $value       = wpinv_get_option( $args['id'], $std );
910 910
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
911 911
 
912
-	echo '<input type="text" class="wpinv-color-picker" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '" data-default-color="' . esc_attr( $std ) . '" />';
913
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
912
+    echo '<input type="text" class="wpinv-color-picker" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '" data-default-color="' . esc_attr( $std ) . '" />';
913
+    echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
914 914
 
915 915
 }
916 916
 
917 917
 function wpinv_country_states_callback( $args ) {
918 918
 
919
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
920
-	$value   = wpinv_get_option( $args['id'], $std );
919
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
920
+    $value   = wpinv_get_option( $args['id'], $std );
921 921
 
922 922
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
923 923
 
924
-	if ( isset( $args['placeholder'] ) ) {
925
-		$placeholder = $args['placeholder'];
926
-	} else {
927
-		$placeholder = '';
928
-	}
924
+    if ( isset( $args['placeholder'] ) ) {
925
+        $placeholder = $args['placeholder'];
926
+    } else {
927
+        $placeholder = '';
928
+    }
929 929
 
930
-	$states = wpinv_get_country_states();
930
+    $states = wpinv_get_country_states();
931 931
 
932
-	$class = empty( $states ) ? 'wpinv-no-states' : 'wpi_select2';
933
-	echo '<select id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="' . esc_attr( $class ) . '" data-placeholder="' . esc_html( $placeholder ) . '"/>';
932
+    $class = empty( $states ) ? 'wpinv-no-states' : 'wpi_select2';
933
+    echo '<select id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="' . esc_attr( $class ) . '" data-placeholder="' . esc_html( $placeholder ) . '"/>';
934 934
 
935
-	foreach ( $states as $option => $name ) {
936
-		echo '<option value="' . esc_attr( $option ) . '" ' . selected( $option, $value ) . '>' . esc_html( $name ) . '</option>';
937
-	}
935
+    foreach ( $states as $option => $name ) {
936
+        echo '<option value="' . esc_attr( $option ) . '" ' . selected( $option, $value ) . '>' . esc_html( $name ) . '</option>';
937
+    }
938 938
 
939
-	echo '</select>';
940
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
939
+    echo '</select>';
940
+    echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
941 941
 
942 942
 }
943 943
 
@@ -946,7 +946,7 @@  discard block
 block discarded – undo
946 946
  */
947 947
 function wpinv_tax_rates_callback() {
948 948
 
949
-	?>
949
+    ?>
950 950
 		</td>
951 951
 	</tr>
952 952
 	<tr class="bsui">
@@ -962,9 +962,9 @@  discard block
 block discarded – undo
962 962
  */
963 963
 function wpinv_tax_rate_callback( $tax_rate, $key ) {
964 964
 
965
-	$key                      = sanitize_key( $key );
966
-	$tax_rate['reduced_rate'] = empty( $tax_rate['reduced_rate'] ) ? 0 : $tax_rate['reduced_rate'];
967
-	include plugin_dir_path( __FILE__ ) . 'views/html-tax-rate-edit.php';
965
+    $key                      = sanitize_key( $key );
966
+    $tax_rate['reduced_rate'] = empty( $tax_rate['reduced_rate'] ) ? 0 : $tax_rate['reduced_rate'];
967
+    include plugin_dir_path( __FILE__ ) . 'views/html-tax-rate-edit.php';
968 968
 
969 969
 }
970 970
 
@@ -973,7 +973,7 @@  discard block
 block discarded – undo
973 973
  */
974 974
 function wpinv_tax_rules_callback() {
975 975
 
976
-	?>
976
+    ?>
977 977
 		</td>
978 978
 	</tr>
979 979
 	<tr class="bsui">
@@ -1011,14 +1011,14 @@  discard block
 block discarded – undo
1011 1011
                 <td>
1012 1012
 					<a href="
1013 1013
                     <?php
1014
-						echo esc_url(
1015
-							wp_nonce_url(
1016
-								add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
1017
-								'getpaid-nonce',
1018
-								'getpaid-nonce'
1019
-							)
1020
-						);
1021
-					?>
1014
+                        echo esc_url(
1015
+                            wp_nonce_url(
1016
+                                add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
1017
+                                'getpaid-nonce',
1018
+                                'getpaid-nonce'
1019
+                            )
1020
+                        );
1021
+                    ?>
1022 1022
                     " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1023 1023
                 </td>
1024 1024
             </tr>
@@ -1030,14 +1030,14 @@  discard block
 block discarded – undo
1030 1030
                 <td>
1031 1031
 					<a href="
1032 1032
                     <?php
1033
-						echo esc_url(
1034
-							wp_nonce_url(
1035
-								add_query_arg( 'getpaid-admin-action', 'refresh_permalinks' ),
1036
-								'getpaid-nonce',
1037
-								'getpaid-nonce'
1038
-							)
1039
-						);
1040
-					?>
1033
+                        echo esc_url(
1034
+                            wp_nonce_url(
1035
+                                add_query_arg( 'getpaid-admin-action', 'refresh_permalinks' ),
1036
+                                'getpaid-nonce',
1037
+                                'getpaid-nonce'
1038
+                            )
1039
+                        );
1040
+                    ?>
1041 1041
                     " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1042 1042
                 </td>
1043 1043
             </tr>
@@ -1049,14 +1049,14 @@  discard block
 block discarded – undo
1049 1049
                 <td>
1050 1050
 					<a href="
1051 1051
                     <?php
1052
-						echo esc_url(
1053
-							wp_nonce_url(
1054
-								add_query_arg( 'getpaid-admin-action', 'create_missing_tables' ),
1055
-								'getpaid-nonce',
1056
-								'getpaid-nonce'
1057
-							)
1058
-						);
1059
-					?>
1052
+                        echo esc_url(
1053
+                            wp_nonce_url(
1054
+                                add_query_arg( 'getpaid-admin-action', 'create_missing_tables' ),
1055
+                                'getpaid-nonce',
1056
+                                'getpaid-nonce'
1057
+                            )
1058
+                        );
1059
+                    ?>
1060 1060
                     " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1061 1061
                 </td>
1062 1062
             </tr>
@@ -1068,14 +1068,14 @@  discard block
 block discarded – undo
1068 1068
                 <td>
1069 1069
 					<a href="
1070 1070
                     <?php
1071
-						echo esc_url(
1072
-							wp_nonce_url(
1073
-								add_query_arg( 'getpaid-admin-action', 'migrate_old_invoices' ),
1074
-								'getpaid-nonce',
1075
-								'getpaid-nonce'
1076
-							)
1077
-						);
1078
-					?>
1071
+                        echo esc_url(
1072
+                            wp_nonce_url(
1073
+                                add_query_arg( 'getpaid-admin-action', 'migrate_old_invoices' ),
1074
+                                'getpaid-nonce',
1075
+                                'getpaid-nonce'
1076
+                            )
1077
+                        );
1078
+                    ?>
1079 1079
                     " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1080 1080
                 </td>
1081 1081
             </tr>
@@ -1088,14 +1088,14 @@  discard block
 block discarded – undo
1088 1088
                 <td>
1089 1089
 					<a href="
1090 1090
                     <?php
1091
-						echo esc_url(
1092
-							wp_nonce_url(
1093
-								add_query_arg( 'getpaid-admin-action', 'recalculate_discounts' ),
1094
-								'getpaid-nonce',
1095
-								'getpaid-nonce'
1096
-							)
1097
-						);
1098
-					?>
1091
+                        echo esc_url(
1092
+                            wp_nonce_url(
1093
+                                add_query_arg( 'getpaid-admin-action', 'recalculate_discounts' ),
1094
+                                'getpaid-nonce',
1095
+                                'getpaid-nonce'
1096
+                            )
1097
+                        );
1098
+                    ?>
1099 1099
                     " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1100 1100
                 </td>
1101 1101
             </tr>
@@ -1108,8 +1108,8 @@  discard block
 block discarded – undo
1108 1108
                 <td>
1109 1109
 					<a href="
1110 1110
                     <?php
1111
-						echo esc_url( admin_url( 'index.php?page=gp-setup' ) );
1112
-					?>
1111
+                        echo esc_url( admin_url( 'index.php?page=gp-setup' ) );
1112
+                    ?>
1113 1113
                     " class="button button-primary"><?php esc_html_e( 'Launch', 'invoicing' ); ?></a>
1114 1114
                 </td>
1115 1115
             </tr>
@@ -1123,19 +1123,19 @@  discard block
 block discarded – undo
1123 1123
 
1124 1124
 
1125 1125
 function wpinv_descriptive_text_callback( $args ) {
1126
-	echo wp_kses_post( $args['desc'] );
1126
+    echo wp_kses_post( $args['desc'] );
1127 1127
 }
1128 1128
 
1129 1129
 function wpinv_raw_html_callback( $args ) {
1130
-	echo wp_kses( $args['desc'], getpaid_allowed_html() );
1130
+    echo wp_kses( $args['desc'], getpaid_allowed_html() );
1131 1131
 }
1132 1132
 
1133 1133
 function wpinv_hook_callback( $args ) {
1134
-	do_action( 'wpinv_' . $args['id'], $args );
1134
+    do_action( 'wpinv_' . $args['id'], $args );
1135 1135
 }
1136 1136
 
1137 1137
 function wpinv_set_settings_cap() {
1138
-	return wpinv_get_capability();
1138
+    return wpinv_get_capability();
1139 1139
 }
1140 1140
 add_filter( 'option_page_capability_wpinv_settings', 'wpinv_set_settings_cap' );
1141 1141
 
@@ -1161,47 +1161,47 @@  discard block
 block discarded – undo
1161 1161
  * @return array
1162 1162
  */
1163 1163
 function wpinv_get_email_merge_tags( $subscription = false ) {
1164
-	$merge_tags = array(
1165
-		'{site_title}'           => __( 'Site Title', 'invoicing' ),
1166
-		'{name}'                 => __( "Customer's full name", 'invoicing' ),
1167
-		'{first_name}'           => __( "Customer's first name", 'invoicing' ),
1168
-		'{last_name}'            => __( "Customer's last name", 'invoicing' ),
1169
-		'{email}'                => __( "Customer's email address", 'invoicing' ),
1170
-		'{invoice_number}'       => __( 'The invoice number', 'invoicing' ),
1171
-		'{invoice_currency}'     => __( 'The invoice currency', 'invoicing' ),
1172
-		'{invoice_total}'        => __( 'The invoice total', 'invoicing' ),
1173
-		'{invoice_link}'         => __( 'The invoice link', 'invoicing' ),
1174
-		'{invoice_pay_link}'     => __( 'The payment link', 'invoicing' ),
1175
-		'{invoice_receipt_link}' => __( 'The receipt link', 'invoicing' ),
1176
-		'{invoice_date}'         => __( 'The date the invoice was created', 'invoicing' ),
1177
-		'{invoice_due_date}'     => __( 'The date the invoice is due', 'invoicing' ),
1178
-		'{date}'                 => __( "Today's date", 'invoicing' ),
1179
-		'{is_was}'               => __( 'If due date of invoice is past, displays "was" otherwise displays "is"', 'invoicing' ),
1180
-		'{invoice_label}'        => __( 'Invoices/quotes singular name. Ex: Invoice/Quote', 'invoicing' ),
1181
-		'{invoice_quote}'        => __( 'Invoices/quotes singular name in small letters. Ex: invoice/quote', 'invoicing' ),
1182
-		'{invoice_description}'  => __( 'The description of the invoice', 'invoicing' ),
1183
-	);
1184
-
1185
-	if ( $subscription ) {
1186
-		$merge_tags = array_merge(
1187
-			$merge_tags,
1188
-			array(
1189
-				'{subscription_renewal_date}'     => __( 'The next renewal date of the subscription', 'invoicing' ),
1190
-				'{subscription_created}'          => __( "The subscription's creation date", 'invoicing' ),
1191
-				'{subscription_status}'           => __( "The subscription's status", 'invoicing' ),
1192
-				'{subscription_profile_id}'       => __( "The subscription's remote profile id", 'invoicing' ),
1193
-				'{subscription_id}'               => __( "The subscription's id", 'invoicing' ),
1194
-				'{subscription_recurring_amount}' => __( 'The renewal amount of the subscription', 'invoicing' ),
1195
-				'{subscription_initial_amount}'   => __( 'The initial amount of the subscription', 'invoicing' ),
1196
-				'{subscription_recurring_period}' => __( 'The recurring period of the subscription (e.g 1 year)', 'invoicing' ),
1197
-				'{subscription_bill_times}'       => __( 'The maximum number of times the subscription can be renewed', 'invoicing' ),
1198
-				'{subscription_url}'              => __( 'The URL to manage a subscription', 'invoicing' ),
1199
-				'{subscription_name}'             => __( 'The name of the recurring item', 'invoicing' ),
1200
-			)
1201
-		);
1202
-	}
1203
-
1204
-	return $merge_tags;
1164
+    $merge_tags = array(
1165
+        '{site_title}'           => __( 'Site Title', 'invoicing' ),
1166
+        '{name}'                 => __( "Customer's full name", 'invoicing' ),
1167
+        '{first_name}'           => __( "Customer's first name", 'invoicing' ),
1168
+        '{last_name}'            => __( "Customer's last name", 'invoicing' ),
1169
+        '{email}'                => __( "Customer's email address", 'invoicing' ),
1170
+        '{invoice_number}'       => __( 'The invoice number', 'invoicing' ),
1171
+        '{invoice_currency}'     => __( 'The invoice currency', 'invoicing' ),
1172
+        '{invoice_total}'        => __( 'The invoice total', 'invoicing' ),
1173
+        '{invoice_link}'         => __( 'The invoice link', 'invoicing' ),
1174
+        '{invoice_pay_link}'     => __( 'The payment link', 'invoicing' ),
1175
+        '{invoice_receipt_link}' => __( 'The receipt link', 'invoicing' ),
1176
+        '{invoice_date}'         => __( 'The date the invoice was created', 'invoicing' ),
1177
+        '{invoice_due_date}'     => __( 'The date the invoice is due', 'invoicing' ),
1178
+        '{date}'                 => __( "Today's date", 'invoicing' ),
1179
+        '{is_was}'               => __( 'If due date of invoice is past, displays "was" otherwise displays "is"', 'invoicing' ),
1180
+        '{invoice_label}'        => __( 'Invoices/quotes singular name. Ex: Invoice/Quote', 'invoicing' ),
1181
+        '{invoice_quote}'        => __( 'Invoices/quotes singular name in small letters. Ex: invoice/quote', 'invoicing' ),
1182
+        '{invoice_description}'  => __( 'The description of the invoice', 'invoicing' ),
1183
+    );
1184
+
1185
+    if ( $subscription ) {
1186
+        $merge_tags = array_merge(
1187
+            $merge_tags,
1188
+            array(
1189
+                '{subscription_renewal_date}'     => __( 'The next renewal date of the subscription', 'invoicing' ),
1190
+                '{subscription_created}'          => __( "The subscription's creation date", 'invoicing' ),
1191
+                '{subscription_status}'           => __( "The subscription's status", 'invoicing' ),
1192
+                '{subscription_profile_id}'       => __( "The subscription's remote profile id", 'invoicing' ),
1193
+                '{subscription_id}'               => __( "The subscription's id", 'invoicing' ),
1194
+                '{subscription_recurring_amount}' => __( 'The renewal amount of the subscription', 'invoicing' ),
1195
+                '{subscription_initial_amount}'   => __( 'The initial amount of the subscription', 'invoicing' ),
1196
+                '{subscription_recurring_period}' => __( 'The recurring period of the subscription (e.g 1 year)', 'invoicing' ),
1197
+                '{subscription_bill_times}'       => __( 'The maximum number of times the subscription can be renewed', 'invoicing' ),
1198
+                '{subscription_url}'              => __( 'The URL to manage a subscription', 'invoicing' ),
1199
+                '{subscription_name}'             => __( 'The name of the recurring item', 'invoicing' ),
1200
+            )
1201
+        );
1202
+    }
1203
+
1204
+    return $merge_tags;
1205 1205
 }
1206 1206
 
1207 1207
 
@@ -1213,28 +1213,28 @@  discard block
 block discarded – undo
1213 1213
  * @return string
1214 1214
  */
1215 1215
 function wpinv_get_merge_tags_help_text( $subscription = false ) {
1216
-	$merge_tags = wpinv_get_email_merge_tags( $subscription );
1216
+    $merge_tags = wpinv_get_email_merge_tags( $subscription );
1217 1217
 
1218
-	$output = '<div class="bsui">';
1218
+    $output = '<div class="bsui">';
1219 1219
 
1220
-	$link = sprintf(
1221
-		'<strong class="getpaid-merge-tags text-primary" role="button">%s</strong>',
1222
-		esc_html__( 'View available merge tags.', 'invoicing' )
1223
-	);
1220
+    $link = sprintf(
1221
+        '<strong class="getpaid-merge-tags text-primary" role="button">%s</strong>',
1222
+        esc_html__( 'View available merge tags.', 'invoicing' )
1223
+    );
1224 1224
 
1225
-	$description = esc_html__( 'The content of the email (Merge Tags and HTML are allowed).', 'invoicing' );
1225
+    $description = esc_html__( 'The content of the email (Merge Tags and HTML are allowed).', 'invoicing' );
1226 1226
 	
1227
-	$output .= "$description $link";
1227
+    $output .= "$description $link";
1228 1228
 
1229
-	$output .= '<div class="getpaid-merge-tags-content mt-2 p-1 d-none">';
1230
-	$output .= '<p class="mb-2">' . esc_html__( 'The following wildcards can be used in email subjects, heading and content:', 'invoicing' ) . '</p>';
1229
+    $output .= '<div class="getpaid-merge-tags-content mt-2 p-1 d-none">';
1230
+    $output .= '<p class="mb-2">' . esc_html__( 'The following wildcards can be used in email subjects, heading and content:', 'invoicing' ) . '</p>';
1231 1231
 
1232
-	$output .= '<ul class="p-0 m-0">';
1233
-	foreach($merge_tags as $tag => $tag_description) {
1234
-		$output .= "<li class='mb-2'><strong class='text-dark'>$tag</strong> &mdash; $tag_description</li>";
1235
-	}
1232
+    $output .= '<ul class="p-0 m-0">';
1233
+    foreach($merge_tags as $tag => $tag_description) {
1234
+        $output .= "<li class='mb-2'><strong class='text-dark'>$tag</strong> &mdash; $tag_description</li>";
1235
+    }
1236 1236
 
1237
-	$output .= '</ul></div></div>';
1237
+    $output .= '</ul></div></div>';
1238 1238
 
1239
-	return $output;
1239
+    return $output;
1240 1240
 }
Please login to merge, or discard this patch.
Spacing   +420 added lines, -420 removed lines patch added patch discarded remove patch
@@ -6,7 +6,7 @@  discard block
 block discarded – undo
6 6
  * @since   1.0.0
7 7
  */
8 8
 
9
-defined( 'ABSPATH' ) || exit;
9
+defined('ABSPATH') || exit;
10 10
 
11 11
 /**
12 12
  * Retrieves all default settings.
@@ -16,13 +16,13 @@  discard block
 block discarded – undo
16 16
 function wpinv_get_settings() {
17 17
     $defaults = array();
18 18
 
19
-    foreach ( array_values( wpinv_get_registered_settings() ) as $tab_settings ) {
19
+    foreach (array_values(wpinv_get_registered_settings()) as $tab_settings) {
20 20
 
21
-        foreach ( array_values( $tab_settings ) as $section_settings ) {
21
+        foreach (array_values($tab_settings) as $section_settings) {
22 22
 
23
-            foreach ( $section_settings as $key => $setting ) {
24
-                if ( isset( $setting['std'] ) ) {
25
-                    $defaults[ $key ] = $setting['std'];
23
+            foreach ($section_settings as $key => $setting) {
24
+                if (isset($setting['std'])) {
25
+                    $defaults[$key] = $setting['std'];
26 26
                 }
27 27
             }
28 28
 		}
@@ -41,12 +41,12 @@  discard block
 block discarded – undo
41 41
     global $wpinv_options;
42 42
 
43 43
     // Try fetching the saved options.
44
-    if ( empty( $wpinv_options ) ) {
45
-        $wpinv_options = get_option( 'wpinv_settings' );
44
+    if (empty($wpinv_options)) {
45
+        $wpinv_options = get_option('wpinv_settings');
46 46
     }
47 47
 
48 48
     // If that fails, don't fetch the default settings to prevent a loop.
49
-    if ( ! is_array( $wpinv_options ) ) {
49
+    if (!is_array($wpinv_options)) {
50 50
         $wpinv_options = array();
51 51
     }
52 52
 
@@ -60,13 +60,13 @@  discard block
 block discarded – undo
60 60
  * @param mixed $default The default value to use if the setting has not been set.
61 61
  * @return mixed
62 62
  */
63
-function wpinv_get_option( $key = '', $default = false ) {
63
+function wpinv_get_option($key = '', $default = false) {
64 64
 
65 65
     $options = wpinv_get_options();
66
-    $value   = isset( $options[ $key ] ) ? $options[ $key ] : $default;
67
-    $value   = apply_filters( 'wpinv_get_option', $value, $key, $default );
66
+    $value   = isset($options[$key]) ? $options[$key] : $default;
67
+    $value   = apply_filters('wpinv_get_option', $value, $key, $default);
68 68
 
69
-    return apply_filters( 'wpinv_get_option_' . $key, $value, $key, $default );
69
+    return apply_filters('wpinv_get_option_' . $key, $value, $key, $default);
70 70
 }
71 71
 
72 72
 /**
@@ -75,11 +75,11 @@  discard block
 block discarded – undo
75 75
  * @param array $options the new options.
76 76
  * @return bool
77 77
  */
78
-function wpinv_update_options( $options ) {
78
+function wpinv_update_options($options) {
79 79
     global $wpinv_options;
80 80
 
81 81
     // update the option.
82
-    if ( is_array( $options ) && update_option( 'wpinv_settings', $options ) ) {
82
+    if (is_array($options) && update_option('wpinv_settings', $options)) {
83 83
         $wpinv_options = $options;
84 84
         return true;
85 85
     }
@@ -94,24 +94,24 @@  discard block
 block discarded – undo
94 94
  * @param mixed $value The setting value.
95 95
  * @return bool
96 96
  */
97
-function wpinv_update_option( $key = '', $value = false ) {
97
+function wpinv_update_option($key = '', $value = false) {
98 98
 
99 99
     // If no key, exit.
100
-    if ( empty( $key ) ) {
100
+    if (empty($key)) {
101 101
         return false;
102 102
     }
103 103
 
104 104
     // Maybe delete the option instead.
105
-    if ( is_null( $value ) ) {
106
-        return wpinv_delete_option( $key );
105
+    if (is_null($value)) {
106
+        return wpinv_delete_option($key);
107 107
     }
108 108
 
109 109
     // Prepare the new options.
110 110
     $options         = wpinv_get_options();
111
-    $options[ $key ] = apply_filters( 'wpinv_update_option', $value, $key );
111
+    $options[$key] = apply_filters('wpinv_update_option', $value, $key);
112 112
 
113 113
     // Save the new options.
114
-    return wpinv_update_options( $options );
114
+    return wpinv_update_options($options);
115 115
 
116 116
 }
117 117
 
@@ -121,18 +121,18 @@  discard block
 block discarded – undo
121 121
  * @param string $key the setting key.
122 122
  * @return bool
123 123
  */
124
-function wpinv_delete_option( $key = '' ) {
124
+function wpinv_delete_option($key = '') {
125 125
 
126 126
     // If no key, exit
127
-    if ( empty( $key ) ) {
127
+    if (empty($key)) {
128 128
         return false;
129 129
     }
130 130
 
131 131
     $options = wpinv_get_options();
132 132
 
133
-    if ( isset( $options[ $key ] ) ) {
134
-        unset( $options[ $key ] );
135
-        return wpinv_update_options( $options );
133
+    if (isset($options[$key])) {
134
+        unset($options[$key]);
135
+        return wpinv_update_options($options);
136 136
     }
137 137
 
138 138
     return true;
@@ -144,22 +144,22 @@  discard block
 block discarded – undo
144 144
  *
145 145
  */
146 146
 function wpinv_register_settings() {
147
-	do_action( 'getpaid_before_register_settings' );
147
+	do_action('getpaid_before_register_settings');
148 148
 
149 149
     // Loop through all tabs.
150
-    foreach ( wpinv_get_registered_settings() as $tab => $sections ) {
150
+    foreach (wpinv_get_registered_settings() as $tab => $sections) {
151 151
 
152 152
         // In each tab, loop through sections.
153
-        foreach ( $sections as $section => $settings ) {
153
+        foreach ($sections as $section => $settings) {
154 154
 
155 155
             // Check for backwards compatibility
156
-            $section_tabs = wpinv_get_settings_tab_sections( $tab );
157
-            if ( ! is_array( $section_tabs ) || ! array_key_exists( $section, $section_tabs ) ) {
156
+            $section_tabs = wpinv_get_settings_tab_sections($tab);
157
+            if (!is_array($section_tabs) || !array_key_exists($section, $section_tabs)) {
158 158
                 $section = 'main';
159 159
                 $settings = $sections;
160 160
             }
161 161
 
162
-			do_action( "getpaid_register_{$tab}_{$section}" );
162
+			do_action("getpaid_register_{$tab}_{$section}");
163 163
 
164 164
             // Register the setting section.
165 165
             add_settings_section(
@@ -169,20 +169,20 @@  discard block
 block discarded – undo
169 169
                 'wpinv_settings_' . $tab . '_' . $section
170 170
             );
171 171
 
172
-            foreach ( $settings as $option ) {
173
-                if ( ! empty( $option['id'] ) ) {
174
-                    wpinv_register_settings_option( $tab, $section, $option );
172
+            foreach ($settings as $option) {
173
+                if (!empty($option['id'])) {
174
+                    wpinv_register_settings_option($tab, $section, $option);
175 175
                 }
176 176
             }
177 177
 }
178 178
     }
179 179
 
180 180
     // Creates our settings in the options table.
181
-    register_setting( 'wpinv_settings', 'wpinv_settings', 'wpinv_settings_sanitize' );
181
+    register_setting('wpinv_settings', 'wpinv_settings', 'wpinv_settings_sanitize');
182 182
 
183
-	do_action( 'getpaid_after_register_settings' );
183
+	do_action('getpaid_after_register_settings');
184 184
 }
185
-add_action( 'admin_init', 'wpinv_register_settings' );
185
+add_action('admin_init', 'wpinv_register_settings');
186 186
 
187 187
 /**
188 188
  * Register a single settings option.
@@ -192,49 +192,49 @@  discard block
 block discarded – undo
192 192
  * @param string $option
193 193
  *
194 194
  */
195
-function wpinv_register_settings_option( $tab, $section, $option ) {
195
+function wpinv_register_settings_option($tab, $section, $option) {
196 196
 
197
-    $name       = isset( $option['name'] ) ? $option['name'] : '';
197
+    $name       = isset($option['name']) ? $option['name'] : '';
198 198
     $cb         = "wpinv_{$option['type']}_callback";
199 199
     $section    = "wpinv_settings_{$tab}_$section";
200
-	$is_wizzard = is_admin() && isset( $_GET['page'] ) && 'gp-setup' == $_GET['page'];
200
+	$is_wizzard = is_admin() && isset($_GET['page']) && 'gp-setup' == $_GET['page'];
201 201
 
202
-	if ( isset( $option['desc'] ) && ( ! $is_wizzard && ! empty( $option['help-tip'] ) ) ) {
203
-		$tip   = wpinv_clean( $option['desc'] );
202
+	if (isset($option['desc']) && (!$is_wizzard && !empty($option['help-tip']))) {
203
+		$tip   = wpinv_clean($option['desc']);
204 204
 		$name .= "<span class='dashicons dashicons-editor-help wpi-help-tip' title='$tip'></span>";
205
-		unset( $option['desc'] );
205
+		unset($option['desc']);
206 206
 	}
207 207
 
208 208
     // Loop through all tabs.
209 209
     add_settings_field(
210 210
         'wpinv_settings[' . $option['id'] . ']',
211 211
         $name,
212
-        function_exists( $cb ) ? $cb : 'wpinv_missing_callback',
212
+        function_exists($cb) ? $cb : 'wpinv_missing_callback',
213 213
         $section,
214 214
         $section,
215 215
         array(
216 216
             'section'         => $section,
217
-            'id'              => isset( $option['id'] ) ? $option['id'] : uniqid( 'wpinv-' ),
218
-            'desc'            => isset( $option['desc'] ) ? $option['desc'] : '',
217
+            'id'              => isset($option['id']) ? $option['id'] : uniqid('wpinv-'),
218
+            'desc'            => isset($option['desc']) ? $option['desc'] : '',
219 219
             'name'            => $name,
220
-            'size'            => isset( $option['size'] ) ? $option['size'] : null,
221
-            'options'         => isset( $option['options'] ) ? $option['options'] : '',
222
-            'selected'        => isset( $option['selected'] ) ? $option['selected'] : null,
223
-            'std'             => isset( $option['std'] ) ? $option['std'] : '',
224
-            'min'             => isset( $option['min'] ) ? $option['min'] : 0,
225
-            'max'             => isset( $option['max'] ) ? $option['max'] : 999999,
226
-            'step'            => isset( $option['step'] ) ? $option['step'] : 1,
227
-            'placeholder'     => isset( $option['placeholder'] ) ? $option['placeholder'] : null,
228
-            'allow_blank'     => isset( $option['allow_blank'] ) ? $option['allow_blank'] : true,
229
-            'readonly'        => isset( $option['readonly'] ) ? $option['readonly'] : false,
230
-            'faux'            => isset( $option['faux'] ) ? $option['faux'] : false,
231
-            'onchange'        => isset( $option['onchange'] ) ? $option['onchange'] : '',
232
-            'custom'          => isset( $option['custom'] ) ? $option['custom'] : '',
233
-			'default_content' => isset( $option['default_content'] ) ? $option['default_content'] : '',
234
-			'class'           => isset( $option['class'] ) ? $option['class'] : '',
235
-			'style'           => isset( $option['style'] ) ? $option['style'] : '',
236
-            'cols'            => isset( $option['cols'] ) && (int) $option['cols'] > 0 ? (int) $option['cols'] : 50,
237
-            'rows'            => isset( $option['rows'] ) && (int) $option['rows'] > 0 ? (int) $option['rows'] : 5,
220
+            'size'            => isset($option['size']) ? $option['size'] : null,
221
+            'options'         => isset($option['options']) ? $option['options'] : '',
222
+            'selected'        => isset($option['selected']) ? $option['selected'] : null,
223
+            'std'             => isset($option['std']) ? $option['std'] : '',
224
+            'min'             => isset($option['min']) ? $option['min'] : 0,
225
+            'max'             => isset($option['max']) ? $option['max'] : 999999,
226
+            'step'            => isset($option['step']) ? $option['step'] : 1,
227
+            'placeholder'     => isset($option['placeholder']) ? $option['placeholder'] : null,
228
+            'allow_blank'     => isset($option['allow_blank']) ? $option['allow_blank'] : true,
229
+            'readonly'        => isset($option['readonly']) ? $option['readonly'] : false,
230
+            'faux'            => isset($option['faux']) ? $option['faux'] : false,
231
+            'onchange'        => isset($option['onchange']) ? $option['onchange'] : '',
232
+            'custom'          => isset($option['custom']) ? $option['custom'] : '',
233
+			'default_content' => isset($option['default_content']) ? $option['default_content'] : '',
234
+			'class'           => isset($option['class']) ? $option['class'] : '',
235
+			'style'           => isset($option['style']) ? $option['style'] : '',
236
+            'cols'            => isset($option['cols']) && (int) $option['cols'] > 0 ? (int) $option['cols'] : 50,
237
+            'rows'            => isset($option['rows']) && (int) $option['rows'] > 0 ? (int) $option['rows'] : 5,
238 238
         )
239 239
     );
240 240
 
@@ -246,7 +246,7 @@  discard block
 block discarded – undo
246 246
  * @return array
247 247
  */
248 248
 function wpinv_get_registered_settings() {
249
-	return array_filter( apply_filters( 'wpinv_registered_settings', wpinv_get_data( 'admin-settings' ) ) );
249
+	return array_filter(apply_filters('wpinv_registered_settings', wpinv_get_data('admin-settings')));
250 250
 }
251 251
 
252 252
 /**
@@ -255,7 +255,7 @@  discard block
 block discarded – undo
255 255
  * @return array
256 256
  */
257 257
 function getpaid_get_integration_settings() {
258
-    return apply_filters( 'getpaid_integration_settings', array() );
258
+    return apply_filters('getpaid_integration_settings', array());
259 259
 }
260 260
 
261 261
 /**
@@ -263,153 +263,153 @@  discard block
 block discarded – undo
263 263
  *
264 264
  * @return array
265 265
  */
266
-function wpinv_settings_sanitize( $input = array() ) {
266
+function wpinv_settings_sanitize($input = array()) {
267 267
 
268 268
 	$wpinv_options = wpinv_get_options();
269 269
 	$raw_referrer  = wp_get_raw_referer();
270 270
 
271
-    if ( empty( $raw_referrer ) ) {
272
-		return array_merge( $wpinv_options, $input );
271
+    if (empty($raw_referrer)) {
272
+		return array_merge($wpinv_options, $input);
273 273
     }
274 274
 
275
-    wp_parse_str( $raw_referrer, $referrer );
275
+    wp_parse_str($raw_referrer, $referrer);
276 276
 
277
-	if ( in_array( 'gp-setup', $referrer ) ) {
278
-		return array_merge( $wpinv_options, $input );
277
+	if (in_array('gp-setup', $referrer)) {
278
+		return array_merge($wpinv_options, $input);
279 279
 	}
280 280
 
281 281
     $settings = wpinv_get_registered_settings();
282
-    $tab      = isset( $referrer['tab'] ) ? $referrer['tab'] : 'general';
283
-    $section  = isset( $referrer['section'] ) ? $referrer['section'] : 'main';
282
+    $tab      = isset($referrer['tab']) ? $referrer['tab'] : 'general';
283
+    $section  = isset($referrer['section']) ? $referrer['section'] : 'main';
284 284
 
285 285
     $input = $input ? $input : array();
286
-    $input = apply_filters( 'wpinv_settings_tab_' . $tab . '_sanitize', $input );
287
-    $input = apply_filters( 'wpinv_settings_' . $tab . '-' . $section . '_sanitize', $input );
286
+    $input = apply_filters('wpinv_settings_tab_' . $tab . '_sanitize', $input);
287
+    $input = apply_filters('wpinv_settings_' . $tab . '-' . $section . '_sanitize', $input);
288 288
 
289 289
     // Loop through each setting being saved and pass it through a sanitization filter
290
-    foreach ( $input as $key => $value ) {
290
+    foreach ($input as $key => $value) {
291 291
 
292 292
         // Get the setting type (checkbox, select, etc)
293
-        $type = isset( $settings[ $tab ][ $section ][ $key ]['type'] ) ? $settings[ $tab ][ $section ][ $key ]['type'] : false;
293
+        $type = isset($settings[$tab][$section][$key]['type']) ? $settings[$tab][$section][$key]['type'] : false;
294 294
 
295
-        if ( $type ) {
295
+        if ($type) {
296 296
             // Field type specific filter
297
-            $input[ $key ] = apply_filters( "wpinv_settings_sanitize_$type", $value, $key );
297
+            $input[$key] = apply_filters("wpinv_settings_sanitize_$type", $value, $key);
298 298
         }
299 299
 
300 300
         // General filter
301
-		$input[ $key ] = apply_filters( 'wpinv_settings_sanitize', $input[ $key ], $key );
301
+		$input[$key] = apply_filters('wpinv_settings_sanitize', $input[$key], $key);
302 302
 
303 303
 		// Key specific filter.
304
-		$input[ $key ] = apply_filters( "wpinv_settings_sanitize_$key", $input[ $key ] );
304
+		$input[$key] = apply_filters("wpinv_settings_sanitize_$key", $input[$key]);
305 305
     }
306 306
 
307 307
     // Loop through the whitelist and unset any that are empty for the tab being saved
308
-    $main_settings    = isset( $settings[ $tab ] ) ? $settings[ $tab ] : array(); // Check for extensions that aren't using new sections
309
-    $section_settings = ! empty( $settings[ $tab ][ $section ] ) ? $settings[ $tab ][ $section ] : array();
308
+    $main_settings    = isset($settings[$tab]) ? $settings[$tab] : array(); // Check for extensions that aren't using new sections
309
+    $section_settings = !empty($settings[$tab][$section]) ? $settings[$tab][$section] : array();
310 310
 
311
-    $found_settings   = array_merge( $main_settings, $section_settings );
311
+    $found_settings   = array_merge($main_settings, $section_settings);
312 312
 
313
-    if ( ! empty( $found_settings ) ) {
314
-        foreach ( $found_settings as $key => $value ) {
313
+    if (!empty($found_settings)) {
314
+        foreach ($found_settings as $key => $value) {
315 315
 
316 316
             // settings used to have numeric keys, now they have keys that match the option ID. This ensures both methods work
317
-            if ( is_numeric( $key ) ) {
317
+            if (is_numeric($key)) {
318 318
                 $key = $value['id'];
319 319
             }
320 320
 
321
-            if ( ! isset( $input[ $key ] ) && isset( $wpinv_options[ $key ] ) ) {
322
-                unset( $wpinv_options[ $key ] );
321
+            if (!isset($input[$key]) && isset($wpinv_options[$key])) {
322
+                unset($wpinv_options[$key]);
323 323
             }
324 324
         }
325 325
     }
326 326
 
327 327
     // Merge our new settings with the existing
328
-    $output = array_merge( $wpinv_options, $input );
328
+    $output = array_merge($wpinv_options, $input);
329 329
 
330
-    add_settings_error( 'wpinv-notices', '', __( 'Settings updated.', 'invoicing' ), 'updated' );
330
+    add_settings_error('wpinv-notices', '', __('Settings updated.', 'invoicing'), 'updated');
331 331
 
332 332
     return $output;
333 333
 }
334
-add_filter( 'wpinv_settings_sanitize_text', 'trim', 10, 1 );
335
-add_filter( 'wpinv_settings_sanitize_tax_rate', 'wpinv_sanitize_amount' );
334
+add_filter('wpinv_settings_sanitize_text', 'trim', 10, 1);
335
+add_filter('wpinv_settings_sanitize_tax_rate', 'wpinv_sanitize_amount');
336 336
 
337
-function wpinv_settings_sanitize_tax_rates( $input ) {
338
-    if ( ! wpinv_current_user_can_manage_invoicing() ) {
337
+function wpinv_settings_sanitize_tax_rates($input) {
338
+    if (!wpinv_current_user_can_manage_invoicing()) {
339 339
         return $input;
340 340
     }
341 341
 
342
-    $new_rates = ! empty( $_POST['tax_rates'] ) ? wp_kses_post_deep( array_values( $_POST['tax_rates'] ) ) : array();
342
+    $new_rates = !empty($_POST['tax_rates']) ? wp_kses_post_deep(array_values($_POST['tax_rates'])) : array();
343 343
     $tax_rates = array();
344 344
 
345
-    foreach ( $new_rates as $rate ) {
345
+    foreach ($new_rates as $rate) {
346 346
 
347
-		$rate['rate']    = wpinv_sanitize_amount( $rate['rate'] );
348
-		$rate['name']    = sanitize_text_field( $rate['name'] );
349
-		$rate['state']   = sanitize_text_field( $rate['state'] );
350
-		$rate['country'] = sanitize_text_field( $rate['country'] );
351
-		$rate['global']  = empty( $rate['state'] );
347
+		$rate['rate']    = wpinv_sanitize_amount($rate['rate']);
348
+		$rate['name']    = sanitize_text_field($rate['name']);
349
+		$rate['state']   = sanitize_text_field($rate['state']);
350
+		$rate['country'] = sanitize_text_field($rate['country']);
351
+		$rate['global']  = empty($rate['state']);
352 352
 		$tax_rates[]     = $rate;
353 353
 
354 354
 	}
355 355
 
356
-    update_option( 'wpinv_tax_rates', $tax_rates );
356
+    update_option('wpinv_tax_rates', $tax_rates);
357 357
 
358 358
     return $input;
359 359
 }
360
-add_filter( 'wpinv_settings_taxes-rates_sanitize', 'wpinv_settings_sanitize_tax_rates' );
360
+add_filter('wpinv_settings_taxes-rates_sanitize', 'wpinv_settings_sanitize_tax_rates');
361 361
 
362
-function wpinv_settings_sanitize_tax_rules( $input ) {
363
-    if ( ! wpinv_current_user_can_manage_invoicing() ) {
362
+function wpinv_settings_sanitize_tax_rules($input) {
363
+    if (!wpinv_current_user_can_manage_invoicing()) {
364 364
         return $input;
365 365
     }
366 366
 
367
-	if ( empty( $_POST['wpinv_tax_rules_nonce'] ) || ! wp_verify_nonce( $_POST['wpinv_tax_rules_nonce'], 'wpinv_tax_rules' ) ) {
367
+	if (empty($_POST['wpinv_tax_rules_nonce']) || !wp_verify_nonce($_POST['wpinv_tax_rules_nonce'], 'wpinv_tax_rules')) {
368 368
 		return $input;
369 369
 	}
370 370
 
371
-    $new_rules = ! empty( $_POST['tax_rules'] ) ? wp_kses_post_deep( array_values( $_POST['tax_rules'] ) ) : array();
371
+    $new_rules = !empty($_POST['tax_rules']) ? wp_kses_post_deep(array_values($_POST['tax_rules'])) : array();
372 372
     $tax_rules = array();
373 373
 
374
-    foreach ( $new_rules as $rule ) {
374
+    foreach ($new_rules as $rule) {
375 375
 
376
-		$rule['key']      = sanitize_title_with_dashes( $rule['key'] );
377
-		$rule['label']    = sanitize_text_field( $rule['label'] );
378
-		$rule['tax_base'] = sanitize_text_field( $rule['tax_base'] );
376
+		$rule['key']      = sanitize_title_with_dashes($rule['key']);
377
+		$rule['label']    = sanitize_text_field($rule['label']);
378
+		$rule['tax_base'] = sanitize_text_field($rule['tax_base']);
379 379
 		$tax_rules[]      = $rule;
380 380
 
381 381
 	}
382 382
 
383
-    update_option( 'wpinv_tax_rules', $tax_rules );
383
+    update_option('wpinv_tax_rules', $tax_rules);
384 384
 
385 385
     return $input;
386 386
 }
387
-add_filter( 'wpinv_settings_taxes-rules_sanitize', 'wpinv_settings_sanitize_tax_rules' );
387
+add_filter('wpinv_settings_taxes-rules_sanitize', 'wpinv_settings_sanitize_tax_rules');
388 388
 
389 389
 function wpinv_get_settings_tabs() {
390 390
     $tabs             = array();
391
-    $tabs['general']  = __( 'General', 'invoicing' );
392
-    $tabs['gateways'] = __( 'Payment Gateways', 'invoicing' );
393
-    $tabs['taxes']    = __( 'Taxes', 'invoicing' );
394
-	$tabs['emails']   = __( 'Emails', 'invoicing' );
391
+    $tabs['general']  = __('General', 'invoicing');
392
+    $tabs['gateways'] = __('Payment Gateways', 'invoicing');
393
+    $tabs['taxes']    = __('Taxes', 'invoicing');
394
+	$tabs['emails'] = __('Emails', 'invoicing');
395 395
 
396
-	if ( count( getpaid_get_integration_settings() ) > 0 ) {
397
-		$tabs['integrations'] = __( 'Integrations', 'invoicing' );
396
+	if (count(getpaid_get_integration_settings()) > 0) {
397
+		$tabs['integrations'] = __('Integrations', 'invoicing');
398 398
 	}
399 399
 
400
-    $tabs['privacy']  = __( 'Privacy', 'invoicing' );
401
-    $tabs['misc']     = __( 'Misc', 'invoicing' );
402
-    $tabs['tools']    = __( 'Tools', 'invoicing' );
400
+    $tabs['privacy']  = __('Privacy', 'invoicing');
401
+    $tabs['misc']     = __('Misc', 'invoicing');
402
+    $tabs['tools']    = __('Tools', 'invoicing');
403 403
 
404
-    return apply_filters( 'wpinv_settings_tabs', $tabs );
404
+    return apply_filters('wpinv_settings_tabs', $tabs);
405 405
 }
406 406
 
407
-function wpinv_get_settings_tab_sections( $tab = false ) {
407
+function wpinv_get_settings_tab_sections($tab = false) {
408 408
     $tabs     = false;
409 409
     $sections = wpinv_get_registered_settings_sections();
410 410
 
411
-    if ( $tab && ! empty( $sections[ $tab ] ) ) {
412
-        $tabs = $sections[ $tab ];
411
+    if ($tab && !empty($sections[$tab])) {
412
+        $tabs = $sections[$tab];
413 413
     }
414 414
 
415 415
     return $tabs;
@@ -418,7 +418,7 @@  discard block
 block discarded – undo
418 418
 function wpinv_get_registered_settings_sections() {
419 419
     static $sections = false;
420 420
 
421
-    if ( false !== $sections ) {
421
+    if (false !== $sections) {
422 422
         return $sections;
423 423
     }
424 424
 
@@ -426,229 +426,229 @@  discard block
 block discarded – undo
426 426
         'general'      => apply_filters(
427 427
             'wpinv_settings_sections_general',
428 428
             array(
429
-				'main'             => __( 'General Settings', 'invoicing' ),
430
-				'page_section'     => __( 'Page Settings', 'invoicing' ),
431
-				'currency_section' => __( 'Currency Settings', 'invoicing' ),
432
-				'labels'           => __( 'Label Texts', 'invoicing' ),
429
+				'main'             => __('General Settings', 'invoicing'),
430
+				'page_section'     => __('Page Settings', 'invoicing'),
431
+				'currency_section' => __('Currency Settings', 'invoicing'),
432
+				'labels'           => __('Label Texts', 'invoicing'),
433 433
             )
434 434
         ),
435 435
         'gateways'     => apply_filters(
436 436
             'wpinv_settings_sections_gateways',
437 437
             array(
438
-				'main' => __( 'Gateway Settings', 'invoicing' ),
438
+				'main' => __('Gateway Settings', 'invoicing'),
439 439
             )
440 440
         ),
441 441
         'taxes'        => apply_filters(
442 442
             'wpinv_settings_sections_taxes',
443 443
             array(
444
-				'main'  => __( 'Tax Settings', 'invoicing' ),
445
-				'rules' => __( 'Tax Rules', 'invoicing' ),
446
-				'rates' => __( 'Tax Rates', 'invoicing' ),
447
-				'vat'   => __( 'EU VAT Settings', 'invoicing' ),
444
+				'main'  => __('Tax Settings', 'invoicing'),
445
+				'rules' => __('Tax Rules', 'invoicing'),
446
+				'rates' => __('Tax Rates', 'invoicing'),
447
+				'vat'   => __('EU VAT Settings', 'invoicing'),
448 448
             )
449 449
         ),
450 450
         'emails'       => apply_filters(
451 451
             'wpinv_settings_sections_emails',
452 452
             array(
453
-				'main' => __( 'Email Settings', 'invoicing' ),
453
+				'main' => __('Email Settings', 'invoicing'),
454 454
             )
455 455
         ),
456 456
 
457
-		'integrations' => wp_list_pluck( getpaid_get_integration_settings(), 'label', 'id' ),
457
+		'integrations' => wp_list_pluck(getpaid_get_integration_settings(), 'label', 'id'),
458 458
 
459 459
         'privacy'      => apply_filters(
460 460
             'wpinv_settings_sections_privacy',
461 461
             array(
462
-				'main' => __( 'Privacy policy', 'invoicing' ),
462
+				'main' => __('Privacy policy', 'invoicing'),
463 463
             )
464 464
         ),
465 465
         'misc'         => apply_filters(
466 466
             'wpinv_settings_sections_misc',
467 467
             array(
468
-				'main'       => __( 'Miscellaneous', 'invoicing' ),
469
-				'custom-css' => __( 'Custom CSS', 'invoicing' ),
468
+				'main'       => __('Miscellaneous', 'invoicing'),
469
+				'custom-css' => __('Custom CSS', 'invoicing'),
470 470
             )
471 471
         ),
472 472
         'tools'        => apply_filters(
473 473
             'wpinv_settings_sections_tools',
474 474
             array(
475
-				'main' => __( 'Diagnostic Tools', 'invoicing' ),
475
+				'main' => __('Diagnostic Tools', 'invoicing'),
476 476
             )
477 477
         ),
478 478
     );
479 479
 
480
-    $sections = apply_filters( 'wpinv_settings_sections', $sections );
480
+    $sections = apply_filters('wpinv_settings_sections', $sections);
481 481
 
482 482
     return $sections;
483 483
 }
484 484
 
485
-function wpinv_get_pages( $with_slug = false, $default_label = null ) {
485
+function wpinv_get_pages($with_slug = false, $default_label = null) {
486 486
 	$pages_options = array();
487 487
 
488
-	if ( $default_label !== null && $default_label !== false ) {
489
-		$pages_options = array( '' => $default_label ); // Blank option
488
+	if ($default_label !== null && $default_label !== false) {
489
+		$pages_options = array('' => $default_label); // Blank option
490 490
 	}
491 491
 
492 492
 	$pages = get_pages();
493
-	if ( $pages ) {
494
-		foreach ( $pages as $page ) {
493
+	if ($pages) {
494
+		foreach ($pages as $page) {
495 495
 			$title = $with_slug ? $page->post_title . ' (' . $page->post_name . ')' : $page->post_title;
496
-            $pages_options[ $page->ID ] = $title;
496
+            $pages_options[$page->ID] = $title;
497 497
 		}
498 498
 	}
499 499
 
500 500
 	return $pages_options;
501 501
 }
502 502
 
503
-function wpinv_header_callback( $args ) {
504
-	if ( ! empty( $args['desc'] ) ) {
505
-        echo wp_kses_post( $args['desc'] );
503
+function wpinv_header_callback($args) {
504
+	if (!empty($args['desc'])) {
505
+        echo wp_kses_post($args['desc']);
506 506
     }
507 507
 }
508 508
 
509
-function wpinv_hidden_callback( $args ) {
509
+function wpinv_hidden_callback($args) {
510 510
 
511
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
512
-	$value   = wpinv_get_option( $args['id'], $std );
511
+	$std     = isset($args['std']) ? $args['std'] : '';
512
+	$value   = wpinv_get_option($args['id'], $std);
513 513
 
514
-	if ( isset( $args['set_value'] ) ) {
514
+	if (isset($args['set_value'])) {
515 515
 		$value = $args['set_value'];
516 516
 	}
517 517
 
518
-	if ( isset( $args['faux'] ) && true === $args['faux'] ) {
518
+	if (isset($args['faux']) && true === $args['faux']) {
519 519
 		$args['readonly'] = true;
520
-		$name  = '';
520
+		$name = '';
521 521
 	} else {
522
-		$name = 'wpinv_settings[' . esc_attr( $args['id'] ) . ']';
522
+		$name = 'wpinv_settings[' . esc_attr($args['id']) . ']';
523 523
 	}
524 524
 
525
-	echo '<input type="hidden" id="wpinv_settings[' . esc_attr( $args['id'] ) . ']" name="' . esc_attr( $name ) . '" value="' . esc_attr( stripslashes( $value ) ) . '" />';
525
+	echo '<input type="hidden" id="wpinv_settings[' . esc_attr($args['id']) . ']" name="' . esc_attr($name) . '" value="' . esc_attr(stripslashes($value)) . '" />';
526 526
 
527 527
 }
528 528
 
529 529
 /**
530 530
  * Displays a checkbox settings callback.
531 531
  */
532
-function wpinv_checkbox_callback( $args ) {
532
+function wpinv_checkbox_callback($args) {
533 533
 
534
-	$std = isset( $args['std'] ) ? $args['std'] : '';
535
-	$std = wpinv_get_option( $args['id'], $std );
536
-	$id  = esc_attr( $args['id'] );
534
+	$std = isset($args['std']) ? $args['std'] : '';
535
+	$std = wpinv_get_option($args['id'], $std);
536
+	$id  = esc_attr($args['id']);
537 537
 
538
-	getpaid_hidden_field( "wpinv_settings[$id]", '0' );
538
+	getpaid_hidden_field("wpinv_settings[$id]", '0');
539 539
 	?>
540 540
 		<label>
541
-			<input id="wpinv-settings-<?php echo esc_attr( $id ); ?>" name="wpinv_settings[<?php echo esc_attr( $id ); ?>]" <?php checked( empty( $std ), false ); ?> value="1" type="checkbox" />
542
-			<?php echo wp_kses_post( $args['desc'] ); ?>
541
+			<input id="wpinv-settings-<?php echo esc_attr($id); ?>" name="wpinv_settings[<?php echo esc_attr($id); ?>]" <?php checked(empty($std), false); ?> value="1" type="checkbox" />
542
+			<?php echo wp_kses_post($args['desc']); ?>
543 543
 		</label>
544 544
 	<?php
545 545
 }
546 546
 
547
-function wpinv_multicheck_callback( $args ) {
547
+function wpinv_multicheck_callback($args) {
548 548
 
549
-	$sanitize_id = wpinv_sanitize_key( $args['id'] );
550
-	$class = ! empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
549
+	$sanitize_id = wpinv_sanitize_key($args['id']);
550
+	$class = !empty($args['class']) ? ' ' . esc_attr($args['class']) : '';
551 551
 
552
-	if ( ! empty( $args['options'] ) ) {
552
+	if (!empty($args['options'])) {
553 553
 
554
-		$std     = isset( $args['std'] ) ? $args['std'] : array();
555
-		$value   = wpinv_get_option( $args['id'], $std );
554
+		$std     = isset($args['std']) ? $args['std'] : array();
555
+		$value   = wpinv_get_option($args['id'], $std);
556 556
 
557
-		echo '<div class="wpi-mcheck-rows wpi-mcheck-' . esc_attr( $sanitize_id . $class ) . '">';
558
-        foreach ( $args['options'] as $key => $option ) :
559
-			$sanitize_key = esc_attr( wpinv_sanitize_key( $key ) );
560
-			if ( in_array( $sanitize_key, $value ) ) {
557
+		echo '<div class="wpi-mcheck-rows wpi-mcheck-' . esc_attr($sanitize_id . $class) . '">';
558
+        foreach ($args['options'] as $key => $option) :
559
+			$sanitize_key = esc_attr(wpinv_sanitize_key($key));
560
+			if (in_array($sanitize_key, $value)) {
561 561
 				$enabled = $sanitize_key;
562 562
 			} else {
563 563
 				$enabled = null;
564 564
 			}
565
-			echo '<div class="wpi-mcheck-row"><input name="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" id="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" type="checkbox" value="' . esc_attr( $sanitize_key ) . '" ' . checked( $sanitize_key, $enabled, false ) . '/>&nbsp;';
566
-			echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']">' . wp_kses_post( $option ) . '</label></div>';
565
+			echo '<div class="wpi-mcheck-row"><input name="wpinv_settings[' . esc_attr($sanitize_id) . '][' . esc_attr($sanitize_key) . ']" id="wpinv_settings[' . esc_attr($sanitize_id) . '][' . esc_attr($sanitize_key) . ']" type="checkbox" value="' . esc_attr($sanitize_key) . '" ' . checked($sanitize_key, $enabled, false) . '/>&nbsp;';
566
+			echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . '][' . esc_attr($sanitize_key) . ']">' . wp_kses_post($option) . '</label></div>';
567 567
 		endforeach;
568 568
 		echo '</div>';
569
-		echo '<p class="description">' . wp_kses_post( $args['desc'] ) . '</p>';
569
+		echo '<p class="description">' . wp_kses_post($args['desc']) . '</p>';
570 570
 	}
571 571
 }
572 572
 
573
-function wpinv_payment_icons_callback( $args ) {
573
+function wpinv_payment_icons_callback($args) {
574 574
 
575
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
576
-	$value   = wpinv_get_option( $args['id'], false );
575
+    $sanitize_id = wpinv_sanitize_key($args['id']);
576
+	$value = wpinv_get_option($args['id'], false);
577 577
 
578
-	if ( ! empty( $args['options'] ) ) {
579
-		foreach ( $args['options'] as $key => $option ) {
580
-            $sanitize_key = wpinv_sanitize_key( $key );
578
+	if (!empty($args['options'])) {
579
+		foreach ($args['options'] as $key => $option) {
580
+            $sanitize_key = wpinv_sanitize_key($key);
581 581
 
582
-			if ( empty( $value ) ) {
582
+			if (empty($value)) {
583 583
 				$enabled = $option;
584 584
 			} else {
585 585
 				$enabled = null;
586 586
 			}
587 587
 
588
-			echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" style="margin-right:10px;line-height:16px;height:16px;display:inline-block;">';
588
+			echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . '][' . esc_attr($sanitize_key) . ']" style="margin-right:10px;line-height:16px;height:16px;display:inline-block;">';
589 589
 
590
-				echo '<input name="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" id="wpinv_settings[' . esc_attr( $sanitize_id ) . '][' . esc_attr( $sanitize_key ) . ']" type="checkbox" value="' . esc_attr( $option ) . '" ' . checked( $option, $enabled, false ) . '/>&nbsp;';
590
+				echo '<input name="wpinv_settings[' . esc_attr($sanitize_id) . '][' . esc_attr($sanitize_key) . ']" id="wpinv_settings[' . esc_attr($sanitize_id) . '][' . esc_attr($sanitize_key) . ']" type="checkbox" value="' . esc_attr($option) . '" ' . checked($option, $enabled, false) . '/>&nbsp;';
591 591
 
592
-				if ( wpinv_string_is_image_url( $key ) ) {
593
-				echo '<img class="payment-icon" src="' . esc_url( $key ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
592
+				if (wpinv_string_is_image_url($key)) {
593
+				echo '<img class="payment-icon" src="' . esc_url($key) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
594 594
 				} else {
595
-				$card = strtolower( str_replace( ' ', '', $option ) );
595
+				$card = strtolower(str_replace(' ', '', $option));
596 596
 
597
-				if ( has_filter( 'wpinv_accepted_payment_' . $card . '_image' ) ) {
598
-					$image = apply_filters( 'wpinv_accepted_payment_' . $card . '_image', '' );
597
+				if (has_filter('wpinv_accepted_payment_' . $card . '_image')) {
598
+					$image = apply_filters('wpinv_accepted_payment_' . $card . '_image', '');
599 599
 					} else {
600
-					$image       = wpinv_locate_template( 'images' . DIRECTORY_SEPARATOR . 'icons' . DIRECTORY_SEPARATOR . $card . '.gif', false );
600
+					$image       = wpinv_locate_template('images' . DIRECTORY_SEPARATOR . 'icons' . DIRECTORY_SEPARATOR . $card . '.gif', false);
601 601
 					$content_dir = WP_CONTENT_DIR;
602 602
 
603
-					if ( function_exists( 'wp_normalize_path' ) ) {
603
+					if (function_exists('wp_normalize_path')) {
604 604
 						// Replaces backslashes with forward slashes for Windows systems
605
-						$image = wp_normalize_path( $image );
606
-						$content_dir = wp_normalize_path( $content_dir );
605
+						$image = wp_normalize_path($image);
606
+						$content_dir = wp_normalize_path($content_dir);
607 607
 						}
608 608
 
609
-					$image = str_replace( $content_dir, content_url(), $image );
609
+					$image = str_replace($content_dir, content_url(), $image);
610 610
 					}
611 611
 
612
-				echo '<img class="payment-icon" src="' . esc_url( $image ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
612
+				echo '<img class="payment-icon" src="' . esc_url($image) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
613 613
 				}
614
-			echo wp_kses_post( $option ) . '</label>';
614
+			echo wp_kses_post($option) . '</label>';
615 615
 		}
616
-		echo '<p class="description" style="margin-top:16px;">' . wp_kses_post( $args['desc'] ) . '</p>';
616
+		echo '<p class="description" style="margin-top:16px;">' . wp_kses_post($args['desc']) . '</p>';
617 617
 	}
618 618
 }
619 619
 
620 620
 /**
621 621
  * Displays a radio settings field.
622 622
  */
623
-function wpinv_radio_callback( $args ) {
623
+function wpinv_radio_callback($args) {
624 624
 
625
-	$std = isset( $args['std'] ) ? $args['std'] : '';
626
-	$std = wpinv_get_option( $args['id'], $std );
625
+	$std = isset($args['std']) ? $args['std'] : '';
626
+	$std = wpinv_get_option($args['id'], $std);
627 627
 	?>
628 628
 		<fieldset>
629
-			<ul id="wpinv-settings-<?php echo esc_attr( $args['id'] ); ?>" style="margin-top: 0;">
630
-				<?php foreach ( $args['options'] as $key => $option ) : ?>
629
+			<ul id="wpinv-settings-<?php echo esc_attr($args['id']); ?>" style="margin-top: 0;">
630
+				<?php foreach ($args['options'] as $key => $option) : ?>
631 631
 					<li>
632 632
 						<label>
633
-							<input name="wpinv_settings[<?php echo esc_attr( $args['id'] ); ?>]" <?php checked( $std, $key ); ?> value="<?php echo esc_attr( $key ); ?>" type="radio">
634
-							<?php echo wp_kses_post( $option ); ?>
633
+							<input name="wpinv_settings[<?php echo esc_attr($args['id']); ?>]" <?php checked($std, $key); ?> value="<?php echo esc_attr($key); ?>" type="radio">
634
+							<?php echo wp_kses_post($option); ?>
635 635
 						</label>
636 636
 					</li>
637 637
 				<?php endforeach; ?>
638 638
 			</ul>
639 639
 		</fieldset>
640 640
 	<?php
641
-	getpaid_settings_description_callback( $args );
641
+	getpaid_settings_description_callback($args);
642 642
 }
643 643
 
644 644
 /**
645 645
  * Displays a description if available.
646 646
  */
647
-function getpaid_settings_description_callback( $args ) {
647
+function getpaid_settings_description_callback($args) {
648 648
 
649
-	if ( ! empty( $args['desc'] ) ) {
649
+	if (!empty($args['desc'])) {
650 650
 		$description = $args['desc'];
651
-		echo wp_kses_post( "<p class='description'>$description</p>" );
651
+		echo wp_kses_post("<p class='description'>$description</p>");
652 652
 	}
653 653
 
654 654
 }
@@ -663,35 +663,35 @@  discard block
 block discarded – undo
663 663
 	</tr>
664 664
 	<tr class="bsui">
665 665
     	<td colspan="2" class="p-0">
666
-			<?php include plugin_dir_path( __FILE__ ) . 'views/html-gateways-edit.php'; ?>
666
+			<?php include plugin_dir_path(__FILE__) . 'views/html-gateways-edit.php'; ?>
667 667
 
668 668
 	<?php
669 669
 }
670 670
 
671
-function wpinv_gateway_select_callback( $args ) {
671
+function wpinv_gateway_select_callback($args) {
672 672
 
673
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
674
-    $class = ! empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
675
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
676
-	$value   = wpinv_get_option( $args['id'], $std );
673
+    $sanitize_id = wpinv_sanitize_key($args['id']);
674
+    $class = !empty($args['class']) ? ' ' . esc_attr($args['class']) : '';
675
+	$std     = isset($args['std']) ? $args['std'] : '';
676
+	$value   = wpinv_get_option($args['id'], $std);
677 677
 
678
-	echo '<select name="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" class="' . esc_attr( $class ) . '" >';
678
+	echo '<select name="wpinv_settings[' . esc_attr($sanitize_id) . ']"" id="wpinv_settings[' . esc_attr($sanitize_id) . ']" class="' . esc_attr($class) . '" >';
679 679
 
680
-	foreach ( $args['options'] as $key => $option ) :
680
+	foreach ($args['options'] as $key => $option) :
681 681
 
682
-		echo '<option value="' . esc_attr( $key ) . '" ';
682
+		echo '<option value="' . esc_attr($key) . '" ';
683 683
 
684
-		if ( isset( $args['selected'] ) && $args['selected'] !== null && $args['selected'] !== false ) {
685
-            selected( $key, $args['selected'] );
684
+		if (isset($args['selected']) && $args['selected'] !== null && $args['selected'] !== false) {
685
+            selected($key, $args['selected']);
686 686
         } else {
687
-            selected( $key, $value );
687
+            selected($key, $value);
688 688
         }
689 689
 
690
-		echo '>' . esc_html( $option['admin_label'] ) . '</option>';
690
+		echo '>' . esc_html($option['admin_label']) . '</option>';
691 691
 	endforeach;
692 692
 
693 693
 	echo '</select>';
694
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
694
+	echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
695 695
 }
696 696
 
697 697
 /**
@@ -700,16 +700,16 @@  discard block
 block discarded – undo
700 700
  * @param array $args
701 701
  * @return string
702 702
  */
703
-function wpinv_settings_attrs_helper( $args ) {
703
+function wpinv_settings_attrs_helper($args) {
704 704
 
705
-	$value = isset( $args['std'] ) ? $args['std'] : '';
706
-	$id    = esc_attr( $args['id'] );
707
-	$value = is_scalar( $value ) ? $value : '';
705
+	$value = isset($args['std']) ? $args['std'] : '';
706
+	$id    = esc_attr($args['id']);
707
+	$value = is_scalar($value) ? $value : '';
708 708
 
709 709
 	$attrs = array(
710
-		'name'     => ! empty( $args['faux'] ) ? false : "wpinv_settings[$id]",
711
-		'readonly' => ! empty( $args['faux'] ),
712
-		'value'    => ! empty( $args['faux'] ) ? $value : wpinv_get_option( $args['id'], $value ),
710
+		'name'     => !empty($args['faux']) ? false : "wpinv_settings[$id]",
711
+		'readonly' => !empty($args['faux']),
712
+		'value'    => !empty($args['faux']) ? $value : wpinv_get_option($args['id'], $value),
713 713
 		'id'       => 'wpinv-settings-' . $args['id'],
714 714
 		'style'    => $args['style'],
715 715
 		'class'    => $args['class'],
@@ -717,20 +717,20 @@  discard block
 block discarded – undo
717 717
 		'data-placeholder' => $args['placeholder'],
718 718
 	);
719 719
 
720
-	if ( ! empty( $args['onchange'] ) ) {
720
+	if (!empty($args['onchange'])) {
721 721
 		$attrs['onchange'] = $args['onchange'];
722 722
 	}
723 723
 
724
-	foreach ( $attrs as $key => $value ) {
724
+	foreach ($attrs as $key => $value) {
725 725
 
726
-		if ( false === $value ) {
726
+		if (false === $value) {
727 727
 			continue;
728 728
 		}
729 729
 
730
-		if ( true === $value ) {
731
-			echo ' ' . esc_attr( $key );
730
+		if (true === $value) {
731
+			echo ' ' . esc_attr($key);
732 732
 		} else {
733
-			echo ' ' . esc_attr( $key ) . '="' . esc_attr( $value ) . '"';
733
+			echo ' ' . esc_attr($key) . '="' . esc_attr($value) . '"';
734 734
 		}
735 735
 
736 736
 	}
@@ -740,12 +740,12 @@  discard block
 block discarded – undo
740 740
 /**
741 741
  * Displays a text input settings callback.
742 742
  */
743
-function wpinv_text_callback( $args ) {
743
+function wpinv_text_callback($args) {
744 744
 
745 745
 	?>
746 746
 		<label style="width: 100%;">
747
-			<input type="text" <?php wpinv_settings_attrs_helper( $args ); ?>>
748
-			<?php getpaid_settings_description_callback( $args ); ?>
747
+			<input type="text" <?php wpinv_settings_attrs_helper($args); ?>>
748
+			<?php getpaid_settings_description_callback($args); ?>
749 749
 		</label>
750 750
 	<?php
751 751
 
@@ -754,174 +754,174 @@  discard block
 block discarded – undo
754 754
 /**
755 755
  * Displays a number input settings callback.
756 756
  */
757
-function wpinv_number_callback( $args ) {
757
+function wpinv_number_callback($args) {
758 758
 
759 759
 	?>
760 760
 		<label style="width: 100%;">
761
-			<input type="number" step="<?php echo esc_attr( $args['step'] ); ?>" max="<?php echo intval( $args['max'] ); ?>" min="<?php echo intval( $args['min'] ); ?>" <?php wpinv_settings_attrs_helper( $args ); ?>>
762
-			<?php getpaid_settings_description_callback( $args ); ?>
761
+			<input type="number" step="<?php echo esc_attr($args['step']); ?>" max="<?php echo intval($args['max']); ?>" min="<?php echo intval($args['min']); ?>" <?php wpinv_settings_attrs_helper($args); ?>>
762
+			<?php getpaid_settings_description_callback($args); ?>
763 763
 		</label>
764 764
 	<?php
765 765
 
766 766
 }
767 767
 
768
-function wpinv_textarea_callback( $args ) {
768
+function wpinv_textarea_callback($args) {
769 769
 
770
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
771
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
772
-	$value   = wpinv_get_option( $args['id'], $std );
770
+    $sanitize_id = wpinv_sanitize_key($args['id']);
771
+	$std     = isset($args['std']) ? $args['std'] : '';
772
+	$value   = wpinv_get_option($args['id'], $std);
773 773
 
774
-    $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
775
-    $class = ( isset( $args['class'] ) && ! is_null( $args['class'] ) ) ? $args['class'] : 'large-text';
774
+    $size = (isset($args['size']) && !is_null($args['size'])) ? $args['size'] : 'regular';
775
+    $class = (isset($args['class']) && !is_null($args['class'])) ? $args['class'] : 'large-text';
776 776
 
777
-	echo '<textarea class="' . esc_attr( $class ) . ' txtarea-' . esc_attr( $size ) . ' wpi-' . esc_attr( sanitize_html_class( $sanitize_id ) ) . ' " cols="' . esc_attr( $args['cols'] ) . '" rows="' . esc_attr( $args['rows'] ) . '" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
778
-	echo '<br /><label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
777
+	echo '<textarea class="' . esc_attr($class) . ' txtarea-' . esc_attr($size) . ' wpi-' . esc_attr(sanitize_html_class($sanitize_id)) . ' " cols="' . esc_attr($args['cols']) . '" rows="' . esc_attr($args['rows']) . '" id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']">' . esc_textarea(stripslashes($value)) . '</textarea>';
778
+	echo '<br /><label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
779 779
 
780 780
 }
781 781
 
782
-function wpinv_password_callback( $args ) {
782
+function wpinv_password_callback($args) {
783 783
 
784
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
785
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
786
-	$value   = wpinv_get_option( $args['id'], $std );
784
+    $sanitize_id = wpinv_sanitize_key($args['id']);
785
+	$std     = isset($args['std']) ? $args['std'] : '';
786
+	$value   = wpinv_get_option($args['id'], $std);
787 787
 
788
-	$size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
789
-	echo '<input type="password" class="' . esc_attr( $size ) . '-text" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '"/>';
790
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
788
+	$size = (isset($args['size']) && !is_null($args['size'])) ? $args['size'] : 'regular';
789
+	echo '<input type="password" class="' . esc_attr($size) . '-text" id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']" value="' . esc_attr($value) . '"/>';
790
+	echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
791 791
 
792 792
 }
793 793
 
794
-function wpinv_missing_callback( $args ) {
794
+function wpinv_missing_callback($args) {
795 795
 	printf(
796
-		esc_html__( 'The callback function used for the %s setting is missing.', 'invoicing' ),
797
-		'<strong>' . esc_html( $args['id'] ) . '</strong>'
796
+		esc_html__('The callback function used for the %s setting is missing.', 'invoicing'),
797
+		'<strong>' . esc_html($args['id']) . '</strong>'
798 798
 	);
799 799
 }
800 800
 
801 801
 /**
802 802
  * Displays a number input settings callback.
803 803
  */
804
-function wpinv_select_callback( $args ) {
804
+function wpinv_select_callback($args) {
805 805
 
806
-	$desc   = wp_kses_post( $args['desc'] );
807
-	$desc   = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
808
-	$value  = isset( $args['std'] ) ? $args['std'] : '';
809
-	$value  = wpinv_get_option( $args['id'], $value );
810
-	$rand   = uniqid( 'random_id' );
806
+	$desc   = wp_kses_post($args['desc']);
807
+	$desc   = empty($desc) ? '' : "<p class='description'>$desc</p>";
808
+	$value  = isset($args['std']) ? $args['std'] : '';
809
+	$value  = wpinv_get_option($args['id'], $value);
810
+	$rand   = uniqid('random_id');
811 811
 
812 812
 	?>
813 813
 		<label style="width: 100%;">
814
-			<select <?php wpinv_settings_attrs_helper( $args ); ?> data-allow-clear="true">
815
-				<?php foreach ( $args['options'] as $option => $name ) : ?>
816
-					<option value="<?php echo esc_attr( $option ); ?>" <?php echo selected( $option, $value ); ?>><?php echo esc_html( $name ); ?></option>
814
+			<select <?php wpinv_settings_attrs_helper($args); ?> data-allow-clear="true">
815
+				<?php foreach ($args['options'] as $option => $name) : ?>
816
+					<option value="<?php echo esc_attr($option); ?>" <?php echo selected($option, $value); ?>><?php echo esc_html($name); ?></option>
817 817
 				<?php endforeach; ?>
818 818
 			</select>
819 819
 
820
-			<?php if ( substr( $args['id'], -5 ) === '_page' && is_numeric( $value ) ) : ?>
821
-				<a href="<?php echo esc_url( get_edit_post_link( $value ) ); ?>" target="_blank" class="button getpaid-page-setting-edit"><?php esc_html_e( 'Edit Page', 'invoicing' ); ?></a>
820
+			<?php if (substr($args['id'], -5) === '_page' && is_numeric($value)) : ?>
821
+				<a href="<?php echo esc_url(get_edit_post_link($value)); ?>" target="_blank" class="button getpaid-page-setting-edit"><?php esc_html_e('Edit Page', 'invoicing'); ?></a>
822 822
 			<?php endif; ?>
823 823
 
824
-			<?php if ( substr( $args['id'], -5 ) === '_page' && ! empty( $args['default_content'] ) ) : ?>
825
-				&nbsp;<a href="#TB_inline?&width=400&height=550&inlineId=<?php echo esc_attr( $rand ); ?>" class="button thickbox getpaid-page-setting-view-default"><?php esc_html_e( 'View Default Content', 'invoicing' ); ?></a>
826
-				<div id='<?php echo esc_attr( $rand ); ?>' style='display:none;'>
824
+			<?php if (substr($args['id'], -5) === '_page' && !empty($args['default_content'])) : ?>
825
+				&nbsp;<a href="#TB_inline?&width=400&height=550&inlineId=<?php echo esc_attr($rand); ?>" class="button thickbox getpaid-page-setting-view-default"><?php esc_html_e('View Default Content', 'invoicing'); ?></a>
826
+				<div id='<?php echo esc_attr($rand); ?>' style='display:none;'>
827 827
 					<div>
828
-						<h3><?php esc_html_e( 'Original Content', 'invoicing' ); ?></h3>
829
-						<textarea readonly onclick="this.select()" rows="8" style="width: 100%;"><?php echo wp_kses_post( gepaid_trim_lines( $args['default_content'] ) ); ?></textarea>
830
-						<h3><?php esc_html_e( 'Current Content', 'invoicing' ); ?></h3>
831
-						<textarea readonly onclick="this.select()" rows="8" style="width: 100%;"><?php $_post = get_post( $value ); echo empty( $_post ) ? '' : wp_kses_post( gepaid_trim_lines( $_post->post_content ) ); ?></textarea>
828
+						<h3><?php esc_html_e('Original Content', 'invoicing'); ?></h3>
829
+						<textarea readonly onclick="this.select()" rows="8" style="width: 100%;"><?php echo wp_kses_post(gepaid_trim_lines($args['default_content'])); ?></textarea>
830
+						<h3><?php esc_html_e('Current Content', 'invoicing'); ?></h3>
831
+						<textarea readonly onclick="this.select()" rows="8" style="width: 100%;"><?php $_post = get_post($value); echo empty($_post) ? '' : wp_kses_post(gepaid_trim_lines($_post->post_content)); ?></textarea>
832 832
 					</div>
833 833
 				</div>
834 834
 			<?php endif; ?>
835 835
 
836
-			<?php echo wp_kses_post( $desc ); ?>
836
+			<?php echo wp_kses_post($desc); ?>
837 837
 		</label>
838 838
 	<?php
839 839
 
840 840
 }
841 841
 
842
-function wpinv_color_select_callback( $args ) {
842
+function wpinv_color_select_callback($args) {
843 843
 
844
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
845
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
846
-	$value   = wpinv_get_option( $args['id'], $std );
844
+    $sanitize_id = wpinv_sanitize_key($args['id']);
845
+	$std     = isset($args['std']) ? $args['std'] : '';
846
+	$value   = wpinv_get_option($args['id'], $std);
847 847
 
848
-	echo '<select id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"/>';
848
+	echo '<select id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']"/>';
849 849
 
850
-	foreach ( $args['options'] as $option => $color ) {
851
-		echo '<option value="' . esc_attr( $option ) . '" ' . selected( $option, $value ) . '>' . esc_html( $color['label'] ) . '</option>';
850
+	foreach ($args['options'] as $option => $color) {
851
+		echo '<option value="' . esc_attr($option) . '" ' . selected($option, $value) . '>' . esc_html($color['label']) . '</option>';
852 852
 	}
853 853
 
854 854
 	echo '</select>';
855
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
855
+	echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
856 856
 
857 857
 }
858 858
 
859
-function wpinv_rich_editor_callback( $args ) {
859
+function wpinv_rich_editor_callback($args) {
860 860
 	global $wp_version;
861 861
 
862
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
862
+    $sanitize_id = wpinv_sanitize_key($args['id']);
863 863
 
864
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
865
-	$value   = wpinv_get_option( $args['id'], $std );
864
+	$std     = isset($args['std']) ? $args['std'] : '';
865
+	$value   = wpinv_get_option($args['id'], $std);
866 866
 
867
-	if ( ! empty( $args['allow_blank'] ) && empty( $value ) ) {
867
+	if (!empty($args['allow_blank']) && empty($value)) {
868 868
 		$value = $std;
869 869
 	}
870 870
 
871
-	$rows = isset( $args['size'] ) ? $args['size'] : 20;
871
+	$rows = isset($args['size']) ? $args['size'] : 20;
872 872
 
873 873
 	echo '<div class="getpaid-settings-editor-input">';
874
-	if ( $wp_version >= 3.3 && function_exists( 'wp_editor' ) ) {
874
+	if ($wp_version >= 3.3 && function_exists('wp_editor')) {
875 875
 		wp_editor(
876
-            stripslashes( $value ),
877
-            'wpinv_settings_' . esc_attr( $args['id'] ),
876
+            stripslashes($value),
877
+            'wpinv_settings_' . esc_attr($args['id']),
878 878
             array(
879
-				'textarea_name' => 'wpinv_settings[' . esc_attr( $args['id'] ) . ']',
880
-				'textarea_rows' => absint( $rows ),
879
+				'textarea_name' => 'wpinv_settings[' . esc_attr($args['id']) . ']',
880
+				'textarea_rows' => absint($rows),
881 881
 				'media_buttons' => false,
882 882
             )
883 883
         );
884 884
 	} else {
885
-		echo '<textarea class="large-text" rows="10" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="wpi-' . esc_attr( sanitize_html_class( $args['id'] ) ) . '">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
885
+		echo '<textarea class="large-text" rows="10" id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']" class="wpi-' . esc_attr(sanitize_html_class($args['id'])) . '">' . esc_textarea(stripslashes($value)) . '</textarea>';
886 886
 	}
887 887
 
888
-	echo '</div><br/><label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
888
+	echo '</div><br/><label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
889 889
 
890 890
 }
891 891
 
892
-function wpinv_upload_callback( $args ) {
892
+function wpinv_upload_callback($args) {
893 893
 
894
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
894
+    $sanitize_id = wpinv_sanitize_key($args['id']);
895 895
 
896
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
897
-	$value   = wpinv_get_option( $args['id'], $std );
896
+	$std     = isset($args['std']) ? $args['std'] : '';
897
+	$value   = wpinv_get_option($args['id'], $std);
898 898
 
899
-	$size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
900
-	echo '<input type="text" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( stripslashes( $value ) ) . '"/>';
901
-	echo '<span>&nbsp;<input type="button" class="wpinv_settings_upload_button button-secondary" value="' . esc_attr__( 'Upload File', 'invoicing' ) . '"/></span>';
902
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
899
+	$size = (isset($args['size']) && !is_null($args['size'])) ? $args['size'] : 'regular';
900
+	echo '<input type="text" class="' . sanitize_html_class($size) . '-text" id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']" value="' . esc_attr(stripslashes($value)) . '"/>';
901
+	echo '<span>&nbsp;<input type="button" class="wpinv_settings_upload_button button-secondary" value="' . esc_attr__('Upload File', 'invoicing') . '"/></span>';
902
+	echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
903 903
 
904 904
 }
905 905
 
906
-function wpinv_color_callback( $args ) {
906
+function wpinv_color_callback($args) {
907 907
 
908
-	$std         = isset( $args['std'] ) ? $args['std'] : '';
909
-	$value       = wpinv_get_option( $args['id'], $std );
910
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
908
+	$std         = isset($args['std']) ? $args['std'] : '';
909
+	$value       = wpinv_get_option($args['id'], $std);
910
+    $sanitize_id = wpinv_sanitize_key($args['id']);
911 911
 
912
-	echo '<input type="text" class="wpinv-color-picker" id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '" data-default-color="' . esc_attr( $std ) . '" />';
913
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
912
+	echo '<input type="text" class="wpinv-color-picker" id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']" value="' . esc_attr($value) . '" data-default-color="' . esc_attr($std) . '" />';
913
+	echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
914 914
 
915 915
 }
916 916
 
917
-function wpinv_country_states_callback( $args ) {
917
+function wpinv_country_states_callback($args) {
918 918
 
919
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
920
-	$value   = wpinv_get_option( $args['id'], $std );
919
+	$std     = isset($args['std']) ? $args['std'] : '';
920
+	$value   = wpinv_get_option($args['id'], $std);
921 921
 
922
-    $sanitize_id = wpinv_sanitize_key( $args['id'] );
922
+    $sanitize_id = wpinv_sanitize_key($args['id']);
923 923
 
924
-	if ( isset( $args['placeholder'] ) ) {
924
+	if (isset($args['placeholder'])) {
925 925
 		$placeholder = $args['placeholder'];
926 926
 	} else {
927 927
 		$placeholder = '';
@@ -929,15 +929,15 @@  discard block
 block discarded – undo
929 929
 
930 930
 	$states = wpinv_get_country_states();
931 931
 
932
-	$class = empty( $states ) ? 'wpinv-no-states' : 'wpi_select2';
933
-	echo '<select id="wpinv_settings[' . esc_attr( $sanitize_id ) . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="' . esc_attr( $class ) . '" data-placeholder="' . esc_html( $placeholder ) . '"/>';
932
+	$class = empty($states) ? 'wpinv-no-states' : 'wpi_select2';
933
+	echo '<select id="wpinv_settings[' . esc_attr($sanitize_id) . ']" name="wpinv_settings[' . esc_attr($args['id']) . ']" class="' . esc_attr($class) . '" data-placeholder="' . esc_html($placeholder) . '"/>';
934 934
 
935
-	foreach ( $states as $option => $name ) {
936
-		echo '<option value="' . esc_attr( $option ) . '" ' . selected( $option, $value ) . '>' . esc_html( $name ) . '</option>';
935
+	foreach ($states as $option => $name) {
936
+		echo '<option value="' . esc_attr($option) . '" ' . selected($option, $value) . '>' . esc_html($name) . '</option>';
937 937
 	}
938 938
 
939 939
 	echo '</select>';
940
-	echo '<label for="wpinv_settings[' . esc_attr( $sanitize_id ) . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
940
+	echo '<label for="wpinv_settings[' . esc_attr($sanitize_id) . ']"> ' . wp_kses_post($args['desc']) . '</label>';
941 941
 
942 942
 }
943 943
 
@@ -951,7 +951,7 @@  discard block
 block discarded – undo
951 951
 	</tr>
952 952
 	<tr class="bsui">
953 953
     	<td colspan="2" class="p-0">
954
-			<?php include plugin_dir_path( __FILE__ ) . 'views/html-tax-rates-edit.php'; ?>
954
+			<?php include plugin_dir_path(__FILE__) . 'views/html-tax-rates-edit.php'; ?>
955 955
 
956 956
 	<?php
957 957
 
@@ -960,11 +960,11 @@  discard block
 block discarded – undo
960 960
 /**
961 961
  * Displays a tax rate' edit row.
962 962
  */
963
-function wpinv_tax_rate_callback( $tax_rate, $key ) {
963
+function wpinv_tax_rate_callback($tax_rate, $key) {
964 964
 
965
-	$key                      = sanitize_key( $key );
966
-	$tax_rate['reduced_rate'] = empty( $tax_rate['reduced_rate'] ) ? 0 : $tax_rate['reduced_rate'];
967
-	include plugin_dir_path( __FILE__ ) . 'views/html-tax-rate-edit.php';
965
+	$key                      = sanitize_key($key);
966
+	$tax_rate['reduced_rate'] = empty($tax_rate['reduced_rate']) ? 0 : $tax_rate['reduced_rate'];
967
+	include plugin_dir_path(__FILE__) . 'views/html-tax-rate-edit.php';
968 968
 
969 969
 }
970 970
 
@@ -978,177 +978,177 @@  discard block
 block discarded – undo
978 978
 	</tr>
979 979
 	<tr class="bsui">
980 980
     	<td colspan="2" class="p-0">
981
-			<?php include plugin_dir_path( __FILE__ ) . 'views/html-tax-rules-edit.php'; ?>
981
+			<?php include plugin_dir_path(__FILE__) . 'views/html-tax-rules-edit.php'; ?>
982 982
 
983 983
 	<?php
984 984
 
985 985
 }
986 986
 
987
-function wpinv_tools_callback( $args ) {
987
+function wpinv_tools_callback($args) {
988 988
     ?>
989 989
     </td><tr>
990 990
     <td colspan="2" class="wpinv_tools_tdbox">
991 991
     <?php
992
-    if ( $args['desc'] ) {
992
+    if ($args['desc']) {
993 993
 ?>
994
-<p><?php echo wp_kses_post( $args['desc'] ); ?></p><?php } ?>
995
-    <?php do_action( 'wpinv_tools_before' ); ?>
994
+<p><?php echo wp_kses_post($args['desc']); ?></p><?php } ?>
995
+    <?php do_action('wpinv_tools_before'); ?>
996 996
     <table id="wpinv_tools_table" class="wp-list-table widefat fixed posts">
997 997
         <thead>
998 998
             <tr>
999
-                <th scope="col" class="wpinv-th-tool"><?php esc_html_e( 'Tool', 'invoicing' ); ?></th>
1000
-                <th scope="col" class="wpinv-th-desc"><?php esc_html_e( 'Description', 'invoicing' ); ?></th>
1001
-                <th scope="col" class="wpinv-th-action"><?php esc_html_e( 'Action', 'invoicing' ); ?></th>
999
+                <th scope="col" class="wpinv-th-tool"><?php esc_html_e('Tool', 'invoicing'); ?></th>
1000
+                <th scope="col" class="wpinv-th-desc"><?php esc_html_e('Description', 'invoicing'); ?></th>
1001
+                <th scope="col" class="wpinv-th-action"><?php esc_html_e('Action', 'invoicing'); ?></th>
1002 1002
             </tr>
1003 1003
         </thead>
1004 1004
 
1005 1005
         <tbody>
1006 1006
 			<tr>
1007
-                <td><?php esc_html_e( 'Check Pages', 'invoicing' ); ?></td>
1007
+                <td><?php esc_html_e('Check Pages', 'invoicing'); ?></td>
1008 1008
                 <td>
1009
-                    <small><?php esc_html_e( 'Creates any missing GetPaid pages.', 'invoicing' ); ?></small>
1009
+                    <small><?php esc_html_e('Creates any missing GetPaid pages.', 'invoicing'); ?></small>
1010 1010
                 </td>
1011 1011
                 <td>
1012 1012
 					<a href="
1013 1013
                     <?php
1014 1014
 						echo esc_url(
1015 1015
 							wp_nonce_url(
1016
-								add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
1016
+								add_query_arg('getpaid-admin-action', 'create_missing_pages'),
1017 1017
 								'getpaid-nonce',
1018 1018
 								'getpaid-nonce'
1019 1019
 							)
1020 1020
 						);
1021 1021
 					?>
1022
-                    " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1022
+                    " class="button button-primary"><?php esc_html_e('Run', 'invoicing'); ?></a>
1023 1023
                 </td>
1024 1024
             </tr>
1025 1025
 			<tr>
1026
-                <td><?php esc_html_e( 'Refresh Permalinks', 'invoicing' ); ?></td>
1026
+                <td><?php esc_html_e('Refresh Permalinks', 'invoicing'); ?></td>
1027 1027
                 <td>
1028
-                    <small><?php esc_html_e( 'Might fix the page not found error when viewing an invoice.', 'invoicing' ); ?></small>
1028
+                    <small><?php esc_html_e('Might fix the page not found error when viewing an invoice.', 'invoicing'); ?></small>
1029 1029
                 </td>
1030 1030
                 <td>
1031 1031
 					<a href="
1032 1032
                     <?php
1033 1033
 						echo esc_url(
1034 1034
 							wp_nonce_url(
1035
-								add_query_arg( 'getpaid-admin-action', 'refresh_permalinks' ),
1035
+								add_query_arg('getpaid-admin-action', 'refresh_permalinks'),
1036 1036
 								'getpaid-nonce',
1037 1037
 								'getpaid-nonce'
1038 1038
 							)
1039 1039
 						);
1040 1040
 					?>
1041
-                    " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1041
+                    " class="button button-primary"><?php esc_html_e('Run', 'invoicing'); ?></a>
1042 1042
                 </td>
1043 1043
             </tr>
1044 1044
 			<tr>
1045
-                <td><?php esc_html_e( 'Repair Database Tables', 'invoicing' ); ?></td>
1045
+                <td><?php esc_html_e('Repair Database Tables', 'invoicing'); ?></td>
1046 1046
                 <td>
1047
-                    <small><?php esc_html_e( 'Run this tool to create any missing database tables.', 'invoicing' ); ?></small>
1047
+                    <small><?php esc_html_e('Run this tool to create any missing database tables.', 'invoicing'); ?></small>
1048 1048
                 </td>
1049 1049
                 <td>
1050 1050
 					<a href="
1051 1051
                     <?php
1052 1052
 						echo esc_url(
1053 1053
 							wp_nonce_url(
1054
-								add_query_arg( 'getpaid-admin-action', 'create_missing_tables' ),
1054
+								add_query_arg('getpaid-admin-action', 'create_missing_tables'),
1055 1055
 								'getpaid-nonce',
1056 1056
 								'getpaid-nonce'
1057 1057
 							)
1058 1058
 						);
1059 1059
 					?>
1060
-                    " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1060
+                    " class="button button-primary"><?php esc_html_e('Run', 'invoicing'); ?></a>
1061 1061
                 </td>
1062 1062
             </tr>
1063 1063
 			<tr>
1064
-                <td><?php esc_html_e( 'Migrate old invoices', 'invoicing' ); ?></td>
1064
+                <td><?php esc_html_e('Migrate old invoices', 'invoicing'); ?></td>
1065 1065
                 <td>
1066
-                    <small><?php esc_html_e( 'If your old invoices were not migrated after updating from Invoicing to GetPaid, you can use this tool to migrate them.', 'invoicing' ); ?></small>
1066
+                    <small><?php esc_html_e('If your old invoices were not migrated after updating from Invoicing to GetPaid, you can use this tool to migrate them.', 'invoicing'); ?></small>
1067 1067
                 </td>
1068 1068
                 <td>
1069 1069
 					<a href="
1070 1070
                     <?php
1071 1071
 						echo esc_url(
1072 1072
 							wp_nonce_url(
1073
-								add_query_arg( 'getpaid-admin-action', 'migrate_old_invoices' ),
1073
+								add_query_arg('getpaid-admin-action', 'migrate_old_invoices'),
1074 1074
 								'getpaid-nonce',
1075 1075
 								'getpaid-nonce'
1076 1076
 							)
1077 1077
 						);
1078 1078
 					?>
1079
-                    " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1079
+                    " class="button button-primary"><?php esc_html_e('Run', 'invoicing'); ?></a>
1080 1080
                 </td>
1081 1081
             </tr>
1082 1082
 
1083 1083
 			<tr>
1084
-                <td><?php esc_html_e( 'Recalculate Discounts', 'invoicing' ); ?></td>
1084
+                <td><?php esc_html_e('Recalculate Discounts', 'invoicing'); ?></td>
1085 1085
                 <td>
1086
-                    <small><?php esc_html_e( 'Recalculate discounts for existing invoices that have discount codes but are not discounted.', 'invoicing' ); ?></small>
1086
+                    <small><?php esc_html_e('Recalculate discounts for existing invoices that have discount codes but are not discounted.', 'invoicing'); ?></small>
1087 1087
                 </td>
1088 1088
                 <td>
1089 1089
 					<a href="
1090 1090
                     <?php
1091 1091
 						echo esc_url(
1092 1092
 							wp_nonce_url(
1093
-								add_query_arg( 'getpaid-admin-action', 'recalculate_discounts' ),
1093
+								add_query_arg('getpaid-admin-action', 'recalculate_discounts'),
1094 1094
 								'getpaid-nonce',
1095 1095
 								'getpaid-nonce'
1096 1096
 							)
1097 1097
 						);
1098 1098
 					?>
1099
-                    " class="button button-primary"><?php esc_html_e( 'Run', 'invoicing' ); ?></a>
1099
+                    " class="button button-primary"><?php esc_html_e('Run', 'invoicing'); ?></a>
1100 1100
                 </td>
1101 1101
             </tr>
1102 1102
 
1103 1103
 			<tr>
1104
-                <td><?php esc_html_e( 'Set-up Wizard', 'invoicing' ); ?></td>
1104
+                <td><?php esc_html_e('Set-up Wizard', 'invoicing'); ?></td>
1105 1105
                 <td>
1106
-                    <small><?php esc_html_e( 'Launch the quick set-up wizard.', 'invoicing' ); ?></small>
1106
+                    <small><?php esc_html_e('Launch the quick set-up wizard.', 'invoicing'); ?></small>
1107 1107
                 </td>
1108 1108
                 <td>
1109 1109
 					<a href="
1110 1110
                     <?php
1111
-						echo esc_url( admin_url( 'index.php?page=gp-setup' ) );
1111
+						echo esc_url(admin_url('index.php?page=gp-setup'));
1112 1112
 					?>
1113
-                    " class="button button-primary"><?php esc_html_e( 'Launch', 'invoicing' ); ?></a>
1113
+                    " class="button button-primary"><?php esc_html_e('Launch', 'invoicing'); ?></a>
1114 1114
                 </td>
1115 1115
             </tr>
1116 1116
 
1117
-			<?php do_action( 'wpinv_tools_row' ); ?>
1117
+			<?php do_action('wpinv_tools_row'); ?>
1118 1118
         </tbody>
1119 1119
     </table>
1120
-    <?php do_action( 'wpinv_tools_after' ); ?>
1120
+    <?php do_action('wpinv_tools_after'); ?>
1121 1121
     <?php
1122 1122
 }
1123 1123
 
1124 1124
 
1125
-function wpinv_descriptive_text_callback( $args ) {
1126
-	echo wp_kses_post( $args['desc'] );
1125
+function wpinv_descriptive_text_callback($args) {
1126
+	echo wp_kses_post($args['desc']);
1127 1127
 }
1128 1128
 
1129
-function wpinv_raw_html_callback( $args ) {
1130
-	echo wp_kses( $args['desc'], getpaid_allowed_html() );
1129
+function wpinv_raw_html_callback($args) {
1130
+	echo wp_kses($args['desc'], getpaid_allowed_html());
1131 1131
 }
1132 1132
 
1133
-function wpinv_hook_callback( $args ) {
1134
-	do_action( 'wpinv_' . $args['id'], $args );
1133
+function wpinv_hook_callback($args) {
1134
+	do_action('wpinv_' . $args['id'], $args);
1135 1135
 }
1136 1136
 
1137 1137
 function wpinv_set_settings_cap() {
1138 1138
 	return wpinv_get_capability();
1139 1139
 }
1140
-add_filter( 'option_page_capability_wpinv_settings', 'wpinv_set_settings_cap' );
1140
+add_filter('option_page_capability_wpinv_settings', 'wpinv_set_settings_cap');
1141 1141
 
1142 1142
 
1143
-function wpinv_on_update_settings( $old_value, $value, $option ) {
1144
-    $old = ! empty( $old_value['remove_data_on_unistall'] ) ? 1 : '';
1145
-    $new = ! empty( $value['remove_data_on_unistall'] ) ? 1 : '';
1143
+function wpinv_on_update_settings($old_value, $value, $option) {
1144
+    $old = !empty($old_value['remove_data_on_unistall']) ? 1 : '';
1145
+    $new = !empty($value['remove_data_on_unistall']) ? 1 : '';
1146 1146
 
1147
-    if ( $old != $new ) {
1148
-        update_option( 'wpinv_remove_data_on_invoice_unistall', $new );
1147
+    if ($old != $new) {
1148
+        update_option('wpinv_remove_data_on_invoice_unistall', $new);
1149 1149
     }
1150 1150
 }
1151
-add_action( 'update_option_wpinv_settings', 'wpinv_on_update_settings', 10, 3 );
1151
+add_action('update_option_wpinv_settings', 'wpinv_on_update_settings', 10, 3);
1152 1152
 
1153 1153
 
1154 1154
 /**
@@ -1160,43 +1160,43 @@  discard block
 block discarded – undo
1160 1160
  *
1161 1161
  * @return array
1162 1162
  */
1163
-function wpinv_get_email_merge_tags( $subscription = false ) {
1163
+function wpinv_get_email_merge_tags($subscription = false) {
1164 1164
 	$merge_tags = array(
1165
-		'{site_title}'           => __( 'Site Title', 'invoicing' ),
1166
-		'{name}'                 => __( "Customer's full name", 'invoicing' ),
1167
-		'{first_name}'           => __( "Customer's first name", 'invoicing' ),
1168
-		'{last_name}'            => __( "Customer's last name", 'invoicing' ),
1169
-		'{email}'                => __( "Customer's email address", 'invoicing' ),
1170
-		'{invoice_number}'       => __( 'The invoice number', 'invoicing' ),
1171
-		'{invoice_currency}'     => __( 'The invoice currency', 'invoicing' ),
1172
-		'{invoice_total}'        => __( 'The invoice total', 'invoicing' ),
1173
-		'{invoice_link}'         => __( 'The invoice link', 'invoicing' ),
1174
-		'{invoice_pay_link}'     => __( 'The payment link', 'invoicing' ),
1175
-		'{invoice_receipt_link}' => __( 'The receipt link', 'invoicing' ),
1176
-		'{invoice_date}'         => __( 'The date the invoice was created', 'invoicing' ),
1177
-		'{invoice_due_date}'     => __( 'The date the invoice is due', 'invoicing' ),
1178
-		'{date}'                 => __( "Today's date", 'invoicing' ),
1179
-		'{is_was}'               => __( 'If due date of invoice is past, displays "was" otherwise displays "is"', 'invoicing' ),
1180
-		'{invoice_label}'        => __( 'Invoices/quotes singular name. Ex: Invoice/Quote', 'invoicing' ),
1181
-		'{invoice_quote}'        => __( 'Invoices/quotes singular name in small letters. Ex: invoice/quote', 'invoicing' ),
1182
-		'{invoice_description}'  => __( 'The description of the invoice', 'invoicing' ),
1165
+		'{site_title}'           => __('Site Title', 'invoicing'),
1166
+		'{name}'                 => __("Customer's full name", 'invoicing'),
1167
+		'{first_name}'           => __("Customer's first name", 'invoicing'),
1168
+		'{last_name}'            => __("Customer's last name", 'invoicing'),
1169
+		'{email}'                => __("Customer's email address", 'invoicing'),
1170
+		'{invoice_number}'       => __('The invoice number', 'invoicing'),
1171
+		'{invoice_currency}'     => __('The invoice currency', 'invoicing'),
1172
+		'{invoice_total}'        => __('The invoice total', 'invoicing'),
1173
+		'{invoice_link}'         => __('The invoice link', 'invoicing'),
1174
+		'{invoice_pay_link}'     => __('The payment link', 'invoicing'),
1175
+		'{invoice_receipt_link}' => __('The receipt link', 'invoicing'),
1176
+		'{invoice_date}'         => __('The date the invoice was created', 'invoicing'),
1177
+		'{invoice_due_date}'     => __('The date the invoice is due', 'invoicing'),
1178
+		'{date}'                 => __("Today's date", 'invoicing'),
1179
+		'{is_was}'               => __('If due date of invoice is past, displays "was" otherwise displays "is"', 'invoicing'),
1180
+		'{invoice_label}'        => __('Invoices/quotes singular name. Ex: Invoice/Quote', 'invoicing'),
1181
+		'{invoice_quote}'        => __('Invoices/quotes singular name in small letters. Ex: invoice/quote', 'invoicing'),
1182
+		'{invoice_description}'  => __('The description of the invoice', 'invoicing'),
1183 1183
 	);
1184 1184
 
1185
-	if ( $subscription ) {
1185
+	if ($subscription) {
1186 1186
 		$merge_tags = array_merge(
1187 1187
 			$merge_tags,
1188 1188
 			array(
1189
-				'{subscription_renewal_date}'     => __( 'The next renewal date of the subscription', 'invoicing' ),
1190
-				'{subscription_created}'          => __( "The subscription's creation date", 'invoicing' ),
1191
-				'{subscription_status}'           => __( "The subscription's status", 'invoicing' ),
1192
-				'{subscription_profile_id}'       => __( "The subscription's remote profile id", 'invoicing' ),
1193
-				'{subscription_id}'               => __( "The subscription's id", 'invoicing' ),
1194
-				'{subscription_recurring_amount}' => __( 'The renewal amount of the subscription', 'invoicing' ),
1195
-				'{subscription_initial_amount}'   => __( 'The initial amount of the subscription', 'invoicing' ),
1196
-				'{subscription_recurring_period}' => __( 'The recurring period of the subscription (e.g 1 year)', 'invoicing' ),
1197
-				'{subscription_bill_times}'       => __( 'The maximum number of times the subscription can be renewed', 'invoicing' ),
1198
-				'{subscription_url}'              => __( 'The URL to manage a subscription', 'invoicing' ),
1199
-				'{subscription_name}'             => __( 'The name of the recurring item', 'invoicing' ),
1189
+				'{subscription_renewal_date}'     => __('The next renewal date of the subscription', 'invoicing'),
1190
+				'{subscription_created}'          => __("The subscription's creation date", 'invoicing'),
1191
+				'{subscription_status}'           => __("The subscription's status", 'invoicing'),
1192
+				'{subscription_profile_id}'       => __("The subscription's remote profile id", 'invoicing'),
1193
+				'{subscription_id}'               => __("The subscription's id", 'invoicing'),
1194
+				'{subscription_recurring_amount}' => __('The renewal amount of the subscription', 'invoicing'),
1195
+				'{subscription_initial_amount}'   => __('The initial amount of the subscription', 'invoicing'),
1196
+				'{subscription_recurring_period}' => __('The recurring period of the subscription (e.g 1 year)', 'invoicing'),
1197
+				'{subscription_bill_times}'       => __('The maximum number of times the subscription can be renewed', 'invoicing'),
1198
+				'{subscription_url}'              => __('The URL to manage a subscription', 'invoicing'),
1199
+				'{subscription_name}'             => __('The name of the recurring item', 'invoicing'),
1200 1200
 			)
1201 1201
 		);
1202 1202
 	}
@@ -1212,25 +1212,25 @@  discard block
 block discarded – undo
1212 1212
  *
1213 1213
  * @return string
1214 1214
  */
1215
-function wpinv_get_merge_tags_help_text( $subscription = false ) {
1216
-	$merge_tags = wpinv_get_email_merge_tags( $subscription );
1215
+function wpinv_get_merge_tags_help_text($subscription = false) {
1216
+	$merge_tags = wpinv_get_email_merge_tags($subscription);
1217 1217
 
1218 1218
 	$output = '<div class="bsui">';
1219 1219
 
1220 1220
 	$link = sprintf(
1221 1221
 		'<strong class="getpaid-merge-tags text-primary" role="button">%s</strong>',
1222
-		esc_html__( 'View available merge tags.', 'invoicing' )
1222
+		esc_html__('View available merge tags.', 'invoicing')
1223 1223
 	);
1224 1224
 
1225
-	$description = esc_html__( 'The content of the email (Merge Tags and HTML are allowed).', 'invoicing' );
1225
+	$description = esc_html__('The content of the email (Merge Tags and HTML are allowed).', 'invoicing');
1226 1226
 	
1227 1227
 	$output .= "$description $link";
1228 1228
 
1229 1229
 	$output .= '<div class="getpaid-merge-tags-content mt-2 p-1 d-none">';
1230
-	$output .= '<p class="mb-2">' . esc_html__( 'The following wildcards can be used in email subjects, heading and content:', 'invoicing' ) . '</p>';
1230
+	$output .= '<p class="mb-2">' . esc_html__('The following wildcards can be used in email subjects, heading and content:', 'invoicing') . '</p>';
1231 1231
 
1232 1232
 	$output .= '<ul class="p-0 m-0">';
1233
-	foreach($merge_tags as $tag => $tag_description) {
1233
+	foreach ($merge_tags as $tag => $tag_description) {
1234 1234
 		$output .= "<li class='mb-2'><strong class='text-dark'>$tag</strong> &mdash; $tag_description</li>";
1235 1235
 	}
1236 1236
 
Please login to merge, or discard this patch.