Passed
Push — master ( 31f474...7d7341 )
by Kiran
10:27 queued 05:04
created
includes/admin/subscriptions.php 1 patch
Switch Indentation   +109 added lines, -109 removed lines patch added patch discarded remove patch
@@ -577,40 +577,40 @@  discard block
 block discarded – undo
577 577
 
578 578
 								switch ( $key ) {
579 579
 
580
-								case 'total':
581
-										echo '<strong>';
582
-										wpinv_the_price( $payment->get_total(), $payment->get_currency() );
583
-										echo '</strong>';
584
-									break;
585
-
586
-								case 'relationship':
587
-										echo $payment->is_renewal() ? esc_html__( 'Renewal Invoice', 'invoicing' ) : esc_html__( 'Initial Invoice', 'invoicing' );
588
-									break;
589
-
590
-								case 'date':
591
-									echo esc_html( getpaid_format_date_value( $payment->get_date_created() ) );
592
-									break;
593
-
594
-								case 'status':
595
-										$status = $payment->get_status_nicename();
596
-										if ( is_admin() ) {
597
-										$status = $payment->get_status_label_html();
598
-										}
599
-
600
-										echo wp_kses_post( $status );
601
-									break;
602
-
603
-								case 'invoice':
604
-										if ( ! is_admin() ) {
605
-											$link = $payment->get_view_url();
606
-										} else {
607
-											$link = get_edit_post_link( $payment->get_id() );
608
-										}
609
-
610
-										$invoice = esc_html( $payment->get_number() );
611
-
612
-										echo wp_kses_post( "<a href='" . ( $link ? esc_url( $link ) : '#' ) . "'>$invoice</a>" );
613
-									break;
580
+								    case 'total':
581
+										    echo '<strong>';
582
+										    wpinv_the_price( $payment->get_total(), $payment->get_currency() );
583
+										    echo '</strong>';
584
+									    break;
585
+
586
+								    case 'relationship':
587
+										    echo $payment->is_renewal() ? esc_html__( 'Renewal Invoice', 'invoicing' ) : esc_html__( 'Initial Invoice', 'invoicing' );
588
+									    break;
589
+
590
+								    case 'date':
591
+									    echo esc_html( getpaid_format_date_value( $payment->get_date_created() ) );
592
+									    break;
593
+
594
+								    case 'status':
595
+										    $status = $payment->get_status_nicename();
596
+										    if ( is_admin() ) {
597
+										    $status = $payment->get_status_label_html();
598
+										    }
599
+
600
+										    echo wp_kses_post( $status );
601
+									    break;
602
+
603
+								    case 'invoice':
604
+										    if ( ! is_admin() ) {
605
+											    $link = $payment->get_view_url();
606
+										    } else {
607
+											    $link = get_edit_post_link( $payment->get_id() );
608
+										    }
609
+
610
+										    $invoice = esc_html( $payment->get_number() );
611
+
612
+										    echo wp_kses_post( "<a href='" . ( $link ? esc_url( $link ) : '#' ) . "'>$invoice</a>" );
613
+									    break;
614 614
 										}
615 615
 
616 616
 								echo '</td>';
@@ -705,37 +705,37 @@  discard block
 block discarded – undo
705 705
 
706 706
 								switch ( $key ) {
707 707
 
708
-								case 'item_name':
709
-										$item_name = get_the_title( $subscription_group_item['item_id'] );
710
-										$item_name = empty( $item_name ) ? $subscription_group_item['item_name'] : $item_name;
708
+								    case 'item_name':
709
+										    $item_name = get_the_title( $subscription_group_item['item_id'] );
710
+										    $item_name = empty( $item_name ) ? $subscription_group_item['item_name'] : $item_name;
711 711
 
712
-										if ( $invoice->get_template() == 'amount' || 1 == (float) $subscription_group_item['quantity'] ) {
713
-										echo esc_html( $item_name );
714
-										} else {
715
-										printf( '%1$s x %2$d', esc_html( $item_name ), (float) $subscription_group_item['quantity'] );
716
-											}
712
+										    if ( $invoice->get_template() == 'amount' || 1 == (float) $subscription_group_item['quantity'] ) {
713
+										    echo esc_html( $item_name );
714
+										    } else {
715
+										    printf( '%1$s x %2$d', esc_html( $item_name ), (float) $subscription_group_item['quantity'] );
716
+											    }
717 717
 
718
-									break;
718
+									    break;
719 719
 
720
-								case 'price':
721
-									wpinv_the_price( $subscription_group_item['item_price'], $invoice->get_currency() );
722
-									break;
720
+								    case 'price':
721
+									    wpinv_the_price( $subscription_group_item['item_price'], $invoice->get_currency() );
722
+									    break;
723 723
 
724
-								case 'tax':
725
-									wpinv_the_price( $subscription_group_item['tax'], $invoice->get_currency() );
726
-									break;
724
+								    case 'tax':
725
+									    wpinv_the_price( $subscription_group_item['tax'], $invoice->get_currency() );
726
+									    break;
727 727
 
728
-								case 'discount':
729
-									wpinv_the_price( $subscription_group_item['discount'], $invoice->get_currency() );
730
-									break;
728
+								    case 'discount':
729
+									    wpinv_the_price( $subscription_group_item['discount'], $invoice->get_currency() );
730
+									    break;
731 731
 
732
-								case 'initial':
733
-									wpinv_the_price( $subscription_group_item['price'] * $subscription_group_item['quantity'], $invoice->get_currency() );
734
-									break;
732
+								    case 'initial':
733
+									    wpinv_the_price( $subscription_group_item['price'] * $subscription_group_item['quantity'], $invoice->get_currency() );
734
+									    break;
735 735
 
736
-								case 'recurring':
737
-										echo wp_kses_post( '<strong>' . wpinv_price( $subscription_group_item['price'] * $subscription_group_item['quantity'], $invoice->get_currency() ) . '</strong>' );
738
-									break;
736
+								    case 'recurring':
737
+										    echo wp_kses_post( '<strong>' . wpinv_price( $subscription_group_item['price'] * $subscription_group_item['quantity'], $invoice->get_currency() ) . '</strong>' );
738
+									    break;
739 739
 
740 740
 										}
741 741
 
@@ -759,29 +759,29 @@  discard block
 block discarded – undo
759 759
 
760 760
 								switch ( $key ) {
761 761
 
762
-								case 'item_name':
763
-										echo esc_html( $subscription_group_fee['name'] );
764
-									break;
762
+								    case 'item_name':
763
+										    echo esc_html( $subscription_group_fee['name'] );
764
+									    break;
765 765
 
766
-								case 'price':
767
-									wpinv_the_price( $subscription_group_fee['initial_fee'], $invoice->get_currency() );
768
-									break;
766
+								    case 'price':
767
+									    wpinv_the_price( $subscription_group_fee['initial_fee'], $invoice->get_currency() );
768
+									    break;
769 769
 
770
-								case 'tax':
771
-									echo '&mdash;';
772
-									break;
770
+								    case 'tax':
771
+									    echo '&mdash;';
772
+									    break;
773 773
 
774
-								case 'discount':
775
-										echo '&mdash;';
776
-									break;
774
+								    case 'discount':
775
+										    echo '&mdash;';
776
+									    break;
777 777
 
778
-								case 'initial':
779
-									wpinv_the_price( $subscription_group_fee['initial_fee'], $invoice->get_currency() );
780
-									break;
778
+								    case 'initial':
779
+									    wpinv_the_price( $subscription_group_fee['initial_fee'], $invoice->get_currency() );
780
+									    break;
781 781
 
782
-								case 'recurring':
783
-										echo wp_kses_post( '<strong>' . wpinv_price( $subscription_group_fee['recurring_fee'], $invoice->get_currency() ) . '</strong>' );
784
-									break;
782
+								    case 'recurring':
783
+										    echo wp_kses_post( '<strong>' . wpinv_price( $subscription_group_fee['recurring_fee'], $invoice->get_currency() ) . '</strong>' );
784
+									    break;
785 785
 
786 786
 										}
787 787
 
@@ -886,39 +886,39 @@  discard block
 block discarded – undo
886 886
 
887 887
 								switch ( $key ) {
888 888
 
889
-								case 'status':
890
-										echo wp_kses_post( $_suscription->get_status_label_html() );
891
-									break;
892
-
893
-								case 'item':
894
-											$markup = array_map( array( 'WPInv_Subscriptions_List_Table', 'generate_item_markup' ), array_keys( $subscription_group['items'] ) );
895
-											echo wp_kses_post( implode( ' | ', $markup ) );
896
-									break;
897
-
898
-								case 'renewals':
899
-									$max_bills = $_suscription->get_bill_times();
900
-									echo ( (int) $_suscription->get_times_billed() ) . ' / ' . ( empty( $max_bills ) ? '&infin;' : (int) $max_bills );
901
-									break;
902
-
903
-								case 'renewal_date':
904
-										echo $_suscription->is_active() ? esc_html( getpaid_format_date_value( $_suscription->get_expiration() ) ) : '&mdash;';
905
-									break;
906
-
907
-								case 'start_date':
908
-										echo 'pending' == $_suscription->get_status() ? '&mdash;' : esc_html( getpaid_format_date_value( $_suscription->get_date_created() ) );
909
-									break;
910
-
911
-								case 'subscription':
912
-										$url = is_admin() ? admin_url( 'admin.php?page=wpinv-subscriptions&id=' . absint( $_suscription->get_id() ) ) : $_suscription->get_view_url();
913
-										printf(
914
-                                            '%1$s#%2$s%3$s',
915
-                                            '<a href="' . esc_url( $url ) . '">',
916
-                                            '<strong>' . intval( $_suscription->get_id() ) . '</strong>',
917
-											'</a>'
918
-                                        );
919
-
920
-											echo wp_kses_post( WPInv_Subscriptions_List_Table::column_amount( $_suscription ) );
921
-									break;
889
+								    case 'status':
890
+										    echo wp_kses_post( $_suscription->get_status_label_html() );
891
+									    break;
892
+
893
+								    case 'item':
894
+											    $markup = array_map( array( 'WPInv_Subscriptions_List_Table', 'generate_item_markup' ), array_keys( $subscription_group['items'] ) );
895
+											    echo wp_kses_post( implode( ' | ', $markup ) );
896
+									    break;
897
+
898
+								    case 'renewals':
899
+									    $max_bills = $_suscription->get_bill_times();
900
+									    echo ( (int) $_suscription->get_times_billed() ) . ' / ' . ( empty( $max_bills ) ? '&infin;' : (int) $max_bills );
901
+									    break;
902
+
903
+								    case 'renewal_date':
904
+										    echo $_suscription->is_active() ? esc_html( getpaid_format_date_value( $_suscription->get_expiration() ) ) : '&mdash;';
905
+									    break;
906
+
907
+								    case 'start_date':
908
+										    echo 'pending' == $_suscription->get_status() ? '&mdash;' : esc_html( getpaid_format_date_value( $_suscription->get_date_created() ) );
909
+									    break;
910
+
911
+								    case 'subscription':
912
+										    $url = is_admin() ? admin_url( 'admin.php?page=wpinv-subscriptions&id=' . absint( $_suscription->get_id() ) ) : $_suscription->get_view_url();
913
+										    printf(
914
+                                                '%1$s#%2$s%3$s',
915
+                                                '<a href="' . esc_url( $url ) . '">',
916
+                                                '<strong>' . intval( $_suscription->get_id() ) . '</strong>',
917
+											    '</a>'
918
+                                            );
919
+
920
+											    echo wp_kses_post( WPInv_Subscriptions_List_Table::column_amount( $_suscription ) );
921
+									    break;
922 922
 
923 923
 										}
924 924
 
Please login to merge, or discard this patch.
templates/invoice/line-item.php 1 patch
Switch Indentation   +66 added lines, -66 removed lines patch added patch discarded remove patch
@@ -1,4 +1,4 @@  discard block
 block discarded – undo
1
-<?php
1
+    <?php
2 2
 /**
3 3
  * Displays a single line item in an invoice.
4 4
  *
@@ -10,11 +10,11 @@  discard block
 block discarded – undo
10 10
  * @var array $columns
11 11
  */
12 12
 
13
-defined( 'ABSPATH' ) || exit;
13
+    defined( 'ABSPATH' ) || exit;
14 14
 
15
-do_action( 'getpaid_before_invoice_line_item', $invoice, $item );
15
+    do_action( 'getpaid_before_invoice_line_item', $invoice, $item );
16 16
 
17
-?>
17
+    ?>
18 18
 
19 19
 <div class='getpaid-invoice-item item-<?php echo (int) $item->get_id(); ?> item-type-<?php echo esc_attr( $item->get_type() ); ?> border-bottom'>
20 20
 
@@ -26,90 +26,90 @@  discard block
 block discarded – undo
26 26
 
27 27
 				<?php
28 28
 
29
-					// Fires before printing a line item column.
30
-					do_action( "getpaid_invoice_line_item_before_$column", $item, $invoice );
29
+					    // Fires before printing a line item column.
30
+					    do_action( "getpaid_invoice_line_item_before_$column", $item, $invoice );
31 31
 
32
-					// Item name.
33
-					if ( 'name' === $column ) {
32
+					    // Item name.
33
+					    if ( 'name' === $column ) {
34 34
 
35
-						$has_featured_image = has_post_thumbnail( $item->get_id() );
35
+						    $has_featured_image = has_post_thumbnail( $item->get_id() );
36 36
 
37
-						if ( $has_featured_image ) {
38
-							echo '<div class="d-flex align-items-center getpaid-form-item-has-featured-image">';
39
-							echo '<div class="getpaid-form-item-image-container mr-2" style="width:85px;">';
40
-							echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'getpaid-form-item-image mb-0' ) );
41
-							echo '</div>';
42
-							echo '<div class="getpaid-form-item-name-container">';
43
-						}
37
+						    if ( $has_featured_image ) {
38
+							    echo '<div class="d-flex align-items-center getpaid-form-item-has-featured-image">';
39
+							    echo '<div class="getpaid-form-item-image-container mr-2" style="width:85px;">';
40
+							    echo get_the_post_thumbnail( $item->get_id(), array( 75, 75 ), array( 'class' => 'getpaid-form-item-image mb-0' ) );
41
+							    echo '</div>';
42
+							    echo '<div class="getpaid-form-item-name-container">';
43
+						    }
44 44
 
45
-						// Display the name.
46
-						echo '<div class="mb-1">' . esc_html( $item->get_name() ) . '</div>';
45
+						    // Display the name.
46
+						    echo '<div class="mb-1">' . esc_html( $item->get_name() ) . '</div>';
47 47
 
48
-						// And an optional description.
49
-						$description = $item->get_description();
48
+						    // And an optional description.
49
+						    $description = $item->get_description();
50 50
 
51
-						if ( ! empty( $description ) ) {
52
-							echo "<small class='form-text text-muted pr-2 m-0'>" . wp_kses_post( $description ) . '</small>';
53
-						}
51
+						    if ( ! empty( $description ) ) {
52
+							    echo "<small class='form-text text-muted pr-2 m-0'>" . wp_kses_post( $description ) . '</small>';
53
+						    }
54 54
 
55
-						// Fires before printing the line item actions.
56
-						do_action( 'getpaid_before_invoice_line_item_actions', $item, $invoice );
55
+						    // Fires before printing the line item actions.
56
+						    do_action( 'getpaid_before_invoice_line_item_actions', $item, $invoice );
57 57
 
58
-						$actions = apply_filters( 'getpaid-invoice-page-line-item-actions', array(), $item, $invoice );
58
+						    $actions = apply_filters( 'getpaid-invoice-page-line-item-actions', array(), $item, $invoice );
59 59
 
60
-						if ( ! empty( $actions ) ) {
60
+						    if ( ! empty( $actions ) ) {
61 61
 
62
-							$sanitized  = array();
63
-							foreach ( $actions as $key => $item_action ) {
64
-								$key         = sanitize_html_class( $key );
65
-								$item_action = wp_kses_post( $item_action );
66
-								$sanitized[] = "<span class='$key'>$item_action</span>";
67
-							}
62
+							    $sanitized  = array();
63
+							    foreach ( $actions as $key => $item_action ) {
64
+								    $key         = sanitize_html_class( $key );
65
+								    $item_action = wp_kses_post( $item_action );
66
+								    $sanitized[] = "<span class='$key'>$item_action</span>";
67
+							    }
68 68
 
69
-							echo "<small class='form-text getpaid-line-item-actions'>";
70
-							echo wp_kses_post( implode( ' | ', $sanitized ) );
71
-							echo '</small>';
69
+							    echo "<small class='form-text getpaid-line-item-actions'>";
70
+							    echo wp_kses_post( implode( ' | ', $sanitized ) );
71
+							    echo '</small>';
72 72
 
73
-						}
73
+						    }
74 74
 
75
-						if ( $has_featured_image ) {
76
-							echo '</div>';
77
-							echo '</div>';
78
-						}
79
-					}
75
+						    if ( $has_featured_image ) {
76
+							    echo '</div>';
77
+							    echo '</div>';
78
+						    }
79
+					    }
80 80
 
81
-					// Item price.
82
-					if ( 'price' === $column ) {
81
+					    // Item price.
82
+					    if ( 'price' === $column ) {
83 83
 
84
-					// Display the item price (or recurring price if this is a renewal invoice)
85
-					$price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
86
-					wpinv_the_price( $price, $invoice->get_currency() );
84
+					    // Display the item price (or recurring price if this is a renewal invoice)
85
+					    $price = $invoice->is_renewal() ? $item->get_price() : $item->get_initial_price();
86
+					    wpinv_the_price( $price, $invoice->get_currency() );
87 87
 
88
-					}
88
+					    }
89 89
 
90
-					// Tax rate.
91
-					if ( 'tax_rate' === $column ) {
92
-					echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
93
-					}
90
+					    // Tax rate.
91
+					    if ( 'tax_rate' === $column ) {
92
+					    echo floatval( round( getpaid_get_invoice_tax_rate( $invoice, $item ), 2 ) ) . '%';
93
+					    }
94 94
 
95
-					// Item quantity.
96
-					if ( 'quantity' === $column ) {
97
-					echo (float) $item->get_quantity();
98
-					}
95
+					    // Item quantity.
96
+					    if ( 'quantity' === $column ) {
97
+					    echo (float) $item->get_quantity();
98
+					    }
99 99
 
100
-					// Item sub total.
101
-					if ( 'subtotal' === $column ) {
102
-					$subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
103
-					wpinv_the_price( $subtotal, $invoice->get_currency() );
104
-					}
100
+					    // Item sub total.
101
+					    if ( 'subtotal' === $column ) {
102
+					    $subtotal = $invoice->is_renewal() ? $item->get_recurring_sub_total() : $item->get_sub_total();
103
+					    wpinv_the_price( $subtotal, $invoice->get_currency() );
104
+					    }
105 105
 
106
-					// Fires when printing a line item column.
107
-					do_action( "getpaid_invoice_line_item_$column", $item, $invoice );
106
+					    // Fires when printing a line item column.
107
+					    do_action( "getpaid_invoice_line_item_$column", $item, $invoice );
108 108
 
109
-					// Fires after printing a line item column.
110
-					do_action( "getpaid_invoice_line_item_after_$column", $item, $invoice );
109
+					    // Fires after printing a line item column.
110
+					    do_action( "getpaid_invoice_line_item_after_$column", $item, $invoice );
111 111
 
112
-				?>
112
+				    ?>
113 113
 
114 114
 			</div>
115 115
 
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/example-plugin.php 1 patch
Switch Indentation   +213 added lines, -213 removed lines patch added patch discarded remove patch
@@ -1,4 +1,4 @@  discard block
 block discarded – undo
1
-<?php
1
+    <?php
2 2
 /*
3 3
 Plugin Name: AyeCode UI
4 4
 Plugin URI: https://ayecode.io/
@@ -14,224 +14,224 @@  discard block
 block discarded – undo
14 14
 Tested up to: 6.7
15 15
 */
16 16
 
17
-// If this file is called directly, abort.
18
-if ( ! defined( 'WPINC' ) ) {
19
-	die;
17
+    // If this file is called directly, abort.
18
+    if ( ! defined( 'WPINC' ) ) {
19
+	    die;
20 20
 }
21 21
 
22
-class AyeCode_UI_Plugin {
22
+    class AyeCode_UI_Plugin {
23 23
 
24
-	/**
24
+	    /**
25 25
 	 * AUI Plugin constructor.
26 26
 	 *
27 27
 	 * @since 1.0.0
28 28
 	 */
29
-	public function __construct() {
30
-
31
-		// load AUI
32
-		require_once( dirname( __FILE__ ) . '/ayecode-ui-loader.php' );
33
-
34
-		// Maybe show example page
35
-		add_action( 'template_redirect', array( $this,'maybe_show_examples' ) );
36
-	}
37
-
38
-	public function maybe_show_examples(){
39
-		if ( current_user_can( 'manage_options' ) && isset( $_REQUEST['preview-aui'] ) ) {
40
-			echo "<head>";
41
-			wp_head();
42
-			echo "</head>";
43
-			echo "<body class='bsui'>";
44
-			echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
45
-			wp_footer();
46
-			echo "</body>";
47
-			exit;
48
-		}
49
-	}
50
-
51
-	public function get_examples(){
52
-		$output = '';
53
-
54
-		// open form
55
-		$output .= "<form class='p-5 m-5 border rounded bg-white'>";
56
-
57
-		$output .= aui()->input(
58
-			array(
59
-				'type'             => 'datepicker',
60
-				'id'               => 'date_example_sm',
61
-				'size'             => 'sm',
62
-				'name'             => 'date_example_sm',
63
-				'label'            => 'Date Input Label (small)',
64
-				'help_text'        => 'help text',
65
-				'label_type'       => 'top',
66
-				'placeholder'      => 'YYYY-MM-DD 00:00',
67
-				'value'            => '',
68
-				'extra_attributes' => array(
69
-					'data-enable-time' => 'true',
70
-					'data-time_24hr'   => 'true',
71
-					'data-allow-input' => 'true',
72
-				),
73
-			)
74
-		);
75
-
76
-		$output .= aui()->input(
77
-			array(
78
-				'type'             => 'datepicker',
79
-				'id'               => 'date_example',
80
-				//'size'             => 'smx',
81
-				'name'             => 'date_example',
82
-				'label'            => 'Date Input Label',
83
-				'help_text'        => 'help text',
84
-				'label_type'       => 'top',
85
-				'placeholder'      => 'YYYY-MM-DD 00:00',
86
-				'value'            => '',
87
-				'extra_attributes' => array(
88
-					'data-enable-time' => 'true',
89
-					'data-time_24hr'   => 'true',
90
-					'data-allow-input' => 'true',
91
-				),
92
-			)
93
-		);
94
-
95
-		$output .= aui()->input(
96
-			array(
97
-				'type'             => 'datepicker',
98
-				'id'               => 'date_example_lg',
99
-				'size'             => 'lg',
100
-				'name'             => 'date_example_lg',
101
-				'label'            => 'Date Input Label (large)',
102
-				'help_text'        => 'help text',
103
-				'label_type'       => 'top',
104
-				'placeholder'      => 'YYYY-MM-DD 00:00',
105
-				'value'            => '',
106
-				'extra_attributes' => array(
107
-					'data-enable-time' => 'true',
108
-					'data-time_24hr'   => 'true',
109
-					//'data-allow-input' => 'true',
110
-				),
111
-			)
112
-		);
113
-
114
-		// input example
115
-		$output .= aui()->input(
116
-			array(
117
-				'type'  =>  'text',
118
-				'id'    =>  'text-example',
119
-				'size'             => 'sm',
120
-				//'clear_icon'    => true,
121
-				'name'    =>  'text-example',
122
-				'placeholder'   => 'text placeholder',
123
-				'title'   => 'Text input example',
124
-				'value' =>  '',
125
-				'required'  => false,
126
-				'help_text' => 'help text',
127
-				'label' => 'Text input example label',
128
-				'label_type' => 'top'
129
-			)
130
-		);
131
-
132
-		$output .= aui()->input(
133
-			array(
134
-				'type'  =>  'search',
135
-				'id'    =>  'text-example',
136
-				'size'             => 'sm',
137
-				//'clear_icon'    => true,
138
-				'name'    =>  'text-example',
139
-				'placeholder'   => 'text placeholder',
140
-				'title'   => 'Text input example',
141
-				'value' =>  '',
142
-				'required'  => false,
143
-				'help_text' => 'help text',
144
-				'label' => 'Text input example label',
145
-				'label_type' => 'top'
146
-			)
147
-		);
148
-
149
-		// input example
150
-		$output .= aui()->input(
151
-			array(
152
-				'type'  =>  'url',
153
-				'id'    =>  'text-example2',
154
-				'name'    =>  'text-example',
155
-				'placeholder'   => 'url placeholder',
156
-				'title'   => 'Text input example',
157
-				'value' =>  '',
158
-				'required'  => false,
159
-				'help_text' => 'help text',
160
-				'label' => 'Text input example label'
161
-			)
162
-		);
163
-
164
-		// checkbox example
165
-		$output .= aui()->input(
166
-			array(
167
-				'type'  =>  'checkbox',
168
-				'id'    =>  'checkbox-example',
169
-				'name'    =>  'checkbox-example',
170
-				'placeholder'   => 'checkbox-example',
171
-				'title'   => 'Checkbox example',
172
-				'value' =>  '1',
173
-				'checked'   => true,
174
-				'required'  => false,
175
-				'help_text' => 'help text',
176
-				'label' => 'Checkbox checked'
177
-			)
178
-		);
179
-
180
-		// checkbox example
181
-		$output .= aui()->input(
182
-			array(
183
-				'type'  =>  'checkbox',
184
-				'id'    =>  'checkbox-example2',
185
-				'name'    =>  'checkbox-example2',
186
-				'placeholder'   => 'checkbox-example',
187
-				'title'   => 'Checkbox example',
188
-				'value' =>  '1',
189
-				'checked'   => false,
190
-				'required'  => false,
191
-				'help_text' => 'help text',
192
-				'label' => 'Checkbox un-checked'
193
-			)
194
-		);
195
-
196
-		// switch example
197
-		$output .= aui()->input(
198
-			array(
199
-				'type'  =>  'checkbox',
200
-				'id'    =>  'switch-example',
201
-				'name'    =>  'switch-example',
202
-				'placeholder'   => 'checkbox-example',
203
-				'title'   => 'Switch example',
204
-				'value' =>  '1',
205
-				'checked'   => true,
206
-				'switch'    => true,
207
-				'required'  => false,
208
-				'help_text' => 'help text',
209
-				'label' => 'Switch on'
210
-			)
211
-		);
212
-
213
-		// switch example
214
-		$output .= aui()->input(
215
-			array(
216
-				'type'  =>  'checkbox',
217
-				'id'    =>  'switch-example2',
218
-				'name'    =>  'switch-example2',
219
-				'placeholder'   => 'checkbox-example',
220
-				'title'   => 'Switch example',
221
-				'value' =>  '1',
222
-				'checked'   => false,
223
-				'switch'    => true,
224
-				'required'  => false,
225
-				'help_text' => 'help text',
226
-				'label' => 'Switch off'
227
-			)
228
-		);
229
-
230
-		// close form
231
-		$output .= "</form>";
232
-
233
-		return $output;
234
-	}
29
+	    public function __construct() {
30
+
31
+		    // load AUI
32
+		    require_once( dirname( __FILE__ ) . '/ayecode-ui-loader.php' );
33
+
34
+		    // Maybe show example page
35
+		    add_action( 'template_redirect', array( $this,'maybe_show_examples' ) );
36
+	    }
37
+
38
+	    public function maybe_show_examples(){
39
+		    if ( current_user_can( 'manage_options' ) && isset( $_REQUEST['preview-aui'] ) ) {
40
+			    echo "<head>";
41
+			    wp_head();
42
+			    echo "</head>";
43
+			    echo "<body class='bsui'>";
44
+			    echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
45
+			    wp_footer();
46
+			    echo "</body>";
47
+			    exit;
48
+		    }
49
+	    }
50
+
51
+	    public function get_examples(){
52
+		    $output = '';
53
+
54
+		    // open form
55
+		    $output .= "<form class='p-5 m-5 border rounded bg-white'>";
56
+
57
+		    $output .= aui()->input(
58
+			    array(
59
+				    'type'             => 'datepicker',
60
+				    'id'               => 'date_example_sm',
61
+				    'size'             => 'sm',
62
+				    'name'             => 'date_example_sm',
63
+				    'label'            => 'Date Input Label (small)',
64
+				    'help_text'        => 'help text',
65
+				    'label_type'       => 'top',
66
+				    'placeholder'      => 'YYYY-MM-DD 00:00',
67
+				    'value'            => '',
68
+				    'extra_attributes' => array(
69
+					    'data-enable-time' => 'true',
70
+					    'data-time_24hr'   => 'true',
71
+					    'data-allow-input' => 'true',
72
+				    ),
73
+			    )
74
+		    );
75
+
76
+		    $output .= aui()->input(
77
+			    array(
78
+				    'type'             => 'datepicker',
79
+				    'id'               => 'date_example',
80
+				    //'size'             => 'smx',
81
+				    'name'             => 'date_example',
82
+				    'label'            => 'Date Input Label',
83
+				    'help_text'        => 'help text',
84
+				    'label_type'       => 'top',
85
+				    'placeholder'      => 'YYYY-MM-DD 00:00',
86
+				    'value'            => '',
87
+				    'extra_attributes' => array(
88
+					    'data-enable-time' => 'true',
89
+					    'data-time_24hr'   => 'true',
90
+					    'data-allow-input' => 'true',
91
+				    ),
92
+			    )
93
+		    );
94
+
95
+		    $output .= aui()->input(
96
+			    array(
97
+				    'type'             => 'datepicker',
98
+				    'id'               => 'date_example_lg',
99
+				    'size'             => 'lg',
100
+				    'name'             => 'date_example_lg',
101
+				    'label'            => 'Date Input Label (large)',
102
+				    'help_text'        => 'help text',
103
+				    'label_type'       => 'top',
104
+				    'placeholder'      => 'YYYY-MM-DD 00:00',
105
+				    'value'            => '',
106
+				    'extra_attributes' => array(
107
+					    'data-enable-time' => 'true',
108
+					    'data-time_24hr'   => 'true',
109
+					    //'data-allow-input' => 'true',
110
+				    ),
111
+			    )
112
+		    );
113
+
114
+		    // input example
115
+		    $output .= aui()->input(
116
+			    array(
117
+				    'type'  =>  'text',
118
+				    'id'    =>  'text-example',
119
+				    'size'             => 'sm',
120
+				    //'clear_icon'    => true,
121
+				    'name'    =>  'text-example',
122
+				    'placeholder'   => 'text placeholder',
123
+				    'title'   => 'Text input example',
124
+				    'value' =>  '',
125
+				    'required'  => false,
126
+				    'help_text' => 'help text',
127
+				    'label' => 'Text input example label',
128
+				    'label_type' => 'top'
129
+			    )
130
+		    );
131
+
132
+		    $output .= aui()->input(
133
+			    array(
134
+				    'type'  =>  'search',
135
+				    'id'    =>  'text-example',
136
+				    'size'             => 'sm',
137
+				    //'clear_icon'    => true,
138
+				    'name'    =>  'text-example',
139
+				    'placeholder'   => 'text placeholder',
140
+				    'title'   => 'Text input example',
141
+				    'value' =>  '',
142
+				    'required'  => false,
143
+				    'help_text' => 'help text',
144
+				    'label' => 'Text input example label',
145
+				    'label_type' => 'top'
146
+			    )
147
+		    );
148
+
149
+		    // input example
150
+		    $output .= aui()->input(
151
+			    array(
152
+				    'type'  =>  'url',
153
+				    'id'    =>  'text-example2',
154
+				    'name'    =>  'text-example',
155
+				    'placeholder'   => 'url placeholder',
156
+				    'title'   => 'Text input example',
157
+				    'value' =>  '',
158
+				    'required'  => false,
159
+				    'help_text' => 'help text',
160
+				    'label' => 'Text input example label'
161
+			    )
162
+		    );
163
+
164
+		    // checkbox example
165
+		    $output .= aui()->input(
166
+			    array(
167
+				    'type'  =>  'checkbox',
168
+				    'id'    =>  'checkbox-example',
169
+				    'name'    =>  'checkbox-example',
170
+				    'placeholder'   => 'checkbox-example',
171
+				    'title'   => 'Checkbox example',
172
+				    'value' =>  '1',
173
+				    'checked'   => true,
174
+				    'required'  => false,
175
+				    'help_text' => 'help text',
176
+				    'label' => 'Checkbox checked'
177
+			    )
178
+		    );
179
+
180
+		    // checkbox example
181
+		    $output .= aui()->input(
182
+			    array(
183
+				    'type'  =>  'checkbox',
184
+				    'id'    =>  'checkbox-example2',
185
+				    'name'    =>  'checkbox-example2',
186
+				    'placeholder'   => 'checkbox-example',
187
+				    'title'   => 'Checkbox example',
188
+				    'value' =>  '1',
189
+				    'checked'   => false,
190
+				    'required'  => false,
191
+				    'help_text' => 'help text',
192
+				    'label' => 'Checkbox un-checked'
193
+			    )
194
+		    );
195
+
196
+		    // switch example
197
+		    $output .= aui()->input(
198
+			    array(
199
+				    'type'  =>  'checkbox',
200
+				    'id'    =>  'switch-example',
201
+				    'name'    =>  'switch-example',
202
+				    'placeholder'   => 'checkbox-example',
203
+				    'title'   => 'Switch example',
204
+				    'value' =>  '1',
205
+				    'checked'   => true,
206
+				    'switch'    => true,
207
+				    'required'  => false,
208
+				    'help_text' => 'help text',
209
+				    'label' => 'Switch on'
210
+			    )
211
+		    );
212
+
213
+		    // switch example
214
+		    $output .= aui()->input(
215
+			    array(
216
+				    'type'  =>  'checkbox',
217
+				    'id'    =>  'switch-example2',
218
+				    'name'    =>  'switch-example2',
219
+				    'placeholder'   => 'checkbox-example',
220
+				    'title'   => 'Switch example',
221
+				    'value' =>  '1',
222
+				    'checked'   => false,
223
+				    'switch'    => true,
224
+				    'required'  => false,
225
+				    'help_text' => 'help text',
226
+				    'label' => 'Switch off'
227
+			    )
228
+		    );
229
+
230
+		    // close form
231
+		    $output .= "</form>";
232
+
233
+		    return $output;
234
+	    }
235 235
 }
236 236
 
237
-new AyeCode_UI_Plugin();
238 237
\ No newline at end of file
238
+    new AyeCode_UI_Plugin();
239 239
\ No newline at end of file
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-input.php 1 patch
Switch Indentation   +1216 added lines, -1216 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1
-<?php
1
+    <?php
2 2
 
3
-if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
3
+    if ( ! defined( 'ABSPATH' ) ) {
4
+	    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -9,1307 +9,1307 @@  discard block
 block discarded – undo
9 9
  *
10 10
  * @since 1.0.0
11 11
  */
12
-class AUI_Component_Input {
12
+    class AUI_Component_Input {
13 13
 
14
-	/**
14
+	    /**
15 15
 	 * Build the component.
16 16
 	 *
17 17
 	 * @param array $args
18 18
 	 *
19 19
 	 * @return string The rendered component.
20 20
 	 */
21
-	public static function input( $args = array() ) {
22
-		global $aui_bs5;
23
-
24
-		$defaults = array(
25
-			'type'                     => 'text',
26
-			'name'                     => '',
27
-			'class'                    => '',
28
-			'wrap_class'               => '',
29
-			'id'                       => '',
30
-			'placeholder'              => '',
31
-			'title'                    => '',
32
-			'value'                    => '',
33
-			'required'                 => false,
34
-			'size'                     => '', // sm, lg, small, large
35
-			'clear_icon'               => '', // true will show a clear icon, can't be used with input_group_right
36
-			'with_hidden'              => false, // Append hidden field for single checkbox.
37
-			'label'                    => '',
38
-			'label_after'              => false,
39
-			'label_class'              => '',
40
-			'label_col'                => '2',
41
-			'label_type'               => '', // top, horizontal, empty = hidden
42
-			'label_force_left'         => false, // used to force checkbox label left when using horizontal
43
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
44
-			'help_text'                => '',
45
-			'validation_text'          => '',
46
-			'validation_pattern'       => '',
47
-			'no_wrap'                  => false,
48
-			'input_group_right'        => '',
49
-			'input_group_left'         => '',
50
-			'input_group_right_inside' => false,
51
-			// forces the input group inside the input
52
-			'input_group_left_inside'  => false,
53
-			// forces the input group inside the input
54
-			'form_group_class'         => '',
55
-			'step'                     => '',
56
-			'switch'                   => false,
57
-			// to show checkbox as a switch
58
-			'checked'                  => false,
59
-			// set a checkbox or radio as selected
60
-			'password_toggle'          => true,
61
-			// toggle view/hide password
62
-			'element_require'          => '',
63
-			// [%element_id%] == "1"
64
-			'extra_attributes'         => array(),
65
-			// an array of extra attributes
66
-			'wrap_attributes'          => array()
67
-		);
68
-
69
-		/**
21
+	    public static function input( $args = array() ) {
22
+		    global $aui_bs5;
23
+
24
+		    $defaults = array(
25
+			    'type'                     => 'text',
26
+			    'name'                     => '',
27
+			    'class'                    => '',
28
+			    'wrap_class'               => '',
29
+			    'id'                       => '',
30
+			    'placeholder'              => '',
31
+			    'title'                    => '',
32
+			    'value'                    => '',
33
+			    'required'                 => false,
34
+			    'size'                     => '', // sm, lg, small, large
35
+			    'clear_icon'               => '', // true will show a clear icon, can't be used with input_group_right
36
+			    'with_hidden'              => false, // Append hidden field for single checkbox.
37
+			    'label'                    => '',
38
+			    'label_after'              => false,
39
+			    'label_class'              => '',
40
+			    'label_col'                => '2',
41
+			    'label_type'               => '', // top, horizontal, empty = hidden
42
+			    'label_force_left'         => false, // used to force checkbox label left when using horizontal
43
+			    // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
44
+			    'help_text'                => '',
45
+			    'validation_text'          => '',
46
+			    'validation_pattern'       => '',
47
+			    'no_wrap'                  => false,
48
+			    'input_group_right'        => '',
49
+			    'input_group_left'         => '',
50
+			    'input_group_right_inside' => false,
51
+			    // forces the input group inside the input
52
+			    'input_group_left_inside'  => false,
53
+			    // forces the input group inside the input
54
+			    'form_group_class'         => '',
55
+			    'step'                     => '',
56
+			    'switch'                   => false,
57
+			    // to show checkbox as a switch
58
+			    'checked'                  => false,
59
+			    // set a checkbox or radio as selected
60
+			    'password_toggle'          => true,
61
+			    // toggle view/hide password
62
+			    'element_require'          => '',
63
+			    // [%element_id%] == "1"
64
+			    'extra_attributes'         => array(),
65
+			    // an array of extra attributes
66
+			    'wrap_attributes'          => array()
67
+		    );
68
+
69
+		    /**
70 70
 		 * Parse incoming $args into an array and merge it with $defaults
71 71
 		 */
72
-		$args   = wp_parse_args( $args, $defaults );
73
-		$output = '';
74
-		if ( ! empty( $args['type'] ) ) {
75
-			// hidden label option needs to be empty
76
-			$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
77
-
78
-			$type = sanitize_html_class( $args['type'] );
79
-
80
-			$help_text   = '';
81
-			$label       = '';
82
-			$label_after = $args['label_after'];
83
-			$label_args  = array(
84
-				'title'      => $args['label'],
85
-				'for'        => $args['id'],
86
-				'class'      => $args['label_class'] . " ",
87
-				'label_type' => $args['label_type'],
88
-				'label_col'  => $args['label_col']
89
-			);
90
-
91
-			// floating labels need label after
92
-			if ( $args['label_type'] == 'floating' && $type != 'checkbox' ) {
93
-				$label_after         = true;
94
-				$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
95
-			}
96
-
97
-			// size
98
-			$size = '';
99
-			if ( $args['size'] == 'lg' || $args['size'] == 'large' ) {
100
-				$size = 'lg';
101
-				$args['class'] .= ' form-control-lg';
102
-			}elseif ( $args['size'] == 'sm' || $args['size'] == 'small' ) {
103
-				$size = 'sm';
104
-				$args['class'] .= ' form-control-sm';
105
-			}
106
-
107
-			// clear function
108
-			$clear_function = 'jQuery(this).parent().parent().find(\'input\').val(\'\');';
109
-
110
-			// Some special sauce for files
111
-			if ( $type == 'file' ) {
112
-				$label_after = true; // if type file we need the label after
113
-				$args['class'] .= ' custom-file-input ';
114
-			} elseif ( $type == 'checkbox' ) {
115
-				$label_after = true; // if type file we need the label after
116
-				$args['class'] .= $aui_bs5 ? ' form-check-input c-pointer ' : ' custom-control-input c-pointer ';
117
-			} elseif ( $type == 'datepicker' || $type == 'timepicker' ) {
118
-				$orig_type = $type;
119
-				$type = 'text';
120
-				$args['class'] .= ' bg-initial '; // @todo not sure why we have this?
121
-				$clear_function .= "jQuery(this).parent().parent().find('input[name=\'" . esc_attr( $args['name'] ) . "\']').trigger('change');";
122
-
123
-				$args['extra_attributes']['data-aui-init'] = 'flatpickr';
124
-
125
-				// Disable native datetime inputs.
126
-				$disable_mobile_attr = isset( $args['extra_attributes']['data-disable-mobile'] ) ? $args['extra_attributes']['data-disable-mobile'] : 'true';
127
-				$disable_mobile_attr = apply_filters( 'aui_flatpickr_disable_disable_mobile_attr', $disable_mobile_attr, $args );
128
-
129
-				$args['extra_attributes']['data-disable-mobile'] = $disable_mobile_attr;
130
-
131
-				// set a way to clear field if empty
132
-				if ( $args['input_group_right'] === '' && $args['clear_icon'] !== false ) {
133
-					$args['input_group_right_inside'] = true;
134
-					$args['clear_icon'] = true;
135
-				}
136
-
137
-				// enqueue the script
138
-				$aui_settings = AyeCode_UI_Settings::instance();
139
-				$aui_settings->enqueue_flatpickr();
140
-			} elseif ( $type == 'iconpicker' ) {
141
-				$type = 'text';
142
-				//$args['class'] .= ' aui-flatpickr bg-initial ';
143
-//				$args['class'] .= ' bg-initial ';
144
-
145
-				$args['extra_attributes']['data-aui-init'] = 'iconpicker';
146
-				$args['extra_attributes']['data-placement'] = 'bottomRight';
147
-
148
-				$args['input_group_right'] = '<span class="input-group-addon input-group-text c-pointer"></span>';
149
-//				$args['input_group_right_inside'] = true;
150
-				// enqueue the script
151
-				$aui_settings = AyeCode_UI_Settings::instance();
152
-				$aui_settings->enqueue_iconpicker();
153
-			}
154
-
155
-			if ( $type == 'checkbox' && ( ( ! empty( $args['name'] ) && strpos( $args['name'], '[' ) === false ) || ! empty( $args['with_hidden'] ) ) ) {
156
-				$output .= '<input type="hidden" name="' . esc_attr( $args['name'] ) . '" value="0" />';
157
-			}
158
-
159
-			// allow clear icon
160
-			if ( $args['input_group_right'] === '' && $args['clear_icon'] ) {
161
-				$font_size = $size == 'sm' ? '1.3' : ( $size == 'lg' ? '1.65' : '1.5' );
162
-				$args['input_group_right_inside'] = true;
163
-				$align_class = $aui_bs5 ? ' h-100 py-0' : '';
164
-				$args['input_group_right'] = '<span class="input-group-text aui-clear-input c-pointer bg-initial border-0 px-2 d-none ' . $align_class . '" onclick="' . $clear_function . '"><span style="font-size: ' . $font_size . 'rem" aria-hidden="true" class="' . ( $aui_bs5 ? 'btn-close' : 'close' ) . '">' . ( $aui_bs5 ? '' : '&times;' ) . '</span></span>';
165
-			}
166
-
167
-			// open/type
168
-			$output .= '<input type="' . $type . '" ';
169
-
170
-			// name
171
-			if ( ! empty( $args['name'] ) ) {
172
-				$output .= ' name="' . esc_attr( $args['name'] ) . '" ';
173
-			}
174
-
175
-			// id
176
-			if ( ! empty( $args['id'] ) ) {
177
-				$output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
178
-			}
179
-
180
-			// placeholder
181
-			if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
182
-				$output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
183
-			}
184
-
185
-			// title
186
-			if ( ! empty( $args['title'] ) ) {
187
-				$output .= ' title="' . esc_attr( $args['title'] ) . '" ';
188
-			}
189
-
190
-			// value
191
-			if ( ! empty( $args['value'] ) ) {
192
-				$output .= AUI_Component_Helper::value( $args['value'] );
193
-			}
194
-
195
-			// checked, for radio and checkboxes
196
-			if ( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ) {
197
-				$output .= ' checked ';
198
-			}
199
-
200
-			// validation text
201
-			if ( ! empty( $args['validation_text'] ) ) {
202
-				$output .= ' oninvalid="setCustomValidity(\'' . esc_attr( addslashes( $args['validation_text'] ) ) . '\')" ';
203
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
204
-			}
205
-
206
-			// validation_pattern
207
-			if ( ! empty( $args['validation_pattern'] ) ) {
208
-				$output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
209
-			}
210
-
211
-			// step (for numbers)
212
-			if ( ! empty( $args['step'] ) ) {
213
-				$output .= ' step="' . $args['step'] . '" ';
214
-			}
215
-
216
-			// required
217
-			if ( ! empty( $args['required'] ) ) {
218
-				$output .= ' required ';
219
-			}
220
-
221
-			// class
222
-			$class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
223
-			$output .= $aui_bs5 &&  $type == 'checkbox' ? ' class="' . $class . '" ' : ' class="form-control ' . $class . '" ';
224
-
225
-			// data-attributes
226
-			$output .= AUI_Component_Helper::data_attributes( $args );
227
-
228
-			// extra attributes
229
-			if ( ! empty( $args['extra_attributes'] ) ) {
230
-				$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
231
-			}
232
-
233
-			// close
234
-			$output .= ' >';
235
-
236
-			// help text
237
-			if ( ! empty( $args['help_text'] ) ) {
238
-				$help_text = AUI_Component_Helper::help_text( $args['help_text'] );
239
-			}
240
-
241
-			// label
242
-			if ( ! empty( $args['label'] ) ) {
243
-				$label_base_class = '';
244
-				if ( $type == 'file' ) {
245
-					$label_base_class = ' custom-file-label';
246
-				} elseif ( $type == 'checkbox' ) {
247
-					if ( ! empty( $args['label_force_left'] ) ) {
248
-						$label_args['title'] = wp_kses_post( $args['help_text'] );
249
-						$help_text = '';
250
-						//$label_args['class'] .= ' d-inline ';
251
-						$args['wrap_class'] .= ' align-items-center ';
252
-					}else{
253
-
254
-					}
255
-
256
-					$label_base_class = $aui_bs5 ? ' form-check-label' : ' custom-control-label';
257
-				}
258
-				$label_args['class'] .= $label_base_class;
259
-				$temp_label_args = $label_args;
260
-				if(! empty( $args['label_force_left'] )){$temp_label_args['class'] = $label_base_class." text-muted";}
261
-				$label = self::label( $temp_label_args, $type );
262
-			}
263
-
264
-
265
-
266
-
267
-			// set help text in the correct position
268
-			if ( $label_after ) {
269
-				$output .= $label . $help_text;
270
-			}
271
-
272
-			// some input types need a separate wrap
273
-			if ( $type == 'file' ) {
274
-				$output = self::wrap( array(
275
-					'content' => $output,
276
-					'class'   => $aui_bs5 ? 'mb-3 custom-file' : 'form-group custom-file'
277
-				) );
278
-			} elseif ( $type == 'checkbox' ) {
279
-
280
-				$label_args['title'] = $args['label'];
281
-				$label_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'label' );
282
-				$label = !empty( $args['label_force_left'] ) ? self::label( $label_args, 'cb' ) : '<div class="' . $label_col . ' col-form-label"></div>';
283
-				$switch_size_class = $args['switch'] && !is_bool( $args['switch'] ) ? ' custom-switch-'.esc_attr( $args['switch'] ) : '';
284
-				if ( $aui_bs5 ) {
285
-					$wrap_class = $args['switch'] ? 'form-check form-switch' . $switch_size_class : 'form-check';
286
-				}else{
287
-					$wrap_class = $args['switch'] ? 'custom-switch' . $switch_size_class :  'custom-checkbox' ;
288
-				}
289
-				if ( ! empty( $args['label_force_left'] ) ) {
290
-					$wrap_class .= $aui_bs5 ? '' : ' d-flex align-content-center';
291
-					$label = str_replace(array("form-check-label","custom-control-label"),"", self::label( $label_args, 'cb' ) );
292
-				}
293
-				$output     = self::wrap( array(
294
-					'content' => $output,
295
-					'class'   => $aui_bs5 ? $wrap_class : 'custom-control ' . $wrap_class
296
-				) );
297
-
298
-				if ( $args['label_type'] == 'horizontal' ) {
299
-					$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
300
-					$output    = $label . '<div class="' . $input_col . '">' . $output . '</div>';
301
-				}
302
-			} elseif ( $type == 'password' && $args['password_toggle'] && ! $args['input_group_right'] ) {
303
-
304
-
305
-				// allow password field to toggle view
306
-				$args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
72
+		    $args   = wp_parse_args( $args, $defaults );
73
+		    $output = '';
74
+		    if ( ! empty( $args['type'] ) ) {
75
+			    // hidden label option needs to be empty
76
+			    $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
77
+
78
+			    $type = sanitize_html_class( $args['type'] );
79
+
80
+			    $help_text   = '';
81
+			    $label       = '';
82
+			    $label_after = $args['label_after'];
83
+			    $label_args  = array(
84
+				    'title'      => $args['label'],
85
+				    'for'        => $args['id'],
86
+				    'class'      => $args['label_class'] . " ",
87
+				    'label_type' => $args['label_type'],
88
+				    'label_col'  => $args['label_col']
89
+			    );
90
+
91
+			    // floating labels need label after
92
+			    if ( $args['label_type'] == 'floating' && $type != 'checkbox' ) {
93
+				    $label_after         = true;
94
+				    $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
95
+			    }
96
+
97
+			    // size
98
+			    $size = '';
99
+			    if ( $args['size'] == 'lg' || $args['size'] == 'large' ) {
100
+				    $size = 'lg';
101
+				    $args['class'] .= ' form-control-lg';
102
+			    }elseif ( $args['size'] == 'sm' || $args['size'] == 'small' ) {
103
+				    $size = 'sm';
104
+				    $args['class'] .= ' form-control-sm';
105
+			    }
106
+
107
+			    // clear function
108
+			    $clear_function = 'jQuery(this).parent().parent().find(\'input\').val(\'\');';
109
+
110
+			    // Some special sauce for files
111
+			    if ( $type == 'file' ) {
112
+				    $label_after = true; // if type file we need the label after
113
+				    $args['class'] .= ' custom-file-input ';
114
+			    } elseif ( $type == 'checkbox' ) {
115
+				    $label_after = true; // if type file we need the label after
116
+				    $args['class'] .= $aui_bs5 ? ' form-check-input c-pointer ' : ' custom-control-input c-pointer ';
117
+			    } elseif ( $type == 'datepicker' || $type == 'timepicker' ) {
118
+				    $orig_type = $type;
119
+				    $type = 'text';
120
+				    $args['class'] .= ' bg-initial '; // @todo not sure why we have this?
121
+				    $clear_function .= "jQuery(this).parent().parent().find('input[name=\'" . esc_attr( $args['name'] ) . "\']').trigger('change');";
122
+
123
+				    $args['extra_attributes']['data-aui-init'] = 'flatpickr';
124
+
125
+				    // Disable native datetime inputs.
126
+				    $disable_mobile_attr = isset( $args['extra_attributes']['data-disable-mobile'] ) ? $args['extra_attributes']['data-disable-mobile'] : 'true';
127
+				    $disable_mobile_attr = apply_filters( 'aui_flatpickr_disable_disable_mobile_attr', $disable_mobile_attr, $args );
128
+
129
+				    $args['extra_attributes']['data-disable-mobile'] = $disable_mobile_attr;
130
+
131
+				    // set a way to clear field if empty
132
+				    if ( $args['input_group_right'] === '' && $args['clear_icon'] !== false ) {
133
+					    $args['input_group_right_inside'] = true;
134
+					    $args['clear_icon'] = true;
135
+				    }
136
+
137
+				    // enqueue the script
138
+				    $aui_settings = AyeCode_UI_Settings::instance();
139
+				    $aui_settings->enqueue_flatpickr();
140
+			    } elseif ( $type == 'iconpicker' ) {
141
+				    $type = 'text';
142
+				    //$args['class'] .= ' aui-flatpickr bg-initial ';
143
+    //				$args['class'] .= ' bg-initial ';
144
+
145
+				    $args['extra_attributes']['data-aui-init'] = 'iconpicker';
146
+				    $args['extra_attributes']['data-placement'] = 'bottomRight';
147
+
148
+				    $args['input_group_right'] = '<span class="input-group-addon input-group-text c-pointer"></span>';
149
+    //				$args['input_group_right_inside'] = true;
150
+				    // enqueue the script
151
+				    $aui_settings = AyeCode_UI_Settings::instance();
152
+				    $aui_settings->enqueue_iconpicker();
153
+			    }
154
+
155
+			    if ( $type == 'checkbox' && ( ( ! empty( $args['name'] ) && strpos( $args['name'], '[' ) === false ) || ! empty( $args['with_hidden'] ) ) ) {
156
+				    $output .= '<input type="hidden" name="' . esc_attr( $args['name'] ) . '" value="0" />';
157
+			    }
158
+
159
+			    // allow clear icon
160
+			    if ( $args['input_group_right'] === '' && $args['clear_icon'] ) {
161
+				    $font_size = $size == 'sm' ? '1.3' : ( $size == 'lg' ? '1.65' : '1.5' );
162
+				    $args['input_group_right_inside'] = true;
163
+				    $align_class = $aui_bs5 ? ' h-100 py-0' : '';
164
+				    $args['input_group_right'] = '<span class="input-group-text aui-clear-input c-pointer bg-initial border-0 px-2 d-none ' . $align_class . '" onclick="' . $clear_function . '"><span style="font-size: ' . $font_size . 'rem" aria-hidden="true" class="' . ( $aui_bs5 ? 'btn-close' : 'close' ) . '">' . ( $aui_bs5 ? '' : '&times;' ) . '</span></span>';
165
+			    }
166
+
167
+			    // open/type
168
+			    $output .= '<input type="' . $type . '" ';
169
+
170
+			    // name
171
+			    if ( ! empty( $args['name'] ) ) {
172
+				    $output .= ' name="' . esc_attr( $args['name'] ) . '" ';
173
+			    }
174
+
175
+			    // id
176
+			    if ( ! empty( $args['id'] ) ) {
177
+				    $output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
178
+			    }
179
+
180
+			    // placeholder
181
+			    if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
182
+				    $output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
183
+			    }
184
+
185
+			    // title
186
+			    if ( ! empty( $args['title'] ) ) {
187
+				    $output .= ' title="' . esc_attr( $args['title'] ) . '" ';
188
+			    }
189
+
190
+			    // value
191
+			    if ( ! empty( $args['value'] ) ) {
192
+				    $output .= AUI_Component_Helper::value( $args['value'] );
193
+			    }
194
+
195
+			    // checked, for radio and checkboxes
196
+			    if ( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ) {
197
+				    $output .= ' checked ';
198
+			    }
199
+
200
+			    // validation text
201
+			    if ( ! empty( $args['validation_text'] ) ) {
202
+				    $output .= ' oninvalid="setCustomValidity(\'' . esc_attr( addslashes( $args['validation_text'] ) ) . '\')" ';
203
+				    $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
204
+			    }
205
+
206
+			    // validation_pattern
207
+			    if ( ! empty( $args['validation_pattern'] ) ) {
208
+				    $output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
209
+			    }
210
+
211
+			    // step (for numbers)
212
+			    if ( ! empty( $args['step'] ) ) {
213
+				    $output .= ' step="' . $args['step'] . '" ';
214
+			    }
215
+
216
+			    // required
217
+			    if ( ! empty( $args['required'] ) ) {
218
+				    $output .= ' required ';
219
+			    }
220
+
221
+			    // class
222
+			    $class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
223
+			    $output .= $aui_bs5 &&  $type == 'checkbox' ? ' class="' . $class . '" ' : ' class="form-control ' . $class . '" ';
224
+
225
+			    // data-attributes
226
+			    $output .= AUI_Component_Helper::data_attributes( $args );
227
+
228
+			    // extra attributes
229
+			    if ( ! empty( $args['extra_attributes'] ) ) {
230
+				    $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
231
+			    }
232
+
233
+			    // close
234
+			    $output .= ' >';
235
+
236
+			    // help text
237
+			    if ( ! empty( $args['help_text'] ) ) {
238
+				    $help_text = AUI_Component_Helper::help_text( $args['help_text'] );
239
+			    }
240
+
241
+			    // label
242
+			    if ( ! empty( $args['label'] ) ) {
243
+				    $label_base_class = '';
244
+				    if ( $type == 'file' ) {
245
+					    $label_base_class = ' custom-file-label';
246
+				    } elseif ( $type == 'checkbox' ) {
247
+					    if ( ! empty( $args['label_force_left'] ) ) {
248
+						    $label_args['title'] = wp_kses_post( $args['help_text'] );
249
+						    $help_text = '';
250
+						    //$label_args['class'] .= ' d-inline ';
251
+						    $args['wrap_class'] .= ' align-items-center ';
252
+					    }else{
253
+
254
+					    }
255
+
256
+					    $label_base_class = $aui_bs5 ? ' form-check-label' : ' custom-control-label';
257
+				    }
258
+				    $label_args['class'] .= $label_base_class;
259
+				    $temp_label_args = $label_args;
260
+				    if(! empty( $args['label_force_left'] )){$temp_label_args['class'] = $label_base_class." text-muted";}
261
+				    $label = self::label( $temp_label_args, $type );
262
+			    }
263
+
264
+
265
+
266
+
267
+			    // set help text in the correct position
268
+			    if ( $label_after ) {
269
+				    $output .= $label . $help_text;
270
+			    }
271
+
272
+			    // some input types need a separate wrap
273
+			    if ( $type == 'file' ) {
274
+				    $output = self::wrap( array(
275
+					    'content' => $output,
276
+					    'class'   => $aui_bs5 ? 'mb-3 custom-file' : 'form-group custom-file'
277
+				    ) );
278
+			    } elseif ( $type == 'checkbox' ) {
279
+
280
+				    $label_args['title'] = $args['label'];
281
+				    $label_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'label' );
282
+				    $label = !empty( $args['label_force_left'] ) ? self::label( $label_args, 'cb' ) : '<div class="' . $label_col . ' col-form-label"></div>';
283
+				    $switch_size_class = $args['switch'] && !is_bool( $args['switch'] ) ? ' custom-switch-'.esc_attr( $args['switch'] ) : '';
284
+				    if ( $aui_bs5 ) {
285
+					    $wrap_class = $args['switch'] ? 'form-check form-switch' . $switch_size_class : 'form-check';
286
+				    }else{
287
+					    $wrap_class = $args['switch'] ? 'custom-switch' . $switch_size_class :  'custom-checkbox' ;
288
+				    }
289
+				    if ( ! empty( $args['label_force_left'] ) ) {
290
+					    $wrap_class .= $aui_bs5 ? '' : ' d-flex align-content-center';
291
+					    $label = str_replace(array("form-check-label","custom-control-label"),"", self::label( $label_args, 'cb' ) );
292
+				    }
293
+				    $output     = self::wrap( array(
294
+					    'content' => $output,
295
+					    'class'   => $aui_bs5 ? $wrap_class : 'custom-control ' . $wrap_class
296
+				    ) );
297
+
298
+				    if ( $args['label_type'] == 'horizontal' ) {
299
+					    $input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
300
+					    $output    = $label . '<div class="' . $input_col . '">' . $output . '</div>';
301
+				    }
302
+			    } elseif ( $type == 'password' && $args['password_toggle'] && ! $args['input_group_right'] ) {
303
+
304
+
305
+				    // allow password field to toggle view
306
+				    $args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
307 307
 onclick="var $el = jQuery(this).find(\'i\');$el.toggleClass(\'fa-eye fa-eye-slash\');
308 308
 var $eli = jQuery(this).parent().parent().find(\'input\');
309 309
 if($el.hasClass(\'fa-eye\'))
310 310
 {$eli.attr(\'type\',\'text\');}
311 311
 else{$eli.attr(\'type\',\'password\');}"
312 312
 ><i class="far fa-fw fa-eye-slash"></i></span>';
313
-			}
314
-
315
-			// input group wraps
316
-			if ( $args['input_group_left'] || $args['input_group_right'] ) {
317
-				$w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
318
-				$group_size = $size == 'lg' ? ' input-group-lg' : '';
319
-				$group_size = !$group_size && $size == 'sm' ? ' input-group-sm' : $group_size;
320
-
321
-				if ( $args['input_group_left'] ) {
322
-					$output = self::wrap( array(
323
-						'content'                 => $output,
324
-						'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 . $group_size : 'input-group' . $group_size,
325
-						'input_group_left'        => $args['input_group_left'],
326
-						'input_group_left_inside' => $args['input_group_left_inside']
327
-					) );
328
-				}
329
-				if ( $args['input_group_right'] ) {
330
-					$output = self::wrap( array(
331
-						'content'                  => $output,
332
-						'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 . $group_size : 'input-group' . $group_size,
333
-						'input_group_right'        => $args['input_group_right'],
334
-						'input_group_right_inside' => $args['input_group_right_inside']
335
-					) );
336
-				}
337
-
338
-			}
339
-
340
-			if ( ! $label_after ) {
341
-				$output .= $help_text;
342
-			}
343
-
344
-
345
-			if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
346
-				$output = self::wrap( array(
347
-					'content' => $output,
348
-					'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
349
-				) );
350
-			}
351
-
352
-			if ( ! $label_after ) {
353
-				$output = $label . $output;
354
-			}
355
-
356
-			// wrap
357
-			if ( ! $args['no_wrap'] ) {
358
-				if ( ! empty( $args['form_group_class'] ) ) {
359
-					$fg_class = esc_attr( $args['form_group_class'] );
360
-				}else{
361
-					$fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
362
-				}
363
-				$form_group_class = $args['label_type'] == 'floating' && $type != 'checkbox' ? 'form-label-group' : $fg_class;
364
-				$wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
365
-				$wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
366
-				$output           = self::wrap( array(
367
-					'content'         => $output,
368
-					'class'           => $wrap_class,
369
-					'element_require' => $args['element_require'],
370
-					'argument_id'     => $args['id'],
371
-					'wrap_attributes' => $args['wrap_attributes'],
372
-				) );
373
-			}
374
-		}
375
-
376
-		return $output;
377
-	}
378
-
379
-	public static function label( $args = array(), $type = '' ) {
380
-		global $aui_bs5;
381
-		//<label for="exampleInputEmail1">Email address</label>
382
-		$defaults = array(
383
-			'title'      => 'div',
384
-			'for'        => '',
385
-			'class'      => '',
386
-			'label_type' => '', // empty = hidden, top, horizontal
387
-			'label_col'  => '',
388
-		);
389
-
390
-		/**
313
+			    }
314
+
315
+			    // input group wraps
316
+			    if ( $args['input_group_left'] || $args['input_group_right'] ) {
317
+				    $w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
318
+				    $group_size = $size == 'lg' ? ' input-group-lg' : '';
319
+				    $group_size = !$group_size && $size == 'sm' ? ' input-group-sm' : $group_size;
320
+
321
+				    if ( $args['input_group_left'] ) {
322
+					    $output = self::wrap( array(
323
+						    'content'                 => $output,
324
+						    'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 . $group_size : 'input-group' . $group_size,
325
+						    'input_group_left'        => $args['input_group_left'],
326
+						    'input_group_left_inside' => $args['input_group_left_inside']
327
+					    ) );
328
+				    }
329
+				    if ( $args['input_group_right'] ) {
330
+					    $output = self::wrap( array(
331
+						    'content'                  => $output,
332
+						    'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 . $group_size : 'input-group' . $group_size,
333
+						    'input_group_right'        => $args['input_group_right'],
334
+						    'input_group_right_inside' => $args['input_group_right_inside']
335
+					    ) );
336
+				    }
337
+
338
+			    }
339
+
340
+			    if ( ! $label_after ) {
341
+				    $output .= $help_text;
342
+			    }
343
+
344
+
345
+			    if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
346
+				    $output = self::wrap( array(
347
+					    'content' => $output,
348
+					    'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
349
+				    ) );
350
+			    }
351
+
352
+			    if ( ! $label_after ) {
353
+				    $output = $label . $output;
354
+			    }
355
+
356
+			    // wrap
357
+			    if ( ! $args['no_wrap'] ) {
358
+				    if ( ! empty( $args['form_group_class'] ) ) {
359
+					    $fg_class = esc_attr( $args['form_group_class'] );
360
+				    }else{
361
+					    $fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
362
+				    }
363
+				    $form_group_class = $args['label_type'] == 'floating' && $type != 'checkbox' ? 'form-label-group' : $fg_class;
364
+				    $wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
365
+				    $wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
366
+				    $output           = self::wrap( array(
367
+					    'content'         => $output,
368
+					    'class'           => $wrap_class,
369
+					    'element_require' => $args['element_require'],
370
+					    'argument_id'     => $args['id'],
371
+					    'wrap_attributes' => $args['wrap_attributes'],
372
+				    ) );
373
+			    }
374
+		    }
375
+
376
+		    return $output;
377
+	    }
378
+
379
+	    public static function label( $args = array(), $type = '' ) {
380
+		    global $aui_bs5;
381
+		    //<label for="exampleInputEmail1">Email address</label>
382
+		    $defaults = array(
383
+			    'title'      => 'div',
384
+			    'for'        => '',
385
+			    'class'      => '',
386
+			    'label_type' => '', // empty = hidden, top, horizontal
387
+			    'label_col'  => '',
388
+		    );
389
+
390
+		    /**
391 391
 		 * Parse incoming $args into an array and merge it with $defaults
392 392
 		 */
393
-		$args   = wp_parse_args( $args, $defaults );
394
-		$output = '';
393
+		    $args   = wp_parse_args( $args, $defaults );
394
+		    $output = '';
395 395
 
396
-		if ( $args['title'] ) {
396
+		    if ( $args['title'] ) {
397 397
 
398
-			// maybe hide labels //@todo set a global option for visibility class
399
-			if ( $type == 'file' || $type == 'checkbox' || $type == 'radio' || ! empty( $args['label_type'] ) ) {
400
-				$class = $args['class'];
401
-			} else {
402
-				$class = 'sr-only ' . $args['class'];
403
-			}
398
+			    // maybe hide labels //@todo set a global option for visibility class
399
+			    if ( $type == 'file' || $type == 'checkbox' || $type == 'radio' || ! empty( $args['label_type'] ) ) {
400
+				    $class = $args['class'];
401
+			    } else {
402
+				    $class = 'sr-only ' . $args['class'];
403
+			    }
404 404
 
405
-			// maybe horizontal
406
-			if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
407
-				$class .= ' ' . AUI_Component_Helper::get_column_class( $args['label_col'], 'label' ) . ' col-form-label '.$type;
408
-			}
405
+			    // maybe horizontal
406
+			    if ( $args['label_type'] == 'horizontal' && $type != 'checkbox' ) {
407
+				    $class .= ' ' . AUI_Component_Helper::get_column_class( $args['label_col'], 'label' ) . ' col-form-label '.$type;
408
+			    }
409 409
 
410
-			if( $aui_bs5 ){ $class .= ' form-label'; }
410
+			    if( $aui_bs5 ){ $class .= ' form-label'; }
411 411
 
412
-			// open
413
-			$output .= '<label ';
412
+			    // open
413
+			    $output .= '<label ';
414 414
 
415
-			// for
416
-			if ( ! empty( $args['for'] ) ) {
417
-				$output .= ' for="' . esc_attr( $args['for'] ) . '" ';
418
-			}
415
+			    // for
416
+			    if ( ! empty( $args['for'] ) ) {
417
+				    $output .= ' for="' . esc_attr( $args['for'] ) . '" ';
418
+			    }
419 419
 
420
-			// class
421
-			$class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
422
-			$output .= ' class="' . $class . '" ';
420
+			    // class
421
+			    $class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
422
+			    $output .= ' class="' . $class . '" ';
423 423
 
424
-			// close
425
-			$output .= '>';
424
+			    // close
425
+			    $output .= '>';
426 426
 
427 427
 
428
-			// title, don't escape fully as can contain html
429
-			if ( ! empty( $args['title'] ) ) {
430
-				$output .= wp_kses_post( $args['title'] );
431
-			}
428
+			    // title, don't escape fully as can contain html
429
+			    if ( ! empty( $args['title'] ) ) {
430
+				    $output .= wp_kses_post( $args['title'] );
431
+			    }
432 432
 
433
-			// close wrap
434
-			$output .= '</label>';
433
+			    // close wrap
434
+			    $output .= '</label>';
435 435
 
436 436
 
437
-		}
437
+		    }
438 438
 
439 439
 
440
-		return $output;
441
-	}
440
+		    return $output;
441
+	    }
442 442
 
443
-	/**
443
+	    /**
444 444
 	 * Wrap some content in a HTML wrapper.
445 445
 	 *
446 446
 	 * @param array $args
447 447
 	 *
448 448
 	 * @return string
449 449
 	 */
450
-	public static function wrap( $args = array() ) {
451
-		global $aui_bs5;
452
-		$defaults = array(
453
-			'type'                     => 'div',
454
-			'class'                    => $aui_bs5 ? 'mb-3' : 'form-group',
455
-			'content'                  => '',
456
-			'input_group_left'         => '',
457
-			'input_group_right'        => '',
458
-			'input_group_left_inside'  => false,
459
-			'input_group_right_inside' => false,
460
-			'element_require'          => '',
461
-			'argument_id'              => '',
462
-			'wrap_attributes'          => array()
463
-		);
464
-
465
-		/**
450
+	    public static function wrap( $args = array() ) {
451
+		    global $aui_bs5;
452
+		    $defaults = array(
453
+			    'type'                     => 'div',
454
+			    'class'                    => $aui_bs5 ? 'mb-3' : 'form-group',
455
+			    'content'                  => '',
456
+			    'input_group_left'         => '',
457
+			    'input_group_right'        => '',
458
+			    'input_group_left_inside'  => false,
459
+			    'input_group_right_inside' => false,
460
+			    'element_require'          => '',
461
+			    'argument_id'              => '',
462
+			    'wrap_attributes'          => array()
463
+		    );
464
+
465
+		    /**
466 466
 		 * Parse incoming $args into an array and merge it with $defaults
467 467
 		 */
468
-		$args   = wp_parse_args( $args, $defaults );
469
-		$output = '';
470
-		if ( $args['type'] ) {
468
+		    $args   = wp_parse_args( $args, $defaults );
469
+		    $output = '';
470
+		    if ( $args['type'] ) {
471 471
 
472
-			// open
473
-			$output .= '<' . sanitize_html_class( $args['type'] );
472
+			    // open
473
+			    $output .= '<' . sanitize_html_class( $args['type'] );
474 474
 
475
-			// element require
476
-			if ( ! empty( $args['element_require'] ) ) {
477
-				$output .= AUI_Component_Helper::element_require( $args['element_require'] );
478
-				$args['class'] .= " aui-conditional-field";
479
-			}
475
+			    // element require
476
+			    if ( ! empty( $args['element_require'] ) ) {
477
+				    $output .= AUI_Component_Helper::element_require( $args['element_require'] );
478
+				    $args['class'] .= " aui-conditional-field";
479
+			    }
480 480
 
481
-			// argument_id
482
-			if ( ! empty( $args['argument_id'] ) ) {
483
-				$output .= ' data-argument="' . esc_attr( $args['argument_id'] ) . '"';
484
-			}
481
+			    // argument_id
482
+			    if ( ! empty( $args['argument_id'] ) ) {
483
+				    $output .= ' data-argument="' . esc_attr( $args['argument_id'] ) . '"';
484
+			    }
485 485
 
486
-			// class
487
-			$class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
488
-			$output .= ' class="' . $class . '" ';
486
+			    // class
487
+			    $class = ! empty( $args['class'] ) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
488
+			    $output .= ' class="' . $class . '" ';
489 489
 
490
-			// Attributes
491
-			if ( ! empty( $args['wrap_attributes'] ) ) {
492
-				$output .= AUI_Component_Helper::extra_attributes( $args['wrap_attributes'] );
493
-			}
490
+			    // Attributes
491
+			    if ( ! empty( $args['wrap_attributes'] ) ) {
492
+				    $output .= AUI_Component_Helper::extra_attributes( $args['wrap_attributes'] );
493
+			    }
494 494
 
495
-			// close wrap
496
-			$output .= ' >';
495
+			    // close wrap
496
+			    $output .= ' >';
497 497
 
498 498
 
499
-			// Input group left
500
-			if ( ! empty( $args['input_group_left'] ) ) {
501
-				$position_class   = ! empty( $args['input_group_left_inside'] ) ? 'position-absolute h-100' : '';
502
-				$input_group_left = strpos( $args['input_group_left'], '<' ) !== false ? $args['input_group_left'] : '<span class="input-group-text">' . $args['input_group_left'] . '</span>';
503
-				$output .= $aui_bs5 ? $input_group_left : '<div class="input-group-prepend ' . $position_class . '">' . $input_group_left . '</div>';
504
-//				$output .= '<div class="input-group-prepend ' . $position_class . '">' . $input_group_left . '</div>';
505
-			}
499
+			    // Input group left
500
+			    if ( ! empty( $args['input_group_left'] ) ) {
501
+				    $position_class   = ! empty( $args['input_group_left_inside'] ) ? 'position-absolute h-100' : '';
502
+				    $input_group_left = strpos( $args['input_group_left'], '<' ) !== false ? $args['input_group_left'] : '<span class="input-group-text">' . $args['input_group_left'] . '</span>';
503
+				    $output .= $aui_bs5 ? $input_group_left : '<div class="input-group-prepend ' . $position_class . '">' . $input_group_left . '</div>';
504
+    //				$output .= '<div class="input-group-prepend ' . $position_class . '">' . $input_group_left . '</div>';
505
+			    }
506 506
 
507
-			// content
508
-			$output .= $args['content'];
507
+			    // content
508
+			    $output .= $args['content'];
509 509
 
510
-			// Input group right
511
-			if ( ! empty( $args['input_group_right'] ) ) {
512
-				$position_class    = ! empty( $args['input_group_right_inside'] ) ? 'position-absolute h-100' : '';
513
-				$input_group_right = strpos( $args['input_group_right'], '<' ) !== false ? $args['input_group_right'] : '<span class="input-group-text">' . $args['input_group_right'] . '</span>';
514
-				$output .= $aui_bs5 ? str_replace( 'input-group-text','input-group-text top-0 end-0', $input_group_right ) : '<div class="input-group-append ' . $position_class . '" style="top:0;right:0;">' . $input_group_right . '</div>';
515
-//				$output .= '<div class="input-group-append ' . $position_class . '" style="top:0;right:0;">' . $input_group_right . '</div>';
516
-			}
510
+			    // Input group right
511
+			    if ( ! empty( $args['input_group_right'] ) ) {
512
+				    $position_class    = ! empty( $args['input_group_right_inside'] ) ? 'position-absolute h-100' : '';
513
+				    $input_group_right = strpos( $args['input_group_right'], '<' ) !== false ? $args['input_group_right'] : '<span class="input-group-text">' . $args['input_group_right'] . '</span>';
514
+				    $output .= $aui_bs5 ? str_replace( 'input-group-text','input-group-text top-0 end-0', $input_group_right ) : '<div class="input-group-append ' . $position_class . '" style="top:0;right:0;">' . $input_group_right . '</div>';
515
+    //				$output .= '<div class="input-group-append ' . $position_class . '" style="top:0;right:0;">' . $input_group_right . '</div>';
516
+			    }
517 517
 
518 518
 
519
-			// close wrap
520
-			$output .= '</' . sanitize_html_class( $args['type'] ) . '>';
519
+			    // close wrap
520
+			    $output .= '</' . sanitize_html_class( $args['type'] ) . '>';
521 521
 
522 522
 
523
-		} else {
524
-			$output = $args['content'];
525
-		}
523
+		    } else {
524
+			    $output = $args['content'];
525
+		    }
526 526
 
527
-		return $output;
528
-	}
527
+		    return $output;
528
+	    }
529 529
 
530
-	/**
530
+	    /**
531 531
 	 * Build the component.
532 532
 	 *
533 533
 	 * @param array $args
534 534
 	 *
535 535
 	 * @return string The rendered component.
536 536
 	 */
537
-	public static function textarea( $args = array() ) {
538
-		global $aui_bs5;
539
-
540
-		$defaults = array(
541
-			'name'               => '',
542
-			'class'              => '',
543
-			'wrap_class'         => '',
544
-			'id'                 => '',
545
-			'placeholder'        => '',
546
-			'title'              => '',
547
-			'value'              => '',
548
-			'required'           => false,
549
-			'label'              => '',
550
-			'label_after'        => false,
551
-			'label_class'        => '',
552
-			'label_type'         => '',
553
-			'label_col'          => '',
554
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
555
-			'input_group_right'        => '',
556
-			'input_group_left'         => '',
557
-			'input_group_right_inside' => false,
558
-			'form_group_class'      => '',
559
-			'help_text'          => '',
560
-			'validation_text'    => '',
561
-			'validation_pattern' => '',
562
-			'no_wrap'            => false,
563
-			'rows'               => '',
564
-			'wysiwyg'            => false,
565
-			'allow_tags'         => false,
566
-			// Allow HTML tags
567
-			'element_require'    => '',
568
-			// [%element_id%] == "1"
569
-			'extra_attributes'   => array(),
570
-			// an array of extra attributes
571
-			'wrap_attributes'    => array(),
572
-		);
573
-
574
-		/**
537
+	    public static function textarea( $args = array() ) {
538
+		    global $aui_bs5;
539
+
540
+		    $defaults = array(
541
+			    'name'               => '',
542
+			    'class'              => '',
543
+			    'wrap_class'         => '',
544
+			    'id'                 => '',
545
+			    'placeholder'        => '',
546
+			    'title'              => '',
547
+			    'value'              => '',
548
+			    'required'           => false,
549
+			    'label'              => '',
550
+			    'label_after'        => false,
551
+			    'label_class'        => '',
552
+			    'label_type'         => '',
553
+			    'label_col'          => '',
554
+			    // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
555
+			    'input_group_right'        => '',
556
+			    'input_group_left'         => '',
557
+			    'input_group_right_inside' => false,
558
+			    'form_group_class'      => '',
559
+			    'help_text'          => '',
560
+			    'validation_text'    => '',
561
+			    'validation_pattern' => '',
562
+			    'no_wrap'            => false,
563
+			    'rows'               => '',
564
+			    'wysiwyg'            => false,
565
+			    'allow_tags'         => false,
566
+			    // Allow HTML tags
567
+			    'element_require'    => '',
568
+			    // [%element_id%] == "1"
569
+			    'extra_attributes'   => array(),
570
+			    // an array of extra attributes
571
+			    'wrap_attributes'    => array(),
572
+		    );
573
+
574
+		    /**
575 575
 		 * Parse incoming $args into an array and merge it with $defaults
576 576
 		 */
577
-		$args   = wp_parse_args( $args, $defaults );
578
-		$output = '';
579
-		$label = '';
580
-
581
-		// hidden label option needs to be empty
582
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
583
-
584
-		// floating labels don't work with wysiwyg so set it as top
585
-		if ( $args['label_type'] == 'floating' && ! empty( $args['wysiwyg'] ) ) {
586
-			$args['label_type'] = 'top';
587
-		}
588
-
589
-		$label_after = $args['label_after'];
590
-
591
-		// floating labels need label after
592
-		if ( $args['label_type'] == 'floating' && empty( $args['wysiwyg'] ) ) {
593
-			$label_after         = true;
594
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
595
-		}
596
-
597
-		// label
598
-		if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
599
-		} elseif ( ! empty( $args['label'] ) && ! $label_after ) {
600
-			$label_args = array(
601
-				'title'      => $args['label'],
602
-				'for'        => $args['id'],
603
-				'class'      => $args['label_class'] . " ",
604
-				'label_type' => $args['label_type'],
605
-				'label_col'  => $args['label_col']
606
-			);
607
-			$label .= self::label( $label_args );
608
-		}
609
-
610
-		// maybe horizontal label
611
-		if ( $args['label_type'] == 'horizontal' ) {
612
-			$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
613
-			$label .= '<div class="' . $input_col . '">';
614
-		}
615
-
616
-		if ( ! empty( $args['wysiwyg'] ) ) {
617
-			ob_start();
618
-			$content   = $args['value'];
619
-			$editor_id = ! empty( $args['id'] ) ? sanitize_html_class( $args['id'] ) : 'wp_editor';
620
-			$settings  = array(
621
-				'textarea_rows' => ! empty( absint( $args['rows'] ) ) ? absint( $args['rows'] ) : 4,
622
-				'quicktags'     => false,
623
-				'media_buttons' => false,
624
-				'editor_class'  => 'form-control',
625
-				'textarea_name' => ! empty( $args['name'] ) ? sanitize_html_class( $args['name'] ) : sanitize_html_class( $args['id'] ),
626
-				'teeny'         => true,
627
-			);
628
-
629
-			// maybe set settings if array
630
-			if ( is_array( $args['wysiwyg'] ) ) {
631
-				$settings = wp_parse_args( $args['wysiwyg'], $settings );
632
-			}
633
-
634
-			wp_editor( $content, $editor_id, $settings );
635
-			$output .= ob_get_clean();
636
-		} else {
637
-
638
-			// open
639
-			$output .= '<textarea ';
640
-
641
-			// name
642
-			if ( ! empty( $args['name'] ) ) {
643
-				$output .= ' name="' . esc_attr( $args['name'] ) . '" ';
644
-			}
645
-
646
-			// id
647
-			if ( ! empty( $args['id'] ) ) {
648
-				$output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
649
-			}
650
-
651
-			// placeholder
652
-			if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
653
-				$output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
654
-			}
655
-
656
-			// title
657
-			if ( ! empty( $args['title'] ) ) {
658
-				$output .= ' title="' . esc_attr( $args['title'] ) . '" ';
659
-			}
660
-
661
-			// validation text
662
-			if ( ! empty( $args['validation_text'] ) ) {
663
-				$output .= ' oninvalid="setCustomValidity(\'' . esc_attr( addslashes( $args['validation_text'] ) ) . '\')" ';
664
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
665
-			}
666
-
667
-			// validation_pattern
668
-			if ( ! empty( $args['validation_pattern'] ) ) {
669
-				$output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
670
-			}
671
-
672
-			// required
673
-			if ( ! empty( $args['required'] ) ) {
674
-				$output .= ' required ';
675
-			}
676
-
677
-			// rows
678
-			if ( ! empty( $args['rows'] ) ) {
679
-				$output .= ' rows="' . absint( $args['rows'] ) . '" ';
680
-			}
681
-
682
-
683
-			// class
684
-			$class = ! empty( $args['class'] ) ? $args['class'] : '';
685
-			$output .= ' class="form-control ' . $class . '" ';
686
-
687
-			// extra attributes
688
-			if ( ! empty( $args['extra_attributes'] ) ) {
689
-				$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
690
-			}
691
-
692
-			// close tag
693
-			$output .= ' >';
694
-
695
-			// value
696
-			if ( ! empty( $args['value'] ) ) {
697
-				if ( ! empty( $args['allow_tags'] ) ) {
698
-					$output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
699
-				} else {
700
-					$output .= AUI_Component_Helper::sanitize_textarea_field( $args['value'] );
701
-				}
702
-			}
703
-
704
-			// closing tag
705
-			$output .= '</textarea>';
706
-
707
-
708
-			// input group wraps
709
-			if ( $args['input_group_left'] || $args['input_group_right'] ) {
710
-				$w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
711
-				if ( $args['input_group_left'] ) {
712
-					$output = self::wrap( array(
713
-						'content'                 => $output,
714
-						'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
715
-						'input_group_left'        => $args['input_group_left'],
716
-						'input_group_left_inside' => $args['input_group_left_inside']
717
-					) );
718
-				}
719
-				if ( $args['input_group_right'] ) {
720
-					$output = self::wrap( array(
721
-						'content'                  => $output,
722
-						'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
723
-						'input_group_right'        => $args['input_group_right'],
724
-						'input_group_right_inside' => $args['input_group_right_inside']
725
-					) );
726
-				}
727
-
728
-			}
729
-
730
-
731
-		}
732
-
733
-		if ( ! empty( $args['label'] ) && $label_after ) {
734
-			$label_args = array(
735
-				'title'      => $args['label'],
736
-				'for'        => $args['id'],
737
-				'class'      => $args['label_class'] . " ",
738
-				'label_type' => $args['label_type'],
739
-				'label_col'  => $args['label_col']
740
-			);
741
-			$output .= self::label( $label_args );
742
-		}
743
-
744
-		// help text
745
-		if ( ! empty( $args['help_text'] ) ) {
746
-			$output .= AUI_Component_Helper::help_text( $args['help_text'] );
747
-		}
748
-
749
-		if ( ! $label_after ) {
750
-			$output = $label . $output;
751
-		}
752
-
753
-		// maybe horizontal label
754
-		if ( $args['label_type'] == 'horizontal' ) {
755
-			$output .= '</div>';
756
-		}
757
-
758
-
759
-		// wrap
760
-		if ( ! $args['no_wrap'] ) {
761
-			if ( ! empty( $args['form_group_class'] ) ) {
762
-				$fg_class = esc_attr( $args['form_group_class'] );
763
-			}else{
764
-				$fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
765
-			}
766
-			$form_group_class = $args['label_type'] == 'floating' ? 'form-label-group' : $fg_class;
767
-			$wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
768
-			$wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
769
-			$output           = self::wrap( array(
770
-				'content'         => $output,
771
-				'class'           => $wrap_class,
772
-				'element_require' => $args['element_require'],
773
-				'argument_id'     => $args['id'],
774
-				'wrap_attributes' => $args['wrap_attributes'],
775
-			) );
776
-		}
777
-
778
-
779
-		return $output;
780
-	}
781
-
782
-	/**
577
+		    $args   = wp_parse_args( $args, $defaults );
578
+		    $output = '';
579
+		    $label = '';
580
+
581
+		    // hidden label option needs to be empty
582
+		    $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
583
+
584
+		    // floating labels don't work with wysiwyg so set it as top
585
+		    if ( $args['label_type'] == 'floating' && ! empty( $args['wysiwyg'] ) ) {
586
+			    $args['label_type'] = 'top';
587
+		    }
588
+
589
+		    $label_after = $args['label_after'];
590
+
591
+		    // floating labels need label after
592
+		    if ( $args['label_type'] == 'floating' && empty( $args['wysiwyg'] ) ) {
593
+			    $label_after         = true;
594
+			    $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
595
+		    }
596
+
597
+		    // label
598
+		    if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
599
+		    } elseif ( ! empty( $args['label'] ) && ! $label_after ) {
600
+			    $label_args = array(
601
+				    'title'      => $args['label'],
602
+				    'for'        => $args['id'],
603
+				    'class'      => $args['label_class'] . " ",
604
+				    'label_type' => $args['label_type'],
605
+				    'label_col'  => $args['label_col']
606
+			    );
607
+			    $label .= self::label( $label_args );
608
+		    }
609
+
610
+		    // maybe horizontal label
611
+		    if ( $args['label_type'] == 'horizontal' ) {
612
+			    $input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
613
+			    $label .= '<div class="' . $input_col . '">';
614
+		    }
615
+
616
+		    if ( ! empty( $args['wysiwyg'] ) ) {
617
+			    ob_start();
618
+			    $content   = $args['value'];
619
+			    $editor_id = ! empty( $args['id'] ) ? sanitize_html_class( $args['id'] ) : 'wp_editor';
620
+			    $settings  = array(
621
+				    'textarea_rows' => ! empty( absint( $args['rows'] ) ) ? absint( $args['rows'] ) : 4,
622
+				    'quicktags'     => false,
623
+				    'media_buttons' => false,
624
+				    'editor_class'  => 'form-control',
625
+				    'textarea_name' => ! empty( $args['name'] ) ? sanitize_html_class( $args['name'] ) : sanitize_html_class( $args['id'] ),
626
+				    'teeny'         => true,
627
+			    );
628
+
629
+			    // maybe set settings if array
630
+			    if ( is_array( $args['wysiwyg'] ) ) {
631
+				    $settings = wp_parse_args( $args['wysiwyg'], $settings );
632
+			    }
633
+
634
+			    wp_editor( $content, $editor_id, $settings );
635
+			    $output .= ob_get_clean();
636
+		    } else {
637
+
638
+			    // open
639
+			    $output .= '<textarea ';
640
+
641
+			    // name
642
+			    if ( ! empty( $args['name'] ) ) {
643
+				    $output .= ' name="' . esc_attr( $args['name'] ) . '" ';
644
+			    }
645
+
646
+			    // id
647
+			    if ( ! empty( $args['id'] ) ) {
648
+				    $output .= ' id="' . sanitize_html_class( $args['id'] ) . '" ';
649
+			    }
650
+
651
+			    // placeholder
652
+			    if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] ) {
653
+				    $output .= ' placeholder="' . esc_attr( $args['placeholder'] ) . '" ';
654
+			    }
655
+
656
+			    // title
657
+			    if ( ! empty( $args['title'] ) ) {
658
+				    $output .= ' title="' . esc_attr( $args['title'] ) . '" ';
659
+			    }
660
+
661
+			    // validation text
662
+			    if ( ! empty( $args['validation_text'] ) ) {
663
+				    $output .= ' oninvalid="setCustomValidity(\'' . esc_attr( addslashes( $args['validation_text'] ) ) . '\')" ';
664
+				    $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
665
+			    }
666
+
667
+			    // validation_pattern
668
+			    if ( ! empty( $args['validation_pattern'] ) ) {
669
+				    $output .= ' pattern="' . esc_attr( $args['validation_pattern'] ) . '" ';
670
+			    }
671
+
672
+			    // required
673
+			    if ( ! empty( $args['required'] ) ) {
674
+				    $output .= ' required ';
675
+			    }
676
+
677
+			    // rows
678
+			    if ( ! empty( $args['rows'] ) ) {
679
+				    $output .= ' rows="' . absint( $args['rows'] ) . '" ';
680
+			    }
681
+
682
+
683
+			    // class
684
+			    $class = ! empty( $args['class'] ) ? $args['class'] : '';
685
+			    $output .= ' class="form-control ' . $class . '" ';
686
+
687
+			    // extra attributes
688
+			    if ( ! empty( $args['extra_attributes'] ) ) {
689
+				    $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
690
+			    }
691
+
692
+			    // close tag
693
+			    $output .= ' >';
694
+
695
+			    // value
696
+			    if ( ! empty( $args['value'] ) ) {
697
+				    if ( ! empty( $args['allow_tags'] ) ) {
698
+					    $output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
699
+				    } else {
700
+					    $output .= AUI_Component_Helper::sanitize_textarea_field( $args['value'] );
701
+				    }
702
+			    }
703
+
704
+			    // closing tag
705
+			    $output .= '</textarea>';
706
+
707
+
708
+			    // input group wraps
709
+			    if ( $args['input_group_left'] || $args['input_group_right'] ) {
710
+				    $w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
711
+				    if ( $args['input_group_left'] ) {
712
+					    $output = self::wrap( array(
713
+						    'content'                 => $output,
714
+						    'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
715
+						    'input_group_left'        => $args['input_group_left'],
716
+						    'input_group_left_inside' => $args['input_group_left_inside']
717
+					    ) );
718
+				    }
719
+				    if ( $args['input_group_right'] ) {
720
+					    $output = self::wrap( array(
721
+						    'content'                  => $output,
722
+						    'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
723
+						    'input_group_right'        => $args['input_group_right'],
724
+						    'input_group_right_inside' => $args['input_group_right_inside']
725
+					    ) );
726
+				    }
727
+
728
+			    }
729
+
730
+
731
+		    }
732
+
733
+		    if ( ! empty( $args['label'] ) && $label_after ) {
734
+			    $label_args = array(
735
+				    'title'      => $args['label'],
736
+				    'for'        => $args['id'],
737
+				    'class'      => $args['label_class'] . " ",
738
+				    'label_type' => $args['label_type'],
739
+				    'label_col'  => $args['label_col']
740
+			    );
741
+			    $output .= self::label( $label_args );
742
+		    }
743
+
744
+		    // help text
745
+		    if ( ! empty( $args['help_text'] ) ) {
746
+			    $output .= AUI_Component_Helper::help_text( $args['help_text'] );
747
+		    }
748
+
749
+		    if ( ! $label_after ) {
750
+			    $output = $label . $output;
751
+		    }
752
+
753
+		    // maybe horizontal label
754
+		    if ( $args['label_type'] == 'horizontal' ) {
755
+			    $output .= '</div>';
756
+		    }
757
+
758
+
759
+		    // wrap
760
+		    if ( ! $args['no_wrap'] ) {
761
+			    if ( ! empty( $args['form_group_class'] ) ) {
762
+				    $fg_class = esc_attr( $args['form_group_class'] );
763
+			    }else{
764
+				    $fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
765
+			    }
766
+			    $form_group_class = $args['label_type'] == 'floating' ? 'form-label-group' : $fg_class;
767
+			    $wrap_class       = $args['label_type'] == 'horizontal' ? $form_group_class . ' row' : $form_group_class;
768
+			    $wrap_class       = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
769
+			    $output           = self::wrap( array(
770
+				    'content'         => $output,
771
+				    'class'           => $wrap_class,
772
+				    'element_require' => $args['element_require'],
773
+				    'argument_id'     => $args['id'],
774
+				    'wrap_attributes' => $args['wrap_attributes'],
775
+			    ) );
776
+		    }
777
+
778
+
779
+		    return $output;
780
+	    }
781
+
782
+	    /**
783 783
 	 * Build the component.
784 784
 	 *
785 785
 	 * @param array $args
786 786
 	 *
787 787
 	 * @return string The rendered component.
788 788
 	 */
789
-	public static function select( $args = array() ) {
790
-		global $aui_bs5, $aui_has_select2, $aui_select2_enqueued;
791
-
792
-		$defaults = array(
793
-			'class'            => '',
794
-			'wrap_class'       => '',
795
-			'id'               => '',
796
-			'title'            => '',
797
-			'value'            => '',
798
-			// can be an array or a string
799
-			'required'         => false,
800
-			'label'            => '',
801
-			'label_after'      => false,
802
-			'label_type'       => '',
803
-			'label_col'        => '',
804
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
805
-			'label_class'      => '',
806
-			'help_text'        => '',
807
-			'placeholder'      => '',
808
-			'options'          => array(),
809
-			// array or string
810
-			'icon'             => '',
811
-			'multiple'         => false,
812
-			'select2'          => false,
813
-			'no_wrap'          => false,
814
-			'input_group_right' => '',
815
-			'input_group_left' => '',
816
-			'input_group_right_inside' => false, // forces the input group inside the input
817
-			'input_group_left_inside' => false, // forces the input group inside the input
818
-			'form_group_class'  => '',
819
-			'element_require'  => '',
820
-			// [%element_id%] == "1"
821
-			'extra_attributes' => array(),
822
-			// an array of extra attributes
823
-			'wrap_attributes'  => array(),
824
-		);
825
-
826
-		/**
789
+	    public static function select( $args = array() ) {
790
+		    global $aui_bs5, $aui_has_select2, $aui_select2_enqueued;
791
+
792
+		    $defaults = array(
793
+			    'class'            => '',
794
+			    'wrap_class'       => '',
795
+			    'id'               => '',
796
+			    'title'            => '',
797
+			    'value'            => '',
798
+			    // can be an array or a string
799
+			    'required'         => false,
800
+			    'label'            => '',
801
+			    'label_after'      => false,
802
+			    'label_type'       => '',
803
+			    'label_col'        => '',
804
+			    // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
805
+			    'label_class'      => '',
806
+			    'help_text'        => '',
807
+			    'placeholder'      => '',
808
+			    'options'          => array(),
809
+			    // array or string
810
+			    'icon'             => '',
811
+			    'multiple'         => false,
812
+			    'select2'          => false,
813
+			    'no_wrap'          => false,
814
+			    'input_group_right' => '',
815
+			    'input_group_left' => '',
816
+			    'input_group_right_inside' => false, // forces the input group inside the input
817
+			    'input_group_left_inside' => false, // forces the input group inside the input
818
+			    'form_group_class'  => '',
819
+			    'element_require'  => '',
820
+			    // [%element_id%] == "1"
821
+			    'extra_attributes' => array(),
822
+			    // an array of extra attributes
823
+			    'wrap_attributes'  => array(),
824
+		    );
825
+
826
+		    /**
827 827
 		 * Parse incoming $args into an array and merge it with $defaults
828 828
 		 */
829
-		$args   = wp_parse_args( $args, $defaults );
830
-		$output = '';
831
-
832
-		// for now lets hide floating labels
833
-		if ( $args['label_type'] == 'floating' ) {
834
-			$args['label_type'] = 'hidden';
835
-		}
836
-
837
-		// hidden label option needs to be empty
838
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
839
-
840
-
841
-		$label_after = $args['label_after'];
842
-
843
-		// floating labels need label after
844
-		if ( $args['label_type'] == 'floating' ) {
845
-			$label_after         = true;
846
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
847
-		}
848
-
849
-		// Maybe setup select2
850
-		$is_select2 = false;
851
-		if ( ! empty( $args['select2'] ) ) {
852
-			$args['class'] .= ' aui-select2';
853
-			$is_select2 = true;
854
-		} elseif ( strpos( $args['class'], 'aui-select2' ) !== false ) {
855
-			$is_select2 = true;
856
-		}
857
-
858
-		if ( $is_select2 && ! $aui_has_select2 ) {
859
-			$aui_has_select2 = true;
860
-			$conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
861
-
862
-			// Enqueue the script,
863
-			if ( empty( $aui_select2_enqueued ) && $conditional_select2 === true ) {
864
-				$aui_select2_enqueued = true;
865
-
866
-				$aui_settings = AyeCode_UI_Settings::instance();
867
-				$aui_settings->enqueue_select2();
868
-			}
869
-		}
870
-
871
-		// select2 tags
872
-		if ( ! empty( $args['select2'] ) && $args['select2'] === 'tags' ) { // triple equals needed here for some reason
873
-			$args['data-tags']             = 'true';
874
-			$args['data-token-separators'] = "[',']";
875
-			$args['multiple']              = true;
876
-		}
877
-
878
-		// select2 placeholder
879
-		if ( $is_select2 && isset( $args['placeholder'] ) && '' != $args['placeholder'] && empty( $args['data-placeholder'] ) ) {
880
-			$args['data-placeholder'] = esc_attr( $args['placeholder'] );
881
-			$args['data-allow-clear'] = isset( $args['data-allow-clear'] ) ? (bool) $args['data-allow-clear'] : true;
882
-		}
883
-
884
-		// Set hidden input to save empty value for multiselect.
885
-		if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
886
-			$output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value="" data-ignore-rule/>';
887
-		}
888
-
889
-		// open/type
890
-		$output .= '<select ';
891
-
892
-		// style
893
-		if ( $is_select2 && !($args['input_group_left'] || $args['input_group_right'])) {
894
-			$output .= " style='width:100%;' ";
895
-		}
896
-
897
-		// element require
898
-		if ( ! empty( $args['element_require'] ) ) {
899
-			$output .= AUI_Component_Helper::element_require( $args['element_require'] );
900
-			$args['class'] .= " aui-conditional-field";
901
-		}
902
-
903
-		// class
904
-		$class = ! empty( $args['class'] ) ? $args['class'] : '';
905
-		$select_class = $aui_bs5 ? 'form-select ' : 'custom-select ';
906
-		$output .= AUI_Component_Helper::class_attr( $select_class . $class );
907
-
908
-		// name
909
-		if ( ! empty( $args['name'] ) ) {
910
-			$output .= AUI_Component_Helper::name( $args['name'], $args['multiple'] );
911
-		}
912
-
913
-		// id
914
-		if ( ! empty( $args['id'] ) ) {
915
-			$output .= AUI_Component_Helper::id( $args['id'] );
916
-		}
917
-
918
-		// title
919
-		if ( ! empty( $args['title'] ) ) {
920
-			$output .= AUI_Component_Helper::title( $args['title'] );
921
-		}
922
-
923
-		// data-attributes
924
-		$output .= AUI_Component_Helper::data_attributes( $args );
925
-
926
-		// aria-attributes
927
-		$output .= AUI_Component_Helper::aria_attributes( $args );
928
-
929
-		// extra attributes
930
-		if ( ! empty( $args['extra_attributes'] ) ) {
931
-			$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
932
-		}
933
-
934
-		// required
935
-		if ( ! empty( $args['required'] ) ) {
936
-			$output .= ' required ';
937
-		}
938
-
939
-		// multiple
940
-		if ( ! empty( $args['multiple'] ) ) {
941
-			$output .= ' multiple ';
942
-		}
943
-
944
-		// close opening tag
945
-		$output .= ' >';
946
-
947
-		// placeholder
948
-		if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] && ! $is_select2 ) {
949
-			$output .= '<option value="" disabled selected hidden>' . esc_attr( $args['placeholder'] ) . '</option>';
950
-		} elseif ( $is_select2 && ! empty( $args['placeholder'] ) ) {
951
-			$output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
952
-		}
953
-
954
-		// Options
955
-		if ( ! empty( $args['options'] ) ) {
956
-
957
-			if ( ! is_array( $args['options'] ) ) {
958
-				$output .= $args['options']; // not the preferred way but an option
959
-			} else {
960
-				foreach ( $args['options'] as $val => $name ) {
961
-					$selected = '';
962
-					if ( is_array( $name ) ) {
963
-						if ( isset( $name['optgroup'] ) && ( $name['optgroup'] == 'start' || $name['optgroup'] == 'end' ) ) {
964
-							$option_label = isset( $name['label'] ) ? $name['label'] : '';
965
-
966
-							$output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr( $option_label ) . '">' : '</optgroup>';
967
-						} else {
968
-							$option_label = isset( $name['label'] ) ? $name['label'] : '';
969
-							$option_value = isset( $name['value'] ) ? $name['value'] : '';
970
-							$extra_attributes = !empty($name['extra_attributes']) ? AUI_Component_Helper::extra_attributes( $name['extra_attributes'] ) : '';
971
-							if ( ! empty( $args['multiple'] ) && ! empty( $args['value'] ) && is_array( $args['value'] ) ) {
972
-								$selected = in_array( $option_value, stripslashes_deep( $args['value'] ) ) ? "selected" : "";
973
-							} elseif ( ! empty( $args['value'] ) ) {
974
-								$selected = selected( $option_value, stripslashes_deep( $args['value'] ), false );
975
-							} elseif ( empty( $args['value'] ) && $args['value'] === $option_value ) {
976
-								$selected = selected( $option_value, $args['value'], false );
977
-							}
978
-
979
-							$output .= '<option value="' . esc_attr( $option_value ) . '" ' . $selected . ' '.$extra_attributes .'>' . $option_label . '</option>';
980
-						}
981
-					} else {
982
-						if ( ! empty( $args['value'] ) ) {
983
-							if ( is_array( $args['value'] ) ) {
984
-								$selected = in_array( $val, $args['value'] ) ? 'selected="selected"' : '';
985
-							} elseif ( ! empty( $args['value'] ) ) {
986
-								$selected = selected( $args['value'], $val, false );
987
-							}
988
-						} elseif ( $args['value'] === $val ) {
989
-							$selected = selected( $args['value'], $val, false );
990
-						}
991
-						$output .= '<option value="' . esc_attr( $val ) . '" ' . $selected . '>' . esc_attr( $name ) . '</option>';
992
-					}
993
-				}
994
-			}
995
-
996
-		}
997
-
998
-		// closing tag
999
-		$output .= '</select>';
1000
-
1001
-		$label = '';
1002
-		$help_text = '';
1003
-		// label
1004
-		if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
1005
-		} elseif ( ! empty( $args['label'] ) && ! $label_after ) {
1006
-			$label_args = array(
1007
-				'title'      => $args['label'],
1008
-				'for'        => $args['id'],
1009
-				'class'      => $args['label_class'] . " ",
1010
-				'label_type' => $args['label_type'],
1011
-				'label_col'  => $args['label_col']
1012
-			);
1013
-			$label = self::label( $label_args );
1014
-		}
1015
-
1016
-		// help text
1017
-		if ( ! empty( $args['help_text'] ) ) {
1018
-			$help_text = AUI_Component_Helper::help_text( $args['help_text'] );
1019
-		}
1020
-
1021
-		// input group wraps
1022
-		if ( $args['input_group_left'] || $args['input_group_right'] ) {
1023
-			$w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
1024
-			if ( $args['input_group_left'] ) {
1025
-				$output = self::wrap( array(
1026
-					'content'                 => $output,
1027
-					'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
1028
-					'input_group_left'        => $args['input_group_left'],
1029
-					'input_group_left_inside' => $args['input_group_left_inside']
1030
-				) );
1031
-			}
1032
-			if ( $args['input_group_right'] ) {
1033
-				$output = self::wrap( array(
1034
-					'content'                  => $output,
1035
-					'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
1036
-					'input_group_right'        => $args['input_group_right'],
1037
-					'input_group_right_inside' => $args['input_group_right_inside']
1038
-				) );
1039
-			}
1040
-
1041
-		}
1042
-
1043
-		if ( ! $label_after ) {
1044
-			$output .= $help_text;
1045
-		}
1046
-
1047
-
1048
-		if ( $args['label_type'] == 'horizontal' ) {
1049
-			$output = self::wrap( array(
1050
-				'content' => $output,
1051
-				'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
1052
-			) );
1053
-		}
1054
-
1055
-		if ( ! $label_after ) {
1056
-			$output = $label . $output;
1057
-		}
1058
-
1059
-		// maybe horizontal label
1060
-//		if ( $args['label_type'] == 'horizontal' ) {
1061
-//			$output .= '</div>';
1062
-//		}
1063
-
1064
-
1065
-		// wrap
1066
-		if ( ! $args['no_wrap'] ) {
1067
-			if ( ! empty( $args['form_group_class'] ) ) {
1068
-				$fg_class = esc_attr( $args['form_group_class'] );
1069
-			}else{
1070
-				$fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
1071
-			}
1072
-			$wrap_class = $args['label_type'] == 'horizontal' ? $fg_class . ' row' : $fg_class;
1073
-			$wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
1074
-			$output     = self::wrap( array(
1075
-				'content'         => $output,
1076
-				'class'           => $wrap_class,
1077
-				'element_require' => $args['element_require'],
1078
-				'argument_id'     => $args['id'],
1079
-				'wrap_attributes' => $args['wrap_attributes'],
1080
-			) );
1081
-		}
1082
-
1083
-
1084
-		return $output;
1085
-	}
1086
-
1087
-	/**
829
+		    $args   = wp_parse_args( $args, $defaults );
830
+		    $output = '';
831
+
832
+		    // for now lets hide floating labels
833
+		    if ( $args['label_type'] == 'floating' ) {
834
+			    $args['label_type'] = 'hidden';
835
+		    }
836
+
837
+		    // hidden label option needs to be empty
838
+		    $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
839
+
840
+
841
+		    $label_after = $args['label_after'];
842
+
843
+		    // floating labels need label after
844
+		    if ( $args['label_type'] == 'floating' ) {
845
+			    $label_after         = true;
846
+			    $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
847
+		    }
848
+
849
+		    // Maybe setup select2
850
+		    $is_select2 = false;
851
+		    if ( ! empty( $args['select2'] ) ) {
852
+			    $args['class'] .= ' aui-select2';
853
+			    $is_select2 = true;
854
+		    } elseif ( strpos( $args['class'], 'aui-select2' ) !== false ) {
855
+			    $is_select2 = true;
856
+		    }
857
+
858
+		    if ( $is_select2 && ! $aui_has_select2 ) {
859
+			    $aui_has_select2 = true;
860
+			    $conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
861
+
862
+			    // Enqueue the script,
863
+			    if ( empty( $aui_select2_enqueued ) && $conditional_select2 === true ) {
864
+				    $aui_select2_enqueued = true;
865
+
866
+				    $aui_settings = AyeCode_UI_Settings::instance();
867
+				    $aui_settings->enqueue_select2();
868
+			    }
869
+		    }
870
+
871
+		    // select2 tags
872
+		    if ( ! empty( $args['select2'] ) && $args['select2'] === 'tags' ) { // triple equals needed here for some reason
873
+			    $args['data-tags']             = 'true';
874
+			    $args['data-token-separators'] = "[',']";
875
+			    $args['multiple']              = true;
876
+		    }
877
+
878
+		    // select2 placeholder
879
+		    if ( $is_select2 && isset( $args['placeholder'] ) && '' != $args['placeholder'] && empty( $args['data-placeholder'] ) ) {
880
+			    $args['data-placeholder'] = esc_attr( $args['placeholder'] );
881
+			    $args['data-allow-clear'] = isset( $args['data-allow-clear'] ) ? (bool) $args['data-allow-clear'] : true;
882
+		    }
883
+
884
+		    // Set hidden input to save empty value for multiselect.
885
+		    if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
886
+			    $output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value="" data-ignore-rule/>';
887
+		    }
888
+
889
+		    // open/type
890
+		    $output .= '<select ';
891
+
892
+		    // style
893
+		    if ( $is_select2 && !($args['input_group_left'] || $args['input_group_right'])) {
894
+			    $output .= " style='width:100%;' ";
895
+		    }
896
+
897
+		    // element require
898
+		    if ( ! empty( $args['element_require'] ) ) {
899
+			    $output .= AUI_Component_Helper::element_require( $args['element_require'] );
900
+			    $args['class'] .= " aui-conditional-field";
901
+		    }
902
+
903
+		    // class
904
+		    $class = ! empty( $args['class'] ) ? $args['class'] : '';
905
+		    $select_class = $aui_bs5 ? 'form-select ' : 'custom-select ';
906
+		    $output .= AUI_Component_Helper::class_attr( $select_class . $class );
907
+
908
+		    // name
909
+		    if ( ! empty( $args['name'] ) ) {
910
+			    $output .= AUI_Component_Helper::name( $args['name'], $args['multiple'] );
911
+		    }
912
+
913
+		    // id
914
+		    if ( ! empty( $args['id'] ) ) {
915
+			    $output .= AUI_Component_Helper::id( $args['id'] );
916
+		    }
917
+
918
+		    // title
919
+		    if ( ! empty( $args['title'] ) ) {
920
+			    $output .= AUI_Component_Helper::title( $args['title'] );
921
+		    }
922
+
923
+		    // data-attributes
924
+		    $output .= AUI_Component_Helper::data_attributes( $args );
925
+
926
+		    // aria-attributes
927
+		    $output .= AUI_Component_Helper::aria_attributes( $args );
928
+
929
+		    // extra attributes
930
+		    if ( ! empty( $args['extra_attributes'] ) ) {
931
+			    $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
932
+		    }
933
+
934
+		    // required
935
+		    if ( ! empty( $args['required'] ) ) {
936
+			    $output .= ' required ';
937
+		    }
938
+
939
+		    // multiple
940
+		    if ( ! empty( $args['multiple'] ) ) {
941
+			    $output .= ' multiple ';
942
+		    }
943
+
944
+		    // close opening tag
945
+		    $output .= ' >';
946
+
947
+		    // placeholder
948
+		    if ( isset( $args['placeholder'] ) && '' != $args['placeholder'] && ! $is_select2 ) {
949
+			    $output .= '<option value="" disabled selected hidden>' . esc_attr( $args['placeholder'] ) . '</option>';
950
+		    } elseif ( $is_select2 && ! empty( $args['placeholder'] ) ) {
951
+			    $output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
952
+		    }
953
+
954
+		    // Options
955
+		    if ( ! empty( $args['options'] ) ) {
956
+
957
+			    if ( ! is_array( $args['options'] ) ) {
958
+				    $output .= $args['options']; // not the preferred way but an option
959
+			    } else {
960
+				    foreach ( $args['options'] as $val => $name ) {
961
+					    $selected = '';
962
+					    if ( is_array( $name ) ) {
963
+						    if ( isset( $name['optgroup'] ) && ( $name['optgroup'] == 'start' || $name['optgroup'] == 'end' ) ) {
964
+							    $option_label = isset( $name['label'] ) ? $name['label'] : '';
965
+
966
+							    $output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr( $option_label ) . '">' : '</optgroup>';
967
+						    } else {
968
+							    $option_label = isset( $name['label'] ) ? $name['label'] : '';
969
+							    $option_value = isset( $name['value'] ) ? $name['value'] : '';
970
+							    $extra_attributes = !empty($name['extra_attributes']) ? AUI_Component_Helper::extra_attributes( $name['extra_attributes'] ) : '';
971
+							    if ( ! empty( $args['multiple'] ) && ! empty( $args['value'] ) && is_array( $args['value'] ) ) {
972
+								    $selected = in_array( $option_value, stripslashes_deep( $args['value'] ) ) ? "selected" : "";
973
+							    } elseif ( ! empty( $args['value'] ) ) {
974
+								    $selected = selected( $option_value, stripslashes_deep( $args['value'] ), false );
975
+							    } elseif ( empty( $args['value'] ) && $args['value'] === $option_value ) {
976
+								    $selected = selected( $option_value, $args['value'], false );
977
+							    }
978
+
979
+							    $output .= '<option value="' . esc_attr( $option_value ) . '" ' . $selected . ' '.$extra_attributes .'>' . $option_label . '</option>';
980
+						    }
981
+					    } else {
982
+						    if ( ! empty( $args['value'] ) ) {
983
+							    if ( is_array( $args['value'] ) ) {
984
+								    $selected = in_array( $val, $args['value'] ) ? 'selected="selected"' : '';
985
+							    } elseif ( ! empty( $args['value'] ) ) {
986
+								    $selected = selected( $args['value'], $val, false );
987
+							    }
988
+						    } elseif ( $args['value'] === $val ) {
989
+							    $selected = selected( $args['value'], $val, false );
990
+						    }
991
+						    $output .= '<option value="' . esc_attr( $val ) . '" ' . $selected . '>' . esc_attr( $name ) . '</option>';
992
+					    }
993
+				    }
994
+			    }
995
+
996
+		    }
997
+
998
+		    // closing tag
999
+		    $output .= '</select>';
1000
+
1001
+		    $label = '';
1002
+		    $help_text = '';
1003
+		    // label
1004
+		    if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
1005
+		    } elseif ( ! empty( $args['label'] ) && ! $label_after ) {
1006
+			    $label_args = array(
1007
+				    'title'      => $args['label'],
1008
+				    'for'        => $args['id'],
1009
+				    'class'      => $args['label_class'] . " ",
1010
+				    'label_type' => $args['label_type'],
1011
+				    'label_col'  => $args['label_col']
1012
+			    );
1013
+			    $label = self::label( $label_args );
1014
+		    }
1015
+
1016
+		    // help text
1017
+		    if ( ! empty( $args['help_text'] ) ) {
1018
+			    $help_text = AUI_Component_Helper::help_text( $args['help_text'] );
1019
+		    }
1020
+
1021
+		    // input group wraps
1022
+		    if ( $args['input_group_left'] || $args['input_group_right'] ) {
1023
+			    $w100 = strpos( $args['class'], 'w-100' ) !== false ? ' w-100' : '';
1024
+			    if ( $args['input_group_left'] ) {
1025
+				    $output = self::wrap( array(
1026
+					    'content'                 => $output,
1027
+					    'class'                   => $args['input_group_left_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
1028
+					    'input_group_left'        => $args['input_group_left'],
1029
+					    'input_group_left_inside' => $args['input_group_left_inside']
1030
+				    ) );
1031
+			    }
1032
+			    if ( $args['input_group_right'] ) {
1033
+				    $output = self::wrap( array(
1034
+					    'content'                  => $output,
1035
+					    'class'                    => $args['input_group_right_inside'] ? 'input-group-inside position-relative' . $w100 : 'input-group',
1036
+					    'input_group_right'        => $args['input_group_right'],
1037
+					    'input_group_right_inside' => $args['input_group_right_inside']
1038
+				    ) );
1039
+			    }
1040
+
1041
+		    }
1042
+
1043
+		    if ( ! $label_after ) {
1044
+			    $output .= $help_text;
1045
+		    }
1046
+
1047
+
1048
+		    if ( $args['label_type'] == 'horizontal' ) {
1049
+			    $output = self::wrap( array(
1050
+				    'content' => $output,
1051
+				    'class'   => AUI_Component_Helper::get_column_class( $args['label_col'], 'input' )
1052
+			    ) );
1053
+		    }
1054
+
1055
+		    if ( ! $label_after ) {
1056
+			    $output = $label . $output;
1057
+		    }
1058
+
1059
+		    // maybe horizontal label
1060
+    //		if ( $args['label_type'] == 'horizontal' ) {
1061
+    //			$output .= '</div>';
1062
+    //		}
1063
+
1064
+
1065
+		    // wrap
1066
+		    if ( ! $args['no_wrap'] ) {
1067
+			    if ( ! empty( $args['form_group_class'] ) ) {
1068
+				    $fg_class = esc_attr( $args['form_group_class'] );
1069
+			    }else{
1070
+				    $fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
1071
+			    }
1072
+			    $wrap_class = $args['label_type'] == 'horizontal' ? $fg_class . ' row' : $fg_class;
1073
+			    $wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
1074
+			    $output     = self::wrap( array(
1075
+				    'content'         => $output,
1076
+				    'class'           => $wrap_class,
1077
+				    'element_require' => $args['element_require'],
1078
+				    'argument_id'     => $args['id'],
1079
+				    'wrap_attributes' => $args['wrap_attributes'],
1080
+			    ) );
1081
+		    }
1082
+
1083
+
1084
+		    return $output;
1085
+	    }
1086
+
1087
+	    /**
1088 1088
 	 * Build the component.
1089 1089
 	 *
1090 1090
 	 * @param array $args
1091 1091
 	 *
1092 1092
 	 * @return string The rendered component.
1093 1093
 	 */
1094
-	public static function radio( $args = array() ) {
1095
-		global $aui_bs5;
1096
-
1097
-		$defaults = array(
1098
-			'class'            => '',
1099
-			'wrap_class'       => '',
1100
-			'id'               => '',
1101
-			'title'            => '',
1102
-			'horizontal'       => false,
1103
-			// sets the lable horizontal
1104
-			'value'            => '',
1105
-			'label'            => '',
1106
-			'label_class'      => '',
1107
-			'label_type'       => '',
1108
-			'label_col'        => '',
1109
-			// sets the label type, default: hidden. Options: hidden, top, horizontal, floating
1110
-			'help_text'        => '',
1111
-			'inline'           => true,
1112
-			'required'         => false,
1113
-			'options'          => array(),
1114
-			'icon'             => '',
1115
-			'no_wrap'          => false,
1116
-			'element_require'  => '',
1117
-			// [%element_id%] == "1"
1118
-			'extra_attributes' => array(),
1119
-			// an array of extra attributes
1120
-			'wrap_attributes'  => array()
1121
-		);
1122
-
1123
-		/**
1094
+	    public static function radio( $args = array() ) {
1095
+		    global $aui_bs5;
1096
+
1097
+		    $defaults = array(
1098
+			    'class'            => '',
1099
+			    'wrap_class'       => '',
1100
+			    'id'               => '',
1101
+			    'title'            => '',
1102
+			    'horizontal'       => false,
1103
+			    // sets the lable horizontal
1104
+			    'value'            => '',
1105
+			    'label'            => '',
1106
+			    'label_class'      => '',
1107
+			    'label_type'       => '',
1108
+			    'label_col'        => '',
1109
+			    // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
1110
+			    'help_text'        => '',
1111
+			    'inline'           => true,
1112
+			    'required'         => false,
1113
+			    'options'          => array(),
1114
+			    'icon'             => '',
1115
+			    'no_wrap'          => false,
1116
+			    'element_require'  => '',
1117
+			    // [%element_id%] == "1"
1118
+			    'extra_attributes' => array(),
1119
+			    // an array of extra attributes
1120
+			    'wrap_attributes'  => array()
1121
+		    );
1122
+
1123
+		    /**
1124 1124
 		 * Parse incoming $args into an array and merge it with $defaults
1125 1125
 		 */
1126
-		$args = wp_parse_args( $args, $defaults );
1127
-
1128
-		// for now lets use horizontal for floating
1129
-		if ( $args['label_type'] == 'floating' ) {
1130
-			$args['label_type'] = 'horizontal';
1131
-		}
1132
-
1133
-		$label_args = array(
1134
-			'title'      => $args['label'],
1135
-			'class'      => $args['label_class'] . " pt-0 ",
1136
-			'label_type' => $args['label_type'],
1137
-			'label_col'  => $args['label_col']
1138
-		);
1139
-
1140
-		if ( $args['label_type'] == 'top' || $args['label_type'] == 'hidden' ) {
1141
-			$label_args['class'] .= 'd-block ';
1142
-
1143
-			if ( $args['label_type'] == 'hidden' ) {
1144
-				$label_args['class'] .= 'sr-only ';
1145
-			}
1146
-		}
1147
-
1148
-		$output = '';
1149
-
1150
-		// label before
1151
-		if ( ! empty( $args['label'] ) ) {
1152
-			$output .= self::label( $label_args, 'radio' );
1153
-		}
1154
-
1155
-		// maybe horizontal label
1156
-		if ( $args['label_type'] == 'horizontal' ) {
1157
-			$input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
1158
-			$output .= '<div class="' . $input_col . '">';
1159
-		}
1160
-
1161
-		if ( ! empty( $args['options'] ) ) {
1162
-			$count = 0;
1163
-			foreach ( $args['options'] as $value => $label ) {
1164
-				$option_args            = $args;
1165
-				$option_args['value']   = $value;
1166
-				$option_args['label']   = $label;
1167
-				$option_args['checked'] = $value == $args['value'] ? true : false;
1168
-				$output .= self::radio_option( $option_args, $count );
1169
-				$count ++;
1170
-			}
1171
-		}
1172
-
1173
-		// help text
1174
-		$help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
1175
-		$output .= $help_text;
1176
-
1177
-		// maybe horizontal label
1178
-		if ( $args['label_type'] == 'horizontal' ) {
1179
-			$output .= '</div>';
1180
-		}
1181
-
1182
-		// wrap
1183
-		$fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
1184
-		$wrap_class = $args['label_type'] == 'horizontal' ? $fg_class . ' row' : $fg_class;
1185
-		$wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
1186
-		$output     = self::wrap( array(
1187
-			'content'         => $output,
1188
-			'class'           => $wrap_class,
1189
-			'element_require' => $args['element_require'],
1190
-			'argument_id'     => $args['id'],
1191
-			'wrap_attributes' => $args['wrap_attributes'],
1192
-		) );
1193
-
1194
-
1195
-		return $output;
1196
-	}
1197
-
1198
-	/**
1126
+		    $args = wp_parse_args( $args, $defaults );
1127
+
1128
+		    // for now lets use horizontal for floating
1129
+		    if ( $args['label_type'] == 'floating' ) {
1130
+			    $args['label_type'] = 'horizontal';
1131
+		    }
1132
+
1133
+		    $label_args = array(
1134
+			    'title'      => $args['label'],
1135
+			    'class'      => $args['label_class'] . " pt-0 ",
1136
+			    'label_type' => $args['label_type'],
1137
+			    'label_col'  => $args['label_col']
1138
+		    );
1139
+
1140
+		    if ( $args['label_type'] == 'top' || $args['label_type'] == 'hidden' ) {
1141
+			    $label_args['class'] .= 'd-block ';
1142
+
1143
+			    if ( $args['label_type'] == 'hidden' ) {
1144
+				    $label_args['class'] .= 'sr-only ';
1145
+			    }
1146
+		    }
1147
+
1148
+		    $output = '';
1149
+
1150
+		    // label before
1151
+		    if ( ! empty( $args['label'] ) ) {
1152
+			    $output .= self::label( $label_args, 'radio' );
1153
+		    }
1154
+
1155
+		    // maybe horizontal label
1156
+		    if ( $args['label_type'] == 'horizontal' ) {
1157
+			    $input_col = AUI_Component_Helper::get_column_class( $args['label_col'], 'input' );
1158
+			    $output .= '<div class="' . $input_col . '">';
1159
+		    }
1160
+
1161
+		    if ( ! empty( $args['options'] ) ) {
1162
+			    $count = 0;
1163
+			    foreach ( $args['options'] as $value => $label ) {
1164
+				    $option_args            = $args;
1165
+				    $option_args['value']   = $value;
1166
+				    $option_args['label']   = $label;
1167
+				    $option_args['checked'] = $value == $args['value'] ? true : false;
1168
+				    $output .= self::radio_option( $option_args, $count );
1169
+				    $count ++;
1170
+			    }
1171
+		    }
1172
+
1173
+		    // help text
1174
+		    $help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
1175
+		    $output .= $help_text;
1176
+
1177
+		    // maybe horizontal label
1178
+		    if ( $args['label_type'] == 'horizontal' ) {
1179
+			    $output .= '</div>';
1180
+		    }
1181
+
1182
+		    // wrap
1183
+		    $fg_class = $aui_bs5 ? 'mb-3' : 'form-group';
1184
+		    $wrap_class = $args['label_type'] == 'horizontal' ? $fg_class . ' row' : $fg_class;
1185
+		    $wrap_class = ! empty( $args['wrap_class'] ) ? $wrap_class . " " . $args['wrap_class'] : $wrap_class;
1186
+		    $output     = self::wrap( array(
1187
+			    'content'         => $output,
1188
+			    'class'           => $wrap_class,
1189
+			    'element_require' => $args['element_require'],
1190
+			    'argument_id'     => $args['id'],
1191
+			    'wrap_attributes' => $args['wrap_attributes'],
1192
+		    ) );
1193
+
1194
+
1195
+		    return $output;
1196
+	    }
1197
+
1198
+	    /**
1199 1199
 	 * Build the component.
1200 1200
 	 *
1201 1201
 	 * @param array $args
1202 1202
 	 *
1203 1203
 	 * @return string The rendered component.
1204 1204
 	 */
1205
-	public static function radio_option( $args = array(), $count = '' ) {
1206
-		$defaults = array(
1207
-			'class'            => '',
1208
-			'id'               => '',
1209
-			'title'            => '',
1210
-			'value'            => '',
1211
-			'required'         => false,
1212
-			'inline'           => true,
1213
-			'label'            => '',
1214
-			'options'          => array(),
1215
-			'icon'             => '',
1216
-			'no_wrap'          => false,
1217
-			'extra_attributes' => array() // an array of extra attributes
1218
-		);
1219
-
1220
-		/**
1205
+	    public static function radio_option( $args = array(), $count = '' ) {
1206
+		    $defaults = array(
1207
+			    'class'            => '',
1208
+			    'id'               => '',
1209
+			    'title'            => '',
1210
+			    'value'            => '',
1211
+			    'required'         => false,
1212
+			    'inline'           => true,
1213
+			    'label'            => '',
1214
+			    'options'          => array(),
1215
+			    'icon'             => '',
1216
+			    'no_wrap'          => false,
1217
+			    'extra_attributes' => array() // an array of extra attributes
1218
+		    );
1219
+
1220
+		    /**
1221 1221
 		 * Parse incoming $args into an array and merge it with $defaults
1222 1222
 		 */
1223
-		$args = wp_parse_args( $args, $defaults );
1224
-
1225
-		$output = '';
1226
-
1227
-		// open/type
1228
-		$output .= '<input type="radio"';
1229
-
1230
-		// class
1231
-		$output .= ' class="form-check-input" ';
1232
-
1233
-		// name
1234
-		if ( ! empty( $args['name'] ) ) {
1235
-			$output .= AUI_Component_Helper::name( $args['name'] );
1236
-		}
1237
-
1238
-		// id
1239
-		if ( ! empty( $args['id'] ) ) {
1240
-			$output .= AUI_Component_Helper::id( $args['id'] . $count );
1241
-		}
1242
-
1243
-		// title
1244
-		if ( ! empty( $args['title'] ) ) {
1245
-			$output .= AUI_Component_Helper::title( $args['title'] );
1246
-		}
1247
-
1248
-		// value
1249
-		if ( isset( $args['value'] ) ) {
1250
-			$output .= AUI_Component_Helper::value( $args['value'] );
1251
-		}
1252
-
1253
-		// checked, for radio and checkboxes
1254
-		if ( $args['checked'] ) {
1255
-			$output .= ' checked ';
1256
-		}
1257
-
1258
-		// data-attributes
1259
-		$output .= AUI_Component_Helper::data_attributes( $args );
1260
-
1261
-		// aria-attributes
1262
-		$output .= AUI_Component_Helper::aria_attributes( $args );
1263
-
1264
-		// extra attributes
1265
-		if ( ! empty( $args['extra_attributes'] ) ) {
1266
-			$output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
1267
-		}
1268
-
1269
-		// required
1270
-		if ( ! empty( $args['required'] ) ) {
1271
-			$output .= ' required ';
1272
-		}
1273
-
1274
-		// close opening tag
1275
-		$output .= ' >';
1276
-
1277
-		// label
1278
-		if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
1279
-		} elseif ( ! empty( $args['label'] ) ) {
1280
-			$output .= self::label( array(
1281
-				'title' => $args['label'],
1282
-				'for'   => $args['id'] . $count,
1283
-				'class' => 'form-check-label'
1284
-			), 'radio' );
1285
-		}
1286
-
1287
-		// wrap
1288
-		if ( ! $args['no_wrap'] ) {
1289
-			$wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1290
-
1291
-			// Unique wrap class
1292
-			$uniq_class = 'fwrap';
1293
-			if ( ! empty( $args['name'] ) ) {
1294
-				$uniq_class .= '-' . $args['name'];
1295
-			} else if ( ! empty( $args['id'] ) ) {
1296
-				$uniq_class .= '-' . $args['id'];
1297
-			}
1298
-
1299
-			if ( isset( $args['value'] ) || $args['value'] !== "" ) {
1300
-				$uniq_class .= '-' . $args['value'];
1301
-			} else {
1302
-				$uniq_class .= '-' . $count;
1303
-			}
1304
-			$wrap_class .= ' ' . sanitize_html_class( $uniq_class );
1305
-
1306
-			$output = self::wrap( array(
1307
-				'content' => $output,
1308
-				'class'   => $wrap_class
1309
-			) );
1310
-		}
1311
-
1312
-		return $output;
1313
-	}
1223
+		    $args = wp_parse_args( $args, $defaults );
1224
+
1225
+		    $output = '';
1226
+
1227
+		    // open/type
1228
+		    $output .= '<input type="radio"';
1229
+
1230
+		    // class
1231
+		    $output .= ' class="form-check-input" ';
1232
+
1233
+		    // name
1234
+		    if ( ! empty( $args['name'] ) ) {
1235
+			    $output .= AUI_Component_Helper::name( $args['name'] );
1236
+		    }
1237
+
1238
+		    // id
1239
+		    if ( ! empty( $args['id'] ) ) {
1240
+			    $output .= AUI_Component_Helper::id( $args['id'] . $count );
1241
+		    }
1242
+
1243
+		    // title
1244
+		    if ( ! empty( $args['title'] ) ) {
1245
+			    $output .= AUI_Component_Helper::title( $args['title'] );
1246
+		    }
1247
+
1248
+		    // value
1249
+		    if ( isset( $args['value'] ) ) {
1250
+			    $output .= AUI_Component_Helper::value( $args['value'] );
1251
+		    }
1252
+
1253
+		    // checked, for radio and checkboxes
1254
+		    if ( $args['checked'] ) {
1255
+			    $output .= ' checked ';
1256
+		    }
1257
+
1258
+		    // data-attributes
1259
+		    $output .= AUI_Component_Helper::data_attributes( $args );
1260
+
1261
+		    // aria-attributes
1262
+		    $output .= AUI_Component_Helper::aria_attributes( $args );
1263
+
1264
+		    // extra attributes
1265
+		    if ( ! empty( $args['extra_attributes'] ) ) {
1266
+			    $output .= AUI_Component_Helper::extra_attributes( $args['extra_attributes'] );
1267
+		    }
1268
+
1269
+		    // required
1270
+		    if ( ! empty( $args['required'] ) ) {
1271
+			    $output .= ' required ';
1272
+		    }
1273
+
1274
+		    // close opening tag
1275
+		    $output .= ' >';
1276
+
1277
+		    // label
1278
+		    if ( ! empty( $args['label'] ) && is_array( $args['label'] ) ) {
1279
+		    } elseif ( ! empty( $args['label'] ) ) {
1280
+			    $output .= self::label( array(
1281
+				    'title' => $args['label'],
1282
+				    'for'   => $args['id'] . $count,
1283
+				    'class' => 'form-check-label'
1284
+			    ), 'radio' );
1285
+		    }
1286
+
1287
+		    // wrap
1288
+		    if ( ! $args['no_wrap'] ) {
1289
+			    $wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1290
+
1291
+			    // Unique wrap class
1292
+			    $uniq_class = 'fwrap';
1293
+			    if ( ! empty( $args['name'] ) ) {
1294
+				    $uniq_class .= '-' . $args['name'];
1295
+			    } else if ( ! empty( $args['id'] ) ) {
1296
+				    $uniq_class .= '-' . $args['id'];
1297
+			    }
1298
+
1299
+			    if ( isset( $args['value'] ) || $args['value'] !== "" ) {
1300
+				    $uniq_class .= '-' . $args['value'];
1301
+			    } else {
1302
+				    $uniq_class .= '-' . $count;
1303
+			    }
1304
+			    $wrap_class .= ' ' . sanitize_html_class( $uniq_class );
1305
+
1306
+			    $output = self::wrap( array(
1307
+				    'content' => $output,
1308
+				    'class'   => $wrap_class
1309
+			    ) );
1310
+		    }
1311
+
1312
+		    return $output;
1313
+	    }
1314 1314
 
1315 1315
 }
1316 1316
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/sd-plugin.php 1 patch
Switch Indentation   +10 added lines, -10 removed lines patch added patch discarded remove patch
@@ -1,4 +1,4 @@  discard block
 block discarded – undo
1
-<?php
1
+    <?php
2 2
 /**
3 3
  * This is a Hello World test plugin for WP Super Duper Class.
4 4
  *
@@ -14,26 +14,26 @@  discard block
 block discarded – undo
14 14
  * Tested up to: 6.7
15 15
  */
16 16
 
17
-if ( ! defined( 'ABSPATH' ) ) {
18
-	exit;
17
+    if ( ! defined( 'ABSPATH' ) ) {
18
+	    exit;
19 19
 }
20 20
 
21
-if ( ! class_exists( 'WP_Super_Duper' ) ) {
22
-	// include the class if needed
23
-	include_once( dirname( __FILE__ ) . "/wp-super-duper.php" );
21
+    if ( ! class_exists( 'WP_Super_Duper' ) ) {
22
+	    // include the class if needed
23
+	    include_once( dirname( __FILE__ ) . "/wp-super-duper.php" );
24 24
 }
25 25
 
26 26
 /*
27 27
  * Hello world example.
28 28
  */
29
-include_once( dirname( __FILE__ ) . "/hello-world.php" );
29
+    include_once( dirname( __FILE__ ) . "/hello-world.php" );
30 30
 
31 31
 /*
32 32
  * Map example.
33 33
  */
34
-include_once( dirname( __FILE__ ) . "/map.php" );
34
+    include_once( dirname( __FILE__ ) . "/map.php" );
35 35
 
36 36
 
37
-if ( ! function_exists( 'sd_get_class_build_keys' ) ) {
38
-	include_once( dirname( __FILE__ ) . "/sd-functions.php" );
37
+    if ( ! function_exists( 'sd_get_class_build_keys' ) ) {
38
+	    include_once( dirname( __FILE__ ) . "/sd-functions.php" );
39 39
 }
40 40
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/ayecode-ui-loader.php 1 patch
Switch Indentation   +23 added lines, -23 removed lines patch added patch discarded remove patch
@@ -1,4 +1,4 @@  discard block
 block discarded – undo
1
-<?php
1
+    <?php
2 2
 /**
3 3
  * This is a file takes advantage of anonymous functions to to load the latest version of the AyeCode UI Settings.
4 4
  */
@@ -6,41 +6,41 @@  discard block
 block discarded – undo
6 6
 /**
7 7
  * Bail if we are not in WP.
8 8
  */
9
-if ( ! defined( 'ABSPATH' ) ) {
10
-	exit;
9
+    if ( ! defined( 'ABSPATH' ) ) {
10
+	    exit;
11 11
 }
12 12
 
13 13
 /**
14 14
  * Set the version only if its the current newest while loading.
15 15
  */
16
-add_action('after_setup_theme', function () {
17
-	global $ayecode_ui_version,$ayecode_ui_file_key;
18
-	$this_version = "0.2.31";
19
-	if(empty($ayecode_ui_version) || version_compare($this_version , $ayecode_ui_version, '>')){
20
-		$ayecode_ui_version = $this_version ;
21
-		$ayecode_ui_file_key = wp_hash( __FILE__ );
22
-	}
16
+    add_action('after_setup_theme', function () {
17
+	    global $ayecode_ui_version,$ayecode_ui_file_key;
18
+	    $this_version = "0.2.31";
19
+	    if(empty($ayecode_ui_version) || version_compare($this_version , $ayecode_ui_version, '>')){
20
+		    $ayecode_ui_version = $this_version ;
21
+		    $ayecode_ui_file_key = wp_hash( __FILE__ );
22
+	    }
23 23
 },0);
24 24
 
25 25
 /**
26 26
  * Load this version of WP Bootstrap Settings only if the file hash is the current one.
27 27
  */
28
-add_action('after_setup_theme', function () {
29
-	global $ayecode_ui_file_key;
30
-	if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){
31
-		include_once( dirname( __FILE__ ) . '/includes/class-aui.php' );
32
-		include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' );
33
-	}
28
+    add_action('after_setup_theme', function () {
29
+	    global $ayecode_ui_file_key;
30
+	    if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){
31
+		    include_once( dirname( __FILE__ ) . '/includes/class-aui.php' );
32
+		    include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' );
33
+	    }
34 34
 },1);
35 35
 
36 36
 /**
37 37
  * Add the function that calls the class.
38 38
  */
39
-if(!function_exists('aui')){
40
-	function aui(){
41
-		if(!class_exists("AUI",false)){
42
-			return false;
43
-		}
44
-		return AUI::instance();
45
-	}
39
+    if(!function_exists('aui')){
40
+	    function aui(){
41
+		    if(!class_exists("AUI",false)){
42
+			    return false;
43
+		    }
44
+		    return AUI::instance();
45
+	    }
46 46
 }
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/ayecode-ui-settings.php 1 patch
Switch Indentation   +2085 added lines, -2085 removed lines patch added patch discarded remove patch
@@ -1,4 +1,4 @@  discard block
 block discarded – undo
1
-<?php
1
+    <?php
2 2
 /**
3 3
  * A class for adjusting AyeCode UI settings on WordPress
4 4
  *
@@ -12,84 +12,84 @@  discard block
 block discarded – undo
12 12
 /**
13 13
  * Bail if we are not in WP.
14 14
  */
15
-if ( ! defined( 'ABSPATH' ) ) {
16
-	exit;
15
+    if ( ! defined( 'ABSPATH' ) ) {
16
+	    exit;
17 17
 }
18 18
 
19 19
 /**
20 20
  * Only add if the class does not already exist.
21 21
  */
22
-if ( ! class_exists( 'AyeCode_UI_Settings' ) ) {
22
+    if ( ! class_exists( 'AyeCode_UI_Settings' ) ) {
23 23
 
24
-	/**
24
+	    /**
25 25
 	 * A Class to be able to change settings for Font Awesome.
26 26
 	 *
27 27
 	 * Class AyeCode_UI_Settings
28 28
 	 * @ver 1.0.0
29 29
 	 * @todo decide how to implement textdomain
30 30
 	 */
31
-	class AyeCode_UI_Settings {
31
+	    class AyeCode_UI_Settings {
32 32
 
33
-		/**
33
+		    /**
34 34
 		 * Class version version.
35 35
 		 *
36 36
 		 * @var string
37 37
 		 */
38
-		public $version = '0.2.31';
38
+		    public $version = '0.2.31';
39 39
 
40
-		/**
40
+		    /**
41 41
 		 * Class textdomain.
42 42
 		 *
43 43
 		 * @var string
44 44
 		 */
45
-		public $textdomain = 'aui';
45
+		    public $textdomain = 'aui';
46 46
 
47
-		/**
47
+		    /**
48 48
 		 * Latest version of Bootstrap at time of publish published.
49 49
 		 *
50 50
 		 * @var string
51 51
 		 */
52
-		public $latest = "5.2.2";
52
+		    public $latest = "5.2.2";
53 53
 
54
-		/**
54
+		    /**
55 55
 		 * Current version of select2 being used.
56 56
 		 *
57 57
 		 * @var string
58 58
 		 */
59
-		public $select2_version = "4.0.11";
59
+		    public $select2_version = "4.0.11";
60 60
 
61
-		/**
61
+		    /**
62 62
 		 * The title.
63 63
 		 *
64 64
 		 * @var string
65 65
 		 */
66
-		public $name = 'AyeCode UI';
66
+		    public $name = 'AyeCode UI';
67 67
 
68
-		/**
68
+		    /**
69 69
 		 * The relative url to the assets.
70 70
 		 *
71 71
 		 * @var string
72 72
 		 */
73
-		public $url = '';
73
+		    public $url = '';
74 74
 
75
-		/**
75
+		    /**
76 76
 		 * Holds the settings values.
77 77
 		 *
78 78
 		 * @var array
79 79
 		 */
80
-		private $settings;
80
+		    private $settings;
81 81
 
82
-		/**
82
+		    /**
83 83
 		 * AyeCode_UI_Settings instance.
84 84
 		 *
85 85
 		 * @access private
86 86
 		 * @since  1.0.0
87 87
 		 * @var    AyeCode_UI_Settings There can be only one!
88 88
 		 */
89
-		private static $instance = null;
89
+		    private static $instance = null;
90 90
 
91 91
 
92
-		/**
92
+		    /**
93 93
 		 * Main AyeCode_UI_Settings Instance.
94 94
 		 *
95 95
 		 * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
@@ -98,34 +98,34 @@  discard block
 block discarded – undo
98 98
 		 * @static
99 99
 		 * @return AyeCode_UI_Settings - Main instance.
100 100
 		 */
101
-		public static function instance() {
102
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
101
+		    public static function instance() {
102
+			    if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
103 103
 
104
-				self::$instance = new AyeCode_UI_Settings;
104
+				    self::$instance = new AyeCode_UI_Settings;
105 105
 
106
-				add_action( 'init', array( self::$instance, 'init' ) ); // set settings
106
+				    add_action( 'init', array( self::$instance, 'init' ) ); // set settings
107 107
 
108
-				if ( is_admin() ) {
109
-					add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
110
-					add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
108
+				    if ( is_admin() ) {
109
+					    add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
110
+					    add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
111 111
 
112
-					// Maybe show example page
113
-					add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
112
+					    // Maybe show example page
113
+					    add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
114 114
 
115
-					if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
116
-						add_filter( 'sd_aui_colors', array( self::$instance,'sd_aui_colors' ), 10, 3 );
117
-					}
118
-				}
115
+					    if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
116
+						    add_filter( 'sd_aui_colors', array( self::$instance,'sd_aui_colors' ), 10, 3 );
117
+					    }
118
+				    }
119 119
 
120
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
120
+				    add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
121 121
 
122
-				do_action( 'ayecode_ui_settings_loaded' );
123
-			}
122
+				    do_action( 'ayecode_ui_settings_loaded' );
123
+			    }
124 124
 
125
-			return self::$instance;
126
-		}
125
+			    return self::$instance;
126
+		    }
127 127
 
128
-		/**
128
+		    /**
129 129
 		 * Add custom colors to the color selector.
130 130
 		 *
131 131
 		 * @param $theme_colors
@@ -134,359 +134,359 @@  discard block
 block discarded – undo
134 134
 		 *
135 135
 		 * @return mixed
136 136
 		 */
137
-		public function sd_aui_colors( $theme_colors, $include_outlines, $include_branding ){
137
+		    public function sd_aui_colors( $theme_colors, $include_outlines, $include_branding ){
138 138
 
139 139
 
140
-			$setting = wp_get_global_settings();
140
+			    $setting = wp_get_global_settings();
141 141
 
142
-			if(!empty($setting['color']['palette']['custom'])){
143
-				foreach($setting['color']['palette']['custom'] as $color){
144
-					$theme_colors[$color['slug']] = esc_attr($color['name']);
145
-				}
146
-			}
142
+			    if(!empty($setting['color']['palette']['custom'])){
143
+				    foreach($setting['color']['palette']['custom'] as $color){
144
+					    $theme_colors[$color['slug']] = esc_attr($color['name']);
145
+				    }
146
+			    }
147 147
 
148
-			return $theme_colors;
149
-		}
148
+			    return $theme_colors;
149
+		    }
150 150
 
151
-		/**
151
+		    /**
152 152
 		 * Setup some constants.
153 153
 		 */
154
-		public function constants(){
155
-			define( 'AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be" );
156
-			define( 'AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d' );
157
-			define( 'AUI_INFO_COLOR_ORIGINAL', '#17a2b8' );
158
-			define( 'AUI_WARNING_COLOR_ORIGINAL', '#ffc107' );
159
-			define( 'AUI_DANGER_COLOR_ORIGINAL', '#dc3545' );
160
-			define( 'AUI_SUCCESS_COLOR_ORIGINAL', '#44c553' );
161
-			define( 'AUI_LIGHT_COLOR_ORIGINAL', '#f8f9fa' );
162
-			define( 'AUI_DARK_COLOR_ORIGINAL', '#343a40' );
163
-			define( 'AUI_WHITE_COLOR_ORIGINAL', '#fff' );
164
-			define( 'AUI_PURPLE_COLOR_ORIGINAL', '#ad6edd' );
165
-			define( 'AUI_SALMON_COLOR_ORIGINAL', '#ff977a' );
166
-			define( 'AUI_CYAN_COLOR_ORIGINAL', '#35bdff' );
167
-			define( 'AUI_GRAY_COLOR_ORIGINAL', '#ced4da' );
168
-			define( 'AUI_INDIGO_COLOR_ORIGINAL', '#502c6c' );
169
-			define( 'AUI_ORANGE_COLOR_ORIGINAL', '#orange' );
170
-			define( 'AUI_BLACK_COLOR_ORIGINAL', '#000' );
171
-
172
-			if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
173
-				define( 'AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL );
174
-			}
175
-			if ( ! defined( 'AUI_SECONDARY_COLOR' ) ) {
176
-				define( 'AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL );
177
-			}
178
-			if ( ! defined( 'AUI_INFO_COLOR' ) ) {
179
-				define( 'AUI_INFO_COLOR', AUI_INFO_COLOR_ORIGINAL );
180
-			}
181
-			if ( ! defined( 'AUI_WARNING_COLOR' ) ) {
182
-				define( 'AUI_WARNING_COLOR', AUI_WARNING_COLOR_ORIGINAL );
183
-			}
184
-			if ( ! defined( 'AUI_DANGER_COLOR' ) ) {
185
-				define( 'AUI_DANGER_COLOR', AUI_DANGER_COLOR_ORIGINAL );
186
-			}
187
-			if ( ! defined( 'AUI_SUCCESS_COLOR' ) ) {
188
-				define( 'AUI_SUCCESS_COLOR', AUI_SUCCESS_COLOR_ORIGINAL );
189
-			}
190
-			if ( ! defined( 'AUI_LIGHT_COLOR' ) ) {
191
-				define( 'AUI_LIGHT_COLOR', AUI_LIGHT_COLOR_ORIGINAL );
192
-			}
193
-			if ( ! defined( 'AUI_DARK_COLOR' ) ) {
194
-				define( 'AUI_DARK_COLOR', AUI_DARK_COLOR_ORIGINAL );
195
-			}
196
-			if ( ! defined( 'AUI_WHITE_COLOR' ) ) {
197
-				define( 'AUI_WHITE_COLOR', AUI_WHITE_COLOR_ORIGINAL );
198
-			}
199
-			if ( ! defined( 'AUI_PURPLE_COLOR' ) ) {
200
-				define( 'AUI_PURPLE_COLOR', AUI_PURPLE_COLOR_ORIGINAL );
201
-			}
202
-			if ( ! defined( 'AUI_SALMON_COLOR' ) ) {
203
-				define( 'AUI_SALMON_COLOR', AUI_SALMON_COLOR_ORIGINAL );
204
-			}
205
-			if ( ! defined( 'AUI_CYAN_COLOR' ) ) {
206
-				define( 'AUI_CYAN_COLOR', AUI_CYAN_COLOR_ORIGINAL );
207
-			}
208
-			if ( ! defined( 'AUI_GRAY_COLOR' ) ) {
209
-				define( 'AUI_GRAY_COLOR', AUI_GRAY_COLOR_ORIGINAL );
210
-			}
211
-			if ( ! defined( 'AUI_INDIGO_COLOR' ) ) {
212
-				define( 'AUI_INDIGO_COLOR', AUI_INDIGO_COLOR_ORIGINAL );
213
-			}
214
-			if ( ! defined( 'AUI_ORANGE_COLOR' ) ) {
215
-				define( 'AUI_ORANGE_COLOR', AUI_ORANGE_COLOR_ORIGINAL );
216
-			}
217
-			if ( ! defined( 'AUI_BLACK_COLOR' ) ) {
218
-				define( 'AUI_BLACK_COLOR', AUI_BLACK_COLOR_ORIGINAL );
219
-			}
220
-
221
-		}
222
-
223
-		public static function get_colors( $original = false){
224
-
225
-			if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
226
-				return array();
227
-			}
228
-			if ( $original ) {
229
-				return array(
230
-					'primary'   => AUI_PRIMARY_COLOR_ORIGINAL,
231
-					'secondary' => AUI_SECONDARY_COLOR_ORIGINAL,
232
-					'info'      => AUI_INFO_COLOR_ORIGINAL,
233
-					'warning'   => AUI_WARNING_COLOR_ORIGINAL,
234
-					'danger'    => AUI_DANGER_COLOR_ORIGINAL,
235
-					'success'   => AUI_SUCCESS_COLOR_ORIGINAL,
236
-					'light'     => AUI_LIGHT_COLOR_ORIGINAL,
237
-					'dark'      => AUI_DARK_COLOR_ORIGINAL,
238
-					'white'     => AUI_WHITE_COLOR_ORIGINAL,
239
-					'purple'    => AUI_PURPLE_COLOR_ORIGINAL,
240
-					'salmon'    => AUI_SALMON_COLOR_ORIGINAL,
241
-					'cyan'      => AUI_CYAN_COLOR_ORIGINAL,
242
-					'gray'      => AUI_GRAY_COLOR_ORIGINAL,
243
-					'indigo'    => AUI_INDIGO_COLOR_ORIGINAL,
244
-					'orange'    => AUI_ORANGE_COLOR_ORIGINAL,
245
-					'black'     => AUI_BLACK_COLOR_ORIGINAL,
246
-				);
247
-			}
248
-
249
-			return array(
250
-				'primary'   => AUI_PRIMARY_COLOR,
251
-				'secondary' => AUI_SECONDARY_COLOR,
252
-				'info'      => AUI_INFO_COLOR,
253
-				'warning'   => AUI_WARNING_COLOR,
254
-				'danger'    => AUI_DANGER_COLOR,
255
-				'success'   => AUI_SUCCESS_COLOR,
256
-				'light'     => AUI_LIGHT_COLOR,
257
-				'dark'      => AUI_DARK_COLOR,
258
-				'white'     => AUI_WHITE_COLOR,
259
-				'purple'    => AUI_PURPLE_COLOR,
260
-				'salmon'    => AUI_SALMON_COLOR,
261
-				'cyan'      => AUI_CYAN_COLOR,
262
-				'gray'      => AUI_GRAY_COLOR,
263
-				'indigo'    => AUI_INDIGO_COLOR,
264
-				'orange'    => AUI_ORANGE_COLOR,
265
-				'black'     => AUI_BLACK_COLOR,
266
-			);
267
-		}
268
-
269
-		/**
154
+		    public function constants(){
155
+			    define( 'AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be" );
156
+			    define( 'AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d' );
157
+			    define( 'AUI_INFO_COLOR_ORIGINAL', '#17a2b8' );
158
+			    define( 'AUI_WARNING_COLOR_ORIGINAL', '#ffc107' );
159
+			    define( 'AUI_DANGER_COLOR_ORIGINAL', '#dc3545' );
160
+			    define( 'AUI_SUCCESS_COLOR_ORIGINAL', '#44c553' );
161
+			    define( 'AUI_LIGHT_COLOR_ORIGINAL', '#f8f9fa' );
162
+			    define( 'AUI_DARK_COLOR_ORIGINAL', '#343a40' );
163
+			    define( 'AUI_WHITE_COLOR_ORIGINAL', '#fff' );
164
+			    define( 'AUI_PURPLE_COLOR_ORIGINAL', '#ad6edd' );
165
+			    define( 'AUI_SALMON_COLOR_ORIGINAL', '#ff977a' );
166
+			    define( 'AUI_CYAN_COLOR_ORIGINAL', '#35bdff' );
167
+			    define( 'AUI_GRAY_COLOR_ORIGINAL', '#ced4da' );
168
+			    define( 'AUI_INDIGO_COLOR_ORIGINAL', '#502c6c' );
169
+			    define( 'AUI_ORANGE_COLOR_ORIGINAL', '#orange' );
170
+			    define( 'AUI_BLACK_COLOR_ORIGINAL', '#000' );
171
+
172
+			    if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
173
+				    define( 'AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL );
174
+			    }
175
+			    if ( ! defined( 'AUI_SECONDARY_COLOR' ) ) {
176
+				    define( 'AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL );
177
+			    }
178
+			    if ( ! defined( 'AUI_INFO_COLOR' ) ) {
179
+				    define( 'AUI_INFO_COLOR', AUI_INFO_COLOR_ORIGINAL );
180
+			    }
181
+			    if ( ! defined( 'AUI_WARNING_COLOR' ) ) {
182
+				    define( 'AUI_WARNING_COLOR', AUI_WARNING_COLOR_ORIGINAL );
183
+			    }
184
+			    if ( ! defined( 'AUI_DANGER_COLOR' ) ) {
185
+				    define( 'AUI_DANGER_COLOR', AUI_DANGER_COLOR_ORIGINAL );
186
+			    }
187
+			    if ( ! defined( 'AUI_SUCCESS_COLOR' ) ) {
188
+				    define( 'AUI_SUCCESS_COLOR', AUI_SUCCESS_COLOR_ORIGINAL );
189
+			    }
190
+			    if ( ! defined( 'AUI_LIGHT_COLOR' ) ) {
191
+				    define( 'AUI_LIGHT_COLOR', AUI_LIGHT_COLOR_ORIGINAL );
192
+			    }
193
+			    if ( ! defined( 'AUI_DARK_COLOR' ) ) {
194
+				    define( 'AUI_DARK_COLOR', AUI_DARK_COLOR_ORIGINAL );
195
+			    }
196
+			    if ( ! defined( 'AUI_WHITE_COLOR' ) ) {
197
+				    define( 'AUI_WHITE_COLOR', AUI_WHITE_COLOR_ORIGINAL );
198
+			    }
199
+			    if ( ! defined( 'AUI_PURPLE_COLOR' ) ) {
200
+				    define( 'AUI_PURPLE_COLOR', AUI_PURPLE_COLOR_ORIGINAL );
201
+			    }
202
+			    if ( ! defined( 'AUI_SALMON_COLOR' ) ) {
203
+				    define( 'AUI_SALMON_COLOR', AUI_SALMON_COLOR_ORIGINAL );
204
+			    }
205
+			    if ( ! defined( 'AUI_CYAN_COLOR' ) ) {
206
+				    define( 'AUI_CYAN_COLOR', AUI_CYAN_COLOR_ORIGINAL );
207
+			    }
208
+			    if ( ! defined( 'AUI_GRAY_COLOR' ) ) {
209
+				    define( 'AUI_GRAY_COLOR', AUI_GRAY_COLOR_ORIGINAL );
210
+			    }
211
+			    if ( ! defined( 'AUI_INDIGO_COLOR' ) ) {
212
+				    define( 'AUI_INDIGO_COLOR', AUI_INDIGO_COLOR_ORIGINAL );
213
+			    }
214
+			    if ( ! defined( 'AUI_ORANGE_COLOR' ) ) {
215
+				    define( 'AUI_ORANGE_COLOR', AUI_ORANGE_COLOR_ORIGINAL );
216
+			    }
217
+			    if ( ! defined( 'AUI_BLACK_COLOR' ) ) {
218
+				    define( 'AUI_BLACK_COLOR', AUI_BLACK_COLOR_ORIGINAL );
219
+			    }
220
+
221
+		    }
222
+
223
+		    public static function get_colors( $original = false){
224
+
225
+			    if ( ! defined( 'AUI_PRIMARY_COLOR' ) ) {
226
+				    return array();
227
+			    }
228
+			    if ( $original ) {
229
+				    return array(
230
+					    'primary'   => AUI_PRIMARY_COLOR_ORIGINAL,
231
+					    'secondary' => AUI_SECONDARY_COLOR_ORIGINAL,
232
+					    'info'      => AUI_INFO_COLOR_ORIGINAL,
233
+					    'warning'   => AUI_WARNING_COLOR_ORIGINAL,
234
+					    'danger'    => AUI_DANGER_COLOR_ORIGINAL,
235
+					    'success'   => AUI_SUCCESS_COLOR_ORIGINAL,
236
+					    'light'     => AUI_LIGHT_COLOR_ORIGINAL,
237
+					    'dark'      => AUI_DARK_COLOR_ORIGINAL,
238
+					    'white'     => AUI_WHITE_COLOR_ORIGINAL,
239
+					    'purple'    => AUI_PURPLE_COLOR_ORIGINAL,
240
+					    'salmon'    => AUI_SALMON_COLOR_ORIGINAL,
241
+					    'cyan'      => AUI_CYAN_COLOR_ORIGINAL,
242
+					    'gray'      => AUI_GRAY_COLOR_ORIGINAL,
243
+					    'indigo'    => AUI_INDIGO_COLOR_ORIGINAL,
244
+					    'orange'    => AUI_ORANGE_COLOR_ORIGINAL,
245
+					    'black'     => AUI_BLACK_COLOR_ORIGINAL,
246
+				    );
247
+			    }
248
+
249
+			    return array(
250
+				    'primary'   => AUI_PRIMARY_COLOR,
251
+				    'secondary' => AUI_SECONDARY_COLOR,
252
+				    'info'      => AUI_INFO_COLOR,
253
+				    'warning'   => AUI_WARNING_COLOR,
254
+				    'danger'    => AUI_DANGER_COLOR,
255
+				    'success'   => AUI_SUCCESS_COLOR,
256
+				    'light'     => AUI_LIGHT_COLOR,
257
+				    'dark'      => AUI_DARK_COLOR,
258
+				    'white'     => AUI_WHITE_COLOR,
259
+				    'purple'    => AUI_PURPLE_COLOR,
260
+				    'salmon'    => AUI_SALMON_COLOR,
261
+				    'cyan'      => AUI_CYAN_COLOR,
262
+				    'gray'      => AUI_GRAY_COLOR,
263
+				    'indigo'    => AUI_INDIGO_COLOR,
264
+				    'orange'    => AUI_ORANGE_COLOR,
265
+				    'black'     => AUI_BLACK_COLOR,
266
+			    );
267
+		    }
268
+
269
+		    /**
270 270
 		 * Add admin body class to show when BS5 is active.
271 271
 		 *
272 272
 		 * @param $classes
273 273
 		 *
274 274
 		 * @return mixed
275 275
 		 */
276
-		public function add_bs5_admin_body_class( $classes = '' ) {
277
-			$classes .= ' aui_bs5';
276
+		    public function add_bs5_admin_body_class( $classes = '' ) {
277
+			    $classes .= ' aui_bs5';
278 278
 
279
-			return $classes;
280
-		}
279
+			    return $classes;
280
+		    }
281 281
 
282
-		/**
282
+		    /**
283 283
 		 * Add a body class to show when BS5 is active.
284 284
 		 *
285 285
 		 * @param $classes
286 286
 		 *
287 287
 		 * @return mixed
288 288
 		 */
289
-		public function add_bs5_body_class( $classes ) {
290
-			$classes[] = 'aui_bs5';
289
+		    public function add_bs5_body_class( $classes ) {
290
+			    $classes[] = 'aui_bs5';
291 291
 
292
-			return $classes;
293
-		}
292
+			    return $classes;
293
+		    }
294 294
 
295
-		/**
295
+		    /**
296 296
 		 * Initiate the settings and add the required action hooks.
297 297
 		 */
298
-		public function init() {
299
-            global $aui_bs5;
300
-
301
-			// Maybe fix settings
302
-			if ( ! empty( $_REQUEST['aui-fix-admin'] ) && !empty($_REQUEST['nonce']) && wp_verify_nonce( $_REQUEST['nonce'], "aui-fix-admin" ) ) {
303
-				$db_settings = get_option( 'ayecode-ui-settings' );
304
-				if ( ! empty( $db_settings ) ) {
305
-					$db_settings['css_backend'] = 'compatibility';
306
-					$db_settings['js_backend'] = 'core-popper';
307
-					update_option( 'ayecode-ui-settings', $db_settings );
308
-					wp_safe_redirect(admin_url("options-general.php?page=ayecode-ui-settings&updated=true"));
309
-				}
310
-			}
311
-
312
-			$this->constants();
313
-			$this->settings = $this->get_settings();
314
-			$this->url = $this->get_url();
315
-
316
-            // define the version
317
-			$aui_bs5 = $this->settings['bs_ver'] === '5';
318
-
319
-			if ( $aui_bs5 ) {
320
-				include_once( dirname( __FILE__ ) . '/inc/bs-conversion.php' );
321
-				add_filter( 'admin_body_class', array( $this, 'add_bs5_admin_body_class' ), 99, 1 );
322
-				add_filter( 'body_class', array( $this, 'add_bs5_body_class' ) );
323
-			}
324
-
325
-			/**
298
+		    public function init() {
299
+                global $aui_bs5;
300
+
301
+			    // Maybe fix settings
302
+			    if ( ! empty( $_REQUEST['aui-fix-admin'] ) && !empty($_REQUEST['nonce']) && wp_verify_nonce( $_REQUEST['nonce'], "aui-fix-admin" ) ) {
303
+				    $db_settings = get_option( 'ayecode-ui-settings' );
304
+				    if ( ! empty( $db_settings ) ) {
305
+					    $db_settings['css_backend'] = 'compatibility';
306
+					    $db_settings['js_backend'] = 'core-popper';
307
+					    update_option( 'ayecode-ui-settings', $db_settings );
308
+					    wp_safe_redirect(admin_url("options-general.php?page=ayecode-ui-settings&updated=true"));
309
+				    }
310
+			    }
311
+
312
+			    $this->constants();
313
+			    $this->settings = $this->get_settings();
314
+			    $this->url = $this->get_url();
315
+
316
+                // define the version
317
+			    $aui_bs5 = $this->settings['bs_ver'] === '5';
318
+
319
+			    if ( $aui_bs5 ) {
320
+				    include_once( dirname( __FILE__ ) . '/inc/bs-conversion.php' );
321
+				    add_filter( 'admin_body_class', array( $this, 'add_bs5_admin_body_class' ), 99, 1 );
322
+				    add_filter( 'body_class', array( $this, 'add_bs5_body_class' ) );
323
+			    }
324
+
325
+			    /**
326 326
 			 * Maybe load CSS
327 327
 			 *
328 328
 			 * We load super early in case there is a theme version that might change the colors
329 329
 			 */
330
-			if ( $this->settings['css'] ) {
331
-				$priority = $this->is_bs3_compat() ? 100 : 1;
332
-                $priority = $aui_bs5 ? 10 : $priority;
333
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), $priority );
334
-			}
335
-			if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
336
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
337
-			}
338
-
339
-			// maybe load JS
340
-			if ( $this->settings['js'] ) {
341
-				$priority = $this->is_bs3_compat() ? 100 : 1;
342
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
343
-			}
344
-			if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
345
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
346
-			}
347
-
348
-			// Maybe set the HTML font size
349
-			if ( $this->settings['html_font_size'] ) {
350
-				add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
351
-			}
352
-
353
-			// Maybe show backend style error
354
-			if( $this->settings['css_backend'] != 'compatibility' || $this->settings['js_backend'] != 'core-popper' ){
355
-				add_action( 'admin_notices', array( $this, 'show_admin_style_notice' ) );
356
-			}
357
-
358
-		}
359
-
360
-		/**
330
+			    if ( $this->settings['css'] ) {
331
+				    $priority = $this->is_bs3_compat() ? 100 : 1;
332
+                    $priority = $aui_bs5 ? 10 : $priority;
333
+				    add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), $priority );
334
+			    }
335
+			    if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
336
+				    add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
337
+			    }
338
+
339
+			    // maybe load JS
340
+			    if ( $this->settings['js'] ) {
341
+				    $priority = $this->is_bs3_compat() ? 100 : 1;
342
+				    add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
343
+			    }
344
+			    if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
345
+				    add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
346
+			    }
347
+
348
+			    // Maybe set the HTML font size
349
+			    if ( $this->settings['html_font_size'] ) {
350
+				    add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
351
+			    }
352
+
353
+			    // Maybe show backend style error
354
+			    if( $this->settings['css_backend'] != 'compatibility' || $this->settings['js_backend'] != 'core-popper' ){
355
+				    add_action( 'admin_notices', array( $this, 'show_admin_style_notice' ) );
356
+			    }
357
+
358
+		    }
359
+
360
+		    /**
361 361
 		 * Show admin notice if backend scripts not loaded.
362 362
 		 */
363
-		public function show_admin_style_notice(){
364
-			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings&aui-fix-admin=true&nonce=".wp_create_nonce('aui-fix-admin'));
365
-			$button = '<a href="'.esc_url($fix_url).'" class="button-primary">Fix Now</a>';
366
-			$message = __( '<b>Style Issue:</b> AyeCode UI is disable or set wrong.')." " .$button;
367
-			echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
368
-		}
363
+		    public function show_admin_style_notice(){
364
+			    $fix_url = admin_url("options-general.php?page=ayecode-ui-settings&aui-fix-admin=true&nonce=".wp_create_nonce('aui-fix-admin'));
365
+			    $button = '<a href="'.esc_url($fix_url).'" class="button-primary">Fix Now</a>';
366
+			    $message = __( '<b>Style Issue:</b> AyeCode UI is disable or set wrong.')." " .$button;
367
+			    echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
368
+		    }
369 369
 
370
-		/**
370
+		    /**
371 371
 		 * Check if we should load the admin scripts or not.
372 372
 		 *
373 373
 		 * @return bool
374 374
 		 */
375
-		public function load_admin_scripts(){
376
-			$result = true;
375
+		    public function load_admin_scripts(){
376
+			    $result = true;
377 377
 
378
-			// check if specifically disabled
379
-			if(!empty($this->settings['disable_admin'])){
380
-				$url_parts = explode("\n",$this->settings['disable_admin']);
381
-				foreach($url_parts as $part){
382
-					if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
383
-						return false; // return early, no point checking further
384
-					}
385
-				}
386
-			}
378
+			    // check if specifically disabled
379
+			    if(!empty($this->settings['disable_admin'])){
380
+				    $url_parts = explode("\n",$this->settings['disable_admin']);
381
+				    foreach($url_parts as $part){
382
+					    if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
383
+						    return false; // return early, no point checking further
384
+					    }
385
+				    }
386
+			    }
387 387
 
388
-			return $result;
389
-		}
388
+			    return $result;
389
+		    }
390 390
 
391
-		/**
391
+		    /**
392 392
 		 * Add a html font size to the footer.
393 393
 		 */
394
-		public function html_font_size(){
395
-			$this->settings = $this->get_settings();
396
-			echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
397
-		}
394
+		    public function html_font_size(){
395
+			    $this->settings = $this->get_settings();
396
+			    echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
397
+		    }
398 398
 
399
-		/**
399
+		    /**
400 400
 		 * Check if the current admin screen should load scripts.
401 401
 		 *
402 402
 		 * @return bool
403 403
 		 */
404
-		public function is_aui_screen(){
405
-//			echo '###';exit;
406
-			$load = false;
407
-			// check if we should load or not
408
-			if ( is_admin() ) {
409
-				// Only enable on set pages
410
-				$aui_screens = array(
411
-					'page',
412
-                    //'docs',
413
-					'post',
414
-					'settings_page_ayecode-ui-settings',
415
-					'appearance_page_gutenberg-widgets',
416
-					'widgets',
417
-					'ayecode-ui-settings',
418
-					'site-editor'
419
-				);
420
-				$screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
421
-
422
-				$screen = get_current_screen();
423
-
424
-//				echo '###'.$screen->id;
425
-
426
-				// check if we are on a AUI screen
427
-				if ( $screen && in_array( $screen->id, $screen_ids ) ) {
428
-					$load = true;
429
-				}
430
-
431
-				//load for widget previews in WP 5.8
432
-				if( !empty($_REQUEST['legacy-widget-preview'])){
433
-					$load = true;
434
-				}
435
-			}
436
-
437
-
438
-
439
-			return apply_filters( 'aui_load_on_admin' , $load );
440
-		}
441
-
442
-		/**
404
+		    public function is_aui_screen(){
405
+    //			echo '###';exit;
406
+			    $load = false;
407
+			    // check if we should load or not
408
+			    if ( is_admin() ) {
409
+				    // Only enable on set pages
410
+				    $aui_screens = array(
411
+					    'page',
412
+                        //'docs',
413
+					    'post',
414
+					    'settings_page_ayecode-ui-settings',
415
+					    'appearance_page_gutenberg-widgets',
416
+					    'widgets',
417
+					    'ayecode-ui-settings',
418
+					    'site-editor'
419
+				    );
420
+				    $screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
421
+
422
+				    $screen = get_current_screen();
423
+
424
+    //				echo '###'.$screen->id;
425
+
426
+				    // check if we are on a AUI screen
427
+				    if ( $screen && in_array( $screen->id, $screen_ids ) ) {
428
+					    $load = true;
429
+				    }
430
+
431
+				    //load for widget previews in WP 5.8
432
+				    if( !empty($_REQUEST['legacy-widget-preview'])){
433
+					    $load = true;
434
+				    }
435
+			    }
436
+
437
+
438
+
439
+			    return apply_filters( 'aui_load_on_admin' , $load );
440
+		    }
441
+
442
+		    /**
443 443
 		 * Check if the current theme is a block theme.
444 444
 		 *
445 445
 		 * @return bool
446 446
 		 */
447
-		public static function is_block_theme() {
448
-			if ( function_exists( 'wp_is_block_theme' && wp_is_block_theme() ) ) {
449
-				return true;
450
-			}
447
+		    public static function is_block_theme() {
448
+			    if ( function_exists( 'wp_is_block_theme' && wp_is_block_theme() ) ) {
449
+				    return true;
450
+			    }
451 451
 
452
-			return false;
453
-		}
452
+			    return false;
453
+		    }
454 454
 
455
-		/**
455
+		    /**
456 456
 		 * Adds the styles.
457 457
 		 */
458
-		public function enqueue_style() {
459
-            global $aui_bs5;
458
+		    public function enqueue_style() {
459
+                global $aui_bs5;
460 460
 
461
-            $load_fse = false;
461
+                $load_fse = false;
462 462
 
463
-			if ( is_admin() && ! $this->is_aui_screen() ) {
464
-				// Don't add wp-admin scripts if not requested to.
465
-			} else {
466
-				$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
467
-				$rtl = is_rtl() && ! $aui_bs5 ? '-rtl' : '';
468
-                $bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
463
+			    if ( is_admin() && ! $this->is_aui_screen() ) {
464
+				    // Don't add wp-admin scripts if not requested to.
465
+			    } else {
466
+				    $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
467
+				    $rtl = is_rtl() && ! $aui_bs5 ? '-rtl' : '';
468
+                    $bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
469 469
 
470
-				if ( $this->settings[ $css_setting ] ) {
471
-					$compatibility = $this->settings[$css_setting]=='core' ? false : true;
472
-					$url = $this->settings[$css_setting]=='core' ? $this->url.'assets'.$bs_ver.'/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets'.$bs_ver.'/css/ayecode-ui-compatibility'.$rtl.'.css';
470
+				    if ( $this->settings[ $css_setting ] ) {
471
+					    $compatibility = $this->settings[$css_setting]=='core' ? false : true;
472
+					    $url = $this->settings[$css_setting]=='core' ? $this->url.'assets'.$bs_ver.'/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets'.$bs_ver.'/css/ayecode-ui-compatibility'.$rtl.'.css';
473 473
 
474
-					wp_register_style( 'ayecode-ui', $url, array(), $this->version );
475
-					wp_enqueue_style( 'ayecode-ui' );
474
+					    wp_register_style( 'ayecode-ui', $url, array(), $this->version );
475
+					    wp_enqueue_style( 'ayecode-ui' );
476 476
 
477
-					if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
478
-						$url = $this->url.'assets'.$bs_ver.'/css/ayecode-ui-fse.css';
479
-						wp_register_style( 'ayecode-ui-fse', $url, array(), $this->version );
480
-						wp_enqueue_style( 'ayecode-ui-fse' );
481
-						$load_fse = true;
482
-					}
477
+					    if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
478
+						    $url = $this->url.'assets'.$bs_ver.'/css/ayecode-ui-fse.css';
479
+						    wp_register_style( 'ayecode-ui-fse', $url, array(), $this->version );
480
+						    wp_enqueue_style( 'ayecode-ui-fse' );
481
+						    $load_fse = true;
482
+					    }
483 483
 
484
-					// flatpickr
485
-					wp_register_style( 'flatpickr', $this->url.'assets'.$bs_ver.'/css/flatpickr.min.css', array(), $this->version );
484
+					    // flatpickr
485
+					    wp_register_style( 'flatpickr', $this->url.'assets'.$bs_ver.'/css/flatpickr.min.css', array(), $this->version );
486 486
 
487
-					// fix some wp-admin issues
488
-					if(is_admin()){
489
-						$custom_css = "
487
+					    // fix some wp-admin issues
488
+					    if(is_admin()){
489
+						    $custom_css = "
490 490
                 body{
491 491
                     background-color: #f1f1f1;
492 492
                     font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif;
@@ -526,84 +526,84 @@  discard block
 block discarded – undo
526 526
 				}
527 527
                 ";
528 528
 
529
-						// @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
530
-						$custom_css .= "
529
+						    // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
530
+						    $custom_css .= "
531 531
 						.edit-post-sidebar input[type=color].components-text-control__input{
532 532
 						    padding: 0;
533 533
 						}
534 534
 					";
535
-						wp_add_inline_style( 'ayecode-ui', $custom_css );
536
-					}
537
-
538
-					// custom changes
539
-					if ( $load_fse ) {
540
-						wp_add_inline_style( 'ayecode-ui-fse', self::custom_css($compatibility, true) );
541
-					}else{
542
-						wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
543
-					}
544
-				}
545
-			}
546
-		}
547
-
548
-		/**
535
+						    wp_add_inline_style( 'ayecode-ui', $custom_css );
536
+					    }
537
+
538
+					    // custom changes
539
+					    if ( $load_fse ) {
540
+						    wp_add_inline_style( 'ayecode-ui-fse', self::custom_css($compatibility, true) );
541
+					    }else{
542
+						    wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
543
+					    }
544
+				    }
545
+			    }
546
+		    }
547
+
548
+		    /**
549 549
 		 * Get inline script used if bootstrap enqueued
550 550
 		 *
551 551
 		 * If this remains small then its best to use this than to add another JS file.
552 552
 		 */
553
-		public function inline_script() {
554
-            global $aui_bs5;
555
-			// Flatpickr calendar locale
556
-			$flatpickr_locale = self::flatpickr_locale();
553
+		    public function inline_script() {
554
+                global $aui_bs5;
555
+			    // Flatpickr calendar locale
556
+			    $flatpickr_locale = self::flatpickr_locale();
557 557
 
558
-			ob_start();
559
-			if ( $aui_bs5 ) {
560
-				include_once( dirname( __FILE__ ) . '/inc/bs5-js.php' );
561
-			}else{
562
-				include_once( dirname( __FILE__ ) . '/inc/bs4-js.php' );
563
-            }
558
+			    ob_start();
559
+			    if ( $aui_bs5 ) {
560
+				    include_once( dirname( __FILE__ ) . '/inc/bs5-js.php' );
561
+			    }else{
562
+				    include_once( dirname( __FILE__ ) . '/inc/bs4-js.php' );
563
+                }
564 564
 
565
-			$output = ob_get_clean();
565
+			    $output = ob_get_clean();
566 566
 
567
-			/*
567
+			    /*
568 568
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
569 569
 			 */
570
-			return str_replace( array(
571
-				'<script>',
572
-				'</script>'
573
-			), '', self::minify_js($output) );
574
-		}
570
+			    return str_replace( array(
571
+				    '<script>',
572
+				    '</script>'
573
+			    ), '', self::minify_js($output) );
574
+		    }
575 575
 
576 576
 
577
-		/**
577
+		    /**
578 578
 		 * JS to help with conflict issues with other plugins and themes using bootstrap v3.
579 579
 		 *
580 580
 		 * @TODO we may need this when other conflicts arrise.
581 581
 		 * @return mixed
582 582
 		 */
583
-		public static function bs3_compat_js() {
584
-			ob_start();
585
-			?>
586
-            <script>
583
+		    public static function bs3_compat_js() {
584
+			    ob_start();
585
+			    ?>
586
+                <script>
587 587
 				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
588
-                /* With Avada builder */
588
+                    /* With Avada builder */
589 589
 
590 590
 				<?php } ?>
591
-            </script>
591
+                </script>
592 592
 			<?php
593
-			return str_replace( array(
594
-				'<script>',
595
-				'</script>'
596
-			), '', ob_get_clean());
597
-		}
593
+			    return str_replace( array(
594
+				    '<script>',
595
+				    '</script>'
596
+			    ), '', ob_get_clean());
597
+		    }
598 598
 
599
-		/**
599
+		    /**
600 600
 		 * Get inline script used if bootstrap file browser enqueued.
601 601
 		 *
602 602
 		 * If this remains small then its best to use this than to add another JS file.
603 603
 		 */
604
-		public function inline_script_file_browser(){
605
-			ob_start();
606
-			?>
604
+		    public function inline_script_file_browser(){
605
+			    ob_start();
606
+			    ?>
607 607
             <script>
608 608
                 // run on doc ready
609 609
                 jQuery(document).ready(function () {
@@ -611,129 +611,129 @@  discard block
 block discarded – undo
611 611
                 });
612 612
             </script>
613 613
 			<?php
614
-			$output = ob_get_clean();
614
+			    $output = ob_get_clean();
615 615
 
616
-			/*
616
+			    /*
617 617
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
618 618
 			 */
619
-			return str_replace( array(
620
-				'<script>',
621
-				'</script>'
622
-			), '', $output );
623
-		}
619
+			    return str_replace( array(
620
+				    '<script>',
621
+				    '</script>'
622
+			    ), '', $output );
623
+		    }
624 624
 
625
-		/**
625
+		    /**
626 626
 		 * Adds the Font Awesome JS.
627 627
 		 */
628
-		public function enqueue_scripts() {
629
-			if( is_admin() && !$this->is_aui_screen()){
630
-				// Don't add wp-admin scripts if not requested to.
631
-			} else {
632
-				$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
633
-
634
-				$bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
635
-
636
-				// select2
637
-				wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
638
-
639
-				// flatpickr
640
-				wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->version );
641
-
642
-				// iconpicker
643
-				if ( defined( 'FAS_ICONPICKER_JS_URL' ) ) {
644
-					wp_register_script( 'iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version );
645
-				}else{
646
-					wp_register_script( 'iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version );
647
-				}
648
-
649
-				// Bootstrap file browser
650
-				wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
651
-				wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
652
-
653
-				$load_inline = false;
654
-
655
-				// Load select2 only when required.
656
-				if ( $this->force_load_select2() ) {
657
-					$dependency = array( 'select2', 'jquery' );
658
-				} else {
659
-					$dependency = array( 'jquery' );
660
-				}
661
-
662
-				if ( $this->settings[ $js_setting ] == 'core-popper' ) {
663
-					// Bootstrap bundle
664
-					$url = $this->url . 'assets' . $bs_ver . '/js/bootstrap.bundle.min.js';
665
-					wp_register_script( 'bootstrap-js-bundle', $url, $dependency, $this->version, $this->is_bs3_compat() );
666
-
667
-					// If in admin then add to footer for compatibility.
668
-					is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
669
-
670
-					$script = $this->inline_script();
671
-					wp_add_inline_script( 'bootstrap-js-bundle', $script );
672
-				} elseif ( $this->settings[ $js_setting ] == 'popper' ) {
673
-					$url = $this->url . 'assets/js/popper.min.js'; // @todo we need to update this to bs5
674
-					wp_register_script( 'bootstrap-js-popper', $url, $dependency, $this->version );
675
-					wp_enqueue_script( 'bootstrap-js-popper' );
676
-					$load_inline = true;
677
-				} else {
678
-					$load_inline = true;
679
-				}
680
-
681
-				// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
682
-				if ( $load_inline ) {
683
-					wp_register_script( 'bootstrap-dummy', '', $dependency );
684
-					wp_enqueue_script( 'bootstrap-dummy' );
685
-
686
-					$script = $this->inline_script();
687
-					wp_add_inline_script( 'bootstrap-dummy', $script );
688
-				}
689
-			}
690
-		}
691
-
692
-		/**
628
+		    public function enqueue_scripts() {
629
+			    if( is_admin() && !$this->is_aui_screen()){
630
+				    // Don't add wp-admin scripts if not requested to.
631
+			    } else {
632
+				    $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
633
+
634
+				    $bs_ver = $this->settings['bs_ver'] == '5' ? '-v5' : '';
635
+
636
+				    // select2
637
+				    wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
638
+
639
+				    // flatpickr
640
+				    wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->version );
641
+
642
+				    // iconpicker
643
+				    if ( defined( 'FAS_ICONPICKER_JS_URL' ) ) {
644
+					    wp_register_script( 'iconpicker', FAS_ICONPICKER_JS_URL, array(), $this->version );
645
+				    }else{
646
+					    wp_register_script( 'iconpicker', $this->url . 'assets/js/fa-iconpicker.min.js', array(), $this->version );
647
+				    }
648
+
649
+				    // Bootstrap file browser
650
+				    wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
651
+				    wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
652
+
653
+				    $load_inline = false;
654
+
655
+				    // Load select2 only when required.
656
+				    if ( $this->force_load_select2() ) {
657
+					    $dependency = array( 'select2', 'jquery' );
658
+				    } else {
659
+					    $dependency = array( 'jquery' );
660
+				    }
661
+
662
+				    if ( $this->settings[ $js_setting ] == 'core-popper' ) {
663
+					    // Bootstrap bundle
664
+					    $url = $this->url . 'assets' . $bs_ver . '/js/bootstrap.bundle.min.js';
665
+					    wp_register_script( 'bootstrap-js-bundle', $url, $dependency, $this->version, $this->is_bs3_compat() );
666
+
667
+					    // If in admin then add to footer for compatibility.
668
+					    is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
669
+
670
+					    $script = $this->inline_script();
671
+					    wp_add_inline_script( 'bootstrap-js-bundle', $script );
672
+				    } elseif ( $this->settings[ $js_setting ] == 'popper' ) {
673
+					    $url = $this->url . 'assets/js/popper.min.js'; // @todo we need to update this to bs5
674
+					    wp_register_script( 'bootstrap-js-popper', $url, $dependency, $this->version );
675
+					    wp_enqueue_script( 'bootstrap-js-popper' );
676
+					    $load_inline = true;
677
+				    } else {
678
+					    $load_inline = true;
679
+				    }
680
+
681
+				    // Load needed inline scripts by faking the loading of a script if the main script is not being loaded
682
+				    if ( $load_inline ) {
683
+					    wp_register_script( 'bootstrap-dummy', '', $dependency );
684
+					    wp_enqueue_script( 'bootstrap-dummy' );
685
+
686
+					    $script = $this->inline_script();
687
+					    wp_add_inline_script( 'bootstrap-dummy', $script );
688
+				    }
689
+			    }
690
+		    }
691
+
692
+		    /**
693 693
 		 * Enqueue select2 if called.
694 694
 		 *
695 695
 		 * @since 0.2.29
696 696
 		 */
697
-		public function force_load_select2() {
698
-			global $aui_select2_enqueued;
697
+		    public function force_load_select2() {
698
+			    global $aui_select2_enqueued;
699 699
 
700
-			$conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
700
+			    $conditional_select2 = apply_filters( 'aui_is_conditional_select2', true );
701 701
 
702
-			if ( $conditional_select2 !== true ) {
703
-				return true;
704
-			}
702
+			    if ( $conditional_select2 !== true ) {
703
+				    return true;
704
+			    }
705 705
 
706
-			$load = is_admin() && ! $aui_select2_enqueued;
706
+			    $load = is_admin() && ! $aui_select2_enqueued;
707 707
 
708
-			return apply_filters( 'aui_force_load_select2', $load );
709
-		}
708
+			    return apply_filters( 'aui_force_load_select2', $load );
709
+		    }
710 710
 
711
-		/**
711
+		    /**
712 712
 		 * Enqueue select2 if called.
713 713
 		 *
714 714
 		 * @since 0.2.29
715 715
 		 */
716
-		public function enqueue_select2() {
717
-			wp_enqueue_script( 'select2' );
718
-		}
716
+		    public function enqueue_select2() {
717
+			    wp_enqueue_script( 'select2' );
718
+		    }
719 719
 
720
-		/**
720
+		    /**
721 721
 		 * Enqueue flatpickr if called.
722 722
 		 */
723
-		public function enqueue_flatpickr(){
724
-			wp_enqueue_style( 'flatpickr' );
725
-			wp_enqueue_script( 'flatpickr' );
726
-		}
723
+		    public function enqueue_flatpickr(){
724
+			    wp_enqueue_style( 'flatpickr' );
725
+			    wp_enqueue_script( 'flatpickr' );
726
+		    }
727 727
 
728
-		/**
728
+		    /**
729 729
 		 * Enqueue iconpicker if called.
730 730
 		 */
731
-		public function enqueue_iconpicker(){
732
-			wp_enqueue_style( 'iconpicker' );
733
-			wp_enqueue_script( 'iconpicker' );
734
-		}
731
+		    public function enqueue_iconpicker(){
732
+			    wp_enqueue_style( 'iconpicker' );
733
+			    wp_enqueue_script( 'iconpicker' );
734
+		    }
735 735
 
736
-        /**
736
+            /**
737 737
          * Get the url path to the current folder.
738 738
          *
739 739
          * This can be called very early, hence the need for the dynamic way of getting the URL.
@@ -741,193 +741,193 @@  discard block
 block discarded – undo
741 741
          * @since 0.2.31 changed to support edge cases like bitnami containers.
742 742
          * @return string
743 743
          */
744
-        public function get_url() {
745
-            $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
746
-            $content_url = untrailingslashit( WP_CONTENT_URL );
744
+            public function get_url() {
745
+                $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
746
+                $content_url = untrailingslashit( WP_CONTENT_URL );
747 747
 
748
-            // maybe Replace http:// to https://.
749
-            if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
750
-                $content_url = str_replace( 'http://', 'https://', $content_url );
751
-            }
748
+                // maybe Replace http:// to https://.
749
+                if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
750
+                    $content_url = str_replace( 'http://', 'https://', $content_url );
751
+                }
752 752
 
753
-            // First find where in the path our content directory starts
754
-            $content_basename = basename($content_dir);
755
-            $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
753
+                // First find where in the path our content directory starts
754
+                $content_basename = basename($content_dir);
755
+                $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
756 756
 
757
-            // Find the relative path by matching from content directory name
758
-            $after_content = substr($file_dir, strpos($file_dir, '/' . $content_basename . '/') + strlen('/' . $content_basename . '/'));
757
+                // Find the relative path by matching from content directory name
758
+                $after_content = substr($file_dir, strpos($file_dir, '/' . $content_basename . '/') + strlen('/' . $content_basename . '/'));
759 759
 
760
-            // Build URL using WP_CONTENT_URL and the relative path
761
-            $url = trailingslashit($content_url) . $after_content;
760
+                // Build URL using WP_CONTENT_URL and the relative path
761
+                $url = trailingslashit($content_url) . $after_content;
762 762
 
763
-            return trailingslashit($url);
764
-        }
763
+                return trailingslashit($url);
764
+            }
765 765
 
766
-		/**
766
+		    /**
767 767
 		 * Get the url path to the current folder.
768 768
 		 * @todo remove
769 769
 		 * @return string
770 770
 		 */
771
-		public function get_url_old() {
771
+		    public function get_url_old() {
772 772
 
773
-			$url = '';
774
-			// check if we are inside a plugin
775
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
773
+			    $url = '';
774
+			    // check if we are inside a plugin
775
+			    $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
776 776
 
777
-			// add check in-case user has changed wp-content dir name.
778
-			$wp_content_folder_name = basename(WP_CONTENT_DIR);
779
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
780
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
777
+			    // add check in-case user has changed wp-content dir name.
778
+			    $wp_content_folder_name = basename(WP_CONTENT_DIR);
779
+			    $dir_parts = explode("/$wp_content_folder_name/",$file_dir);
780
+			    $url_parts = explode("/$wp_content_folder_name/",plugins_url());
781 781
 
782
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
783
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
784
-			}
782
+			    if(!empty($url_parts[0]) && !empty($dir_parts[1])){
783
+				    $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
784
+			    }
785 785
 
786
-			return $url;
787
-		}
786
+			    return $url;
787
+		    }
788 788
 
789
-		/**
789
+		    /**
790 790
 		 * Register the database settings with WordPress.
791 791
 		 */
792
-		public function register_settings() {
793
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
794
-		}
792
+		    public function register_settings() {
793
+			    register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
794
+		    }
795 795
 
796
-		/**
796
+		    /**
797 797
 		 * Add the WordPress settings menu item.
798 798
 		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
799 799
 		 */
800
-		public function menu_item() {
801
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
802
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
803
-				$this,
804
-				'settings_page'
805
-			) );
806
-		}
800
+		    public function menu_item() {
801
+			    $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
802
+			    call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
803
+				    $this,
804
+				    'settings_page'
805
+			    ) );
806
+		    }
807 807
 
808
-		/**
808
+		    /**
809 809
 		 * Get a list of themes and their default JS settings.
810 810
 		 *
811 811
 		 * @return array
812 812
 		 */
813
-		public function theme_js_settings(){
814
-			return array(
815
-				'ayetheme' => 'popper',
816
-				'listimia' => 'required',
817
-				'listimia_backend' => 'core-popper',
818
-				//'avada'    => 'required', // removed as we now add compatibility
819
-			);
820
-		}
813
+		    public function theme_js_settings(){
814
+			    return array(
815
+				    'ayetheme' => 'popper',
816
+				    'listimia' => 'required',
817
+				    'listimia_backend' => 'core-popper',
818
+				    //'avada'    => 'required', // removed as we now add compatibility
819
+			    );
820
+		    }
821 821
 
822
-		/**
822
+		    /**
823 823
          * Get the date the site was installed.
824 824
          *
825 825
 		 * @return false|string
826 826
 		 */
827
-        public function get_site_install_date() {
828
-	        global $wpdb; // This gives you access to the WordPress database object
827
+            public function get_site_install_date() {
828
+	            global $wpdb; // This gives you access to the WordPress database object
829 829
 
830
-	        // Prepare the SQL query to get the oldest registration date
831
-	        $query = "SELECT MIN(user_registered) AS oldest_registration_date FROM {$wpdb->users}";
830
+	            // Prepare the SQL query to get the oldest registration date
831
+	            $query = "SELECT MIN(user_registered) AS oldest_registration_date FROM {$wpdb->users}";
832 832
 
833
-	        // Execute the query
834
-	        $date = $wpdb->get_var( $query ); // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
833
+	            // Execute the query
834
+	            $date = $wpdb->get_var( $query ); // phpcs:ignore WordPress.DB.DirectDatabaseQuery.DirectQuery, WordPress.DB.DirectDatabaseQuery.NoCaching
835 835
 
836
-	        return $date ? $date : false;
837
-        }
836
+	            return $date ? $date : false;
837
+            }
838 838
 
839
-		/**
839
+		    /**
840 840
 		 * Show admin notice if backend scripts not loaded.
841 841
 		 */
842
-		public function show_admin_version_notice(){
843
-			$fix_url = admin_url("options-general.php?page=ayecode-ui-settings" );
844
-			$button = '<a href="'.esc_url($fix_url).'" class="button-primary">View Settings</a>';
845
-			$message = __( '<b>Style Issue:</b> AyeCode UI has changed its default version from v4 to v5, if you notice unwanted style changes, please revert to v4 (saving the settings page will remove this notice)')." " .$button;
846
-			echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
847
-		}
842
+		    public function show_admin_version_notice(){
843
+			    $fix_url = admin_url("options-general.php?page=ayecode-ui-settings" );
844
+			    $button = '<a href="'.esc_url($fix_url).'" class="button-primary">View Settings</a>';
845
+			    $message = __( '<b>Style Issue:</b> AyeCode UI has changed its default version from v4 to v5, if you notice unwanted style changes, please revert to v4 (saving the settings page will remove this notice)')." " .$button;
846
+			    echo '<div class="notice notice-error aui-settings-error-notice"><p>'. wp_kses_post( $message ).'</p></div>';
847
+		    }
848 848
 
849
-		/**
849
+		    /**
850 850
 		 * Get the current Font Awesome output settings.
851 851
 		 *
852 852
 		 * @return array The array of settings.
853 853
 		 */
854
-		public function get_settings() {
854
+		    public function get_settings() {
855 855
 
856
-			$db_settings = get_option( 'ayecode-ui-settings' );
856
+			    $db_settings = get_option( 'ayecode-ui-settings' );
857 857
 
858
-            // Maybe show default version notice
859
-			$site_install_date = new DateTime( self::get_site_install_date() );
860
-			$switch_over_date = new DateTime("2024-02-01");
861
-			if ( empty( $db_settings ) && $site_install_date < $switch_over_date ) {
862
-				add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
863
-			}
858
+                // Maybe show default version notice
859
+			    $site_install_date = new DateTime( self::get_site_install_date() );
860
+			    $switch_over_date = new DateTime("2024-02-01");
861
+			    if ( empty( $db_settings ) && $site_install_date < $switch_over_date ) {
862
+				    add_action( 'admin_notices', array( $this, 'show_admin_version_notice' ) );
863
+			    }
864 864
 
865
-			$js_default = 'core-popper';
866
-			$js_default_backend = $js_default;
865
+			    $js_default = 'core-popper';
866
+			    $js_default_backend = $js_default;
867 867
 
868
-			// maybe set defaults (if no settings set)
869
-			if(empty($db_settings)){
870
-				$active_theme = strtolower( get_template() ); // active parent theme.
871
-				$theme_js_settings = self::theme_js_settings();
872
-				if(isset($theme_js_settings[$active_theme])){
873
-					$js_default = $theme_js_settings[$active_theme];
874
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
875
-				}
876
-			}
868
+			    // maybe set defaults (if no settings set)
869
+			    if(empty($db_settings)){
870
+				    $active_theme = strtolower( get_template() ); // active parent theme.
871
+				    $theme_js_settings = self::theme_js_settings();
872
+				    if(isset($theme_js_settings[$active_theme])){
873
+					    $js_default = $theme_js_settings[$active_theme];
874
+					    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
875
+				    }
876
+			    }
877 877
 
878
-			/**
878
+			    /**
879 879
 			 * Filter the default settings.
880 880
 			 */
881
-			$defaults = apply_filters( 'ayecode-ui-default-settings', array(
882
-				'css'            => 'compatibility', // core, compatibility
883
-				'js'             => $js_default, // js to load, core-popper, popper
884
-				'html_font_size' => '16', // js to load, core-popper, popper
885
-				'css_backend'    => 'compatibility', // core, compatibility
886
-				'js_backend'     => $js_default_backend, // js to load, core-popper, popper
887
-				'disable_admin'  => '', // URL snippets to disable loading on admin
888
-                'bs_ver'         => '5', // The default bootstrap version to sue by default
889
-			), $db_settings );
890
-
891
-			$settings = wp_parse_args( $db_settings, $defaults );
892
-
893
-			/**
881
+			    $defaults = apply_filters( 'ayecode-ui-default-settings', array(
882
+				    'css'            => 'compatibility', // core, compatibility
883
+				    'js'             => $js_default, // js to load, core-popper, popper
884
+				    'html_font_size' => '16', // js to load, core-popper, popper
885
+				    'css_backend'    => 'compatibility', // core, compatibility
886
+				    'js_backend'     => $js_default_backend, // js to load, core-popper, popper
887
+				    'disable_admin'  => '', // URL snippets to disable loading on admin
888
+                    'bs_ver'         => '5', // The default bootstrap version to sue by default
889
+			    ), $db_settings );
890
+
891
+			    $settings = wp_parse_args( $db_settings, $defaults );
892
+
893
+			    /**
894 894
 			 * Filter the Bootstrap settings.
895 895
 			 *
896 896
 			 * @todo if we add this filer people might use it and then it defeats the purpose of this class :/
897 897
 			 */
898
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
899
-		}
898
+			    return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
899
+		    }
900 900
 
901 901
 
902
-		/**
902
+		    /**
903 903
 		 * The settings page html output.
904 904
 		 */
905
-		public function settings_page() {
906
-			if ( ! current_user_can( 'manage_options' ) ) {
907
-				wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
908
-			}
909
-            $overrides = apply_filters( 'ayecode-ui-settings', array(), array(), array() );
905
+		    public function settings_page() {
906
+			    if ( ! current_user_can( 'manage_options' ) ) {
907
+				    wp_die( esc_attr__( 'You do not have sufficient permissions to access this page.', 'ayecode-connect' ) );
908
+			    }
909
+                $overrides = apply_filters( 'ayecode-ui-settings', array(), array(), array() );
910 910
 
911
-			?>
911
+			    ?>
912 912
             <div class="wrap">
913 913
                 <h1><?php echo esc_attr( $this->name ); ?></h1>
914 914
                 <p><?php echo esc_html( apply_filters( 'ayecode-ui-settings-message', __("Here you can adjust settings if you are having compatibility issues.", 'ayecode-connect' ) ) );?></p>
915 915
                 <form method="post" action="options.php">
916 916
 					<?php
917
-					settings_fields( 'ayecode-ui-settings' );
918
-					do_settings_sections( 'ayecode-ui-settings' );
919
-					?>
917
+					    settings_fields( 'ayecode-ui-settings' );
918
+					    do_settings_sections( 'ayecode-ui-settings' );
919
+					    ?>
920 920
 
921 921
                     <h2><?php esc_html_e( 'BootStrap Version', 'ayecode-connect' ); ?></h2>
922 922
                     <p><?php echo esc_html( apply_filters( 'ayecode-ui-version-settings-message', __("V5 is recommended, however if you have another plugin installed using v4, you may need to use v4 also.", 'ayecode-connect' ) ) );?></p>
923 923
 	                <div class="bsui"><?php
924
-	                if ( ! empty( $overrides ) ) {
925
-		                echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
926
-			                'type'=> 'info',
927
-			                'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
928
-		                ));
929
-	                }
930
-	                ?>
924
+	                    if ( ! empty( $overrides ) ) {
925
+		                    echo aui()->alert(array( // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
926
+			                    'type'=> 'info',
927
+			                    'content'=> esc_attr__("Some options are disabled as your current theme is overriding them.", 'ayecode-connect' )
928
+		                    ));
929
+	                    }
930
+	                    ?>
931 931
                     </div>
932 932
                     <table class="form-table wpbs-table-version-settings">
933 933
                         <tr valign="top">
@@ -1011,77 +1011,77 @@  discard block
 block discarded – undo
1011 1011
                     </table>
1012 1012
 
1013 1013
 					<?php
1014
-					submit_button();
1015
-					?>
1014
+					    submit_button();
1015
+					    ?>
1016 1016
                 </form>
1017 1017
                 <div id="wpbs-version" data-aui-source="<?php echo esc_attr( $this->get_load_source() ); ?>"><?php echo esc_html( $this->version ); ?></div>
1018 1018
             </div>
1019 1019
 			<?php
1020
-		}
1021
-
1022
-        public function get_load_source(){
1023
-	        $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1024
-	        $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1025
-
1026
-	        // Find source plugin/theme of SD
1027
-	        $source = array();
1028
-	        if ( strpos( $file, $plugins_dir ) !== false ) {
1029
-		        $source = explode( "/", plugin_basename( $file ) );
1030
-	        } else if ( function_exists( 'get_theme_root' ) ) {
1031
-		        $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1032
-
1033
-		        if ( strpos( $file, $themes_dir ) !== false ) {
1034
-			        $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1035
-		        }
1036
-	        }
1037
-
1038
-            return isset($source[0]) ? esc_attr($source[0]) : '';
1039
-        }
1040
-
1041
-		public function customizer_settings($wp_customize){
1042
-			$wp_customize->add_section('aui_settings', array(
1043
-				'title'    => __('AyeCode UI', 'ayecode-connect' ),
1044
-				'priority' => 120,
1045
-			));
1046
-
1047
-			//  =============================
1048
-			//  = Color Picker              =
1049
-			//  =============================
1050
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1051
-				'default'           => AUI_PRIMARY_COLOR,
1052
-				'sanitize_callback' => 'sanitize_hex_color',
1053
-				'capability'        => 'edit_theme_options',
1054
-				'type'              => 'option',
1055
-				'transport'         => 'refresh',
1056
-			));
1057
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1058
-				'label'    => __('Primary Color', 'ayecode-connect' ),
1059
-				'section'  => 'aui_settings',
1060
-				'settings' => 'aui_options[color_primary]',
1061
-			)));
1062
-
1063
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1064
-				'default'           => '#6c757d',
1065
-				'sanitize_callback' => 'sanitize_hex_color',
1066
-				'capability'        => 'edit_theme_options',
1067
-				'type'              => 'option',
1068
-				'transport'         => 'refresh',
1069
-			));
1070
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1071
-				'label'    => __('Secondary Color', 'ayecode-connect' ),
1072
-				'section'  => 'aui_settings',
1073
-				'settings' => 'aui_options[color_secondary]',
1074
-			)));
1075
-		}
1076
-
1077
-		/**
1020
+		    }
1021
+
1022
+            public function get_load_source(){
1023
+	            $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
1024
+	            $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
1025
+
1026
+	            // Find source plugin/theme of SD
1027
+	            $source = array();
1028
+	            if ( strpos( $file, $plugins_dir ) !== false ) {
1029
+		            $source = explode( "/", plugin_basename( $file ) );
1030
+	            } else if ( function_exists( 'get_theme_root' ) ) {
1031
+		            $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
1032
+
1033
+		            if ( strpos( $file, $themes_dir ) !== false ) {
1034
+			            $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
1035
+		            }
1036
+	            }
1037
+
1038
+                return isset($source[0]) ? esc_attr($source[0]) : '';
1039
+            }
1040
+
1041
+		    public function customizer_settings($wp_customize){
1042
+			    $wp_customize->add_section('aui_settings', array(
1043
+				    'title'    => __('AyeCode UI', 'ayecode-connect' ),
1044
+				    'priority' => 120,
1045
+			    ));
1046
+
1047
+			    //  =============================
1048
+			    //  = Color Picker              =
1049
+			    //  =============================
1050
+			    $wp_customize->add_setting('aui_options[color_primary]', array(
1051
+				    'default'           => AUI_PRIMARY_COLOR,
1052
+				    'sanitize_callback' => 'sanitize_hex_color',
1053
+				    'capability'        => 'edit_theme_options',
1054
+				    'type'              => 'option',
1055
+				    'transport'         => 'refresh',
1056
+			    ));
1057
+			    $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1058
+				    'label'    => __('Primary Color', 'ayecode-connect' ),
1059
+				    'section'  => 'aui_settings',
1060
+				    'settings' => 'aui_options[color_primary]',
1061
+			    )));
1062
+
1063
+			    $wp_customize->add_setting('aui_options[color_secondary]', array(
1064
+				    'default'           => '#6c757d',
1065
+				    'sanitize_callback' => 'sanitize_hex_color',
1066
+				    'capability'        => 'edit_theme_options',
1067
+				    'type'              => 'option',
1068
+				    'transport'         => 'refresh',
1069
+			    ));
1070
+			    $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1071
+				    'label'    => __('Secondary Color', 'ayecode-connect' ),
1072
+				    'section'  => 'aui_settings',
1073
+				    'settings' => 'aui_options[color_secondary]',
1074
+			    )));
1075
+		    }
1076
+
1077
+		    /**
1078 1078
 		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1079 1079
 		 *
1080 1080
 		 * @return mixed
1081 1081
 		 */
1082
-		public static function bs3_compat_css() {
1083
-			ob_start();
1084
-			?>
1082
+		    public static function bs3_compat_css() {
1083
+			    ob_start();
1084
+			    ?>
1085 1085
             <style>
1086 1086
                 /* Bootstrap 3 compatibility */
1087 1087
                 body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1098,7 +1098,7 @@  discard block
 block discarded – undo
1098 1098
                 /* KLEO theme specific */
1099 1099
                 .kleo-main-header .navbar-collapse.collapse.show:not(.in){display: block !important;}
1100 1100
                 <?php } ?>
1101
-
1101
+    
1102 1102
                 <?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
1103 1103
                 /* With Avada builder */
1104 1104
                 body.modal-open .modal.in  {opacity:1;z-index: 99999}
@@ -1108,248 +1108,248 @@  discard block
 block discarded – undo
1108 1108
                 .bsui .collapse.in.row:not(.show){display: none;}
1109 1109
 
1110 1110
                 <?php } ?>
1111
-            </style>
1111
+                </style>
1112 1112
 			<?php
1113
-			return str_replace( array(
1114
-				'<style>',
1115
-				'</style>'
1116
-			), '', self::minify_css( ob_get_clean() ) );
1117
-		}
1118
-
1119
-		public static function custom_css( $compatibility = true, $is_fse = false ) {
1120
-			global $aui_bs5;
1121
-
1122
-			$colors = array();
1123
-
1124
-			if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1125
-				$setting = wp_get_global_settings();
1126
-
1127
-				if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1128
-					foreach ( $setting['color']['palette']['theme'] as $color ) {
1129
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1130
-					}
1131
-				}
1132
-
1133
-				if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1134
-					foreach ( $setting['color']['palette']['custom'] as $color ) {
1135
-						$colors[$color['slug']] = esc_attr( $color['color'] );
1136
-					}
1137
-				}
1138
-			} else {
1139
-				$settings = get_option( 'aui_options' );
1140
-
1141
-				$colors = array(
1142
-					'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1143
-					'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1144
-				);
1145
-			}
1146
-
1147
-			ob_start();
1148
-			?><style><?php
1149
-			// BS v3 compat
1150
-			if( self::is_bs3_compat() ){
1151
-				echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1152
-			}
1153
-
1154
-			//$is_fse = false;
1155
-			//if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
1156
-				//$is_fse = true;
1157
-			//}
1158
-
1159
-			$custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1160
-			$custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1161
-            $bs_custom_css = apply_filters( 'ayecode_ui_bs_custom_css', $custom_admin || $custom_front );
1162
-			//$bs_custom_css = true; // Force true to fix any color issue.
1163
-
1164
-			$colors_css = '';
1165
-			if ( ! empty( $colors ) && $bs_custom_css ) {
1166
-				$d_colors = self::get_colors(true);
1167
-
1168
-				foreach ( $colors as $key => $color ) {
1169
-					if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1170
-						$var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1171
-						$compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1172
-
1173
-						$colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1174
-					}
1175
-				}
1176
-			}
1177
-
1178
-			if ( $colors_css ) {
1179
-				echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1180
-			}
1181
-
1182
-			// Set admin bar z-index lower when modal is open.
1183
-			echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1184
-
1185
-			if ( is_admin() ) {
1186
-				echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1187
-			}
1188
-
1189
-			$custom_css = '';
1190
-
1191
-			if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1192
-				$css = '';
1193
-				$theme_settings = wp_get_global_styles();
1194
-
1195
-				// Font face
1196
-				if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1197
-					$t_fontface = str_replace( array('var:preset|','font-family|'), array('--wp--preset--','font-family--'), $theme_settings['typography']['fontFamily']  ); //var(--wp--preset--font-family--poppins)
1198
-					$css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1199
-				}
1200
-
1201
-				// font size
1202
-				if( !empty( $theme_settings['typography']['fontSize'] ) ){
1203
-					$css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1204
-				}
1205
-
1206
-				// line height
1207
-				 if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1208
-					$css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1209
-				}
1210
-
1211
-
1212
-				   // font weight
1213
-				 if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1214
-					$css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1215
-				}
1216
-
1217
-				// Background
1218
-				 if( !empty( $theme_settings['color']['background'] ) ){
1219
-					$css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1220
-				}
1221
-
1222
-				 // Background Gradient
1223
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1224
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1225
-				}
1226
-
1227
-				   // Background Gradient
1228
-				 if( !empty( $theme_settings['color']['gradient'] ) ){
1229
-					$css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1230
-				}
1231
-
1232
-				// text color
1233
-				if( !empty( $theme_settings['color']['text'] ) ){
1234
-					$css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1235
-				}
1236
-
1237
-
1238
-				// link colors
1239
-				if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1240
-					$css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1241
-				}
1242
-				if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1243
-					$css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1244
-				}
1245
-
1246
-				if($css){
1247
-					$custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1248
-				}
1249
-
1250
-				$bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1251
-
1252
-				// Headings
1253
-				$headings_css = '';
1254
-				if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1255
-					$headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1256
-				}
1257
-
1258
-				// heading background
1259
-				if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1260
-					$headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1261
-				}
1262
-
1263
-				 // heading font family
1264
-				if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1265
-					$headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1266
-				}
1267
-
1268
-				if( $headings_css ){
1269
-					$custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1270
-				}
1271
-
1272
-				$hs = array('h1','h2','h3','h4','h5','h6');
1273
-
1274
-				foreach($hs as $hn){
1275
-					$h_css = '';
1276
-					 if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1277
-						$h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1278
-					 }
1279
-
1280
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1281
-						$h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1282
-					 }
1283
-
1284
-					  if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1285
-						$h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1286
-					 }
1287
-
1288
-					 if($h_css){
1289
-						$custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1290
-					 }
1291
-				}
1292
-			}
1113
+			    return str_replace( array(
1114
+				    '<style>',
1115
+				    '</style>'
1116
+			    ), '', self::minify_css( ob_get_clean() ) );
1117
+		    }
1118
+
1119
+		    public static function custom_css( $compatibility = true, $is_fse = false ) {
1120
+			    global $aui_bs5;
1121
+
1122
+			    $colors = array();
1123
+
1124
+			    if ( defined( 'BLOCKSTRAP_VERSION' ) ) {
1125
+				    $setting = wp_get_global_settings();
1126
+
1127
+				    if ( ! empty( $setting['color']['palette']['theme'] ) ) {
1128
+					    foreach ( $setting['color']['palette']['theme'] as $color ) {
1129
+						    $colors[$color['slug']] = esc_attr( $color['color'] );
1130
+					    }
1131
+				    }
1132
+
1133
+				    if ( ! empty( $setting['color']['palette']['custom'] ) ) {
1134
+					    foreach ( $setting['color']['palette']['custom'] as $color ) {
1135
+						    $colors[$color['slug']] = esc_attr( $color['color'] );
1136
+					    }
1137
+				    }
1138
+			    } else {
1139
+				    $settings = get_option( 'aui_options' );
1140
+
1141
+				    $colors = array(
1142
+					    'primary'   => ! empty( $settings['color_primary'] ) ? $settings['color_primary'] : AUI_PRIMARY_COLOR,
1143
+					    'secondary' => ! empty( $settings['color_secondary'] ) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR
1144
+				    );
1145
+			    }
1146
+
1147
+			    ob_start();
1148
+			    ?><style><?php
1149
+			    // BS v3 compat
1150
+			    if( self::is_bs3_compat() ){
1151
+				    echo self::bs3_compat_css(); //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1152
+			    }
1153
+
1154
+			    //$is_fse = false;
1155
+			    //if ( is_admin() && ( !empty($_REQUEST['postType']) || self::is_block_editor() ) && ( defined( 'BLOCKSTRAP_VERSION' ) || defined( 'AUI_FSE' ) )  ) {
1156
+				    //$is_fse = true;
1157
+			    //}
1158
+
1159
+			    $custom_front = ! is_admin() ? true : apply_filters('ayecode_ui_custom_front', false );
1160
+			    $custom_admin = $is_fse || self::is_preview() ? true : apply_filters('ayecode_ui_custom_admin', false );
1161
+                $bs_custom_css = apply_filters( 'ayecode_ui_bs_custom_css', $custom_admin || $custom_front );
1162
+			    //$bs_custom_css = true; // Force true to fix any color issue.
1163
+
1164
+			    $colors_css = '';
1165
+			    if ( ! empty( $colors ) && $bs_custom_css ) {
1166
+				    $d_colors = self::get_colors(true);
1167
+
1168
+				    foreach ( $colors as $key => $color ) {
1169
+					    if ( ( empty( $d_colors[$key]) || $d_colors[$key] != $color) || $is_fse ) {
1170
+						    $var = $is_fse ? "var(--wp--preset--color--$key)" : $color;
1171
+						    $compat = $is_fse ? '.editor-styles-wrapper' : $compatibility;
1172
+
1173
+						    $colors_css .= $aui_bs5 ? self::css_overwrite_bs5( $key,$var, $compat, $color ) : self::css_overwrite( $key, $var, $compat, $color );
1174
+					    }
1175
+				    }
1176
+			    }
1177
+
1178
+			    if ( $colors_css ) {
1179
+				    echo $colors_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1180
+			    }
1181
+
1182
+			    // Set admin bar z-index lower when modal is open.
1183
+			    echo ' body.modal-open #wpadminbar{z-index:999}.embed-responsive-16by9 .fluid-width-video-wrapper{padding:0 !important;position:initial}';
1184
+
1185
+			    if ( is_admin() ) {
1186
+				    echo ' body.modal-open #adminmenuwrap{z-index:999} body.modal-open #wpadminbar{z-index:1025}';
1187
+			    }
1188
+
1189
+			    $custom_css = '';
1190
+
1191
+			    if ( $aui_bs5 && defined( 'BLOCKSTRAP_VERSION' ) && $bs_custom_css ) {
1192
+				    $css = '';
1193
+				    $theme_settings = wp_get_global_styles();
1194
+
1195
+				    // Font face
1196
+				    if( !empty( $theme_settings['typography']['fontFamily'] ) ){
1197
+					    $t_fontface = str_replace( array('var:preset|','font-family|'), array('--wp--preset--','font-family--'), $theme_settings['typography']['fontFamily']  ); //var(--wp--preset--font-family--poppins)
1198
+					    $css .= '--bs-body-font-family: ' . esc_attr($t_fontface) . ';';
1199
+				    }
1200
+
1201
+				    // font size
1202
+				    if( !empty( $theme_settings['typography']['fontSize'] ) ){
1203
+					    $css .= '--bs-body-font-size: ' . esc_attr( $theme_settings['typography']['fontSize'] ) . ' ;';
1204
+				    }
1205
+
1206
+				    // line height
1207
+				     if( !empty( $theme_settings['typography']['lineHeight'] ) ){
1208
+					    $css .= '--bs-body-line-height: ' . esc_attr( $theme_settings['typography']['lineHeight'] ) . ';';
1209
+				    }
1210
+
1211
+
1212
+				       // font weight
1213
+				     if( !empty( $theme_settings['typography']['fontWeight'] ) ){
1214
+					    $css .= '--bs-body-font-weight: ' . esc_attr( $theme_settings['typography']['fontWeight'] ) . ';';
1215
+				    }
1216
+
1217
+				    // Background
1218
+				     if( !empty( $theme_settings['color']['background'] ) ){
1219
+					    $css .= '--bs-body-bg: ' . esc_attr( $theme_settings['color']['background'] ) . ';';
1220
+				    }
1221
+
1222
+				     // Background Gradient
1223
+				     if( !empty( $theme_settings['color']['gradient'] ) ){
1224
+					    $css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1225
+				    }
1226
+
1227
+				       // Background Gradient
1228
+				     if( !empty( $theme_settings['color']['gradient'] ) ){
1229
+					    $css .= 'background: ' . esc_attr( $theme_settings['color']['gradient'] ) . ';';
1230
+				    }
1231
+
1232
+				    // text color
1233
+				    if( !empty( $theme_settings['color']['text'] ) ){
1234
+					    $css .= '--bs-body-color: ' . esc_attr( $theme_settings['color']['text'] ) . ';';
1235
+				    }
1236
+
1237
+
1238
+				    // link colors
1239
+				    if( !empty( $theme_settings['elements']['link']['color']['text'] ) ){
1240
+					    $css .= '--bs-link-color: ' . esc_attr( $theme_settings['elements']['link']['color']['text'] ) . ';';
1241
+				    }
1242
+				    if( !empty( $theme_settings['elements']['link'][':hover']['color']['text'] ) ){
1243
+					    $css .= '--bs-link-hover-color: ' . esc_attr( $theme_settings['elements']['link'][':hover']['color']['text'] ) . ';';
1244
+				    }
1245
+
1246
+				    if($css){
1247
+					    $custom_css .= $is_fse ? 'body.editor-styles-wrapper{' . esc_attr( $css ) . '}' : 'body{' . esc_attr( $css ) . '}';
1248
+				    }
1249
+
1250
+				    $bep = $is_fse ? 'body.editor-styles-wrapper ' : '';
1251
+
1252
+				    // Headings
1253
+				    $headings_css = '';
1254
+				    if( !empty( $theme_settings['elements']['heading']['color']['text'] ) ){
1255
+					    $headings_css .= "color: " . esc_attr( $theme_settings['elements']['heading']['color']['text'] ) . ";";
1256
+				    }
1257
+
1258
+				    // heading background
1259
+				    if( !empty( $theme_settings['elements']['heading']['color']['background'] ) ){
1260
+					    $headings_css .= 'background: ' . esc_attr( $theme_settings['elements']['heading']['color']['background'] ) . ';';
1261
+				    }
1262
+
1263
+				     // heading font family
1264
+				    if( !empty( $theme_settings['elements']['heading']['typography']['fontFamily'] ) ){
1265
+					    $headings_css .= 'font-family: ' . esc_attr( $theme_settings['elements']['heading']['typography']['fontFamily']  ) . ';';
1266
+				    }
1267
+
1268
+				    if( $headings_css ){
1269
+					    $custom_css .= "$bep h1,$bep h2,$bep h3, $bep h4,$bep h5,$bep h6{ " . esc_attr( $headings_css ) . "}";
1270
+				    }
1271
+
1272
+				    $hs = array('h1','h2','h3','h4','h5','h6');
1273
+
1274
+				    foreach($hs as $hn){
1275
+					    $h_css = '';
1276
+					     if( !empty( $theme_settings['elements'][$hn]['color']['text'] ) ){
1277
+						    $h_css .= 'color: ' . esc_attr( $theme_settings['elements'][$hn]['color']['text'] ) . ';';
1278
+					     }
1279
+
1280
+					      if( !empty( $theme_settings['elements'][$hn]['typography']['fontSize'] ) ){
1281
+						    $h_css .= 'font-size: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontSize']  ) . ';';
1282
+					     }
1283
+
1284
+					      if( !empty( $theme_settings['elements'][$hn]['typography']['fontFamily'] ) ){
1285
+						    $h_css .= 'font-family: ' . esc_attr( $theme_settings['elements'][$hn]['typography']['fontFamily']  ) . ';';
1286
+					     }
1287
+
1288
+					     if($h_css){
1289
+						    $custom_css .= esc_attr( $bep  . $hn ) . '{'.esc_attr( $h_css ).'}';
1290
+					     }
1291
+				    }
1292
+			    }
1293 1293
 			
1294
-			if ( $custom_css ) {
1295
-				echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1296
-			}
1297
-
1298
-			// Pagination on Hello Elementor theme.
1299
-			if ( function_exists( 'hello_elementor_setup' ) ) {
1300
-				echo '.aui-nav-links .pagination{justify-content:inherit}';
1301
-			}
1302
-			?></style><?php
1303
-			$custom_css = ob_get_clean();
1304
-
1305
-			/*
1294
+			    if ( $custom_css ) {
1295
+				    echo $custom_css; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
1296
+			    }
1297
+
1298
+			    // Pagination on Hello Elementor theme.
1299
+			    if ( function_exists( 'hello_elementor_setup' ) ) {
1300
+				    echo '.aui-nav-links .pagination{justify-content:inherit}';
1301
+			    }
1302
+			    ?></style><?php
1303
+			    $custom_css = ob_get_clean();
1304
+
1305
+			    /*
1306 1306
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1307 1307
 			 */
1308
-			return str_replace( array(
1309
-				'<style>',
1310
-				'</style>'
1311
-			), '', self::minify_css( $custom_css ) );
1312
-		}
1308
+			    return str_replace( array(
1309
+				    '<style>',
1310
+				    '</style>'
1311
+			    ), '', self::minify_css( $custom_css ) );
1312
+		    }
1313 1313
 
1314
-		/**
1314
+		    /**
1315 1315
 		 * Check if we should add booststrap 3 compatibility changes.
1316 1316
 		 *
1317 1317
 		 * @return bool
1318 1318
 		 */
1319
-		public static function is_bs3_compat(){
1320
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1321
-		}
1319
+		    public static function is_bs3_compat(){
1320
+			    return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1321
+		    }
1322 1322
 
1323
-		public static function hex_to_rgb( $hex ) {
1324
-			// Remove '#' if present
1325
-			$hex = str_replace( '#', '', $hex );
1323
+		    public static function hex_to_rgb( $hex ) {
1324
+			    // Remove '#' if present
1325
+			    $hex = str_replace( '#', '', $hex );
1326 1326
 
1327
-			// Check if input is RGB
1328
-			if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1329
-				$_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1327
+			    // Check if input is RGB
1328
+			    if ( strpos( $hex, 'rgba(' ) === 0 || strpos( $hex, 'rgb(' ) === 0 ) {
1329
+				    $_rgb = explode( ',', str_replace( array( 'rgba(', 'rgb(', ')' ), '', $hex ) );
1330 1330
 
1331
-				$rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1332
-				$rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1333
-				$rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1331
+				    $rgb = ( isset( $_rgb[0] ) ? (int) trim( $_rgb[0] ) : '0' ) . ',';
1332
+				    $rgb .= ( isset( $_rgb[1] ) ? (int) trim( $_rgb[1] ) : '0' ) . ',';
1333
+				    $rgb .= ( isset( $_rgb[2] ) ? (int) trim( $_rgb[2] ) : '0' );
1334 1334
 
1335
-				return $rgb;
1336
-			}
1335
+				    return $rgb;
1336
+			    }
1337 1337
 
1338
-			// Convert 3-digit hex to 6-digit hex
1339
-			if ( strlen( $hex ) == 3 ) {
1340
-				$hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1341
-			}
1338
+			    // Convert 3-digit hex to 6-digit hex
1339
+			    if ( strlen( $hex ) == 3 ) {
1340
+				    $hex = str_repeat( substr( $hex, 0, 1 ), 2 ) . str_repeat( substr( $hex, 1, 1 ), 2 ) . str_repeat( substr( $hex, 2, 1 ), 2 );
1341
+			    }
1342 1342
 
1343
-			// Convert hex to RGB
1344
-			$r = hexdec( substr( $hex, 0, 2 ) );
1345
-			$g = hexdec( substr( $hex, 2, 2 ) );
1346
-			$b = hexdec( substr( $hex, 4, 2 ) );
1343
+			    // Convert hex to RGB
1344
+			    $r = hexdec( substr( $hex, 0, 2 ) );
1345
+			    $g = hexdec( substr( $hex, 2, 2 ) );
1346
+			    $b = hexdec( substr( $hex, 4, 2 ) );
1347 1347
 
1348
-			// Return RGB values as an array
1349
-			return $r . ',' . $g . ',' . $b;
1350
-		}
1348
+			    // Return RGB values as an array
1349
+			    return $r . ',' . $g . ',' . $b;
1350
+		    }
1351 1351
 
1352
-		/**
1352
+		    /**
1353 1353
 		 * Build the CSS to overwrite a bootstrap color variable.
1354 1354
 		 *
1355 1355
 		 * @param $type
@@ -1358,120 +1358,120 @@  discard block
 block discarded – undo
1358 1358
 		 *
1359 1359
 		 * @return string
1360 1360
 		 */
1361
-		public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1362
-			global $aui_bs5;
1361
+		    public static function css_overwrite_bs5($type,$color_code,$compatibility, $hex = '' ){
1362
+			    global $aui_bs5;
1363 1363
 
1364
-			$is_var = false;
1365
-			$is_custom = strpos($type, 'custom-') !== false ? true : false;
1366
-			if(!$color_code){return '';}
1367
-			if(strpos($color_code, 'var') !== false){
1368
-				//if(!sanitize_hex_color($color_code)){
1369
-				$color_code = esc_attr($color_code);
1370
-				$is_var = true;
1371
-//				$color_code = "rgba($color_code, 0.5)";
1372
-//                echo '###1'.$color_code.'###';//exit;
1373
-			}
1364
+			    $is_var = false;
1365
+			    $is_custom = strpos($type, 'custom-') !== false ? true : false;
1366
+			    if(!$color_code){return '';}
1367
+			    if(strpos($color_code, 'var') !== false){
1368
+				    //if(!sanitize_hex_color($color_code)){
1369
+				    $color_code = esc_attr($color_code);
1370
+				    $is_var = true;
1371
+    //				$color_code = "rgba($color_code, 0.5)";
1372
+    //                echo '###1'.$color_code.'###';//exit;
1373
+			    }
1374 1374
 
1375
-//            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1375
+    //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1376 1376
 
1377
-			if(!$color_code){return '';}
1377
+			    if(!$color_code){return '';}
1378 1378
 
1379
-			$rgb = self::hex_to_rgb($hex);
1379
+			    $rgb = self::hex_to_rgb($hex);
1380 1380
 
1381
-			if($compatibility===true || $compatibility===1){
1382
-				$compatibility = '.bsui';
1383
-			}elseif(!$compatibility){
1384
-				$compatibility = '';
1385
-			}else{
1386
-				$compatibility = esc_attr($compatibility);
1387
-			}
1381
+			    if($compatibility===true || $compatibility===1){
1382
+				    $compatibility = '.bsui';
1383
+			    }elseif(!$compatibility){
1384
+				    $compatibility = '';
1385
+			    }else{
1386
+				    $compatibility = esc_attr($compatibility);
1387
+			    }
1388 1388
 
1389
-			$prefix = $compatibility ? $compatibility . " " : "";
1389
+			    $prefix = $compatibility ? $compatibility . " " : "";
1390 1390
 
1391 1391
 
1392
-            $output = '';
1392
+                $output = '';
1393 1393
 
1394
-//            echo '####'.$color_code;exit;
1394
+    //            echo '####'.$color_code;exit;
1395 1395
 
1396
-			$type = sanitize_html_class($type);
1396
+			    $type = sanitize_html_class($type);
1397 1397
 
1398
-			/**
1398
+			    /**
1399 1399
 			 * c = color, b = background color, o = border-color, f = fill
1400 1400
 			 */
1401
-			$selectors = array(
1402
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1403
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1404
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1405
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1406
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1407
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1408
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1409
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1410
-				".badge-{$type}"                                            => array( 'b' ),
1411
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1412
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1413
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1414
-				".text-{$type}"                                     => array( 'c' ),
1415
-			);
1416
-
1417
-			if ( $aui_bs5 ) {
1418
-				unset($selectors[".alert-{$type}" ]);
1419
-			}
1420
-
1421
-			if ( $type == 'primary' ) {
1422
-				$selectors = $selectors + array(
1423
-						'a'                                                                                                    => array( 'c' ),
1424
-						'.btn-link'                                                                                            => array( 'c' ),
1425
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1426
-						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1427
-							'b',
1428
-							'o'
1429
-						),
1430
-						'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1431
-							'b',
1432
-							'o'
1433
-						),
1434
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1435
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1436
-						'.page-link'                                                                                           => array( 'c' ),
1437
-						'.page-item.active .page-link'                                                                         => array(
1438
-							'b',
1439
-							'o'
1440
-						),
1441
-						'.progress-bar'                                                                                        => array( 'b' ),
1442
-						'.list-group-item.active'                                                                              => array(
1443
-							'b',
1444
-							'o'
1445
-						),
1446
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1447
-					);
1448
-			}
1449
-
1450
-
1451
-
1452
-            // link
1453
-			if ( $type === 'primary' ) {
1454
-				$output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1455
-				$output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1456
-				$output .= $prefix . ' .navbar { --bs-nav-link-hover-color: '.esc_attr($color_code).'; --bs-navbar-hover-color: '.esc_attr($color_code).'; --bs-navbar-active-color: '.esc_attr($color_code).'; }';
1457
-
1458
-				$output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1459
-				$output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1460
-
1461
-                // dropdown
1462
-				$output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1463
-
1464
-                // pagination
1465
-				$output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1466
-
1467
-			}
1468
-
1469
-			$output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1470
-			$output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1471
-
1472
-			//  buttons
1473
-			$output .= $prefix . ' .btn-'.esc_attr($type).'{';
1474
-			$output .= ' 
1401
+			    $selectors = array(
1402
+				    ".btn-{$type}"                                              => array( 'b', 'o' ),
1403
+				    ".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1404
+				    ".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1405
+				    ".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1406
+				    ".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1407
+				    ".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1408
+				    ".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1409
+				    ".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1410
+				    ".badge-{$type}"                                            => array( 'b' ),
1411
+				    ".alert-{$type}"                                            => array( 'b', 'o' ),
1412
+				    ".bg-{$type}"                                               => array( 'b', 'f' ),
1413
+				    ".btn-link.btn-{$type}"                                     => array( 'c' ),
1414
+				    ".text-{$type}"                                     => array( 'c' ),
1415
+			    );
1416
+
1417
+			    if ( $aui_bs5 ) {
1418
+				    unset($selectors[".alert-{$type}" ]);
1419
+			    }
1420
+
1421
+			    if ( $type == 'primary' ) {
1422
+				    $selectors = $selectors + array(
1423
+						    'a'                                                                                                    => array( 'c' ),
1424
+						    '.btn-link'                                                                                            => array( 'c' ),
1425
+						    '.dropdown-item.active'                                                                                => array( 'b' ),
1426
+						    '.custom-control-input:checked~.custom-control-label::before'                                          => array(
1427
+							    'b',
1428
+							    'o'
1429
+						    ),
1430
+						    '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1431
+							    'b',
1432
+							    'o'
1433
+						    ),
1434
+						    '.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1435
+						    '.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1436
+						    '.page-link'                                                                                           => array( 'c' ),
1437
+						    '.page-item.active .page-link'                                                                         => array(
1438
+							    'b',
1439
+							    'o'
1440
+						    ),
1441
+						    '.progress-bar'                                                                                        => array( 'b' ),
1442
+						    '.list-group-item.active'                                                                              => array(
1443
+							    'b',
1444
+							    'o'
1445
+						    ),
1446
+						    '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1447
+					    );
1448
+			    }
1449
+
1450
+
1451
+
1452
+                // link
1453
+			    if ( $type === 'primary' ) {
1454
+				    $output .= 'html body {--bs-link-hover-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .75); --bs-link-color: var(--bs-'.esc_attr($type).'); }';
1455
+				    $output .= $prefix . ' .breadcrumb{--bs-breadcrumb-item-active-color: '.esc_attr($color_code).';  }';
1456
+				    $output .= $prefix . ' .navbar { --bs-nav-link-hover-color: '.esc_attr($color_code).'; --bs-navbar-hover-color: '.esc_attr($color_code).'; --bs-navbar-active-color: '.esc_attr($color_code).'; }';
1457
+
1458
+				    $output .= $prefix . ' a{color: var(--bs-'.esc_attr($type).');}';
1459
+				    $output .= $prefix . ' .text-primary{color: var(--bs-'.esc_attr($type).') !important;}';
1460
+
1461
+                    // dropdown
1462
+				    $output .= $prefix . ' .dropdown-menu{--bs-dropdown-link-hover-color: var(--bs-'.esc_attr($type).'); --bs-dropdown-link-active-color: var(--bs-'.esc_attr($type).');}';
1463
+
1464
+                    // pagination
1465
+				    $output .= $prefix . ' .pagination{--bs-pagination-hover-color: var(--bs-'.esc_attr($type).'); --bs-pagination-active-bg: var(--bs-'.esc_attr($type).');}';
1466
+
1467
+			    }
1468
+
1469
+			    $output .= $prefix . ' .link-'.esc_attr($type).' {color: var(--bs-'.esc_attr($type).'-rgb) !important;}';
1470
+			    $output .= $prefix . ' .link-'.esc_attr($type).':hover {color: rgba(var(--bs-'.esc_attr($type).'-rgb), .8) !important;}';
1471
+
1472
+			    //  buttons
1473
+			    $output .= $prefix . ' .btn-'.esc_attr($type).'{';
1474
+			    $output .= ' 
1475 1475
             --bs-btn-bg: '.esc_attr($color_code).';
1476 1476
             --bs-btn-border-color: '.esc_attr($color_code).';
1477 1477
             --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
@@ -1483,17 +1483,17 @@  discard block
 block discarded – undo
1483 1483
             --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .5);
1484 1484
             --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .1);
1485 1485
             ';
1486
-//			$output .= '
1487
-//		    --bs-btn-color: #fff;
1488
-//			--bs-btn-hover-color: #fff;
1489
-//			--bs-btn-active-color: #fff;
1490
-//			--bs-btn-disabled-color: #fff;
1491
-//            ';
1492
-			$output .= '}';
1493
-
1494
-			//  buttons outline
1495
-			$output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1496
-			$output .= ' 
1486
+    //			$output .= '
1487
+    //		    --bs-btn-color: #fff;
1488
+    //			--bs-btn-hover-color: #fff;
1489
+    //			--bs-btn-active-color: #fff;
1490
+    //			--bs-btn-disabled-color: #fff;
1491
+    //            ';
1492
+			    $output .= '}';
1493
+
1494
+			    //  buttons outline
1495
+			    $output .= $prefix . ' .btn-outline-'.esc_attr($type).'{';
1496
+			    $output .= ' 
1497 1497
 			--bs-btn-color: '.esc_attr($color_code).';
1498 1498
             --bs-btn-border-color: '.esc_attr($color_code).';
1499 1499
             --bs-btn-hover-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .9);
@@ -1505,140 +1505,140 @@  discard block
 block discarded – undo
1505 1505
             --bs-btn-disabled-bg: rgba(var(--bs-'.esc_attr($type).'-rgb), .5);
1506 1506
             --bs-btn-disabled-border-color: rgba(var(--bs-'.esc_attr($type).'-rgb), .1);
1507 1507
             ';
1508
-//			$output .= '
1509
-//		    --bs-btn-color: #fff;
1510
-//			--bs-btn-hover-color: #fff;
1511
-//			--bs-btn-active-color: #fff;
1512
-//			--bs-btn-disabled-color: #fff;
1513
-//            ';
1514
-			$output .= '}';
1515
-
1516
-
1517
-            // button hover
1518
-			$output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1519
-			$output .= ' 
1508
+    //			$output .= '
1509
+    //		    --bs-btn-color: #fff;
1510
+    //			--bs-btn-hover-color: #fff;
1511
+    //			--bs-btn-active-color: #fff;
1512
+    //			--bs-btn-disabled-color: #fff;
1513
+    //            ';
1514
+			    $output .= '}';
1515
+
1516
+
1517
+                // button hover
1518
+			    $output .= $prefix . ' .btn-'.esc_attr($type).':hover{';
1519
+			    $output .= ' 
1520 1520
             box-shadow: 0 0.25rem 0.25rem 0.125rem rgb(var(--bs-'.esc_attr($type).'-rgb), .1), 0 0.375rem 0.75rem -0.125rem rgb(var(--bs-'.esc_attr($type).'-rgb) , .4);
1521 1521
             }
1522 1522
             ';
1523 1523
 
1524 1524
 
1525
-			if ( $aui_bs5 ) {
1526
-//				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1527
-				$output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1528
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1529
-			}
1530
-
1531
-
1532
-			if ( $is_custom ) {
1533
-
1534
-//				echo '###'.$type;exit;
1535
-
1536
-				// build rules into each type
1537
-				foreach($selectors as $selector => $types){
1538
-					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1539
-					$types = array_combine($types,$types);
1540
-					if(isset($types['c'])){$color[] = $selector;}
1541
-					if(isset($types['b'])){$background[] = $selector;}
1542
-					if(isset($types['o'])){$border[] = $selector;}
1543
-					if(isset($types['f'])){$fill[] = $selector;}
1544
-				}
1545
-
1546
-//				// build rules into each type
1547
-//				foreach($important_selectors as $selector => $types){
1548
-//					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1549
-//					$types = array_combine($types,$types);
1550
-//					if(isset($types['c'])){$color_i[] = $selector;}
1551
-//					if(isset($types['b'])){$background_i[] = $selector;}
1552
-//					if(isset($types['o'])){$border_i[] = $selector;}
1553
-//					if(isset($types['f'])){$fill_i[] = $selector;}
1554
-//				}
1555
-
1556
-				// add any color rules
1557
-				if(!empty($color)){
1558
-					$output .= implode(",",$color) . "{color: $color_code;} ";
1559
-				}
1560
-				if(!empty($color_i)){
1561
-					$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1562
-				}
1563
-
1564
-				// add any background color rules
1565
-				if(!empty($background)){
1566
-					$output .= implode(",",$background) . "{background-color: $color_code;} ";
1567
-				}
1568
-				if(!empty($background_i)){
1569
-					$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1570
-//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1571
-				}
1572
-
1573
-				// add any border color rules
1574
-				if(!empty($border)){
1575
-					$output .= implode(",",$border) . "{border-color: $color_code;} ";
1576
-				}
1577
-				if(!empty($border_i)){
1578
-					$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1579
-				}
1580
-
1581
-				// add any fill color rules
1582
-				if(!empty($fill)){
1583
-					$output .= implode(",",$fill) . "{fill: $color_code;} ";
1584
-				}
1585
-				if(!empty($fill_i)){
1586
-					$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1587
-				}
1588
-
1589
-			}
1590
-
1591
-
1592
-
1593
-
1594
-			$transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1595
-			// darken
1596
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1597
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1598
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1599
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1600
-
1601
-			// lighten
1602
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1603
-
1604
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1605
-			$op_25 = $color_code."40"; // 25% opacity
1606
-
1607
-
1608
-			// button states
1609
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1610
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1611
-//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1612
-			$output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1613
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1614
-            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1615
-            $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled):focus {box-shadow: 0 0.25rem 0.25rem 0.125rem rgba(var(--bs-{$type}-rgb), 0.1), 0 0.375rem 0.75rem -0.125rem rgba(var(--bs-{$type}-rgb), 0.4);} ";
1616
-
1617
-			// text
1618
-//			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
1619
-
1620
-
1621
-//			if ( $type == 'primary' ) {
1622
-//				// dropdown's
1623
-//				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1624
-//
1625
-//				// input states
1626
-//				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1627
-//
1628
-//				// page link
1629
-//				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1630
-//			}
1631
-
1632
-			// alerts
1633
-			if ( $aui_bs5 ) {
1634
-//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1635
-				$output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1636
-			}
1637
-
1638
-			return $output;
1639
-		}
1640
-
1641
-		/**
1525
+			    if ( $aui_bs5 ) {
1526
+    //				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1527
+				    $output .= 'html body {--bs-'.esc_attr($type).': '.esc_attr($color_code).'; }';
1528
+				    $output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1529
+			    }
1530
+
1531
+
1532
+			    if ( $is_custom ) {
1533
+
1534
+    //				echo '###'.$type;exit;
1535
+
1536
+				    // build rules into each type
1537
+				    foreach($selectors as $selector => $types){
1538
+					    $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1539
+					    $types = array_combine($types,$types);
1540
+					    if(isset($types['c'])){$color[] = $selector;}
1541
+					    if(isset($types['b'])){$background[] = $selector;}
1542
+					    if(isset($types['o'])){$border[] = $selector;}
1543
+					    if(isset($types['f'])){$fill[] = $selector;}
1544
+				    }
1545
+
1546
+    //				// build rules into each type
1547
+    //				foreach($important_selectors as $selector => $types){
1548
+    //					$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1549
+    //					$types = array_combine($types,$types);
1550
+    //					if(isset($types['c'])){$color_i[] = $selector;}
1551
+    //					if(isset($types['b'])){$background_i[] = $selector;}
1552
+    //					if(isset($types['o'])){$border_i[] = $selector;}
1553
+    //					if(isset($types['f'])){$fill_i[] = $selector;}
1554
+    //				}
1555
+
1556
+				    // add any color rules
1557
+				    if(!empty($color)){
1558
+					    $output .= implode(",",$color) . "{color: $color_code;} ";
1559
+				    }
1560
+				    if(!empty($color_i)){
1561
+					    $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1562
+				    }
1563
+
1564
+				    // add any background color rules
1565
+				    if(!empty($background)){
1566
+					    $output .= implode(",",$background) . "{background-color: $color_code;} ";
1567
+				    }
1568
+				    if(!empty($background_i)){
1569
+					    $output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1570
+    //				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1571
+				    }
1572
+
1573
+				    // add any border color rules
1574
+				    if(!empty($border)){
1575
+					    $output .= implode(",",$border) . "{border-color: $color_code;} ";
1576
+				    }
1577
+				    if(!empty($border_i)){
1578
+					    $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1579
+				    }
1580
+
1581
+				    // add any fill color rules
1582
+				    if(!empty($fill)){
1583
+					    $output .= implode(",",$fill) . "{fill: $color_code;} ";
1584
+				    }
1585
+				    if(!empty($fill_i)){
1586
+					    $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1587
+				    }
1588
+
1589
+			    }
1590
+
1591
+
1592
+
1593
+
1594
+			    $transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1595
+			    // darken
1596
+			    $darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1597
+			    $darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1598
+			    $darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1599
+			    $darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1600
+
1601
+			    // lighten
1602
+			    $lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1603
+
1604
+			    // opacity see https://css-tricks.com/8-digit-hex-codes/
1605
+			    $op_25 = $color_code."40"; // 25% opacity
1606
+
1607
+
1608
+			    // button states
1609
+			    $output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1610
+			    $output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1611
+    //			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1612
+			    $output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1613
+			    $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1614
+                $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1615
+                $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled):focus {box-shadow: 0 0.25rem 0.25rem 0.125rem rgba(var(--bs-{$type}-rgb), 0.1), 0 0.375rem 0.75rem -0.125rem rgba(var(--bs-{$type}-rgb), 0.4);} ";
1616
+
1617
+			    // text
1618
+    //			$output .= $prefix .".xxx, .text-{$type} {color: var(--bs-".esc_attr($type).");} ";
1619
+
1620
+
1621
+    //			if ( $type == 'primary' ) {
1622
+    //				// dropdown's
1623
+    //				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1624
+    //
1625
+    //				// input states
1626
+    //				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1627
+    //
1628
+    //				// page link
1629
+    //				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1630
+    //			}
1631
+
1632
+			    // alerts
1633
+			    if ( $aui_bs5 ) {
1634
+    //				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1635
+				    $output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1636
+			    }
1637
+
1638
+			    return $output;
1639
+		    }
1640
+
1641
+		    /**
1642 1642
 		 * Build the CSS to overwrite a bootstrap color variable.
1643 1643
 		 *
1644 1644
 		 * @param $type
@@ -1647,214 +1647,214 @@  discard block
 block discarded – undo
1647 1647
 		 *
1648 1648
 		 * @return string
1649 1649
 		 */
1650
-		public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1651
-            global $aui_bs5;
1650
+		    public static function css_overwrite($type,$color_code,$compatibility, $hex = '' ){
1651
+                global $aui_bs5;
1652 1652
 
1653
-			$is_var = false;
1654
-			if(!$color_code){return '';}
1655
-			if(strpos($color_code, 'var') !== false){
1656
-				//if(!sanitize_hex_color($color_code)){
1657
-				$color_code = esc_attr($color_code);
1658
-				$is_var = true;
1659
-//				$color_code = "rgba($color_code, 0.5)";
1660
-//                echo '###1'.$color_code.'###';//exit;
1661
-			}
1653
+			    $is_var = false;
1654
+			    if(!$color_code){return '';}
1655
+			    if(strpos($color_code, 'var') !== false){
1656
+				    //if(!sanitize_hex_color($color_code)){
1657
+				    $color_code = esc_attr($color_code);
1658
+				    $is_var = true;
1659
+    //				$color_code = "rgba($color_code, 0.5)";
1660
+    //                echo '###1'.$color_code.'###';//exit;
1661
+			    }
1662 1662
 
1663
-//            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1663
+    //            echo '@@@'.$color_code.'==='.self::hex_to_rgb($color_code);exit;
1664 1664
 
1665
-			if(!$color_code){return '';}
1665
+			    if(!$color_code){return '';}
1666 1666
 
1667
-            $rgb = self::hex_to_rgb($hex);
1667
+                $rgb = self::hex_to_rgb($hex);
1668 1668
 
1669
-			if($compatibility===true || $compatibility===1){
1670
-				$compatibility = '.bsui';
1671
-			}elseif(!$compatibility){
1672
-				$compatibility = '';
1673
-			}else{
1674
-				$compatibility = esc_attr($compatibility);
1675
-			}
1669
+			    if($compatibility===true || $compatibility===1){
1670
+				    $compatibility = '.bsui';
1671
+			    }elseif(!$compatibility){
1672
+				    $compatibility = '';
1673
+			    }else{
1674
+				    $compatibility = esc_attr($compatibility);
1675
+			    }
1676 1676
 
1677 1677
 
1678 1678
 
1679
-//            echo '####'.$color_code;exit;
1679
+    //            echo '####'.$color_code;exit;
1680 1680
 
1681
-			$type = sanitize_html_class($type);
1681
+			    $type = sanitize_html_class($type);
1682 1682
 
1683
-			/**
1683
+			    /**
1684 1684
 			 * c = color, b = background color, o = border-color, f = fill
1685 1685
 			 */
1686
-			$selectors = array(
1687
-				".btn-{$type}"                                              => array( 'b', 'o' ),
1688
-				".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1689
-				".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1690
-				".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1691
-				".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1692
-				".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1693
-				".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1694
-				".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1695
-				".badge-{$type}"                                            => array( 'b' ),
1696
-				".alert-{$type}"                                            => array( 'b', 'o' ),
1697
-				".bg-{$type}"                                               => array( 'b', 'f' ),
1698
-				".btn-link.btn-{$type}"                                     => array( 'c' ),
1699
-			);
1700
-
1701
-			if ( $aui_bs5 ) {
1702
-                unset($selectors[".alert-{$type}" ]);
1703
-			}
1704
-
1705
-			if ( $type == 'primary' ) {
1706
-				$selectors = $selectors + array(
1707
-						'a'                                                                                                    => array( 'c' ),
1708
-						'.btn-link'                                                                                            => array( 'c' ),
1709
-						'.dropdown-item.active'                                                                                => array( 'b' ),
1710
-						'.custom-control-input:checked~.custom-control-label::before'                                          => array(
1711
-							'b',
1712
-							'o'
1713
-						),
1714
-						'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1715
-							'b',
1716
-							'o'
1717
-						),
1718
-						'.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1719
-						'.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1720
-						'.page-link'                                                                                           => array( 'c' ),
1721
-						'.page-item.active .page-link'                                                                         => array(
1722
-							'b',
1723
-							'o'
1724
-						),
1725
-						'.progress-bar'                                                                                        => array( 'b' ),
1726
-						'.list-group-item.active'                                                                              => array(
1727
-							'b',
1728
-							'o'
1729
-						),
1730
-						'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1731
-//				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1732
-//				    '.custom-range::-moz-range-thumb' => array('b'),
1733
-//				    '.custom-range::-ms-thumb' => array('b'),
1734
-					);
1735
-			}
1736
-
1737
-			$important_selectors = array(
1738
-				".bg-{$type}" => array('b','f'),
1739
-				".border-{$type}" => array('o'),
1740
-				".text-{$type}" => array('c'),
1741
-			);
1742
-
1743
-			$color = array();
1744
-			$color_i = array();
1745
-			$background = array();
1746
-			$background_i = array();
1747
-			$border = array();
1748
-			$border_i = array();
1749
-			$fill = array();
1750
-			$fill_i = array();
1751
-
1752
-			$output = '';
1753
-
1754
-			if ( $aui_bs5 ) {
1755
-//				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1756
-				$output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1757
-			}
1758
-
1759
-			// build rules into each type
1760
-			foreach($selectors as $selector => $types){
1761
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1762
-				$types = array_combine($types,$types);
1763
-				if(isset($types['c'])){$color[] = $selector;}
1764
-				if(isset($types['b'])){$background[] = $selector;}
1765
-				if(isset($types['o'])){$border[] = $selector;}
1766
-				if(isset($types['f'])){$fill[] = $selector;}
1767
-			}
1768
-
1769
-			// build rules into each type
1770
-			foreach($important_selectors as $selector => $types){
1771
-				$selector = $compatibility ? $compatibility . " ".$selector : $selector;
1772
-				$types = array_combine($types,$types);
1773
-				if(isset($types['c'])){$color_i[] = $selector;}
1774
-				if(isset($types['b'])){$background_i[] = $selector;}
1775
-				if(isset($types['o'])){$border_i[] = $selector;}
1776
-				if(isset($types['f'])){$fill_i[] = $selector;}
1777
-			}
1778
-
1779
-			// add any color rules
1780
-			if(!empty($color)){
1781
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1782
-			}
1783
-			if(!empty($color_i)){
1784
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1785
-			}
1786
-
1787
-			// add any background color rules
1788
-			if(!empty($background)){
1789
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1790
-			}
1791
-			if(!empty($background_i)){
1792
-				$output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1793
-//				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1794
-			}
1795
-
1796
-			// add any border color rules
1797
-			if(!empty($border)){
1798
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1799
-			}
1800
-			if(!empty($border_i)){
1801
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1802
-			}
1803
-
1804
-			// add any fill color rules
1805
-			if(!empty($fill)){
1806
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1807
-			}
1808
-			if(!empty($fill_i)){
1809
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1810
-			}
1811
-
1812
-
1813
-			$prefix = $compatibility ? $compatibility . " " : "";
1814
-
1815
-			$transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1816
-			// darken
1817
-			$darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1818
-			$darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1819
-			$darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1820
-			$darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1821
-
1822
-			// lighten
1823
-			$lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1824
-
1825
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1826
-			$op_25 = $color_code."40"; // 25% opacity
1827
-
1828
-
1829
-			// button states
1830
-			$output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1831
-			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1832
-//			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1833
-			$output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1834
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1835
-			$output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1836
-
1837
-			if ( $type == 'primary' ) {
1838
-				// dropdown's
1839
-				$output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1840
-
1841
-				// input states
1842
-				$output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1843
-
1844
-				// page link
1845
-				$output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1846
-			}
1847
-
1848
-            // alerts
1849
-			if ( $aui_bs5 ) {
1850
-//				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1851
-				$output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1852
-			}
1853
-
1854
-			return $output;
1855
-		}
1856
-
1857
-		/**
1686
+			    $selectors = array(
1687
+				    ".btn-{$type}"                                              => array( 'b', 'o' ),
1688
+				    ".btn-{$type}.disabled"                                     => array( 'b', 'o' ),
1689
+				    ".btn-{$type}:disabled"                                     => array( 'b', 'o' ),
1690
+				    ".btn-outline-{$type}"                                      => array( 'c', 'o' ),
1691
+				    ".btn-outline-{$type}:hover"                                => array( 'b', 'o' ),
1692
+				    ".btn-outline-{$type}:not(:disabled):not(.disabled).active" => array( 'b', 'o' ),
1693
+				    ".btn-outline-{$type}:not(:disabled):not(.disabled):active" => array( 'b', 'o' ),
1694
+				    ".show>.btn-outline-{$type}.dropdown-toggle"                => array( 'b', 'o' ),
1695
+				    ".badge-{$type}"                                            => array( 'b' ),
1696
+				    ".alert-{$type}"                                            => array( 'b', 'o' ),
1697
+				    ".bg-{$type}"                                               => array( 'b', 'f' ),
1698
+				    ".btn-link.btn-{$type}"                                     => array( 'c' ),
1699
+			    );
1700
+
1701
+			    if ( $aui_bs5 ) {
1702
+                    unset($selectors[".alert-{$type}" ]);
1703
+			    }
1704
+
1705
+			    if ( $type == 'primary' ) {
1706
+				    $selectors = $selectors + array(
1707
+						    'a'                                                                                                    => array( 'c' ),
1708
+						    '.btn-link'                                                                                            => array( 'c' ),
1709
+						    '.dropdown-item.active'                                                                                => array( 'b' ),
1710
+						    '.custom-control-input:checked~.custom-control-label::before'                                          => array(
1711
+							    'b',
1712
+							    'o'
1713
+						    ),
1714
+						    '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before'                   => array(
1715
+							    'b',
1716
+							    'o'
1717
+						    ),
1718
+						    '.nav-pills .nav-link.active'                                                                          => array( 'b' ),
1719
+						    '.nav-pills .show>.nav-link'                                                                           => array( 'b' ),
1720
+						    '.page-link'                                                                                           => array( 'c' ),
1721
+						    '.page-item.active .page-link'                                                                         => array(
1722
+							    'b',
1723
+							    'o'
1724
+						    ),
1725
+						    '.progress-bar'                                                                                        => array( 'b' ),
1726
+						    '.list-group-item.active'                                                                              => array(
1727
+							    'b',
1728
+							    'o'
1729
+						    ),
1730
+						    '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array( 'b' ),
1731
+    //				    '.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1732
+    //				    '.custom-range::-moz-range-thumb' => array('b'),
1733
+    //				    '.custom-range::-ms-thumb' => array('b'),
1734
+					    );
1735
+			    }
1736
+
1737
+			    $important_selectors = array(
1738
+				    ".bg-{$type}" => array('b','f'),
1739
+				    ".border-{$type}" => array('o'),
1740
+				    ".text-{$type}" => array('c'),
1741
+			    );
1742
+
1743
+			    $color = array();
1744
+			    $color_i = array();
1745
+			    $background = array();
1746
+			    $background_i = array();
1747
+			    $border = array();
1748
+			    $border_i = array();
1749
+			    $fill = array();
1750
+			    $fill_i = array();
1751
+
1752
+			    $output = '';
1753
+
1754
+			    if ( $aui_bs5 ) {
1755
+    //				$output .= $is_var ? 'html body {--bs-'.esc_attr($type).'-rgb: '.$color_code.'; }' : 'html body {--bs-'.esc_attr($type).'-rgb: '.self::hex_to_rgb($color_code).'; }';
1756
+				    $output .= 'html body {--bs-'.esc_attr($type).'-rgb: '.$rgb.'; }';
1757
+			    }
1758
+
1759
+			    // build rules into each type
1760
+			    foreach($selectors as $selector => $types){
1761
+				    $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1762
+				    $types = array_combine($types,$types);
1763
+				    if(isset($types['c'])){$color[] = $selector;}
1764
+				    if(isset($types['b'])){$background[] = $selector;}
1765
+				    if(isset($types['o'])){$border[] = $selector;}
1766
+				    if(isset($types['f'])){$fill[] = $selector;}
1767
+			    }
1768
+
1769
+			    // build rules into each type
1770
+			    foreach($important_selectors as $selector => $types){
1771
+				    $selector = $compatibility ? $compatibility . " ".$selector : $selector;
1772
+				    $types = array_combine($types,$types);
1773
+				    if(isset($types['c'])){$color_i[] = $selector;}
1774
+				    if(isset($types['b'])){$background_i[] = $selector;}
1775
+				    if(isset($types['o'])){$border_i[] = $selector;}
1776
+				    if(isset($types['f'])){$fill_i[] = $selector;}
1777
+			    }
1778
+
1779
+			    // add any color rules
1780
+			    if(!empty($color)){
1781
+				    $output .= implode(",",$color) . "{color: $color_code;} ";
1782
+			    }
1783
+			    if(!empty($color_i)){
1784
+				    $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1785
+			    }
1786
+
1787
+			    // add any background color rules
1788
+			    if(!empty($background)){
1789
+				    $output .= implode(",",$background) . "{background-color: $color_code;} ";
1790
+			    }
1791
+			    if(!empty($background_i)){
1792
+				    $output .= $aui_bs5 ? '' : implode(",",$background_i) . "{background-color: $color_code !important;} ";
1793
+    //				$output .= implode(",",$background_i) . "{background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;} ";
1794
+			    }
1795
+
1796
+			    // add any border color rules
1797
+			    if(!empty($border)){
1798
+				    $output .= implode(",",$border) . "{border-color: $color_code;} ";
1799
+			    }
1800
+			    if(!empty($border_i)){
1801
+				    $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1802
+			    }
1803
+
1804
+			    // add any fill color rules
1805
+			    if(!empty($fill)){
1806
+				    $output .= implode(",",$fill) . "{fill: $color_code;} ";
1807
+			    }
1808
+			    if(!empty($fill_i)){
1809
+				    $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1810
+			    }
1811
+
1812
+
1813
+			    $prefix = $compatibility ? $compatibility . " " : "";
1814
+
1815
+			    $transition = $is_var ? 'transition: color 0.15s ease-in-out,background-color 0.15s ease-in-out,border-color 0.15s ease-in-out,box-shadow 0.15s ease-in-out,filter 0.15s ease-in-out;' : '';
1816
+			    // darken
1817
+			    $darker_075 = $is_var ? $color_code.';filter:brightness(0.925)' : self::css_hex_lighten_darken($color_code,"-0.075");
1818
+			    $darker_10 = $is_var ? $color_code.';filter:brightness(0.9)' : self::css_hex_lighten_darken($color_code,"-0.10");
1819
+			    $darker_125 = $is_var ? $color_code.';filter:brightness(0.875)' : self::css_hex_lighten_darken($color_code,"-0.125");
1820
+			    $darker_40 = $is_var ? $color_code.';filter:brightness(0.6)' : self::css_hex_lighten_darken($color_code,"-0.4");
1821
+
1822
+			    // lighten
1823
+			    $lighten_25 = $is_var ? $color_code.';filter:brightness(1.25)' :self::css_hex_lighten_darken($color_code,"0.25");
1824
+
1825
+			    // opacity see https://css-tricks.com/8-digit-hex-codes/
1826
+			    $op_25 = $color_code."40"; // 25% opacity
1827
+
1828
+
1829
+			    // button states
1830
+			    $output .= $is_var ? $prefix ." .btn-{$type}{{$transition }} " : '';
1831
+			    $output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1832
+    //			$output .= $prefix ." .btn-{$type}:hover, $prefix .btn-{$type}:focus, $prefix .btn-{$type}.focus{background-color: #000;    border-color: #000;} ";
1833
+			    $output .= $prefix ." .btn-outline-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-{$type}.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1834
+			    $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active, $prefix .btn-{$type}:not(:disabled):not(.disabled).active, .show>$prefix .btn-{$type}.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1835
+			    $output .= $prefix ." .btn-{$type}:not(:disabled):not(.disabled):active:focus, $prefix .btn-{$type}:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-{$type}.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1836
+
1837
+			    if ( $type == 'primary' ) {
1838
+				    // dropdown's
1839
+				    $output .= $prefix . " .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1840
+
1841
+				    // input states
1842
+				    $output .= $prefix . " .form-control:focus{border-color: " . $lighten_25 . ";box-shadow: 0 0 0 0.2rem $op_25;} ";
1843
+
1844
+				    // page link
1845
+				    $output .= $prefix . " .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1846
+			    }
1847
+
1848
+                // alerts
1849
+			    if ( $aui_bs5 ) {
1850
+    //				$output .= $is_var ? '' : $prefix ." .alert-{$type} {background-color: ".$color_code."20;    border-color: ".$color_code."30;color:$darker_40} ";
1851
+				    $output .= $prefix ." .alert-{$type} {--bs-alert-bg: rgba(var(--bs-{$type}-rgb), .1 ) !important;--bs-alert-border-color: rgba(var(--bs-{$type}-rgb), .25 ) !important;--bs-alert-color: rgba(var(--bs-{$type}-rgb), 1 ) !important;} ";
1852
+			    }
1853
+
1854
+			    return $output;
1855
+		    }
1856
+
1857
+		    /**
1858 1858
 		 *
1859 1859
 		 * @deprecated 0.1.76 Use css_overwrite()
1860 1860
 		 *
@@ -1864,151 +1864,151 @@  discard block
 block discarded – undo
1864 1864
 		 *
1865 1865
 		 * @return string
1866 1866
 		 */
1867
-		public static function css_primary($color_code,$compatibility, $use_variable = false){
1867
+		    public static function css_primary($color_code,$compatibility, $use_variable = false){
1868 1868
 
1869
-			if(!$use_variable){
1870
-				$color_code = sanitize_hex_color($color_code);
1871
-				if(!$color_code){return '';}
1872
-			}
1869
+			    if(!$use_variable){
1870
+				    $color_code = sanitize_hex_color($color_code);
1871
+				    if(!$color_code){return '';}
1872
+			    }
1873 1873
 
1874
-			/**
1874
+			    /**
1875 1875
 			 * c = color, b = background color, o = border-color, f = fill
1876 1876
 			 */
1877
-			$selectors = array(
1878
-				'a' => array('c'),
1879
-				'.btn-primary' => array('b','o'),
1880
-				'.btn-primary.disabled' => array('b','o'),
1881
-				'.btn-primary:disabled' => array('b','o'),
1882
-				'.btn-outline-primary' => array('c','o'),
1883
-				'.btn-outline-primary:hover' => array('b','o'),
1884
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1885
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1886
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1887
-				'.btn-link' => array('c'),
1888
-				'.dropdown-item.active' => array('b'),
1889
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1890
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1891
-//				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1892
-//				'.custom-range::-moz-range-thumb' => array('b'),
1893
-//				'.custom-range::-ms-thumb' => array('b'),
1894
-				'.nav-pills .nav-link.active' => array('b'),
1895
-				'.nav-pills .show>.nav-link' => array('b'),
1896
-				'.page-link' => array('c'),
1897
-				'.page-item.active .page-link' => array('b','o'),
1898
-				'.badge-primary' => array('b'),
1899
-				'.alert-primary' => array('b','o'),
1900
-				'.progress-bar' => array('b'),
1901
-				'.list-group-item.active' => array('b','o'),
1902
-				'.bg-primary' => array('b','f'),
1903
-				'.btn-link.btn-primary' => array('c'),
1904
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1905
-			);
1906
-
1907
-			$important_selectors = array(
1908
-				'.bg-primary' => array('b','f'),
1909
-				'.border-primary' => array('o'),
1910
-				'.text-primary' => array('c'),
1911
-			);
1912
-
1913
-			$color = array();
1914
-			$color_i = array();
1915
-			$background = array();
1916
-			$background_i = array();
1917
-			$border = array();
1918
-			$border_i = array();
1919
-			$fill = array();
1920
-			$fill_i = array();
1921
-
1922
-			$output = '';
1923
-
1924
-			// build rules into each type
1925
-			foreach($selectors as $selector => $types){
1926
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1927
-				$types = array_combine($types,$types);
1928
-				if(isset($types['c'])){$color[] = $selector;}
1929
-				if(isset($types['b'])){$background[] = $selector;}
1930
-				if(isset($types['o'])){$border[] = $selector;}
1931
-				if(isset($types['f'])){$fill[] = $selector;}
1932
-			}
1933
-
1934
-			// build rules into each type
1935
-			foreach($important_selectors as $selector => $types){
1936
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1937
-				$types = array_combine($types,$types);
1938
-				if(isset($types['c'])){$color_i[] = $selector;}
1939
-				if(isset($types['b'])){$background_i[] = $selector;}
1940
-				if(isset($types['o'])){$border_i[] = $selector;}
1941
-				if(isset($types['f'])){$fill_i[] = $selector;}
1942
-			}
1943
-
1944
-			// add any color rules
1945
-			if(!empty($color)){
1946
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1947
-			}
1948
-			if(!empty($color_i)){
1949
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1950
-			}
1951
-
1952
-			// add any background color rules
1953
-			if(!empty($background)){
1954
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1955
-			}
1956
-			if(!empty($background_i)){
1957
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1958
-			}
1959
-
1960
-			// add any border color rules
1961
-			if(!empty($border)){
1962
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1963
-			}
1964
-			if(!empty($border_i)){
1965
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1966
-			}
1967
-
1968
-			// add any fill color rules
1969
-			if(!empty($fill)){
1970
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1971
-			}
1972
-			if(!empty($fill_i)){
1973
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1974
-			}
1975
-
1976
-
1977
-			$prefix = $compatibility ? ".bsui " : "";
1978
-
1979
-			// darken
1980
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1981
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1982
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1983
-
1984
-			// lighten
1985
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1986
-
1987
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1988
-			$op_25 = $color_code."40"; // 25% opacity
1989
-
1990
-
1991
-			// button states
1992
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1993
-			$output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1994
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1995
-			$output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1996
-
1997
-
1998
-			// dropdown's
1999
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2000
-
2001
-
2002
-			// input states
2003
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
2004
-
2005
-			// page link
2006
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2007
-
2008
-			return $output;
2009
-		}
2010
-
2011
-		/**
1877
+			    $selectors = array(
1878
+				    'a' => array('c'),
1879
+				    '.btn-primary' => array('b','o'),
1880
+				    '.btn-primary.disabled' => array('b','o'),
1881
+				    '.btn-primary:disabled' => array('b','o'),
1882
+				    '.btn-outline-primary' => array('c','o'),
1883
+				    '.btn-outline-primary:hover' => array('b','o'),
1884
+				    '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1885
+				    '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1886
+				    '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1887
+				    '.btn-link' => array('c'),
1888
+				    '.dropdown-item.active' => array('b'),
1889
+				    '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1890
+				    '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1891
+    //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1892
+    //				'.custom-range::-moz-range-thumb' => array('b'),
1893
+    //				'.custom-range::-ms-thumb' => array('b'),
1894
+				    '.nav-pills .nav-link.active' => array('b'),
1895
+				    '.nav-pills .show>.nav-link' => array('b'),
1896
+				    '.page-link' => array('c'),
1897
+				    '.page-item.active .page-link' => array('b','o'),
1898
+				    '.badge-primary' => array('b'),
1899
+				    '.alert-primary' => array('b','o'),
1900
+				    '.progress-bar' => array('b'),
1901
+				    '.list-group-item.active' => array('b','o'),
1902
+				    '.bg-primary' => array('b','f'),
1903
+				    '.btn-link.btn-primary' => array('c'),
1904
+				    '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1905
+			    );
1906
+
1907
+			    $important_selectors = array(
1908
+				    '.bg-primary' => array('b','f'),
1909
+				    '.border-primary' => array('o'),
1910
+				    '.text-primary' => array('c'),
1911
+			    );
1912
+
1913
+			    $color = array();
1914
+			    $color_i = array();
1915
+			    $background = array();
1916
+			    $background_i = array();
1917
+			    $border = array();
1918
+			    $border_i = array();
1919
+			    $fill = array();
1920
+			    $fill_i = array();
1921
+
1922
+			    $output = '';
1923
+
1924
+			    // build rules into each type
1925
+			    foreach($selectors as $selector => $types){
1926
+				    $selector = $compatibility ? ".bsui ".$selector : $selector;
1927
+				    $types = array_combine($types,$types);
1928
+				    if(isset($types['c'])){$color[] = $selector;}
1929
+				    if(isset($types['b'])){$background[] = $selector;}
1930
+				    if(isset($types['o'])){$border[] = $selector;}
1931
+				    if(isset($types['f'])){$fill[] = $selector;}
1932
+			    }
1933
+
1934
+			    // build rules into each type
1935
+			    foreach($important_selectors as $selector => $types){
1936
+				    $selector = $compatibility ? ".bsui ".$selector : $selector;
1937
+				    $types = array_combine($types,$types);
1938
+				    if(isset($types['c'])){$color_i[] = $selector;}
1939
+				    if(isset($types['b'])){$background_i[] = $selector;}
1940
+				    if(isset($types['o'])){$border_i[] = $selector;}
1941
+				    if(isset($types['f'])){$fill_i[] = $selector;}
1942
+			    }
1943
+
1944
+			    // add any color rules
1945
+			    if(!empty($color)){
1946
+				    $output .= implode(",",$color) . "{color: $color_code;} ";
1947
+			    }
1948
+			    if(!empty($color_i)){
1949
+				    $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1950
+			    }
1951
+
1952
+			    // add any background color rules
1953
+			    if(!empty($background)){
1954
+				    $output .= implode(",",$background) . "{background-color: $color_code;} ";
1955
+			    }
1956
+			    if(!empty($background_i)){
1957
+				    $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1958
+			    }
1959
+
1960
+			    // add any border color rules
1961
+			    if(!empty($border)){
1962
+				    $output .= implode(",",$border) . "{border-color: $color_code;} ";
1963
+			    }
1964
+			    if(!empty($border_i)){
1965
+				    $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1966
+			    }
1967
+
1968
+			    // add any fill color rules
1969
+			    if(!empty($fill)){
1970
+				    $output .= implode(",",$fill) . "{fill: $color_code;} ";
1971
+			    }
1972
+			    if(!empty($fill_i)){
1973
+				    $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1974
+			    }
1975
+
1976
+
1977
+			    $prefix = $compatibility ? ".bsui " : "";
1978
+
1979
+			    // darken
1980
+			    $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1981
+			    $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1982
+			    $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1983
+
1984
+			    // lighten
1985
+			    $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1986
+
1987
+			    // opacity see https://css-tricks.com/8-digit-hex-codes/
1988
+			    $op_25 = $color_code."40"; // 25% opacity
1989
+
1990
+
1991
+			    // button states
1992
+			    $output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1993
+			    $output .= $prefix ." .btn-outline-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-primary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1994
+			    $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active, $prefix .btn-primary:not(:disabled):not(.disabled).active, .show>$prefix .btn-primary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
1995
+			    $output .= $prefix ." .btn-primary:not(:disabled):not(.disabled):active:focus, $prefix .btn-primary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-primary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
1996
+
1997
+
1998
+			    // dropdown's
1999
+			    $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
2000
+
2001
+
2002
+			    // input states
2003
+			    $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
2004
+
2005
+			    // page link
2006
+			    $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2007
+
2008
+			    return $output;
2009
+		    }
2010
+
2011
+		    /**
2012 2012
 		 *
2013 2013
 		 * @deprecated 0.1.76 Use css_overwrite()
2014 2014
 		 *
@@ -2017,123 +2017,123 @@  discard block
 block discarded – undo
2017 2017
 		 *
2018 2018
 		 * @return string
2019 2019
 		 */
2020
-		public static function css_secondary($color_code,$compatibility){;
2021
-			$color_code = sanitize_hex_color($color_code);
2022
-			if(!$color_code){return '';}
2023
-			/**
2020
+		    public static function css_secondary($color_code,$compatibility){;
2021
+			    $color_code = sanitize_hex_color($color_code);
2022
+			    if(!$color_code){return '';}
2023
+			    /**
2024 2024
 			 * c = color, b = background color, o = border-color, f = fill
2025 2025
 			 */
2026
-			$selectors = array(
2027
-				'.btn-secondary' => array('b','o'),
2028
-				'.btn-secondary.disabled' => array('b','o'),
2029
-				'.btn-secondary:disabled' => array('b','o'),
2030
-				'.btn-outline-secondary' => array('c','o'),
2031
-				'.btn-outline-secondary:hover' => array('b','o'),
2032
-				'.btn-outline-secondary.disabled' => array('c'),
2033
-				'.btn-outline-secondary:disabled' => array('c'),
2034
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2035
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2036
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2037
-				'.badge-secondary' => array('b'),
2038
-				'.alert-secondary' => array('b','o'),
2039
-				'.btn-link.btn-secondary' => array('c'),
2040
-			);
2041
-
2042
-			$important_selectors = array(
2043
-				'.bg-secondary' => array('b','f'),
2044
-				'.border-secondary' => array('o'),
2045
-				'.text-secondary' => array('c'),
2046
-			);
2047
-
2048
-			$color = array();
2049
-			$color_i = array();
2050
-			$background = array();
2051
-			$background_i = array();
2052
-			$border = array();
2053
-			$border_i = array();
2054
-			$fill = array();
2055
-			$fill_i = array();
2056
-
2057
-			$output = '';
2058
-
2059
-			// build rules into each type
2060
-			foreach($selectors as $selector => $types){
2061
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2062
-				$types = array_combine($types,$types);
2063
-				if(isset($types['c'])){$color[] = $selector;}
2064
-				if(isset($types['b'])){$background[] = $selector;}
2065
-				if(isset($types['o'])){$border[] = $selector;}
2066
-				if(isset($types['f'])){$fill[] = $selector;}
2067
-			}
2068
-
2069
-			// build rules into each type
2070
-			foreach($important_selectors as $selector => $types){
2071
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
2072
-				$types = array_combine($types,$types);
2073
-				if(isset($types['c'])){$color_i[] = $selector;}
2074
-				if(isset($types['b'])){$background_i[] = $selector;}
2075
-				if(isset($types['o'])){$border_i[] = $selector;}
2076
-				if(isset($types['f'])){$fill_i[] = $selector;}
2077
-			}
2078
-
2079
-			// add any color rules
2080
-			if(!empty($color)){
2081
-				$output .= implode(",",$color) . "{color: $color_code;} ";
2082
-			}
2083
-			if(!empty($color_i)){
2084
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2085
-			}
2086
-
2087
-			// add any background color rules
2088
-			if(!empty($background)){
2089
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
2090
-			}
2091
-			if(!empty($background_i)){
2092
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2093
-			}
2094
-
2095
-			// add any border color rules
2096
-			if(!empty($border)){
2097
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
2098
-			}
2099
-			if(!empty($border_i)){
2100
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2101
-			}
2102
-
2103
-			// add any fill color rules
2104
-			if(!empty($fill)){
2105
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
2106
-			}
2107
-			if(!empty($fill_i)){
2108
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2109
-			}
2110
-
2111
-
2112
-			$prefix = $compatibility ? ".bsui " : "";
2113
-
2114
-			// darken
2115
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2116
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2117
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
2118
-
2119
-			// lighten
2120
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
2121
-
2122
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
2123
-			$op_25 = $color_code."40"; // 25% opacity
2124
-
2125
-
2126
-			// button states
2127
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2128
-			$output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2129
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2130
-			$output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2131
-
2132
-
2133
-			return $output;
2134
-		}
2135
-
2136
-		/**
2026
+			    $selectors = array(
2027
+				    '.btn-secondary' => array('b','o'),
2028
+				    '.btn-secondary.disabled' => array('b','o'),
2029
+				    '.btn-secondary:disabled' => array('b','o'),
2030
+				    '.btn-outline-secondary' => array('c','o'),
2031
+				    '.btn-outline-secondary:hover' => array('b','o'),
2032
+				    '.btn-outline-secondary.disabled' => array('c'),
2033
+				    '.btn-outline-secondary:disabled' => array('c'),
2034
+				    '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
2035
+				    '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
2036
+				    '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
2037
+				    '.badge-secondary' => array('b'),
2038
+				    '.alert-secondary' => array('b','o'),
2039
+				    '.btn-link.btn-secondary' => array('c'),
2040
+			    );
2041
+
2042
+			    $important_selectors = array(
2043
+				    '.bg-secondary' => array('b','f'),
2044
+				    '.border-secondary' => array('o'),
2045
+				    '.text-secondary' => array('c'),
2046
+			    );
2047
+
2048
+			    $color = array();
2049
+			    $color_i = array();
2050
+			    $background = array();
2051
+			    $background_i = array();
2052
+			    $border = array();
2053
+			    $border_i = array();
2054
+			    $fill = array();
2055
+			    $fill_i = array();
2056
+
2057
+			    $output = '';
2058
+
2059
+			    // build rules into each type
2060
+			    foreach($selectors as $selector => $types){
2061
+				    $selector = $compatibility ? ".bsui ".$selector : $selector;
2062
+				    $types = array_combine($types,$types);
2063
+				    if(isset($types['c'])){$color[] = $selector;}
2064
+				    if(isset($types['b'])){$background[] = $selector;}
2065
+				    if(isset($types['o'])){$border[] = $selector;}
2066
+				    if(isset($types['f'])){$fill[] = $selector;}
2067
+			    }
2068
+
2069
+			    // build rules into each type
2070
+			    foreach($important_selectors as $selector => $types){
2071
+				    $selector = $compatibility ? ".bsui ".$selector : $selector;
2072
+				    $types = array_combine($types,$types);
2073
+				    if(isset($types['c'])){$color_i[] = $selector;}
2074
+				    if(isset($types['b'])){$background_i[] = $selector;}
2075
+				    if(isset($types['o'])){$border_i[] = $selector;}
2076
+				    if(isset($types['f'])){$fill_i[] = $selector;}
2077
+			    }
2078
+
2079
+			    // add any color rules
2080
+			    if(!empty($color)){
2081
+				    $output .= implode(",",$color) . "{color: $color_code;} ";
2082
+			    }
2083
+			    if(!empty($color_i)){
2084
+				    $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
2085
+			    }
2086
+
2087
+			    // add any background color rules
2088
+			    if(!empty($background)){
2089
+				    $output .= implode(",",$background) . "{background-color: $color_code;} ";
2090
+			    }
2091
+			    if(!empty($background_i)){
2092
+				    $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
2093
+			    }
2094
+
2095
+			    // add any border color rules
2096
+			    if(!empty($border)){
2097
+				    $output .= implode(",",$border) . "{border-color: $color_code;} ";
2098
+			    }
2099
+			    if(!empty($border_i)){
2100
+				    $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
2101
+			    }
2102
+
2103
+			    // add any fill color rules
2104
+			    if(!empty($fill)){
2105
+				    $output .= implode(",",$fill) . "{fill: $color_code;} ";
2106
+			    }
2107
+			    if(!empty($fill_i)){
2108
+				    $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
2109
+			    }
2110
+
2111
+
2112
+			    $prefix = $compatibility ? ".bsui " : "";
2113
+
2114
+			    // darken
2115
+			    $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
2116
+			    $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
2117
+			    $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
2118
+
2119
+			    // lighten
2120
+			    $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
2121
+
2122
+			    // opacity see https://css-tricks.com/8-digit-hex-codes/
2123
+			    $op_25 = $color_code."40"; // 25% opacity
2124
+
2125
+
2126
+			    // button states
2127
+			    $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
2128
+			    $output .= $prefix ." .btn-outline-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-outline-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-outline-secondary.dropdown-toggle:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
2129
+			    $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active, $prefix .btn-secondary:not(:disabled):not(.disabled).active, .show>$prefix .btn-secondary.dropdown-toggle{background-color: ".$darker_10.";    border-color: ".$darker_125.";} ";
2130
+			    $output .= $prefix ." .btn-secondary:not(:disabled):not(.disabled):active:focus, $prefix .btn-secondary:not(:disabled):not(.disabled).active:focus, .show>$prefix .btn-secondary.dropdown-toggle:focus {box-shadow: 0 0 0 0.2rem $op_25;} ";
2131
+
2132
+
2133
+			    return $output;
2134
+		    }
2135
+
2136
+		    /**
2137 2137
 		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
2138 2138
 		 *
2139 2139
 		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
@@ -2141,265 +2141,265 @@  discard block
 block discarded – undo
2141 2141
 		 *
2142 2142
 		 * @return  string
2143 2143
 		 */
2144
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2145
-			$hexCode = ltrim($hexCode, '#');
2144
+		    public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
2145
+			    $hexCode = ltrim($hexCode, '#');
2146 2146
 
2147
-			if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2148
-				return $hexCode;
2149
-			}
2147
+			    if ( strpos( $hexCode, 'rgba(' ) !== false || strpos( $hexCode, 'rgb(' ) !== false ) {
2148
+				    return $hexCode;
2149
+			    }
2150 2150
 
2151
-			if (strlen($hexCode) == 3) {
2152
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
2153
-			}
2151
+			    if (strlen($hexCode) == 3) {
2152
+				    $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
2153
+			    }
2154 2154
 
2155
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
2155
+			    $hexCode = array_map('hexdec', str_split($hexCode, 2));
2156 2156
 
2157
-			foreach ($hexCode as & $color) {
2158
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
2159
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
2157
+			    foreach ($hexCode as & $color) {
2158
+				    $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
2159
+				    $adjustAmount = ceil($adjustableLimit * $adjustPercent);
2160 2160
 
2161
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
2162
-			}
2161
+				    $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
2162
+			    }
2163 2163
 
2164
-			return '#' . implode($hexCode);
2165
-		}
2164
+			    return '#' . implode($hexCode);
2165
+		    }
2166 2166
 
2167
-		/**
2167
+		    /**
2168 2168
 		 * Check if we should display examples.
2169 2169
 		 */
2170
-		public function maybe_show_examples(){
2171
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2172
-				echo "<head>";
2173
-				wp_head();
2174
-				echo "</head>";
2175
-				echo "<body>";
2176
-				echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2177
-				echo "</body>";
2178
-				exit;
2179
-			}
2180
-		}
2181
-
2182
-		/**
2170
+		    public function maybe_show_examples(){
2171
+			    if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
2172
+				    echo "<head>";
2173
+				    wp_head();
2174
+				    echo "</head>";
2175
+				    echo "<body>";
2176
+				    echo $this->get_examples(); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2177
+				    echo "</body>";
2178
+				    exit;
2179
+			    }
2180
+		    }
2181
+
2182
+		    /**
2183 2183
 		 * Get developer examples.
2184 2184
 		 *
2185 2185
 		 * @return string
2186 2186
 		 */
2187
-		public function get_examples(){
2188
-			$output = '';
2189
-
2190
-
2191
-			// open form
2192
-			$output .= "<form class='p-5 m-5 border rounded'>";
2193
-
2194
-			// input example
2195
-			$output .= aui()->input(array(
2196
-				'type'  =>  'text',
2197
-				'id'    =>  'text-example',
2198
-				'name'    =>  'text-example',
2199
-				'placeholder'   => 'text placeholder',
2200
-				'title'   => 'Text input example',
2201
-				'value' =>  '',
2202
-				'required'  => false,
2203
-				'help_text' => 'help text',
2204
-				'label' => 'Text input example label'
2205
-			));
2206
-
2207
-			// input example
2208
-			$output .= aui()->input(array(
2209
-				'type'  =>  'url',
2210
-				'id'    =>  'text-example2',
2211
-				'name'    =>  'text-example',
2212
-				'placeholder'   => 'url placeholder',
2213
-				'title'   => 'Text input example',
2214
-				'value' =>  '',
2215
-				'required'  => false,
2216
-				'help_text' => 'help text',
2217
-				'label' => 'Text input example label'
2218
-			));
2219
-
2220
-			// checkbox example
2221
-			$output .= aui()->input(array(
2222
-				'type'  =>  'checkbox',
2223
-				'id'    =>  'checkbox-example',
2224
-				'name'    =>  'checkbox-example',
2225
-				'placeholder'   => 'checkbox-example',
2226
-				'title'   => 'Checkbox example',
2227
-				'value' =>  '1',
2228
-				'checked'   => true,
2229
-				'required'  => false,
2230
-				'help_text' => 'help text',
2231
-				'label' => 'Checkbox checked'
2232
-			));
2233
-
2234
-			// checkbox example
2235
-			$output .= aui()->input(array(
2236
-				'type'  =>  'checkbox',
2237
-				'id'    =>  'checkbox-example2',
2238
-				'name'    =>  'checkbox-example2',
2239
-				'placeholder'   => 'checkbox-example',
2240
-				'title'   => 'Checkbox example',
2241
-				'value' =>  '1',
2242
-				'checked'   => false,
2243
-				'required'  => false,
2244
-				'help_text' => 'help text',
2245
-				'label' => 'Checkbox un-checked'
2246
-			));
2247
-
2248
-			// switch example
2249
-			$output .= aui()->input(array(
2250
-				'type'  =>  'checkbox',
2251
-				'id'    =>  'switch-example',
2252
-				'name'    =>  'switch-example',
2253
-				'placeholder'   => 'checkbox-example',
2254
-				'title'   => 'Switch example',
2255
-				'value' =>  '1',
2256
-				'checked'   => true,
2257
-				'switch'    => true,
2258
-				'required'  => false,
2259
-				'help_text' => 'help text',
2260
-				'label' => 'Switch on'
2261
-			));
2262
-
2263
-			// switch example
2264
-			$output .= aui()->input(array(
2265
-				'type'  =>  'checkbox',
2266
-				'id'    =>  'switch-example2',
2267
-				'name'    =>  'switch-example2',
2268
-				'placeholder'   => 'checkbox-example',
2269
-				'title'   => 'Switch example',
2270
-				'value' =>  '1',
2271
-				'checked'   => false,
2272
-				'switch'    => true,
2273
-				'required'  => false,
2274
-				'help_text' => 'help text',
2275
-				'label' => 'Switch off'
2276
-			));
2277
-
2278
-			// close form
2279
-			$output .= "</form>";
2280
-
2281
-			return $output;
2282
-		}
2283
-
2284
-		/**
2187
+		    public function get_examples(){
2188
+			    $output = '';
2189
+
2190
+
2191
+			    // open form
2192
+			    $output .= "<form class='p-5 m-5 border rounded'>";
2193
+
2194
+			    // input example
2195
+			    $output .= aui()->input(array(
2196
+				    'type'  =>  'text',
2197
+				    'id'    =>  'text-example',
2198
+				    'name'    =>  'text-example',
2199
+				    'placeholder'   => 'text placeholder',
2200
+				    'title'   => 'Text input example',
2201
+				    'value' =>  '',
2202
+				    'required'  => false,
2203
+				    'help_text' => 'help text',
2204
+				    'label' => 'Text input example label'
2205
+			    ));
2206
+
2207
+			    // input example
2208
+			    $output .= aui()->input(array(
2209
+				    'type'  =>  'url',
2210
+				    'id'    =>  'text-example2',
2211
+				    'name'    =>  'text-example',
2212
+				    'placeholder'   => 'url placeholder',
2213
+				    'title'   => 'Text input example',
2214
+				    'value' =>  '',
2215
+				    'required'  => false,
2216
+				    'help_text' => 'help text',
2217
+				    'label' => 'Text input example label'
2218
+			    ));
2219
+
2220
+			    // checkbox example
2221
+			    $output .= aui()->input(array(
2222
+				    'type'  =>  'checkbox',
2223
+				    'id'    =>  'checkbox-example',
2224
+				    'name'    =>  'checkbox-example',
2225
+				    'placeholder'   => 'checkbox-example',
2226
+				    'title'   => 'Checkbox example',
2227
+				    'value' =>  '1',
2228
+				    'checked'   => true,
2229
+				    'required'  => false,
2230
+				    'help_text' => 'help text',
2231
+				    'label' => 'Checkbox checked'
2232
+			    ));
2233
+
2234
+			    // checkbox example
2235
+			    $output .= aui()->input(array(
2236
+				    'type'  =>  'checkbox',
2237
+				    'id'    =>  'checkbox-example2',
2238
+				    'name'    =>  'checkbox-example2',
2239
+				    'placeholder'   => 'checkbox-example',
2240
+				    'title'   => 'Checkbox example',
2241
+				    'value' =>  '1',
2242
+				    'checked'   => false,
2243
+				    'required'  => false,
2244
+				    'help_text' => 'help text',
2245
+				    'label' => 'Checkbox un-checked'
2246
+			    ));
2247
+
2248
+			    // switch example
2249
+			    $output .= aui()->input(array(
2250
+				    'type'  =>  'checkbox',
2251
+				    'id'    =>  'switch-example',
2252
+				    'name'    =>  'switch-example',
2253
+				    'placeholder'   => 'checkbox-example',
2254
+				    'title'   => 'Switch example',
2255
+				    'value' =>  '1',
2256
+				    'checked'   => true,
2257
+				    'switch'    => true,
2258
+				    'required'  => false,
2259
+				    'help_text' => 'help text',
2260
+				    'label' => 'Switch on'
2261
+			    ));
2262
+
2263
+			    // switch example
2264
+			    $output .= aui()->input(array(
2265
+				    'type'  =>  'checkbox',
2266
+				    'id'    =>  'switch-example2',
2267
+				    'name'    =>  'switch-example2',
2268
+				    'placeholder'   => 'checkbox-example',
2269
+				    'title'   => 'Switch example',
2270
+				    'value' =>  '1',
2271
+				    'checked'   => false,
2272
+				    'switch'    => true,
2273
+				    'required'  => false,
2274
+				    'help_text' => 'help text',
2275
+				    'label' => 'Switch off'
2276
+			    ));
2277
+
2278
+			    // close form
2279
+			    $output .= "</form>";
2280
+
2281
+			    return $output;
2282
+		    }
2283
+
2284
+		    /**
2285 2285
 		 * Calendar params.
2286 2286
 		 *
2287 2287
 		 * @since 0.1.44
2288 2288
 		 *
2289 2289
 		 * @return array Calendar params.
2290 2290
 		 */
2291
-		public static function calendar_params() {
2292
-			$params = array(
2293
-				'month_long_1' => __( 'January', 'ayecode-connect' ),
2294
-				'month_long_2' => __( 'February', 'ayecode-connect' ),
2295
-				'month_long_3' => __( 'March', 'ayecode-connect' ),
2296
-				'month_long_4' => __( 'April', 'ayecode-connect' ),
2297
-				'month_long_5' => __( 'May', 'ayecode-connect' ),
2298
-				'month_long_6' => __( 'June', 'ayecode-connect' ),
2299
-				'month_long_7' => __( 'July', 'ayecode-connect' ),
2300
-				'month_long_8' => __( 'August', 'ayecode-connect' ),
2301
-				'month_long_9' => __( 'September', 'ayecode-connect' ),
2302
-				'month_long_10' => __( 'October', 'ayecode-connect' ),
2303
-				'month_long_11' => __( 'November', 'ayecode-connect' ),
2304
-				'month_long_12' => __( 'December', 'ayecode-connect' ),
2305
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2306
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2307
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2308
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2309
-				'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2310
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2311
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2312
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2313
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2314
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2315
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2316
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2317
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2318
-				'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2319
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2320
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2321
-				'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2322
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2323
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2324
-				'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2325
-				'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2326
-				'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2327
-				'day_s2_4' => __( 'We', 'ayecode-connect' ),
2328
-				'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2329
-				'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2330
-				'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2331
-				'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2332
-				'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2333
-				'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2334
-				'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2335
-				'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2336
-				'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2337
-				'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2338
-				'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2339
-				'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2340
-				'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2341
-				'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2342
-				'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2343
-				'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2344
-				'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2345
-				'am_lower' => __( 'am', 'ayecode-connect' ),
2346
-				'pm_lower' => __( 'pm', 'ayecode-connect' ),
2347
-				'am_upper' => __( 'AM', 'ayecode-connect' ),
2348
-				'pm_upper' => __( 'PM', 'ayecode-connect' ),
2349
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2350
-				'time_24hr' => false,
2351
-				'year' => __( 'Year', 'ayecode-connect' ),
2352
-				'hour' => __( 'Hour', 'ayecode-connect' ),
2353
-				'minute' => __( 'Minute', 'ayecode-connect' ),
2354
-				'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2355
-				'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2356
-				'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2357
-				'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2358
-			);
2359
-
2360
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
2361
-		}
2362
-
2363
-		/**
2291
+		    public static function calendar_params() {
2292
+			    $params = array(
2293
+				    'month_long_1' => __( 'January', 'ayecode-connect' ),
2294
+				    'month_long_2' => __( 'February', 'ayecode-connect' ),
2295
+				    'month_long_3' => __( 'March', 'ayecode-connect' ),
2296
+				    'month_long_4' => __( 'April', 'ayecode-connect' ),
2297
+				    'month_long_5' => __( 'May', 'ayecode-connect' ),
2298
+				    'month_long_6' => __( 'June', 'ayecode-connect' ),
2299
+				    'month_long_7' => __( 'July', 'ayecode-connect' ),
2300
+				    'month_long_8' => __( 'August', 'ayecode-connect' ),
2301
+				    'month_long_9' => __( 'September', 'ayecode-connect' ),
2302
+				    'month_long_10' => __( 'October', 'ayecode-connect' ),
2303
+				    'month_long_11' => __( 'November', 'ayecode-connect' ),
2304
+				    'month_long_12' => __( 'December', 'ayecode-connect' ),
2305
+				    'month_s_1' => _x( 'Jan', 'January abbreviation', 'ayecode-connect' ),
2306
+				    'month_s_2' => _x( 'Feb', 'February abbreviation', 'ayecode-connect' ),
2307
+				    'month_s_3' => _x( 'Mar', 'March abbreviation', 'ayecode-connect' ),
2308
+				    'month_s_4' => _x( 'Apr', 'April abbreviation', 'ayecode-connect' ),
2309
+				    'month_s_5' => _x( 'May', 'May abbreviation', 'ayecode-connect' ),
2310
+				    'month_s_6' => _x( 'Jun', 'June abbreviation', 'ayecode-connect' ),
2311
+				    'month_s_7' => _x( 'Jul', 'July abbreviation', 'ayecode-connect' ),
2312
+				    'month_s_8' => _x( 'Aug', 'August abbreviation', 'ayecode-connect' ),
2313
+				    'month_s_9' => _x( 'Sep', 'September abbreviation', 'ayecode-connect' ),
2314
+				    'month_s_10' => _x( 'Oct', 'October abbreviation', 'ayecode-connect' ),
2315
+				    'month_s_11' => _x( 'Nov', 'November abbreviation', 'ayecode-connect' ),
2316
+				    'month_s_12' => _x( 'Dec', 'December abbreviation', 'ayecode-connect' ),
2317
+				    'day_s1_1' => _x( 'S', 'Sunday initial', 'ayecode-connect' ),
2318
+				    'day_s1_2' => _x( 'M', 'Monday initial', 'ayecode-connect' ),
2319
+				    'day_s1_3' => _x( 'T', 'Tuesday initial', 'ayecode-connect' ),
2320
+				    'day_s1_4' => _x( 'W', 'Wednesday initial', 'ayecode-connect' ),
2321
+				    'day_s1_5' => _x( 'T', 'Friday initial', 'ayecode-connect' ),
2322
+				    'day_s1_6' => _x( 'F', 'Thursday initial', 'ayecode-connect' ),
2323
+				    'day_s1_7' => _x( 'S', 'Saturday initial', 'ayecode-connect' ),
2324
+				    'day_s2_1' => __( 'Su', 'ayecode-connect' ),
2325
+				    'day_s2_2' => __( 'Mo', 'ayecode-connect' ),
2326
+				    'day_s2_3' => __( 'Tu', 'ayecode-connect' ),
2327
+				    'day_s2_4' => __( 'We', 'ayecode-connect' ),
2328
+				    'day_s2_5' => __( 'Th', 'ayecode-connect' ),
2329
+				    'day_s2_6' => __( 'Fr', 'ayecode-connect' ),
2330
+				    'day_s2_7' => __( 'Sa', 'ayecode-connect' ),
2331
+				    'day_s3_1' => __( 'Sun', 'ayecode-connect' ),
2332
+				    'day_s3_2' => __( 'Mon', 'ayecode-connect' ),
2333
+				    'day_s3_3' => __( 'Tue', 'ayecode-connect' ),
2334
+				    'day_s3_4' => __( 'Wed', 'ayecode-connect' ),
2335
+				    'day_s3_5' => __( 'Thu', 'ayecode-connect' ),
2336
+				    'day_s3_6' => __( 'Fri', 'ayecode-connect' ),
2337
+				    'day_s3_7' => __( 'Sat', 'ayecode-connect' ),
2338
+				    'day_s5_1' => __( 'Sunday', 'ayecode-connect' ),
2339
+				    'day_s5_2' => __( 'Monday', 'ayecode-connect' ),
2340
+				    'day_s5_3' => __( 'Tuesday', 'ayecode-connect' ),
2341
+				    'day_s5_4' => __( 'Wednesday', 'ayecode-connect' ),
2342
+				    'day_s5_5' => __( 'Thursday', 'ayecode-connect' ),
2343
+				    'day_s5_6' => __( 'Friday', 'ayecode-connect' ),
2344
+				    'day_s5_7' => __( 'Saturday', 'ayecode-connect' ),
2345
+				    'am_lower' => __( 'am', 'ayecode-connect' ),
2346
+				    'pm_lower' => __( 'pm', 'ayecode-connect' ),
2347
+				    'am_upper' => __( 'AM', 'ayecode-connect' ),
2348
+				    'pm_upper' => __( 'PM', 'ayecode-connect' ),
2349
+				    'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
2350
+				    'time_24hr' => false,
2351
+				    'year' => __( 'Year', 'ayecode-connect' ),
2352
+				    'hour' => __( 'Hour', 'ayecode-connect' ),
2353
+				    'minute' => __( 'Minute', 'ayecode-connect' ),
2354
+				    'weekAbbreviation' => __( 'Wk', 'ayecode-connect' ),
2355
+				    'rangeSeparator' => __( ' to ', 'ayecode-connect' ),
2356
+				    'scrollTitle' => __( 'Scroll to increment', 'ayecode-connect' ),
2357
+				    'toggleTitle' => __( 'Click to toggle', 'ayecode-connect' )
2358
+			    );
2359
+
2360
+			    return apply_filters( 'ayecode_ui_calendar_params', $params );
2361
+		    }
2362
+
2363
+		    /**
2364 2364
 		 * Flatpickr calendar localize.
2365 2365
 		 *
2366 2366
 		 * @since 0.1.44
2367 2367
 		 *
2368 2368
 		 * @return string Calendar locale.
2369 2369
 		 */
2370
-		public static function flatpickr_locale() {
2371
-			$params = self::calendar_params();
2370
+		    public static function flatpickr_locale() {
2371
+			    $params = self::calendar_params();
2372 2372
 
2373
-			if ( is_string( $params ) ) {
2374
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2375
-			} else {
2376
-				foreach ( (array) $params as $key => $value ) {
2377
-					if ( ! is_scalar( $value ) ) {
2378
-						continue;
2379
-					}
2373
+			    if ( is_string( $params ) ) {
2374
+				    $params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
2375
+			    } else {
2376
+				    foreach ( (array) $params as $key => $value ) {
2377
+					    if ( ! is_scalar( $value ) ) {
2378
+						    continue;
2379
+					    }
2380 2380
 
2381
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2382
-				}
2383
-			}
2381
+					    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2382
+				    }
2383
+			    }
2384 2384
 
2385
-			$day_s3 = array();
2386
-			$day_s5 = array();
2385
+			    $day_s3 = array();
2386
+			    $day_s5 = array();
2387 2387
 
2388
-			for ( $i = 1; $i <= 7; $i ++ ) {
2389
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2390
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2391
-			}
2388
+			    for ( $i = 1; $i <= 7; $i ++ ) {
2389
+				    $day_s3[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2390
+				    $day_s5[] = addslashes( $params[ 'day_s3_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2391
+			    }
2392 2392
 
2393
-			$month_s = array();
2394
-			$month_long = array();
2393
+			    $month_s = array();
2394
+			    $month_long = array();
2395 2395
 
2396
-			for ( $i = 1; $i <= 12; $i ++ ) {
2397
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2398
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
-			}
2396
+			    for ( $i = 1; $i <= 12; $i ++ ) {
2397
+				    $month_s[] = addslashes( $params[ 'month_s_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2398
+				    $month_long[] = addslashes( $params[ 'month_long_' . $i ] ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
2399
+			    }
2400 2400
 
2401
-			ob_start();
2402
-		if ( 0 ) { ?><script><?php } ?>
2401
+			    ob_start();
2402
+		    if ( 0 ) { ?><script><?php } ?>
2403 2403
                 {
2404 2404
                     weekdays: {
2405 2405
                         shorthand: ['<?php echo implode( "','", $day_s3 ); // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped ?>'],
@@ -2435,192 +2435,192 @@  discard block
 block discarded – undo
2435 2435
                     hourAriaLabel: '<?php echo esc_attr( $params[ 'hour' ] ); ?>',
2436 2436
                     minuteAriaLabel: '<?php echo esc_attr( $params[ 'minute' ] ); ?>',
2437 2437
                     time_24hr: <?php echo ( $params[ 'time_24hr' ] ? 'true' : 'false' ) ; ?>
2438
-                }
2438
+                    }
2439 2439
 				<?php if ( 0 ) { ?></script><?php } ?>
2440
-			<?php
2441
-			$locale = ob_get_clean();
2440
+    			<?php
2441
+			    $locale = ob_get_clean();
2442 2442
 
2443
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2444
-		}
2443
+			    return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2444
+		    }
2445 2445
 
2446
-		/**
2446
+		    /**
2447 2447
 		 * Select2 JS params.
2448 2448
 		 *
2449 2449
 		 * @since 0.1.44
2450 2450
 		 *
2451 2451
 		 * @return array Select2 JS params.
2452 2452
 		 */
2453
-		public static function select2_params() {
2454
-			$params = array(
2455
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2456
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2457
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2458
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2459
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2460
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2461
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2462
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2463
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2464
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2465
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2466
-			);
2467
-
2468
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2469
-		}
2470
-
2471
-		/**
2453
+		    public static function select2_params() {
2454
+			    $params = array(
2455
+				    'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'ayecode-connect' ),
2456
+				    'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'ayecode-connect' ),
2457
+				    'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'ayecode-connect' ),
2458
+				    'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'ayecode-connect' ),
2459
+				    'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'ayecode-connect' ),
2460
+				    'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'ayecode-connect' ),
2461
+				    'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'ayecode-connect' ),
2462
+				    'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'ayecode-connect' ),
2463
+				    'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'ayecode-connect' ),
2464
+				    'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'ayecode-connect' ),
2465
+				    'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'ayecode-connect' )
2466
+			    );
2467
+
2468
+			    return apply_filters( 'ayecode_ui_select2_params', $params );
2469
+		    }
2470
+
2471
+		    /**
2472 2472
 		 * Select2 JS localize.
2473 2473
 		 *
2474 2474
 		 * @since 0.1.44
2475 2475
 		 *
2476 2476
 		 * @return string Select2 JS locale.
2477 2477
 		 */
2478
-		public static function select2_locale() {
2479
-			$params = self::select2_params();
2478
+		    public static function select2_locale() {
2479
+			    $params = self::select2_params();
2480 2480
 
2481
-			foreach ( (array) $params as $key => $value ) {
2482
-				if ( ! is_scalar( $value ) ) {
2483
-					continue;
2484
-				}
2481
+			    foreach ( (array) $params as $key => $value ) {
2482
+				    if ( ! is_scalar( $value ) ) {
2483
+					    continue;
2484
+				    }
2485 2485
 
2486
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2487
-			}
2486
+				    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2487
+			    }
2488 2488
 
2489
-			$locale = json_encode( $params );
2489
+			    $locale = json_encode( $params );
2490 2490
 
2491
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2492
-		}
2491
+			    return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2492
+		    }
2493 2493
 
2494
-		/**
2494
+		    /**
2495 2495
 		 * Time ago JS localize.
2496 2496
 		 *
2497 2497
 		 * @since 0.1.47
2498 2498
 		 *
2499 2499
 		 * @return string Time ago JS locale.
2500 2500
 		 */
2501
-		public static function timeago_locale() {
2502
-			$params = array(
2503
-				'prefix_ago' => '',
2504
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2505
-				'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2506
-				'suffix_after' => '',
2507
-				'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2508
-				'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2509
-				'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2510
-				'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2511
-				'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2512
-				'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2513
-				'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2514
-				'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2515
-				'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2516
-				'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2517
-				'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2518
-			);
2519
-
2520
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2521
-
2522
-			foreach ( (array) $params as $key => $value ) {
2523
-				if ( ! is_scalar( $value ) ) {
2524
-					continue;
2525
-				}
2526
-
2527
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2528
-			}
2529
-
2530
-			$locale = json_encode( $params );
2531
-
2532
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2533
-		}
2534
-
2535
-		/**
2501
+		    public static function timeago_locale() {
2502
+			    $params = array(
2503
+				    'prefix_ago' => '',
2504
+				    'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'ayecode-connect' ),
2505
+				    'prefix_after' => _x( 'after', 'time ago', 'ayecode-connect' ) . ' ',
2506
+				    'suffix_after' => '',
2507
+				    'seconds' => _x( 'less than a minute', 'time ago', 'ayecode-connect' ),
2508
+				    'minute' => _x( 'about a minute', 'time ago', 'ayecode-connect' ),
2509
+				    'minutes' => _x( '%d minutes', 'time ago', 'ayecode-connect' ),
2510
+				    'hour' => _x( 'about an hour', 'time ago', 'ayecode-connect' ),
2511
+				    'hours' => _x( 'about %d hours', 'time ago', 'ayecode-connect' ),
2512
+				    'day' => _x( 'a day', 'time ago', 'ayecode-connect' ),
2513
+				    'days' => _x( '%d days', 'time ago', 'ayecode-connect' ),
2514
+				    'month' => _x( 'about a month', 'time ago', 'ayecode-connect' ),
2515
+				    'months' => _x( '%d months', 'time ago', 'ayecode-connect' ),
2516
+				    'year' => _x( 'about a year', 'time ago', 'ayecode-connect' ),
2517
+				    'years' => _x( '%d years', 'time ago', 'ayecode-connect' ),
2518
+			    );
2519
+
2520
+			    $params = apply_filters( 'ayecode_ui_timeago_params', $params );
2521
+
2522
+			    foreach ( (array) $params as $key => $value ) {
2523
+				    if ( ! is_scalar( $value ) ) {
2524
+					    continue;
2525
+				    }
2526
+
2527
+				    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2528
+			    }
2529
+
2530
+			    $locale = json_encode( $params );
2531
+
2532
+			    return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2533
+		    }
2534
+
2535
+		    /**
2536 2536
 		 * JavaScript Minifier
2537 2537
 		 *
2538 2538
 		 * @param $input
2539 2539
 		 *
2540 2540
 		 * @return mixed
2541 2541
 		 */
2542
-		public static function minify_js($input) {
2543
-			if(trim($input) === "") return $input;
2544
-			return preg_replace(
2545
-				array(
2546
-					// Remove comment(s)
2547
-					'#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2548
-					// Remove white-space(s) outside the string and regex
2549
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2550
-					// Remove the last semicolon
2551
-					'#;+\}#',
2552
-					// Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2553
-					'#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2554
-					// --ibid. From `foo['bar']` to `foo.bar`
2555
-					'#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2556
-				),
2557
-				array(
2558
-					'$1',
2559
-					'$1$2',
2560
-					'}',
2561
-					'$1$3',
2562
-					'$1.$3'
2563
-				),
2564
-				$input);
2565
-		}
2566
-
2567
-		/**
2542
+		    public static function minify_js($input) {
2543
+			    if(trim($input) === "") return $input;
2544
+			    return preg_replace(
2545
+				    array(
2546
+					    // Remove comment(s)
2547
+					    '#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2548
+					    // Remove white-space(s) outside the string and regex
2549
+					    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2550
+					    // Remove the last semicolon
2551
+					    '#;+\}#',
2552
+					    // Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2553
+					    '#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2554
+					    // --ibid. From `foo['bar']` to `foo.bar`
2555
+					    '#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2556
+				    ),
2557
+				    array(
2558
+					    '$1',
2559
+					    '$1$2',
2560
+					    '}',
2561
+					    '$1$3',
2562
+					    '$1.$3'
2563
+				    ),
2564
+				    $input);
2565
+		    }
2566
+
2567
+		    /**
2568 2568
 		 * Minify CSS
2569 2569
 		 *
2570 2570
 		 * @param $input
2571 2571
 		 *
2572 2572
 		 * @return mixed
2573 2573
 		 */
2574
-		public static function minify_css($input) {
2575
-			if(trim($input) === "") return $input;
2576
-			return preg_replace(
2577
-				array(
2578
-					// Remove comment(s)
2579
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2580
-					// Remove unused white-space(s)
2581
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2582
-					// Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2583
-					'#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2584
-					// Replace `:0 0 0 0` with `:0`
2585
-					'#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2586
-					// Replace `background-position:0` with `background-position:0 0`
2587
-					'#(background-position):0(?=[;\}])#si',
2588
-					// Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2589
-					'#(?<=[\s:,\-])0+\.(\d+)#s',
2590
-					// Minify string value
2591
-					'#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2592
-					'#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2593
-					// Minify HEX color code
2594
-					'#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2595
-					// Replace `(border|outline):none` with `(border|outline):0`
2596
-					'#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2597
-					// Remove empty selector(s)
2598
-					'#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2599
-				),
2600
-				array(
2601
-					'$1',
2602
-					'$1$2$3$4$5$6$7',
2603
-					'$1',
2604
-					':0',
2605
-					'$1:0 0',
2606
-					'.$1',
2607
-					'$1$3',
2608
-					'$1$2$4$5',
2609
-					'$1$2$3',
2610
-					'$1:0',
2611
-					'$1$2'
2612
-				),
2613
-				$input);
2614
-		}
2615
-
2616
-		/**
2574
+		    public static function minify_css($input) {
2575
+			    if(trim($input) === "") return $input;
2576
+			    return preg_replace(
2577
+				    array(
2578
+					    // Remove comment(s)
2579
+					    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2580
+					    // Remove unused white-space(s)
2581
+					    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2582
+					    // Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2583
+					    '#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2584
+					    // Replace `:0 0 0 0` with `:0`
2585
+					    '#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2586
+					    // Replace `background-position:0` with `background-position:0 0`
2587
+					    '#(background-position):0(?=[;\}])#si',
2588
+					    // Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2589
+					    '#(?<=[\s:,\-])0+\.(\d+)#s',
2590
+					    // Minify string value
2591
+					    '#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2592
+					    '#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2593
+					    // Minify HEX color code
2594
+					    '#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2595
+					    // Replace `(border|outline):none` with `(border|outline):0`
2596
+					    '#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2597
+					    // Remove empty selector(s)
2598
+					    '#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2599
+				    ),
2600
+				    array(
2601
+					    '$1',
2602
+					    '$1$2$3$4$5$6$7',
2603
+					    '$1',
2604
+					    ':0',
2605
+					    '$1:0 0',
2606
+					    '.$1',
2607
+					    '$1$3',
2608
+					    '$1$2$4$5',
2609
+					    '$1$2$3',
2610
+					    '$1:0',
2611
+					    '$1$2'
2612
+				    ),
2613
+				    $input);
2614
+		    }
2615
+
2616
+		    /**
2617 2617
 		 * Get the conditional fields JavaScript.
2618 2618
 		 *
2619 2619
 		 * @return mixed
2620 2620
 		 */
2621
-		public function conditional_fields_js() {
2622
-			ob_start();
2623
-			?>
2621
+		    public function conditional_fields_js() {
2622
+			    ob_start();
2623
+			    ?>
2624 2624
             <script>
2625 2625
                 /**
2626 2626
                  * Conditional Fields
@@ -3153,33 +3153,33 @@  discard block
 block discarded – undo
3153 3153
                     }
3154 3154
                 }
3155 3155
 				<?php do_action( 'aui_conditional_fields_js', $this ); ?>
3156
-            </script>
3156
+                </script>
3157 3157
 			<?php
3158
-			$output = ob_get_clean();
3158
+			    $output = ob_get_clean();
3159 3159
 
3160
-			return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3161
-		}
3160
+			    return str_replace( array( '<script>', '</script>' ), '', self::minify_js( $output ) );
3161
+		    }
3162 3162
 
3163
-		/**
3163
+		    /**
3164 3164
 		 * Check if block editor page.
3165 3165
 		 *
3166 3166
 		 * @since 0.2.27
3167 3167
 		 *
3168 3168
 		 * @return bool
3169 3169
 		 */
3170
-		public static function is_block_editor() {
3171
-			if ( is_admin() ) {
3172
-				$current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3170
+		    public static function is_block_editor() {
3171
+			    if ( is_admin() ) {
3172
+				    $current_screen = function_exists('get_current_screen' ) ? get_current_screen() : array();
3173 3173
 
3174
-				if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3175
-					return true;
3176
-				}
3177
-			}
3174
+				    if ( ! empty( $current_screen ) && $current_screen->is_block_editor() ) {
3175
+					    return true;
3176
+				    }
3177
+			    }
3178 3178
 
3179
-			return false;
3180
-		}
3179
+			    return false;
3180
+		    }
3181 3181
 
3182
-		/**
3182
+		    /**
3183 3183
 		 * Checks if the current call is a ajax call to get the block content.
3184 3184
 		 *
3185 3185
 		 * This can be used in your widget to return different content as the block content.
@@ -3188,32 +3188,32 @@  discard block
 block discarded – undo
3188 3188
 		 *
3189 3189
 		 * @return bool
3190 3190
 		 */
3191
-		public static function is_block_content_call() {
3192
-			$result = false;
3193
-			if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3194
-				$result = true;
3195
-			}
3191
+		    public static function is_block_content_call() {
3192
+			    $result = false;
3193
+			    if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) {
3194
+				    $result = true;
3195
+			    }
3196 3196
 
3197
-			return $result;
3198
-		}
3197
+			    return $result;
3198
+		    }
3199 3199
 
3200
-		/**
3200
+		    /**
3201 3201
 		 * Tests if the current output is inside a Divi preview.
3202 3202
 		 *
3203 3203
 		 * @since 0.2.27
3204 3204
 		 *
3205 3205
 		 * @return bool
3206 3206
 		 */
3207
-		public static function is_divi_preview() {
3208
-			$result = false;
3209
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3210
-				$result = true;
3211
-			}
3207
+		    public static function is_divi_preview() {
3208
+			    $result = false;
3209
+			    if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
3210
+				    $result = true;
3211
+			    }
3212 3212
 
3213
-			return $result;
3214
-		}
3213
+			    return $result;
3214
+		    }
3215 3215
 
3216
-		/**
3216
+		    /**
3217 3217
 		 * Tests if the current output is inside a elementor preview.
3218 3218
 		 *
3219 3219
 		 *
@@ -3221,171 +3221,171 @@  discard block
 block discarded – undo
3221 3221
 		 *
3222 3222
 		 * @return bool
3223 3223
 		 */
3224
-		public static function is_elementor_preview() {
3225
-			$result = false;
3226
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3227
-				$result = true;
3228
-			}
3224
+		    public static function is_elementor_preview() {
3225
+			    $result = false;
3226
+			    if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
3227
+				    $result = true;
3228
+			    }
3229 3229
 
3230
-			return $result;
3231
-		}
3230
+			    return $result;
3231
+		    }
3232 3232
 
3233
-		/**
3233
+		    /**
3234 3234
 		 * Tests if the current output is inside a Beaver builder preview.
3235 3235
 		 *
3236 3236
 		 * @since 0.2.27
3237 3237
 		 *
3238 3238
 		 * @return bool
3239 3239
 		 */
3240
-		public static function is_beaver_preview() {
3241
-			$result = false;
3242
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
3243
-				$result = true;
3244
-			}
3240
+		    public static function is_beaver_preview() {
3241
+			    $result = false;
3242
+			    if ( isset( $_REQUEST['fl_builder'] ) ) {
3243
+				    $result = true;
3244
+			    }
3245 3245
 
3246
-			return $result;
3247
-		}
3246
+			    return $result;
3247
+		    }
3248 3248
 
3249
-		/**
3249
+		    /**
3250 3250
 		 * Tests if the current output is inside a siteorigin builder preview.
3251 3251
 		 *
3252 3252
 		 * @since 0.2.27
3253 3253
 		 *
3254 3254
 		 * @return bool
3255 3255
 		 */
3256
-		public static function is_siteorigin_preview() {
3257
-			$result = false;
3258
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3259
-				$result = true;
3260
-			}
3256
+		    public static function is_siteorigin_preview() {
3257
+			    $result = false;
3258
+			    if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
3259
+				    $result = true;
3260
+			    }
3261 3261
 
3262
-			return $result;
3263
-		}
3262
+			    return $result;
3263
+		    }
3264 3264
 
3265
-		/**
3265
+		    /**
3266 3266
 		 * Tests if the current output is inside a cornerstone builder preview.
3267 3267
 		 *
3268 3268
 		 * @since 0.2.27
3269 3269
 		 *
3270 3270
 		 * @return bool
3271 3271
 		 */
3272
-		public static function is_cornerstone_preview() {
3273
-			$result = false;
3274
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3275
-				$result = true;
3276
-			}
3272
+		    public static function is_cornerstone_preview() {
3273
+			    $result = false;
3274
+			    if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
3275
+				    $result = true;
3276
+			    }
3277 3277
 
3278
-			return $result;
3279
-		}
3278
+			    return $result;
3279
+		    }
3280 3280
 
3281
-		/**
3281
+		    /**
3282 3282
 		 * Tests if the current output is inside a fusion builder preview.
3283 3283
 		 *
3284 3284
 		 * @return bool
3285 3285
 		 *@since 1.1.0
3286 3286
 		 */
3287
-		public static function is_fusion_preview() {
3288
-			$result = false;
3289
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3290
-				$result = true;
3291
-			}
3287
+		    public static function is_fusion_preview() {
3288
+			    $result = false;
3289
+			    if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
3290
+				    $result = true;
3291
+			    }
3292 3292
 
3293
-			return $result;
3294
-		}
3293
+			    return $result;
3294
+		    }
3295 3295
 
3296
-		/**
3296
+		    /**
3297 3297
 		 * Tests if the current output is inside a Oxygen builder preview.
3298 3298
 		 *
3299 3299
 		 * @return bool
3300 3300
 		 *@since 1.0.18
3301 3301
 		 */
3302
-		public static function is_oxygen_preview() {
3303
-			$result = false;
3304
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3305
-				$result = true;
3306
-			}
3302
+		    public static function is_oxygen_preview() {
3303
+			    $result = false;
3304
+			    if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
3305
+				    $result = true;
3306
+			    }
3307 3307
 
3308
-			return $result;
3309
-		}
3308
+			    return $result;
3309
+		    }
3310 3310
 
3311
-		/**
3311
+		    /**
3312 3312
 		 * Check for Kallyas theme Zion builder preview.
3313 3313
 		 *
3314 3314
 		 * @since 0.2.27
3315 3315
 		 *
3316 3316
 		 * @return bool
3317 3317
 		 */
3318
-		public static function is_kallyas_zion_preview() {
3319
-			$result = false;
3318
+		    public static function is_kallyas_zion_preview() {
3319
+			    $result = false;
3320 3320
 
3321
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3322
-				$result = true;
3323
-			}
3321
+			    if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
3322
+				    $result = true;
3323
+			    }
3324 3324
 
3325
-			return $result;
3326
-		}
3325
+			    return $result;
3326
+		    }
3327 3327
 
3328
-		/**
3328
+		    /**
3329 3329
 		 * Check for Bricks theme builder preview.
3330 3330
 		 *
3331 3331
 		 * @since 0.2.27
3332 3332
 		 *
3333 3333
 		 * @return bool
3334 3334
 		 */
3335
-		public static function is_bricks_preview() {
3336
-			$result = false;
3335
+		    public static function is_bricks_preview() {
3336
+			    $result = false;
3337 3337
 
3338
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3339
-				$result = true;
3340
-			}
3338
+			    if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
3339
+				    $result = true;
3340
+			    }
3341 3341
 
3342
-			return $result;
3343
-		}
3342
+			    return $result;
3343
+		    }
3344 3344
 
3345
-		/**
3345
+		    /**
3346 3346
 		 * General function to check if we are in a preview situation.
3347 3347
 		 *
3348 3348
 		 * @since 0.2.27
3349 3349
 		 *
3350 3350
 		 * @return bool
3351 3351
 		 */
3352
-		public static function is_preview() {
3353
-			$preview = false;
3354
-
3355
-			if ( self::is_block_editor() ) {
3356
-				return true;
3357
-			}
3358
-
3359
-			if( self::is_block_content_call() ) {
3360
-				$preview = true;
3361
-			} elseif ( self::is_divi_preview() ) {
3362
-				$preview = true;
3363
-			} elseif ( self::is_elementor_preview() ) {
3364
-				$preview = true;
3365
-			} elseif ( self::is_beaver_preview() ) {
3366
-				$preview = true;
3367
-			} elseif ( self::is_siteorigin_preview() ) {
3368
-				$preview = true;
3369
-			} elseif ( self::is_cornerstone_preview() ) {
3370
-				$preview = true;
3371
-			} elseif ( self::is_fusion_preview() ) {
3372
-				$preview = true;
3373
-			} elseif ( self::is_oxygen_preview() ) {
3374
-				$preview = true;
3375
-			} elseif( self::is_kallyas_zion_preview() ) {
3376
-				$preview = true;
3377
-			} elseif( self::is_bricks_preview() ) {
3378
-				$preview = true;
3379
-			}
3380
-
3381
-			return $preview;
3382
-		}
3383
-	}
3384
-
3385
-	global $ayecode_ui_settings;
3386
-
3387
-	/**
3352
+		    public static function is_preview() {
3353
+			    $preview = false;
3354
+
3355
+			    if ( self::is_block_editor() ) {
3356
+				    return true;
3357
+			    }
3358
+
3359
+			    if( self::is_block_content_call() ) {
3360
+				    $preview = true;
3361
+			    } elseif ( self::is_divi_preview() ) {
3362
+				    $preview = true;
3363
+			    } elseif ( self::is_elementor_preview() ) {
3364
+				    $preview = true;
3365
+			    } elseif ( self::is_beaver_preview() ) {
3366
+				    $preview = true;
3367
+			    } elseif ( self::is_siteorigin_preview() ) {
3368
+				    $preview = true;
3369
+			    } elseif ( self::is_cornerstone_preview() ) {
3370
+				    $preview = true;
3371
+			    } elseif ( self::is_fusion_preview() ) {
3372
+				    $preview = true;
3373
+			    } elseif ( self::is_oxygen_preview() ) {
3374
+				    $preview = true;
3375
+			    } elseif( self::is_kallyas_zion_preview() ) {
3376
+				    $preview = true;
3377
+			    } elseif( self::is_bricks_preview() ) {
3378
+				    $preview = true;
3379
+			    }
3380
+
3381
+			    return $preview;
3382
+		    }
3383
+	    }
3384
+
3385
+	    global $ayecode_ui_settings;
3386
+
3387
+	    /**
3388 3388
 	 * Run the class if found.
3389 3389
 	 */
3390
-	$ayecode_ui_settings = AyeCode_UI_Settings::instance();
3390
+	    $ayecode_ui_settings = AyeCode_UI_Settings::instance();
3391 3391
 }
3392 3392
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-super-duper/wp-super-duper.php 1 patch
Switch Indentation   +2015 added lines, -2015 removed lines patch added patch discarded remove patch
@@ -1,13 +1,13 @@  discard block
 block discarded – undo
1
-<?php
2
-if ( ! defined( 'ABSPATH' ) ) {
3
-	exit;
1
+    <?php
2
+    if ( ! defined( 'ABSPATH' ) ) {
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.2.17' );
8
+	    define( 'SUPER_DUPER_VER', '1.2.17' );
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.
12 12
 	 *
13 13
 	 * Should not be called direct but extended instead.
@@ -16,298 +16,298 @@  discard block
 block discarded – undo
16 16
 	 * @since 1.0.16 change log moved to file change-log.txt - CHANGED
17 17
 	 * @ver 1.1.1
18 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
-		/**
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 32
 		 * The relative url to the current folder.
33 33
 		 *
34 34
 		 * @var string
35 35
 		 */
36
-		public $url = '';
36
+		    public $url = '';
37 37
 
38
-		/**
38
+		    /**
39 39
 		 * Take the array options and use them to build.
40 40
 		 */
41
-		public function __construct( $options ) {
42
-			global $sd_widgets;
43
-
44
-			$sd_widgets[ $options['base_id'] ] = array(
45
-				'name'       => $options['name'],
46
-				'class_name' => $options['class_name'],
47
-				'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
-			);
49
-			$this->base_id                     = $options['base_id'];
50
-			// lets filter the options before we do anything
51
-			$options       = apply_filters( "wp_super_duper_options", $options );
52
-			$options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
-			$options       = $this->add_name_from_key( $options );
54
-			$this->options = $options;
55
-
56
-			$this->base_id   = $options['base_id'];
57
-			$this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
58
-
59
-			// nested blocks can't work as a widget
60
-			if(!empty($this->options['nested-block'])){
61
-				if(empty($this->options['output_types'])){
62
-					$this->options['output_types'] = array('shortcode','block');
63
-				}elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64
-					unset($this->options['output_types'][$key]);
65
-				}
66
-			}
67
-
68
-			// init parent
69
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
-				parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
-			}
72
-
73
-
74
-			if ( isset( $options['class_name'] ) ) {
75
-				// register widget
76
-				$this->class_name = $options['class_name'];
77
-
78
-				// register shortcode, this needs to be done even for blocks and widgets
79
-				$this->register_shortcode();
80
-
81
-
82
-				// Fusion Builder (avada) support
83
-				if ( function_exists( 'fusion_builder_map' ) ) {
84
-					add_action( 'init', array( $this, 'register_fusion_element' ) );
85
-				}
86
-
87
-                // maybe load the Bricks transformer class
88
-                if( class_exists('\Bricks\Elements', false) ){
89
-					add_action( 'init', array( $this, 'load_bricks_element_class' ) );
90
-                }
91
-
92
-				// register block
93
-				if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
94
-					add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
95
-				}
96
-			}
97
-
98
-			// add the CSS and JS we need ONCE
99
-			global $sd_widget_scripts;
100
-
101
-			if ( ! $sd_widget_scripts ) {
102
-				wp_add_inline_script( 'admin-widgets', $this->widget_js() );
103
-				wp_add_inline_script( 'customize-controls', $this->widget_js() );
104
-				wp_add_inline_style( 'widgets', $this->widget_css() );
105
-
106
-				// maybe add elementor editor styles
107
-				add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
108
-
109
-				$sd_widget_scripts = true;
110
-
111
-				// add shortcode insert button once
112
-				add_action( 'media_buttons', array( $this, 'wp_media_buttons' ), 1 );
113
-				add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
114
-				// generatepress theme sections compatibility
115
-				if ( function_exists( 'generate_sections_sections_metabox' ) ) {
116
-					add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
117
-				}
118
-				/* Load script on Divi theme builder page */
119
-				if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
120
-					add_thickbox();
121
-					add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
122
-				}
123
-
124
-				if ( $this->is_preview() ) {
125
-					add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
126
-					// this makes the insert button work for elementor
127
-					add_action( 'elementor/editor/after_enqueue_scripts', array(
128
-						$this,
129
-						'shortcode_insert_button_script'
130
-					) ); // for elementor
131
-				}
132
-				// this makes the insert button work for cornerstone
133
-				add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
134
-
135
-				add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
136
-				add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
137
-
138
-				// add generator text to head
139
-				add_action( 'admin_head', array( $this, 'generator' ), 99 );
140
-				add_action( 'wp_head', array( $this, 'generator' ), 99 );
141
-			}
142
-
143
-			do_action( 'wp_super_duper_widget_init', $options, $this );
144
-		}
145
-
146
-        /**
41
+		    public function __construct( $options ) {
42
+			    global $sd_widgets;
43
+
44
+			    $sd_widgets[ $options['base_id'] ] = array(
45
+				    'name'       => $options['name'],
46
+				    'class_name' => $options['class_name'],
47
+				    'output_types' => !empty($options['output_types']) ? $options['output_types'] : array()
48
+			    );
49
+			    $this->base_id                     = $options['base_id'];
50
+			    // lets filter the options before we do anything
51
+			    $options       = apply_filters( "wp_super_duper_options", $options );
52
+			    $options       = apply_filters( "wp_super_duper_options_{$this->base_id}", $options );
53
+			    $options       = $this->add_name_from_key( $options );
54
+			    $this->options = $options;
55
+
56
+			    $this->base_id   = $options['base_id'];
57
+			    $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array();
58
+
59
+			    // nested blocks can't work as a widget
60
+			    if(!empty($this->options['nested-block'])){
61
+				    if(empty($this->options['output_types'])){
62
+					    $this->options['output_types'] = array('shortcode','block');
63
+				    }elseif (($key = array_search('widget', $this->options['output_types'])) !== false) {
64
+					    unset($this->options['output_types'][$key]);
65
+				    }
66
+			    }
67
+
68
+			    // init parent
69
+			    if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
70
+				    parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] );
71
+			    }
72
+
73
+
74
+			    if ( isset( $options['class_name'] ) ) {
75
+				    // register widget
76
+				    $this->class_name = $options['class_name'];
77
+
78
+				    // register shortcode, this needs to be done even for blocks and widgets
79
+				    $this->register_shortcode();
80
+
81
+
82
+				    // Fusion Builder (avada) support
83
+				    if ( function_exists( 'fusion_builder_map' ) ) {
84
+					    add_action( 'init', array( $this, 'register_fusion_element' ) );
85
+				    }
86
+
87
+                    // maybe load the Bricks transformer class
88
+                    if( class_exists('\Bricks\Elements', false) ){
89
+					    add_action( 'init', array( $this, 'load_bricks_element_class' ) );
90
+                    }
91
+
92
+				    // register block
93
+				    if(empty($this->options['output_types']) || in_array('block',$this->options['output_types'])){
94
+					    add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) );
95
+				    }
96
+			    }
97
+
98
+			    // add the CSS and JS we need ONCE
99
+			    global $sd_widget_scripts;
100
+
101
+			    if ( ! $sd_widget_scripts ) {
102
+				    wp_add_inline_script( 'admin-widgets', $this->widget_js() );
103
+				    wp_add_inline_script( 'customize-controls', $this->widget_js() );
104
+				    wp_add_inline_style( 'widgets', $this->widget_css() );
105
+
106
+				    // maybe add elementor editor styles
107
+				    add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) );
108
+
109
+				    $sd_widget_scripts = true;
110
+
111
+				    // add shortcode insert button once
112
+				    add_action( 'media_buttons', array( $this, 'wp_media_buttons' ), 1 );
113
+				    add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) );
114
+				    // generatepress theme sections compatibility
115
+				    if ( function_exists( 'generate_sections_sections_metabox' ) ) {
116
+					    add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) );
117
+				    }
118
+				    /* Load script on Divi theme builder page */
119
+				    if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) {
120
+					    add_thickbox();
121
+					    add_action( 'admin_footer', array( $this, 'shortcode_insert_button_script' ) );
122
+				    }
123
+
124
+				    if ( $this->is_preview() ) {
125
+					    add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) );
126
+					    // this makes the insert button work for elementor
127
+					    add_action( 'elementor/editor/after_enqueue_scripts', array(
128
+						    $this,
129
+						    'shortcode_insert_button_script'
130
+					    ) ); // for elementor
131
+				    }
132
+				    // this makes the insert button work for cornerstone
133
+				    add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) );
134
+
135
+				    add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) );
136
+				    add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) );
137
+
138
+				    // add generator text to head
139
+				    add_action( 'admin_head', array( $this, 'generator' ), 99 );
140
+				    add_action( 'wp_head', array( $this, 'generator' ), 99 );
141
+			    }
142
+
143
+			    do_action( 'wp_super_duper_widget_init', $options, $this );
144
+		    }
145
+
146
+            /**
147 147
          * Load the Bricks conversion class if we are running Bricks.
148 148
          * @return void
149 149
          */
150
-        public function load_bricks_element_class() {
151
-                    include_once __DIR__ . '/includes/class-super-duper-bricks-element.php';
152
-        }
150
+            public function load_bricks_element_class() {
151
+                        include_once __DIR__ . '/includes/class-super-duper-bricks-element.php';
152
+            }
153 153
 
154
-		/**
154
+		    /**
155 155
 		 * The register widget function
156 156
 		 * @return void
157 157
 		 */
158
-		public function _register() {
159
-			if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
160
-				parent::_register();
161
-			}
162
-		}
158
+		    public function _register() {
159
+			    if(empty($this->options['output_types']) || in_array('widget',$this->options['output_types'])){
160
+				    parent::_register();
161
+			    }
162
+		    }
163 163
 
164
-		/**
164
+		    /**
165 165
 		 * Add our widget CSS to elementor editor.
166 166
 		 */
167
-		public function elementor_editor_styles() {
168
-			wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
169
-		}
170
-
171
-		public function register_fusion_element() {
172
-
173
-			$options = $this->options;
174
-
175
-			if ( $this->base_id ) {
176
-
177
-				$params = $this->get_fusion_params();
178
-
179
-				$args = array(
180
-					'name'            => $options['name'],
181
-					'shortcode'       => $this->base_id,
182
-					'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
183
-					'allow_generator' => true,
184
-				);
185
-
186
-				if ( ! empty( $params ) ) {
187
-					$args['params'] = $params;
188
-				}
189
-
190
-				fusion_builder_map( $args );
191
-			}
192
-
193
-		}
194
-
195
-		public function get_fusion_params() {
196
-			$params    = array();
197
-			$arguments = $this->get_arguments();
198
-
199
-			if ( ! empty( $arguments ) ) {
200
-				foreach ( $arguments as $key => $val ) {
201
-					$param = array();
202
-					// type
203
-					$param['type'] = str_replace(
204
-						array(
205
-							"text",
206
-							"number",
207
-							"email",
208
-							"color",
209
-							"checkbox"
210
-						),
211
-						array(
212
-							"textfield",
213
-							"textfield",
214
-							"textfield",
215
-							"colorpicker",
216
-							"select",
217
-
218
-						),
219
-						$val['type'] );
220
-
221
-					// multiselect
222
-					if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
223
-						$param['type']     = 'multiple_select';
224
-						$param['multiple'] = true;
225
-					}
226
-
227
-					// heading
228
-					$param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
229
-
230
-					// description
231
-					$param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
232
-
233
-					// param_name
234
-					$param['param_name'] = $key;
235
-
236
-					// Default
237
-					$param['default'] = isset( $val['default'] ) ? $val['default'] : '';
238
-
239
-					// Group
240
-					if ( isset( $val['group'] ) ) {
241
-						$param['group'] = $val['group'];
242
-					}
243
-
244
-					// value
245
-					if ( $val['type'] == 'checkbox' ) {
246
-						if ( isset( $val['default'] ) && $val['default'] == '0' ) {
247
-							unset( $param['default'] );
248
-						}
249
-						$param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
250
-					} elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
251
-						$param['value'] = isset( $val['options'] ) ? $val['options'] : array();
252
-					} else {
253
-						$param['value'] = isset( $val['default'] ) ? $val['default'] : '';
254
-					}
255
-
256
-					// setup the param
257
-					$params[] = $param;
258
-
259
-				}
260
-			}
261
-
262
-
263
-			return $params;
264
-		}
265
-
266
-		/**
167
+		    public function elementor_editor_styles() {
168
+			    wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) );
169
+		    }
170
+
171
+		    public function register_fusion_element() {
172
+
173
+			    $options = $this->options;
174
+
175
+			    if ( $this->base_id ) {
176
+
177
+				    $params = $this->get_fusion_params();
178
+
179
+				    $args = array(
180
+					    'name'            => $options['name'],
181
+					    'shortcode'       => $this->base_id,
182
+					    'icon'            => $options['block-icon'] ? $options['block-icon'] : 'far fa-square',
183
+					    'allow_generator' => true,
184
+				    );
185
+
186
+				    if ( ! empty( $params ) ) {
187
+					    $args['params'] = $params;
188
+				    }
189
+
190
+				    fusion_builder_map( $args );
191
+			    }
192
+
193
+		    }
194
+
195
+		    public function get_fusion_params() {
196
+			    $params    = array();
197
+			    $arguments = $this->get_arguments();
198
+
199
+			    if ( ! empty( $arguments ) ) {
200
+				    foreach ( $arguments as $key => $val ) {
201
+					    $param = array();
202
+					    // type
203
+					    $param['type'] = str_replace(
204
+						    array(
205
+							    "text",
206
+							    "number",
207
+							    "email",
208
+							    "color",
209
+							    "checkbox"
210
+						    ),
211
+						    array(
212
+							    "textfield",
213
+							    "textfield",
214
+							    "textfield",
215
+							    "colorpicker",
216
+							    "select",
217
+
218
+						    ),
219
+						    $val['type'] );
220
+
221
+					    // multiselect
222
+					    if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) {
223
+						    $param['type']     = 'multiple_select';
224
+						    $param['multiple'] = true;
225
+					    }
226
+
227
+					    // heading
228
+					    $param['heading'] = isset( $val['title'] ) ? $val['title'] : '';
229
+
230
+					    // description
231
+					    $param['description'] = isset( $val['desc'] ) ? $val['desc'] : '';
232
+
233
+					    // param_name
234
+					    $param['param_name'] = $key;
235
+
236
+					    // Default
237
+					    $param['default'] = isset( $val['default'] ) ? $val['default'] : '';
238
+
239
+					    // Group
240
+					    if ( isset( $val['group'] ) ) {
241
+						    $param['group'] = $val['group'];
242
+					    }
243
+
244
+					    // value
245
+					    if ( $val['type'] == 'checkbox' ) {
246
+						    if ( isset( $val['default'] ) && $val['default'] == '0' ) {
247
+							    unset( $param['default'] );
248
+						    }
249
+						    $param['value'] = array( '0' => __( "No", 'ayecode-connect' ), '1' => __( "Yes", 'ayecode-connect' ) );
250
+					    } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) {
251
+						    $param['value'] = isset( $val['options'] ) ? $val['options'] : array();
252
+					    } else {
253
+						    $param['value'] = isset( $val['default'] ) ? $val['default'] : '';
254
+					    }
255
+
256
+					    // setup the param
257
+					    $params[] = $param;
258
+
259
+				    }
260
+			    }
261
+
262
+
263
+			    return $params;
264
+		    }
265
+
266
+		    /**
267 267
 		 * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder
268 268
 		 */
269
-		public static function maybe_cornerstone_builder() {
270
-			if ( did_action( 'cornerstone_before_boot_app' ) ) {
271
-				self::shortcode_insert_button_script();
272
-			}
273
-		}
269
+		    public static function maybe_cornerstone_builder() {
270
+			    if ( did_action( 'cornerstone_before_boot_app' ) ) {
271
+				    self::shortcode_insert_button_script();
272
+			    }
273
+		    }
274 274
 
275
-		/**
275
+		    /**
276 276
 		 * A function to ge the shortcode builder picker html.
277 277
 		 *
278 278
 		 * @param string $editor_id
279 279
 		 *
280 280
 		 * @return string
281 281
 		 */
282
-		public static function get_picker( $editor_id = '' ) {
282
+		    public static function get_picker( $editor_id = '' ) {
283 283
 
284
-			ob_start();
285
-			if ( isset( $_POST['editor_id'] ) ) {
286
-				$editor_id = esc_attr( $_POST['editor_id'] );
287
-			} elseif ( isset( $_REQUEST['et_fb'] ) ) {
288
-				$editor_id = 'main_content_content_vb_tiny_mce';
289
-			}
284
+			    ob_start();
285
+			    if ( isset( $_POST['editor_id'] ) ) {
286
+				    $editor_id = esc_attr( $_POST['editor_id'] );
287
+			    } elseif ( isset( $_REQUEST['et_fb'] ) ) {
288
+				    $editor_id = 'main_content_content_vb_tiny_mce';
289
+			    }
290 290
 
291
-			global $sd_widgets;
291
+			    global $sd_widgets;
292 292
 
293
-//			print_r($sd_widgets);exit;
294
-			?>
293
+    //			print_r($sd_widgets);exit;
294
+			    ?>
295 295
 
296 296
 			<div class="sd-shortcode-left-wrap">
297 297
 				<?php
298
-				ksort( $sd_widgets );
299
-				//				print_r($sd_widgets);exit;
300
-				if ( ! empty( $sd_widgets ) ) {
301
-					echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
302
-					echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
303
-					foreach ( $sd_widgets as $shortcode => $class ) {
304
-						if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
305
-						echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
306
-					}
307
-					echo "</select>";
308
-
309
-				}
310
-				?>
298
+				    ksort( $sd_widgets );
299
+				    //				print_r($sd_widgets);exit;
300
+				    if ( ! empty( $sd_widgets ) ) {
301
+					    echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">';
302
+					    echo "<option>" . __( 'Select shortcode', 'ayecode-connect' ) . "</option>";
303
+					    foreach ( $sd_widgets as $shortcode => $class ) {
304
+						    if(!empty($class['output_types']) && !in_array('shortcode', $class['output_types'])){ continue; }
305
+						    echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>";
306
+					    }
307
+					    echo "</select>";
308
+
309
+				    }
310
+				    ?>
311 311
 				<div class="sd-shortcode-settings"></div>
312 312
 
313 313
 			</div>
@@ -318,8 +318,8 @@  discard block
 block discarded – undo
318 318
 					<?php if ( $editor_id != '' ) { ?>
319 319
 						<button class="button sd-insert-shortcode-button"
320 320
 								onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) {
321
-									echo "'" . $editor_id . "'";
322
-								} ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
321
+									    echo "'" . $editor_id . "'";
322
+								    } ?>)"><?php _e( 'Insert shortcode', 'ayecode-connect' ); ?></button>
323 323
 					<?php } ?>
324 324
 					<button class="button"
325 325
 							onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button>
@@ -327,94 +327,94 @@  discard block
 block discarded – undo
327 327
 			</div>
328 328
 			<?php
329 329
 
330
-			$html = ob_get_clean();
330
+			    $html = ob_get_clean();
331 331
 
332
-			if ( wp_doing_ajax() ) {
333
-				echo $html;
334
-				$should_die = true;
332
+			    if ( wp_doing_ajax() ) {
333
+				    echo $html;
334
+				    $should_die = true;
335 335
 
336
-				// some builder get the editor via ajax so we should not die on those occasions
337
-				$dont_die = array(
338
-					'parent_tag',// WP Bakery
339
-					'avia_request' // enfold
340
-				);
336
+				    // some builder get the editor via ajax so we should not die on those occasions
337
+				    $dont_die = array(
338
+					    'parent_tag',// WP Bakery
339
+					    'avia_request' // enfold
340
+				    );
341 341
 
342
-				foreach ( $dont_die as $request ) {
343
-					if ( isset( $_REQUEST[ $request ] ) ) {
344
-						$should_die = false;
345
-					}
346
-				}
342
+				    foreach ( $dont_die as $request ) {
343
+					    if ( isset( $_REQUEST[ $request ] ) ) {
344
+						    $should_die = false;
345
+					    }
346
+				    }
347 347
 
348
-				if ( $should_die ) {
349
-					wp_die();
350
-				}
348
+				    if ( $should_die ) {
349
+					    wp_die();
350
+				    }
351 351
 
352
-			} else {
353
-				return $html;
354
-			}
352
+			    } else {
353
+				    return $html;
354
+			    }
355 355
 
356
-			return '';
356
+			    return '';
357 357
 
358
-		}
358
+		    }
359 359
 
360
-		/**
360
+		    /**
361 361
 		 * Output the version in the header.
362 362
 		 */
363
-		public function generator() {
364
-			$file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
365
-			$plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
366
-
367
-			// Find source plugin/theme of SD
368
-			$source = array();
369
-			if ( strpos( $file, $plugins_dir ) !== false ) {
370
-				$source = explode( "/", plugin_basename( $file ) );
371
-			} else if ( function_exists( 'get_theme_root' ) ) {
372
-				$themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
373
-
374
-				if ( strpos( $file, $themes_dir ) !== false ) {
375
-					$source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
376
-				}
377
-			}
378
-
379
-			echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
380
-		}
381
-
382
-		/**
363
+		    public function generator() {
364
+			    $file = str_replace( array( "/", "\\" ), "/", realpath( __FILE__ ) );
365
+			    $plugins_dir = str_replace( array( "/", "\\" ), "/", realpath( WP_PLUGIN_DIR ) );
366
+
367
+			    // Find source plugin/theme of SD
368
+			    $source = array();
369
+			    if ( strpos( $file, $plugins_dir ) !== false ) {
370
+				    $source = explode( "/", plugin_basename( $file ) );
371
+			    } else if ( function_exists( 'get_theme_root' ) ) {
372
+				    $themes_dir = str_replace( array( "/", "\\" ), "/", realpath( get_theme_root() ) );
373
+
374
+				    if ( strpos( $file, $themes_dir ) !== false ) {
375
+					    $source = explode( "/", ltrim( str_replace( $themes_dir, "", $file ), "/" ) );
376
+				    }
377
+			    }
378
+
379
+			    echo '<meta name="generator" content="WP Super Duper v' . esc_attr( $this->version ) . '"' . ( ! empty( $source[0] ) ? ' data-sd-source="' . esc_attr( $source[0] ) . '"' : '' ) . ' />';
380
+		    }
381
+
382
+		    /**
383 383
 		 * Get widget settings.
384 384
 		 *
385 385
 		 * @since 1.0.0
386 386
 		 */
387
-		public static function get_widget_settings() {
388
-			global $sd_widgets;
389
-
390
-			$shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
391
-			if ( ! $shortcode ) {
392
-				wp_die();
393
-			}
394
-			$widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
395
-			if ( ! $widget_args ) {
396
-				wp_die();
397
-			}
398
-			$class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
399
-			if ( ! $class_name ) {
400
-				wp_die();
401
-			}
402
-
403
-			// invoke an instance method
404
-			$widget = new $class_name;
405
-
406
-			ob_start();
407
-			$widget->form( array() );
408
-			$form = ob_get_clean();
409
-			echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
410
-			echo "<style>" . $widget->widget_css() . "</style>";
411
-			echo "<script>" . $widget->widget_js() . "</script>";
412
-			?>
413
-			<?php
414
-			wp_die();
415
-		}
416
-
417
-		/**
387
+		    public static function get_widget_settings() {
388
+			    global $sd_widgets;
389
+
390
+			    $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : '';
391
+			    if ( ! $shortcode ) {
392
+				    wp_die();
393
+			    }
394
+			    $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : '';
395
+			    if ( ! $widget_args ) {
396
+				    wp_die();
397
+			    }
398
+			    $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : '';
399
+			    if ( ! $class_name ) {
400
+				    wp_die();
401
+			    }
402
+
403
+			    // invoke an instance method
404
+			    $widget = new $class_name;
405
+
406
+			    ob_start();
407
+			    $widget->form( array() );
408
+			    $form = ob_get_clean();
409
+			    echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>";
410
+			    echo "<style>" . $widget->widget_css() . "</style>";
411
+			    echo "<script>" . $widget->widget_js() . "</script>";
412
+			    ?>
413
+    			<?php
414
+			    wp_die();
415
+		    }
416
+
417
+		    /**
418 418
 		 * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed).
419 419
 		 *
420 420
 		 * @param string $editor_id Optional. Shortcode editor id. Default null.
@@ -423,39 +423,39 @@  discard block
 block discarded – undo
423 423
 		 *@since 1.0.0
424 424
 		 *
425 425
 		 */
426
-		public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
427
-			global $sd_widgets, $shortcode_insert_button_once;
428
-			if ( $shortcode_insert_button_once ) {
429
-				return;
430
-			}
431
-			add_thickbox();
426
+		    public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) {
427
+			    global $sd_widgets, $shortcode_insert_button_once;
428
+			    if ( $shortcode_insert_button_once ) {
429
+				    return;
430
+			    }
431
+			    add_thickbox();
432 432
 
433 433
 
434
-			/**
434
+			    /**
435 435
 			 * Cornerstone makes us play dirty tricks :/
436 436
 			 * 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.
437 437
 			 */
438
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
439
-				echo '<span id="insert-media-button">';
440
-			}
438
+			    if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
439
+				    echo '<span id="insert-media-button">';
440
+			    }
441 441
 
442
-			echo self::shortcode_button( 'this', 'true' );
442
+			    echo self::shortcode_button( 'this', 'true' );
443 443
 
444
-			// see opening note
445
-			if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
446
-				echo '</span>'; // end #insert-media-button
447
-			}
444
+			    // see opening note
445
+			    if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) {
446
+				    echo '</span>'; // end #insert-media-button
447
+			    }
448 448
 
449
-			// Add separate script for generatepress theme sections
450
-			if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
451
-			} else {
452
-				self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
453
-			}
449
+			    // Add separate script for generatepress theme sections
450
+			    if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) {
451
+			    } else {
452
+				    self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function );
453
+			    }
454 454
 
455
-			$shortcode_insert_button_once = true;
456
-		}
455
+			    $shortcode_insert_button_once = true;
456
+		    }
457 457
 
458
-		/**
458
+		    /**
459 459
 		 * Gets the shortcode insert button html.
460 460
 		 *
461 461
 		 * @param string $id
@@ -463,14 +463,14 @@  discard block
 block discarded – undo
463 463
 		 *
464 464
 		 * @return mixed
465 465
 		 */
466
-		public static function shortcode_button( $id = '', $search_for_id = '' ) {
467
-			ob_start();
468
-			?>
466
+		    public static function shortcode_button( $id = '', $search_for_id = '' ) {
467
+			    ob_start();
468
+			    ?>
469 469
 			<span class="sd-lable-shortcode-inserter">
470 470
 				<a onclick="sd_ajax_get_picker(<?php echo $id;
471
-				if ( $search_for_id ) {
472
-					echo "," . $search_for_id;
473
-				} ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
471
+				    if ( $search_for_id ) {
472
+					    echo "," . $search_for_id;
473
+				    } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed"
474 474
 				   class="thickbox button super-duper-content-open" title="Add Shortcode">
475 475
 					<span style="vertical-align: middle;line-height: 18px;font-size: 20px;"
476 476
 						  class="dashicons dashicons-screenoptions"></span>
@@ -481,21 +481,21 @@  discard block
 block discarded – undo
481 481
 			</span>
482 482
 
483 483
 			<?php
484
-			$html = ob_get_clean();
484
+			    $html = ob_get_clean();
485 485
 
486
-			// remove line breaks so we can use it in js
487
-			return preg_replace( "/\r|\n/", "", trim( $html ) );
488
-		}
486
+			    // remove line breaks so we can use it in js
487
+			    return preg_replace( "/\r|\n/", "", trim( $html ) );
488
+		    }
489 489
 
490
-		/**
490
+		    /**
491 491
 		 * Makes SD work with the siteOrigin page builder.
492 492
 		 *
493 493
 		 * @return mixed
494 494
 		 *@since 1.0.6
495 495
 		 */
496
-		public static function siteorigin_js() {
497
-			ob_start();
498
-			?>
496
+		    public static function siteorigin_js() {
497
+			    ob_start();
498
+			    ?>
499 499
 			<script>
500 500
 				/**
501 501
 				 * Check a form to see what items should be shown or hidden.
@@ -571,19 +571,19 @@  discard block
 block discarded – undo
571 571
 				});
572 572
 			</script>
573 573
 			<?php
574
-			$output = ob_get_clean();
574
+			    $output = ob_get_clean();
575 575
 
576
-			/*
576
+			    /*
577 577
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
578 578
 			 */
579 579
 
580
-			return str_replace( array(
581
-				'<script>',
582
-				'</script>'
583
-			), '', $output );
584
-		}
580
+			    return str_replace( array(
581
+				    '<script>',
582
+				    '</script>'
583
+			    ), '', $output );
584
+		    }
585 585
 
586
-		/**
586
+		    /**
587 587
 		 * Output the JS and CSS for the shortcode insert button.
588 588
 		 *
589 589
 		 * @param string $editor_id
@@ -592,8 +592,8 @@  discard block
 block discarded – undo
592 592
 		 *@since 1.0.6
593 593
 		 *
594 594
 		 */
595
-		public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
596
-			?>
595
+		    public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) {
596
+			    ?>
597 597
 			<style>
598 598
 				.sd-shortcode-left-wrap {
599 599
 					float: left;
@@ -716,40 +716,40 @@  discard block
 block discarded – undo
716 716
 					display: inline;
717 717
 				}
718 718
 				<?php } ?>
719
-				<?php if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) { ?>
720
-				body.divi_page_et_theme_builder div#TB_window.gd-tb-window{z-index:9999999}
719
+    				<?php if ( function_exists( 'et_builder_is_tb_admin_screen' ) && et_builder_is_tb_admin_screen() ) { ?>
720
+    				body.divi_page_et_theme_builder div#TB_window.gd-tb-window{z-index:9999999}
721 721
 				<?php } ?>
722
-			</style>
722
+    			</style>
723 723
 			<?php
724
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
725
-				echo "<script>" . self::siteorigin_js() . "</script>";
726
-			}
727
-			?>
728
-			<script>
724
+			    if ( class_exists( 'SiteOrigin_Panels' ) ) {
725
+				    echo "<script>" . self::siteorigin_js() . "</script>";
726
+			    }
727
+			    ?>
728
+    			<script>
729 729
 				<?php
730
-				if(! empty( $insert_shortcode_function )){
731
-					echo $insert_shortcode_function;
732
-				}else{
730
+				    if(! empty( $insert_shortcode_function )){
731
+					    echo $insert_shortcode_function;
732
+				    }else{
733 733
 
734
-				/**
734
+				    /**
735 735
 				 * Function for super duper insert shortcode.
736 736
 				 *
737 737
 				 * @since 1.0.0
738 738
 				 */
739
-				?>
739
+				    ?>
740 740
 				function sd_insert_shortcode($editor_id) {
741 741
 					$shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val();
742 742
 					if ($shortcode) {
743 743
 						if (!$editor_id) {
744 744
 							<?php
745
-							if ( isset( $_REQUEST['et_fb'] ) ) {
746
-								echo '$editor_id = "#main_content_content_vb_tiny_mce";';
747
-							} elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
748
-								echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
749
-							} else {
750
-								echo '$editor_id = "#wp-content-editor-container textarea";';
751
-							}
752
-							?>
745
+							    if ( isset( $_REQUEST['et_fb'] ) ) {
746
+								    echo '$editor_id = "#main_content_content_vb_tiny_mce";';
747
+							    } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) {
748
+								    echo '$editor_id = "#elementor-controls .wp-editor-container textarea";';
749
+							    } else {
750
+								    echo '$editor_id = "#wp-content-editor-container textarea";';
751
+							    }
752
+							    ?>
753 753
 						} else {
754 754
 							$editor_id = '#' + $editor_id;
755 755
 						}
@@ -1063,19 +1063,19 @@  discard block
 block discarded – undo
1063 1063
 				}
1064 1064
 			</script>
1065 1065
 			<?php
1066
-		}
1066
+		    }
1067 1067
 
1068
-		/**
1068
+		    /**
1069 1069
 		 * Gets some CSS for the widgets screen.
1070 1070
 		 *
1071 1071
 		 * @param bool $advanced If we should include advanced CSS.
1072 1072
 		 *
1073 1073
 		 * @return mixed
1074 1074
 		 */
1075
-		public function widget_css( $advanced = true ) {
1076
-			ob_start();
1077
-			?>
1078
-			<style>
1075
+		    public function widget_css( $advanced = true ) {
1076
+			    ob_start();
1077
+			    ?>
1078
+    			<style>
1079 1079
 				<?php if( $advanced ){ ?>
1080 1080
 				.sd-advanced-setting {
1081 1081
 					display: none;
@@ -1114,26 +1114,26 @@  discard block
 block discarded – undo
1114 1114
 				.elementor-control .sd-argument select[multiple] option{padding:3px}
1115 1115
 			</style>
1116 1116
 			<?php
1117
-			$output = ob_get_clean();
1117
+			    $output = ob_get_clean();
1118 1118
 
1119
-			/*
1119
+			    /*
1120 1120
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1121 1121
 			 */
1122 1122
 
1123
-			return str_replace( array(
1124
-				'<style>',
1125
-				'</style>'
1126
-			), '', $output );
1127
-		}
1123
+			    return str_replace( array(
1124
+				    '<style>',
1125
+				    '</style>'
1126
+			    ), '', $output );
1127
+		    }
1128 1128
 
1129
-		/**
1129
+		    /**
1130 1130
 		 * Gets some JS for the widgets screen.
1131 1131
 		 *
1132 1132
 		 * @return mixed
1133 1133
 		 */
1134
-		public function widget_js() {
1135
-			ob_start();
1136
-			?>
1134
+		    public function widget_js() {
1135
+			    ob_start();
1136
+			    ?>
1137 1137
 			<script>
1138 1138
 
1139 1139
 				/**
@@ -1282,110 +1282,110 @@  discard block
 block discarded – undo
1282 1282
 
1283 1283
 				}
1284 1284
 				<?php do_action( 'wp_super_duper_widget_js', $this ); ?>
1285
-			</script>
1285
+    			</script>
1286 1286
 			<?php
1287
-			$output = ob_get_clean();
1287
+			    $output = ob_get_clean();
1288 1288
 
1289
-			/*
1289
+			    /*
1290 1290
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1291 1291
 			 */
1292 1292
 
1293
-			return str_replace( array(
1294
-				'<script>',
1295
-				'</script>'
1296
-			), '', $output );
1297
-		}
1293
+			    return str_replace( array(
1294
+				    '<script>',
1295
+				    '</script>'
1296
+			    ), '', $output );
1297
+		    }
1298 1298
 
1299 1299
 
1300
-		/**
1300
+		    /**
1301 1301
 		 * Set the name from the argument key.
1302 1302
 		 *
1303 1303
 		 * @param $options
1304 1304
 		 *
1305 1305
 		 * @return mixed
1306 1306
 		 */
1307
-		private function add_name_from_key( $options, $arguments = false ) {
1308
-			if ( ! empty( $options['arguments'] ) ) {
1309
-				foreach ( $options['arguments'] as $key => $val ) {
1310
-					$options['arguments'][ $key ]['name'] = $key;
1311
-				}
1312
-			} elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1313
-				foreach ( $options as $key => $val ) {
1314
-					$options[ $key ]['name'] = $key;
1315
-				}
1316
-			}
1317
-
1318
-			return $options;
1319
-		}
1320
-
1321
-		/**
1307
+		    private function add_name_from_key( $options, $arguments = false ) {
1308
+			    if ( ! empty( $options['arguments'] ) ) {
1309
+				    foreach ( $options['arguments'] as $key => $val ) {
1310
+					    $options['arguments'][ $key ]['name'] = $key;
1311
+				    }
1312
+			    } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) {
1313
+				    foreach ( $options as $key => $val ) {
1314
+					    $options[ $key ]['name'] = $key;
1315
+				    }
1316
+			    }
1317
+
1318
+			    return $options;
1319
+		    }
1320
+
1321
+		    /**
1322 1322
 		 * Register the parent shortcode.
1323 1323
 		 *
1324 1324
 		 * @since 1.0.0
1325 1325
 		 */
1326
-		public function register_shortcode() {
1327
-			add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1328
-			add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1329
-		}
1326
+		    public function register_shortcode() {
1327
+			    add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) );
1328
+			    add_action( 'wp_ajax_super_duper_output_shortcode', array( $this, 'render_shortcode' ) );
1329
+		    }
1330 1330
 
1331
-		/**
1331
+		    /**
1332 1332
 		 * Render the shortcode via ajax so we can return it to Gutenberg.
1333 1333
 		 *
1334 1334
 		 * @since 1.0.0
1335 1335
 		 */
1336
-		public function render_shortcode() {
1337
-			check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1338
-			if ( ! current_user_can( 'manage_options' ) ) {
1339
-				wp_die();
1340
-			}
1341
-
1342
-			// we might need the $post value here so lets set it.
1343
-			if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1344
-				$post_obj = get_post( absint( $_POST['post_id'] ) );
1345
-				if ( ! empty( $post_obj ) && empty( $post ) ) {
1346
-					global $post;
1347
-					$post = $post_obj;
1348
-				}
1349
-			}
1350
-
1351
-			if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1352
-				$is_preview = $this->is_preview();
1353
-				$shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1354
-				$attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1355
-				$attributes       = '';
1356
-				if ( ! empty( $attributes_array ) ) {
1357
-					foreach ( $attributes_array as $key => $value ) {
1358
-						if ( is_array( $value ) ) {
1359
-							$value = implode( ",", $value );
1360
-						}
1361
-
1362
-						if ( ! empty( $value ) ) {
1363
-							$value = wp_unslash( $value );
1364
-
1365
-							// Encode [ and ].
1366
-							if ( $is_preview ) {
1367
-								$value = $this->encode_shortcodes( $value );
1368
-							}
1369
-						}
1370
-						$attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1371
-					}
1372
-				}
1373
-
1374
-				$shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1375
-
1376
-				$content = do_shortcode( $shortcode );
1377
-
1378
-				// Decode [ and ].
1379
-				if ( ! empty( $content ) && $is_preview ) {
1380
-					$content = $this->decode_shortcodes( $content );
1381
-				}
1382
-
1383
-				echo $content;
1384
-			}
1385
-			wp_die();
1386
-		}
1387
-
1388
-		/**
1336
+		    public function render_shortcode() {
1337
+			    check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true );
1338
+			    if ( ! current_user_can( 'manage_options' ) ) {
1339
+				    wp_die();
1340
+			    }
1341
+
1342
+			    // we might need the $post value here so lets set it.
1343
+			    if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) {
1344
+				    $post_obj = get_post( absint( $_POST['post_id'] ) );
1345
+				    if ( ! empty( $post_obj ) && empty( $post ) ) {
1346
+					    global $post;
1347
+					    $post = $post_obj;
1348
+				    }
1349
+			    }
1350
+
1351
+			    if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) {
1352
+				    $is_preview = $this->is_preview();
1353
+				    $shortcode_name   = sanitize_title_with_dashes( $_POST['shortcode'] );
1354
+				    $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array();
1355
+				    $attributes       = '';
1356
+				    if ( ! empty( $attributes_array ) ) {
1357
+					    foreach ( $attributes_array as $key => $value ) {
1358
+						    if ( is_array( $value ) ) {
1359
+							    $value = implode( ",", $value );
1360
+						    }
1361
+
1362
+						    if ( ! empty( $value ) ) {
1363
+							    $value = wp_unslash( $value );
1364
+
1365
+							    // Encode [ and ].
1366
+							    if ( $is_preview ) {
1367
+								    $value = $this->encode_shortcodes( $value );
1368
+							    }
1369
+						    }
1370
+						    $attributes .= " " . esc_attr( sanitize_title_with_dashes( $key ) ) . "='" . esc_attr( $value ) . "' ";
1371
+					    }
1372
+				    }
1373
+
1374
+				    $shortcode = "[" . esc_attr( $shortcode_name ) . " " . $attributes . "]";
1375
+
1376
+				    $content = do_shortcode( $shortcode );
1377
+
1378
+				    // Decode [ and ].
1379
+				    if ( ! empty( $content ) && $is_preview ) {
1380
+					    $content = $this->decode_shortcodes( $content );
1381
+				    }
1382
+
1383
+				    echo $content;
1384
+			    }
1385
+			    wp_die();
1386
+		    }
1387
+
1388
+		    /**
1389 1389
 		 * Output the shortcode.
1390 1390
 		 *
1391 1391
 		 * @param array $args
@@ -1393,22 +1393,22 @@  discard block
 block discarded – undo
1393 1393
 		 *
1394 1394
 		 * @return string
1395 1395
 		 */
1396
-		public function shortcode_output( $args = array(), $content = '' ) {
1397
-			$_instance = $args;
1396
+		    public function shortcode_output( $args = array(), $content = '' ) {
1397
+			    $_instance = $args;
1398 1398
 
1399
-			$args = $this->argument_values( $args );
1399
+			    $args = $this->argument_values( $args );
1400 1400
 
1401
-			// add extra argument so we know its a output to gutenberg
1402
-			//$args
1403
-			$args = $this->string_to_bool( $args );
1401
+			    // add extra argument so we know its a output to gutenberg
1402
+			    //$args
1403
+			    $args = $this->string_to_bool( $args );
1404 1404
 
1405
-			// if we have a enclosed shortcode we add it to the special `html` argument
1406
-			if ( ! empty( $content ) ) {
1407
-				$args['html'] = $content;
1408
-			}
1405
+			    // if we have a enclosed shortcode we add it to the special `html` argument
1406
+			    if ( ! empty( $content ) ) {
1407
+				    $args['html'] = $content;
1408
+			    }
1409 1409
 
1410
-			if ( ! $this->is_preview() ) {
1411
-				/**
1410
+			    if ( ! $this->is_preview() ) {
1411
+				    /**
1412 1412
 				 * Filters the settings for a particular widget args.
1413 1413
 				 *
1414 1414
 				 * @param array          $args      The current widget instance's settings.
@@ -1418,95 +1418,95 @@  discard block
 block discarded – undo
1418 1418
 				 *@since 1.0.28
1419 1419
 				 *
1420 1420
 				 */
1421
-				$args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1422
-
1423
-				if ( ! is_array( $args ) ) {
1424
-					return $args;
1425
-				}
1426
-			}
1427
-
1428
-			$class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1429
-			$class .= " sdel-".$this->get_instance_hash();
1430
-
1431
-			$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1432
-			$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1433
-
1434
-			$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1435
-			$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1436
-
1437
-			$shortcode_args = array();
1438
-			$output         = '';
1439
-			$no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1440
-			if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1441
-				$no_wrap = true;
1442
-			}
1443
-			$main_content = $this->output( $args, $shortcode_args, $content );
1444
-			if ( $main_content && ! $no_wrap ) {
1445
-				// wrap the shortcode in a div with the same class as the widget
1446
-				$output .= '<div class="' . $class . '" ' . $attrs . '>';
1447
-				if ( ! empty( $args['title'] ) ) {
1448
-					// if its a shortcode and there is a title try to grab the title wrappers
1449
-					$shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1450
-					if ( empty( $instance ) ) {
1451
-						global $wp_registered_sidebars;
1452
-						if ( ! empty( $wp_registered_sidebars ) ) {
1453
-							foreach ( $wp_registered_sidebars as $sidebar ) {
1454
-								if ( ! empty( $sidebar['before_title'] ) ) {
1455
-									$shortcode_args['before_title'] = $sidebar['before_title'];
1456
-									$shortcode_args['after_title']  = $sidebar['after_title'];
1457
-									break;
1458
-								}
1459
-							}
1460
-						}
1461
-					}
1462
-					$output .= $this->output_title( $shortcode_args, $args );
1463
-				}
1464
-				$output .= $main_content;
1465
-				$output .= '</div>';
1466
-			} elseif ( $main_content && $no_wrap ) {
1467
-				$output .= $main_content;
1468
-			}
1469
-
1470
-			// if preview show a placeholder if empty
1471
-			if ( $this->is_preview() && $output == '' ) {
1472
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1473
-			}
1474
-
1475
-			return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1476
-		}
1477
-
1478
-		/**
1421
+				    $args = apply_filters( 'wp_super_duper_widget_display_callback', $args, $this, $_instance );
1422
+
1423
+				    if ( ! is_array( $args ) ) {
1424
+					    return $args;
1425
+				    }
1426
+			    }
1427
+
1428
+			    $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : '';
1429
+			    $class .= " sdel-".$this->get_instance_hash();
1430
+
1431
+			    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
1432
+			    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
1433
+
1434
+			    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
1435
+			    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
1436
+
1437
+			    $shortcode_args = array();
1438
+			    $output         = '';
1439
+			    $no_wrap        = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
1440
+			    if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) {
1441
+				    $no_wrap = true;
1442
+			    }
1443
+			    $main_content = $this->output( $args, $shortcode_args, $content );
1444
+			    if ( $main_content && ! $no_wrap ) {
1445
+				    // wrap the shortcode in a div with the same class as the widget
1446
+				    $output .= '<div class="' . $class . '" ' . $attrs . '>';
1447
+				    if ( ! empty( $args['title'] ) ) {
1448
+					    // if its a shortcode and there is a title try to grab the title wrappers
1449
+					    $shortcode_args = array( 'before_title' => '', 'after_title' => '' );
1450
+					    if ( empty( $instance ) ) {
1451
+						    global $wp_registered_sidebars;
1452
+						    if ( ! empty( $wp_registered_sidebars ) ) {
1453
+							    foreach ( $wp_registered_sidebars as $sidebar ) {
1454
+								    if ( ! empty( $sidebar['before_title'] ) ) {
1455
+									    $shortcode_args['before_title'] = $sidebar['before_title'];
1456
+									    $shortcode_args['after_title']  = $sidebar['after_title'];
1457
+									    break;
1458
+								    }
1459
+							    }
1460
+						    }
1461
+					    }
1462
+					    $output .= $this->output_title( $shortcode_args, $args );
1463
+				    }
1464
+				    $output .= $main_content;
1465
+				    $output .= '</div>';
1466
+			    } elseif ( $main_content && $no_wrap ) {
1467
+				    $output .= $main_content;
1468
+			    }
1469
+
1470
+			    // if preview show a placeholder if empty
1471
+			    if ( $this->is_preview() && $output == '' ) {
1472
+				    $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
1473
+			    }
1474
+
1475
+			    return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this );
1476
+		    }
1477
+
1478
+		    /**
1479 1479
 		 * Placeholder text to show if output is empty and we are on a preview/builder page.
1480 1480
 		 *
1481 1481
 		 * @param string $name
1482 1482
 		 *
1483 1483
 		 * @return string
1484 1484
 		 */
1485
-		public function preview_placeholder_text( $name = '' ) {
1486
-			return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1487
-		}
1485
+		    public function preview_placeholder_text( $name = '' ) {
1486
+			    return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . wp_sprintf( __( 'Placeholder for: %s', 'ayecode-connect' ), $name ) . "</div>";
1487
+		    }
1488 1488
 
1489
-		/**
1489
+		    /**
1490 1490
 		 * Sometimes booleans values can be turned to strings, so we fix that.
1491 1491
 		 *
1492 1492
 		 * @param $options
1493 1493
 		 *
1494 1494
 		 * @return mixed
1495 1495
 		 */
1496
-		public function string_to_bool( $options ) {
1497
-			// convert bool strings to booleans
1498
-			foreach ( $options as $key => $val ) {
1499
-				if ( $val == 'false' ) {
1500
-					$options[ $key ] = false;
1501
-				} elseif ( $val == 'true' ) {
1502
-					$options[ $key ] = true;
1503
-				}
1504
-			}
1505
-
1506
-			return $options;
1507
-		}
1508
-
1509
-		/**
1496
+		    public function string_to_bool( $options ) {
1497
+			    // convert bool strings to booleans
1498
+			    foreach ( $options as $key => $val ) {
1499
+				    if ( $val == 'false' ) {
1500
+					    $options[ $key ] = false;
1501
+				    } elseif ( $val == 'true' ) {
1502
+					    $options[ $key ] = true;
1503
+				    }
1504
+			    }
1505
+
1506
+			    return $options;
1507
+		    }
1508
+
1509
+		    /**
1510 1510
 		 * Get the argument values that are also filterable.
1511 1511
 		 *
1512 1512
 		 * @param $instance
@@ -1515,159 +1515,159 @@  discard block
 block discarded – undo
1515 1515
 		 *@since 1.0.12 Don't set checkbox default value if the value is empty.
1516 1516
 		 *
1517 1517
 		 */
1518
-		public function argument_values( $instance ) {
1519
-			$argument_values = array();
1520
-
1521
-			// set widget instance
1522
-			$this->instance = $instance;
1523
-
1524
-			if ( empty( $this->arguments ) ) {
1525
-				$this->arguments = $this->get_arguments();
1526
-			}
1527
-
1528
-			if ( ! empty( $this->arguments ) ) {
1529
-				foreach ( $this->arguments as $key => $args ) {
1530
-					// set the input name from the key
1531
-					$args['name'] = $key;
1532
-					//
1533
-					$argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1534
-					if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1535
-						// don't set default for an empty checkbox
1536
-					} elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1537
-						$argument_values[ $key ] = $args['default'];
1538
-					}
1539
-				}
1540
-			}
1541
-
1542
-			return $argument_values;
1543
-		}
1544
-
1545
-		/**
1518
+		    public function argument_values( $instance ) {
1519
+			    $argument_values = array();
1520
+
1521
+			    // set widget instance
1522
+			    $this->instance = $instance;
1523
+
1524
+			    if ( empty( $this->arguments ) ) {
1525
+				    $this->arguments = $this->get_arguments();
1526
+			    }
1527
+
1528
+			    if ( ! empty( $this->arguments ) ) {
1529
+				    foreach ( $this->arguments as $key => $args ) {
1530
+					    // set the input name from the key
1531
+					    $args['name'] = $key;
1532
+					    //
1533
+					    $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : '';
1534
+					    if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) {
1535
+						    // don't set default for an empty checkbox
1536
+					    } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) {
1537
+						    $argument_values[ $key ] = $args['default'];
1538
+					    }
1539
+				    }
1540
+			    }
1541
+
1542
+			    return $argument_values;
1543
+		    }
1544
+
1545
+		    /**
1546 1546
 		 * Set arguments in super duper.
1547 1547
 		 *
1548 1548
 		 * @return array Set arguments.
1549 1549
 		 *@since 1.0.0
1550 1550
 		 *
1551 1551
 		 */
1552
-		public function set_arguments() {
1553
-			return $this->arguments;
1554
-		}
1552
+		    public function set_arguments() {
1553
+			    return $this->arguments;
1554
+		    }
1555 1555
 
1556
-		/**
1556
+		    /**
1557 1557
 		 * Get arguments in super duper.
1558 1558
 		 *
1559 1559
 		 * @return array Get arguments.
1560 1560
 		 *@since 1.0.0
1561 1561
 		 *
1562 1562
 		 */
1563
-		public function get_arguments() {
1564
-			if ( empty( $this->arguments ) ) {
1565
-				$this->arguments = $this->set_arguments();
1566
-			}
1563
+		    public function get_arguments() {
1564
+			    if ( empty( $this->arguments ) ) {
1565
+				    $this->arguments = $this->set_arguments();
1566
+			    }
1567 1567
 
1568
-			$this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1569
-			$this->arguments = $this->add_name_from_key( $this->arguments, true );
1568
+			    $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance );
1569
+			    $this->arguments = $this->add_name_from_key( $this->arguments, true );
1570 1570
 
1571
-			return $this->arguments;
1572
-		}
1571
+			    return $this->arguments;
1572
+		    }
1573 1573
 
1574
-		/**
1574
+		    /**
1575 1575
 		 * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class.
1576 1576
 		 *
1577 1577
 		 * @param array $args
1578 1578
 		 * @param array $widget_args
1579 1579
 		 * @param string $content
1580 1580
 		 */
1581
-		public function output( $args = array(), $widget_args = array(), $content = '' ) {
1581
+		    public function output( $args = array(), $widget_args = array(), $content = '' ) {
1582 1582
 
1583
-		}
1583
+		    }
1584 1584
 
1585
-		/**
1585
+		    /**
1586 1586
 		 * Add the dynamic block code inline when the wp-block in enqueued.
1587 1587
 		 */
1588
-		public function register_block() {
1589
-			wp_add_inline_script( 'wp-blocks', $this->block() );
1590
-			if ( class_exists( 'SiteOrigin_Panels' ) ) {
1591
-				wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1592
-			}
1593
-		}
1594
-
1595
-		/**
1588
+		    public function register_block() {
1589
+			    wp_add_inline_script( 'wp-blocks', $this->block() );
1590
+			    if ( class_exists( 'SiteOrigin_Panels' ) ) {
1591
+				    wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() );
1592
+			    }
1593
+		    }
1594
+
1595
+		    /**
1596 1596
 		 * Check if we need to show advanced options.
1597 1597
 		 *
1598 1598
 		 * @return bool
1599 1599
 		 */
1600
-		public function block_show_advanced() {
1600
+		    public function block_show_advanced() {
1601 1601
 
1602
-			$show      = false;
1603
-			$arguments = $this->get_arguments();
1602
+			    $show      = false;
1603
+			    $arguments = $this->get_arguments();
1604 1604
 
1605
-			if ( ! empty( $arguments ) ) {
1606
-				foreach ( $arguments as $argument ) {
1607
-					if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1608
-						$show = true;
1609
-						break; // no need to continue if we know we have it
1610
-					}
1611
-				}
1612
-			}
1605
+			    if ( ! empty( $arguments ) ) {
1606
+				    foreach ( $arguments as $argument ) {
1607
+					    if ( isset( $argument['advanced'] ) && $argument['advanced'] ) {
1608
+						    $show = true;
1609
+						    break; // no need to continue if we know we have it
1610
+					    }
1611
+				    }
1612
+			    }
1613 1613
 
1614
-			return $show;
1615
-		}
1614
+			    return $show;
1615
+		    }
1616 1616
 
1617
-		/**
1617
+		    /**
1618 1618
 		 * Get the url path to the current folder.
1619 1619
 		 *
1620 1620
 		 * @return string
1621 1621
 		 */
1622
-		public function get_url() {
1623
-			$url = $this->url;
1622
+		    public function get_url() {
1623
+			    $url = $this->url;
1624 1624
 
1625
-			if ( ! $url ) {
1626
-				$content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1627
-				$content_url = untrailingslashit( WP_CONTENT_URL );
1625
+			    if ( ! $url ) {
1626
+				    $content_dir = wp_normalize_path( untrailingslashit( WP_CONTENT_DIR ) );
1627
+				    $content_url = untrailingslashit( WP_CONTENT_URL );
1628 1628
 
1629
-				// Replace http:// to https://.
1630
-				if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1631
-					$content_url = str_replace( 'http://', 'https://', $content_url );
1632
-				}
1629
+				    // Replace http:// to https://.
1630
+				    if ( strpos( $content_url, 'http://' ) === 0 && strpos( plugins_url(), 'https://' ) === 0 ) {
1631
+					    $content_url = str_replace( 'http://', 'https://', $content_url );
1632
+				    }
1633 1633
 
1634
-				// Check if we are inside a plugin
1635
-				$file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1636
-				$url = str_replace( $content_dir, $content_url, $file_dir );
1637
-				$url = trailingslashit( $url );
1638
-				$this->url = $url;
1639
-			}
1634
+				    // Check if we are inside a plugin
1635
+				    $file_dir = str_replace( "/includes", "", wp_normalize_path( dirname( __FILE__ ) ) );
1636
+				    $url = str_replace( $content_dir, $content_url, $file_dir );
1637
+				    $url = trailingslashit( $url );
1638
+				    $this->url = $url;
1639
+			    }
1640 1640
 
1641
-			return $url;
1642
-		}
1641
+			    return $url;
1642
+		    }
1643 1643
 
1644
-		/**
1644
+		    /**
1645 1645
 		 * Get the url path to the current folder.
1646 1646
 		 *
1647 1647
 		 * @return string
1648 1648
 		 */
1649
-		public function get_url_old() {
1649
+		    public function get_url_old() {
1650 1650
 
1651
-			$url = $this->url;
1651
+			    $url = $this->url;
1652 1652
 
1653
-			if ( ! $url ) {
1654
-				// check if we are inside a plugin
1655
-				$file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1653
+			    if ( ! $url ) {
1654
+				    // check if we are inside a plugin
1655
+				    $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) );
1656 1656
 
1657
-				$dir_parts = explode( "/wp-content/", $file_dir );
1658
-				$url_parts = explode( "/wp-content/", plugins_url() );
1657
+				    $dir_parts = explode( "/wp-content/", $file_dir );
1658
+				    $url_parts = explode( "/wp-content/", plugins_url() );
1659 1659
 
1660
-				if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1661
-					$url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1662
-					$this->url = $url;
1663
-				}
1664
-			}
1660
+				    if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) {
1661
+					    $url       = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] );
1662
+					    $this->url = $url;
1663
+				    }
1664
+			    }
1665 1665
 
1666 1666
 
1667
-			return $url;
1668
-		}
1667
+			    return $url;
1668
+		    }
1669 1669
 
1670
-		/**
1670
+		    /**
1671 1671
 		 * Generate the block icon.
1672 1672
 		 *
1673 1673
 		 * Enables the use of Font Awesome icons.
@@ -1679,99 +1679,99 @@  discard block
 block discarded – undo
1679 1679
 		 * @return string
1680 1680
 		 *@since 1.1.0
1681 1681
 		 */
1682
-		public function get_block_icon( $icon ) {
1683
-
1684
-			// check if we have a Font Awesome icon
1685
-			$fa_type = '';
1686
-			if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1687
-				$fa_type = 'solid';
1688
-			} elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1689
-				$fa_type = 'regular';
1690
-			} elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1691
-				$fa_type = 'brands';
1692
-			} else {
1693
-				$icon = "'" . $icon . "'";
1694
-			}
1682
+		    public function get_block_icon( $icon ) {
1683
+
1684
+			    // check if we have a Font Awesome icon
1685
+			    $fa_type = '';
1686
+			    if ( substr( $icon, 0, 7 ) === "fas fa-" ) {
1687
+				    $fa_type = 'solid';
1688
+			    } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) {
1689
+				    $fa_type = 'regular';
1690
+			    } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) {
1691
+				    $fa_type = 'brands';
1692
+			    } else {
1693
+				    $icon = "'" . $icon . "'";
1694
+			    }
1695
+
1696
+			    // set the icon if we found one
1697
+			    if ( $fa_type ) {
1698
+				    $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1699
+				    $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 . "'}))";
1700
+			    }
1701
+
1702
+			    return $icon;
1703
+		    }
1704
+
1705
+		    public function group_arguments( $arguments ) {
1706
+			    if ( ! empty( $arguments ) ) {
1707
+				    $temp_arguments = array();
1708
+				    $general        = __( "General", 'ayecode-connect' );
1709
+				    $add_sections   = false;
1710
+				    foreach ( $arguments as $key => $args ) {
1711
+					    if ( isset( $args['group'] ) ) {
1712
+						    $temp_arguments[ $args['group'] ][ $key ] = $args;
1713
+						    $add_sections                             = true;
1714
+					    } else {
1715
+						    $temp_arguments[ $general ][ $key ] = $args;
1716
+					    }
1717
+				    }
1718
+
1719
+				    // only add sections if more than one
1720
+				    if ( $add_sections ) {
1721
+					    $arguments = $temp_arguments;
1722
+				    }
1723
+			    }
1724
+
1725
+			    return $arguments;
1726
+		    }
1727
+
1728
+		    /**
1729
+		 * Parse used group tabs.
1730
+		 *
1731
+		 * @since 1.1.17
1732
+		 */
1733
+		    public function group_block_tabs( $tabs, $arguments ) {
1734
+			    if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1735
+				    $has_sections = false;
1695 1736
 
1696
-			// set the icon if we found one
1697
-			if ( $fa_type ) {
1698
-				$fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon );
1699
-				$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 . "'}))";
1700
-			}
1737
+				    foreach ( $this->arguments as $key => $args ) {
1738
+					    if ( isset( $args['group'] ) ) {
1739
+						    $has_sections = true;
1740
+						    break;
1741
+					    }
1742
+				    }
1701 1743
 
1702
-			return $icon;
1703
-		}
1744
+				    if ( ! $has_sections ) {
1745
+					    return $tabs;
1746
+				    }
1704 1747
 
1705
-		public function group_arguments( $arguments ) {
1706
-			if ( ! empty( $arguments ) ) {
1707
-				$temp_arguments = array();
1708
-				$general        = __( "General", 'ayecode-connect' );
1709
-				$add_sections   = false;
1710
-				foreach ( $arguments as $key => $args ) {
1711
-					if ( isset( $args['group'] ) ) {
1712
-						$temp_arguments[ $args['group'] ][ $key ] = $args;
1713
-						$add_sections                             = true;
1714
-					} else {
1715
-						$temp_arguments[ $general ][ $key ] = $args;
1716
-					}
1717
-				}
1748
+				    $new_tabs = array();
1718 1749
 
1719
-				// only add sections if more than one
1720
-				if ( $add_sections ) {
1721
-					$arguments = $temp_arguments;
1722
-				}
1723
-			}
1750
+				    foreach ( $tabs as $tab_key => $tab ) {
1751
+					    $new_groups = array();
1724 1752
 
1725
-			return $arguments;
1726
-		}
1753
+					    if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1754
+						    foreach ( $tab['groups'] as $group ) {
1755
+							    if ( isset( $arguments[ $group ] ) ) {
1756
+								    $new_groups[] = $group;
1757
+							    }
1758
+						    }
1759
+					    }
1727 1760
 
1728
-		/**
1729
-		 * Parse used group tabs.
1730
-		 *
1731
-		 * @since 1.1.17
1732
-		 */
1733
-		public function group_block_tabs( $tabs, $arguments ) {
1734
-			if ( ! empty( $tabs ) && ! empty( $arguments ) ) {
1735
-				$has_sections = false;
1736
-
1737
-				foreach ( $this->arguments as $key => $args ) {
1738
-					if ( isset( $args['group'] ) ) {
1739
-						$has_sections = true;
1740
-						break;
1741
-					}
1742
-				}
1743
-
1744
-				if ( ! $has_sections ) {
1745
-					return $tabs;
1746
-				}
1747
-
1748
-				$new_tabs = array();
1749
-
1750
-				foreach ( $tabs as $tab_key => $tab ) {
1751
-					$new_groups = array();
1752
-
1753
-					if ( ! empty( $tab['groups'] ) && is_array( $tab['groups'] ) ) {
1754
-						foreach ( $tab['groups'] as $group ) {
1755
-							if ( isset( $arguments[ $group ] ) ) {
1756
-								$new_groups[] = $group;
1757
-							}
1758
-						}
1759
-					}
1761
+					    if ( ! empty( $new_groups ) ) {
1762
+						    $tab['groups'] = $new_groups;
1760 1763
 
1761
-					if ( ! empty( $new_groups ) ) {
1762
-						$tab['groups'] = $new_groups;
1764
+						    $new_tabs[ $tab_key ] = $tab;
1765
+					    }
1766
+				    }
1763 1767
 
1764
-						$new_tabs[ $tab_key ] = $tab;
1765
-					}
1766
-				}
1767
-
1768
-				$tabs = $new_tabs;
1769
-			}
1768
+				    $tabs = $new_tabs;
1769
+			    }
1770 1770
 
1771
-			return $tabs;
1772
-		}
1771
+			    return $tabs;
1772
+		    }
1773 1773
 
1774
-		/**
1774
+		    /**
1775 1775
 		 * Output the JS for building the dynamic Guntenberg block.
1776 1776
 		 *
1777 1777
 		 * @return mixed
@@ -1779,18 +1779,18 @@  discard block
 block discarded – undo
1779 1779
 		 * @since 1.1.0 Font Awesome classes can be used for icons.
1780 1780
 		 * @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.
1781 1781
 		 */
1782
-		public function block() {
1783
-			global $sd_is_js_functions_loaded, $aui_bs5;
1782
+		    public function block() {
1783
+			    global $sd_is_js_functions_loaded, $aui_bs5;
1784 1784
 
1785
-			$show_advanced = $this->block_show_advanced();
1785
+			    $show_advanced = $this->block_show_advanced();
1786 1786
 
1787
-			ob_start();
1788
-			?>
1789
-			<script>
1787
+			    ob_start();
1788
+			    ?>
1789
+    			<script>
1790 1790
 			<?php
1791
-			if ( ! $sd_is_js_functions_loaded ) {
1792
-				$sd_is_js_functions_loaded = true;
1793
-			?>
1791
+			    if ( ! $sd_is_js_functions_loaded ) {
1792
+				    $sd_is_js_functions_loaded = true;
1793
+			    ?>
1794 1794
 function sd_show_view_options($this){
1795 1795
 	if(jQuery($this).html().length){
1796 1796
 		jQuery($this).html('');
@@ -2290,8 +2290,8 @@  discard block
 block discarded – undo
2290 2290
 				$classes = [];
2291 2291
 
2292 2292
 				<?php
2293
-				if($aui_bs5){
2294
-					?>
2293
+				    if($aui_bs5){
2294
+					    ?>
2295 2295
 				$aui_bs5 = true;
2296 2296
 				$p_ml = 'ms-';
2297 2297
 				$p_mr = 'me-';
@@ -2299,8 +2299,8 @@  discard block
 block discarded – undo
2299 2299
 				$p_pl = 'ps-';
2300 2300
 				$p_pr = 'pe-';
2301 2301
 					<?php
2302
-				}else{
2303
-						?>
2302
+				    }else{
2303
+						    ?>
2304 2304
 				$aui_bs5 = false;
2305 2305
 				$p_ml = 'ml-';
2306 2306
 				$p_mr = 'mr-';
@@ -2308,8 +2308,8 @@  discard block
 block discarded – undo
2308 2308
 				$p_pl = 'pl-';
2309 2309
 				$p_pr = 'pr-';
2310 2310
 					<?php
2311
-				}
2312
-				?>
2311
+				    }
2312
+				    ?>
2313 2313
 
2314 2314
 				// margins
2315 2315
 				if ( $args['mt'] !== undefined && $args['mt'] !== '' ) { $classes.push( "mt-" + $args['mt'] );  $mt = $args['mt']; }else{$mt = null;}
@@ -2493,12 +2493,12 @@  discard block
 block discarded – undo
2493 2493
 			<?php
2494 2494
 
2495 2495
 
2496
-			}
2496
+			    }
2497 2497
 
2498
-			if(method_exists($this,'block_global_js')){
2499
-					echo $this->block_global_js();
2500
-			}
2501
-			?>
2498
+			    if(method_exists($this,'block_global_js')){
2499
+					    echo $this->block_global_js();
2500
+			    }
2501
+			    ?>
2502 2502
 
2503 2503
 jQuery(function() {
2504 2504
 
@@ -2551,13 +2551,13 @@  discard block
 block discarded – undo
2551 2551
 						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/.
2552 2552
 						supports: {
2553 2553
 							<?php
2554
-							if(!isset($this->options['block-supports']['renaming'])){
2555
-								$this->options['block-supports']['renaming'] = false;
2556
-							}
2557
-							if ( isset( $this->options['block-supports'] ) ) {
2558
-								echo $this->array_to_attributes( $this->options['block-supports'] );
2559
-							}
2560
-							?>
2554
+							    if(!isset($this->options['block-supports']['renaming'])){
2555
+								    $this->options['block-supports']['renaming'] = false;
2556
+							    }
2557
+							    if ( isset( $this->options['block-supports'] ) ) {
2558
+								    echo $this->array_to_attributes( $this->options['block-supports'] );
2559
+							    }
2560
+							    ?>
2561 2561
 						},
2562 2562
 						__experimentalLabel( attributes, { context } ) {
2563 2563
 							var visibility_html = attributes && attributes.visibility_conditions ? ' &#128065;' : '';
@@ -2567,174 +2567,174 @@  discard block
 block discarded – undo
2567 2567
 						},
2568 2568
 						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.
2569 2569
 						<?php if ( isset( $this->options['block-keywords'] ) ) {
2570
-						echo "keywords : " . $this->options['block-keywords'] . ",";
2571
-						}
2572
-
2573
-
2574
-						// block hover preview.
2575
-						$example_args = array();
2576
-						if(!empty($this->arguments)){
2577
-							foreach($this->arguments as $key => $a_args){
2578
-								if(isset($a_args['example'])){
2579
-									$example_args[$key] = $a_args['example'];
2580
-								}
2581
-							}
2582
-						}
2583
-						$viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2584
-						$example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2585
-						if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2586
-							// no preview if set to false
2587
-						}elseif( !empty( $example_args ) ){
2588
-							echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2589
-						}elseif( !empty( $this->options['example'] ) ){
2590
-							unset($this->options['example']['viewportWidth']);
2591
-							unset($this->options['example']['innerBlocks']);
2592
-							$example_atts = $this->array_to_attributes( $this->options['example'] );
2593
-							$example_parts = array();
2594
-							if($example_atts){
2595
-								$example_parts[] = rtrim($example_atts,",");
2596
-							}
2597
-							if($viewport_width){
2598
-								$example_parts[] = $viewport_width;
2599
-							}
2600
-							if($example_inner_blocks){
2601
-								$example_parts[] = $example_inner_blocks;
2602
-							}
2603
-							if(!empty($example_parts)){
2604
-								echo "example : {".implode(',', $example_parts)."},";
2605
-							}
2606
-						}else{
2607
-							echo 'example : {viewportWidth: 500},';
2608
-						}
2609
-
2610
-
2611
-
2612
-						// limit to parent
2613
-						if( !empty( $this->options['parent'] ) ){
2614
-							echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2615
-						}
2616
-
2617
-						// limit allowed blocks
2618
-						if( !empty( $this->options['allowed-blocks'] ) ){
2619
-							echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2620
-						}
2621
-
2622
-						// maybe set no_wrap
2623
-						$no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2624
-						if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2625
-							$no_wrap = true;
2626
-						}
2627
-						if ( $no_wrap ) {
2628
-							$this->options['block-wrap'] = '';
2629
-						}
2630
-
2631
-						// maybe load the drag/drop functions.
2632
-						$img_drag_drop = false;
2633
-
2634
-						$show_alignment = false;
2635
-						// align feature
2636
-						/*echo "supports: {";
2570
+						    echo "keywords : " . $this->options['block-keywords'] . ",";
2571
+						    }
2572
+
2573
+
2574
+						    // block hover preview.
2575
+						    $example_args = array();
2576
+						    if(!empty($this->arguments)){
2577
+							    foreach($this->arguments as $key => $a_args){
2578
+								    if(isset($a_args['example'])){
2579
+									    $example_args[$key] = $a_args['example'];
2580
+								    }
2581
+							    }
2582
+						    }
2583
+						    $viewport_width = isset($this->options['example']['viewportWidth']) ? 'viewportWidth: '.absint($this->options['example']['viewportWidth']) : '';
2584
+						    $example_inner_blocks = !empty($this->options['example']['innerBlocks']) && is_array($this->options['example']['innerBlocks']) ? 'innerBlocks: ' . wp_json_encode($this->options['example']['innerBlocks']) : '';
2585
+						    if( isset( $this->options['example'] ) && $this->options['example'] === false ){
2586
+							    // no preview if set to false
2587
+						    }elseif( !empty( $example_args ) ){
2588
+							    echo "example : {attributes:{".$this->array_to_attributes( $example_args )."},$viewport_width},";
2589
+						    }elseif( !empty( $this->options['example'] ) ){
2590
+							    unset($this->options['example']['viewportWidth']);
2591
+							    unset($this->options['example']['innerBlocks']);
2592
+							    $example_atts = $this->array_to_attributes( $this->options['example'] );
2593
+							    $example_parts = array();
2594
+							    if($example_atts){
2595
+								    $example_parts[] = rtrim($example_atts,",");
2596
+							    }
2597
+							    if($viewport_width){
2598
+								    $example_parts[] = $viewport_width;
2599
+							    }
2600
+							    if($example_inner_blocks){
2601
+								    $example_parts[] = $example_inner_blocks;
2602
+							    }
2603
+							    if(!empty($example_parts)){
2604
+								    echo "example : {".implode(',', $example_parts)."},";
2605
+							    }
2606
+						    }else{
2607
+							    echo 'example : {viewportWidth: 500},';
2608
+						    }
2609
+
2610
+
2611
+
2612
+						    // limit to parent
2613
+						    if( !empty( $this->options['parent'] ) ){
2614
+							    echo "parent : " . wp_json_encode( $this->options['parent'] ) . ",";
2615
+						    }
2616
+
2617
+						    // limit allowed blocks
2618
+						    if( !empty( $this->options['allowed-blocks'] ) ){
2619
+							    echo "allowedBlocks : " . wp_json_encode( $this->options['allowed-blocks'] ) . ",";
2620
+						    }
2621
+
2622
+						    // maybe set no_wrap
2623
+						    $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false;
2624
+						    if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) {
2625
+							    $no_wrap = true;
2626
+						    }
2627
+						    if ( $no_wrap ) {
2628
+							    $this->options['block-wrap'] = '';
2629
+						    }
2630
+
2631
+						    // maybe load the drag/drop functions.
2632
+						    $img_drag_drop = false;
2633
+
2634
+						    $show_alignment = false;
2635
+						    // align feature
2636
+						    /*echo "supports: {";
2637 2637
 						echo "	align: true,";
2638 2638
 						echo "  html: false";
2639 2639
 						echo "},";*/
2640 2640
 
2641 2641
 
2642
-							echo "attributes : {";
2643
-
2644
-							if ( $show_advanced ) {
2645
-								echo "show_advanced: {";
2646
-								echo "	type: 'boolean',";
2647
-								echo "  default: false,";
2648
-								echo "},";
2649
-							}
2650
-
2651
-							// block wrap element
2652
-							if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2653
-								echo "block_wrap: {";
2654
-								echo "	type: 'string',";
2655
-								echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2656
-								echo "},";
2657
-							}
2658
-
2659
-
2660
-							if ( ! empty( $this->arguments ) ) {
2661
-
2662
-								foreach ( $this->arguments as $key => $args ) {
2663
-
2664
-									if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2665
-										$img_drag_drop = true;
2666
-									}
2667
-
2668
-									// set if we should show alignment
2669
-									if ( $key == 'alignment' ) {
2670
-										$show_alignment = true;
2671
-									}
2672
-
2673
-									$extra = '';
2674
-
2675
-									if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2676
-										continue;
2677
-									}
2678
-									elseif ( $args['type'] == 'checkbox' ) {
2679
-										$type    = 'boolean';
2680
-										$default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2681
-									} elseif ( $args['type'] == 'number' ) {
2682
-										$type    = 'number';
2683
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2684
-									} elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2685
-										$type = 'array';
2686
-										if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2687
-											$default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2688
-										} else {
2689
-											$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2690
-										}
2691
-									} elseif ( $args['type'] == 'tagselect' ) {
2692
-										$type    = 'array';
2693
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2694
-									} elseif ( $args['type'] == 'multiselect' ) {
2695
-										$type    = 'array';
2696
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2697
-									} elseif ( $args['type'] == 'image_xy' ) {
2698
-										$type    = 'object';
2699
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2700
-									} elseif ( $args['type'] == 'image' ) {
2701
-										$type    = 'string';
2702
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2703
-
2704
-										// add a field for ID
2705
-	//                                    echo $key . "_id : {";
2706
-	//                                    echo "type : 'number',";
2707
-	//                                    echo "},";
2708
-	//                                    echo $key . "_xy : {";
2709
-	//                                    echo "type : 'object',";
2710
-	//                                    echo "},";
2711
-
2712
-									} else {
2713
-										$type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2714
-										$default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2715
-
2716
-									}
2717
-									echo $key . " : {";
2718
-									echo "type : '$type',";
2719
-									echo "default : $default,";
2720
-									echo "},";
2721
-								}
2722
-							}
2723
-
2724
-							echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2725
-							echo "sd_shortcode : {type : 'string',default: ''},";
2726
-
2727
-							if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2728
-								echo "sd_shortcode_close : {type : 'string',default: ''},";
2729
-							}
2730
-
2731
-							echo "className: { type: 'string', default: '' },";
2732
-
2733
-							echo "},";
2734
-
2735
-
2736
-
2737
-						?>
2642
+							    echo "attributes : {";
2643
+
2644
+							    if ( $show_advanced ) {
2645
+								    echo "show_advanced: {";
2646
+								    echo "	type: 'boolean',";
2647
+								    echo "  default: false,";
2648
+								    echo "},";
2649
+							    }
2650
+
2651
+							    // block wrap element
2652
+							    if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this?
2653
+								    echo "block_wrap: {";
2654
+								    echo "	type: 'string',";
2655
+								    echo "  default: '" . esc_attr( $this->options['block-wrap'] ) . "',";
2656
+								    echo "},";
2657
+							    }
2658
+
2659
+
2660
+							    if ( ! empty( $this->arguments ) ) {
2661
+
2662
+								    foreach ( $this->arguments as $key => $args ) {
2663
+
2664
+									    if( $args['type'] == 'image' ||  $args['type'] == 'images' ){
2665
+										    $img_drag_drop = true;
2666
+									    }
2667
+
2668
+									    // set if we should show alignment
2669
+									    if ( $key == 'alignment' ) {
2670
+										    $show_alignment = true;
2671
+									    }
2672
+
2673
+									    $extra = '';
2674
+
2675
+									    if ( $args['type'] == 'notice' ||  $args['type'] == 'tab' ) {
2676
+										    continue;
2677
+									    }
2678
+									    elseif ( $args['type'] == 'checkbox' ) {
2679
+										    $type    = 'boolean';
2680
+										    $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false';
2681
+									    } elseif ( $args['type'] == 'number' ) {
2682
+										    $type    = 'number';
2683
+										    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2684
+									    } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) {
2685
+										    $type = 'array';
2686
+										    if ( isset( $args['default'] ) && is_array( $args['default'] ) ) {
2687
+											    $default = ! empty( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]";
2688
+										    } else {
2689
+											    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2690
+										    }
2691
+									    } elseif ( $args['type'] == 'tagselect' ) {
2692
+										    $type    = 'array';
2693
+										    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2694
+									    } elseif ( $args['type'] == 'multiselect' ) {
2695
+										    $type    = 'array';
2696
+										    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2697
+									    } elseif ( $args['type'] == 'image_xy' ) {
2698
+										    $type    = 'object';
2699
+										    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2700
+									    } elseif ( $args['type'] == 'image' ) {
2701
+										    $type    = 'string';
2702
+										    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2703
+
2704
+										    // add a field for ID
2705
+	    //                                    echo $key . "_id : {";
2706
+	    //                                    echo "type : 'number',";
2707
+	    //                                    echo "},";
2708
+	    //                                    echo $key . "_xy : {";
2709
+	    //                                    echo "type : 'object',";
2710
+	    //                                    echo "},";
2711
+
2712
+									    } else {
2713
+										    $type    = !empty($args['hidden_type']) ? esc_attr($args['hidden_type']) : 'string';
2714
+										    $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''";
2715
+
2716
+									    }
2717
+									    echo $key . " : {";
2718
+									    echo "type : '$type',";
2719
+									    echo "default : $default,";
2720
+									    echo "},";
2721
+								    }
2722
+							    }
2723
+
2724
+							    echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},";
2725
+							    echo "sd_shortcode : {type : 'string',default: ''},";
2726
+
2727
+							    if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
2728
+								    echo "sd_shortcode_close : {type : 'string',default: ''},";
2729
+							    }
2730
+
2731
+							    echo "className: { type: 'string', default: '' },";
2732
+
2733
+							    echo "},";
2734
+
2735
+
2736
+
2737
+						    ?>
2738 2738
 
2739 2739
 						// The "edit" property must be a valid function.
2740 2740
 						edit: function (props) {
@@ -2742,10 +2742,10 @@  discard block
 block discarded – undo
2742 2742
 							const selectedBlock = wp.data.select('core/block-editor').getSelectedBlock();
2743 2743
 
2744 2744
 <?php
2745
-// only include the drag/drop functions if required.
2746
-if( $img_drag_drop ){
2745
+    // only include the drag/drop functions if required.
2746
+    if( $img_drag_drop ){
2747 2747
 
2748
-?>
2748
+    ?>
2749 2749
 
2750 2750
 function enableDragSort(listClass) {
2751 2751
 	setTimeout(function(){
@@ -2809,10 +2809,10 @@  discard block
 block discarded – undo
2809 2809
 							}
2810 2810
 
2811 2811
 							<?php
2812
-							if(!empty($this->options['block-edit-raw'])) {
2813
-								echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2814
-							}else{
2815
-							?>
2812
+							    if(!empty($this->options['block-edit-raw'])) {
2813
+								    echo $this->options['block-edit-raw']; // strings have to be in single quotes, may cause issues
2814
+							    }else{
2815
+							    ?>
2816 2816
 
2817 2817
 function hasSelectedInnerBlock(props) {
2818 2818
 	const select = wp.data.select('core/editor');
@@ -2834,9 +2834,9 @@  discard block
 block discarded – undo
2834 2834
 
2835 2835
 	var $value = '';
2836 2836
 	<?php
2837
-	// if we have a post_type and a category then link them
2838
-	if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2839
-	?>
2837
+	    // if we have a post_type and a category then link them
2838
+	    if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){
2839
+	    ?>
2840 2840
 	if(typeof(prev_attributes[props.clientId]) != 'undefined' && selectedBlock && selectedBlock.clientId === props.clientId){
2841 2841
 		$pt = props.attributes.post_type;
2842 2842
 		if(post_type_rest_slugs.length){
@@ -2849,12 +2849,12 @@  discard block
 block discarded – undo
2849 2849
 			term_query_type = $pt;
2850 2850
 		}
2851 2851
 <?php
2852
-	$cat_path = '';
2853
-	if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2854
-		$cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2855
-		$cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2856
-	}
2857
-?>
2852
+	    $cat_path = '';
2853
+	    if ( ! empty( $this->arguments['post_type']['onchange_rest']['path'] ) ) {
2854
+		    $cat_path = esc_js( strip_tags( $this->arguments['post_type']['onchange_rest']['path'] ) );
2855
+		    $cat_path = str_replace( array( '&quot;', '&#039;' ), array( '"', "'" ), $cat_path );
2856
+	    }
2857
+    ?>
2858 2858
 		/* taxonomies */
2859 2859
 		if($value && 'post_type' in prev_attributes[props.clientId] && 'category' in prev_attributes[props.clientId] && run){
2860 2860
 			if (!window.gdCPTCats) {
@@ -2942,12 +2942,12 @@  discard block
 block discarded – undo
2942 2942
 		}
2943 2943
 	}
2944 2944
 	<?php } ?>
2945
-<?php
2946
-$current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2947
-if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2948
-	echo 'const { deviceType } = "";';
2945
+    <?php
2946
+    $current_screen = function_exists('get_current_screen') ? get_current_screen() : '';
2947
+    if(!empty($current_screen->base) && $current_screen->base==='widgets'){
2948
+	    echo 'const { deviceType } = "";';
2949 2949
 }else{
2950
-?>
2950
+    ?>
2951 2951
 /** Get device type const. */
2952 2952
 const wpVersion = '<?php global $wp_version; echo esc_attr($wp_version); ?>';
2953 2953
 const { deviceType } = typeof wp.data.useSelect !== 'undefined' ? wp.data.useSelect(select => {
@@ -3009,8 +3009,8 @@  discard block
 block discarded – undo
3009 3009
 										'attributes': props.attributes,
3010 3010
 										'block_parent_name': parentBlocks.length ? parentBlocks[parentBlocks.length - 1].name : '',
3011 3011
 										'post_id': <?php global $post; if ( isset( $post->ID ) ) {
3012
-										echo $post->ID;
3013
-									}else{echo '0';}?>,
3012
+										    echo $post->ID;
3013
+									    }else{echo '0';}?>,
3014 3014
 										'_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>'
3015 3015
 									};
3016 3016
 
@@ -3024,20 +3024,20 @@  discard block
 block discarded – undo
3024 3024
 										}
3025 3025
 
3026 3026
 										 <?php
3027
-										if(!empty($this->options['nested-block'])){
3028
-											?>
3027
+										    if(!empty($this->options['nested-block'])){
3028
+											    ?>
3029 3029
 											// props.setAttributes({content: env});
3030 3030
 										is_fetching = false;
3031 3031
 										prev_attributes[props.clientId] = props.attributes;
3032 3032
 											 <?php
3033
-										}else{
3034
-										?>
3033
+										    }else{
3034
+										    ?>
3035 3035
 										props.setAttributes({content: env});
3036 3036
 										is_fetching = false;
3037 3037
 										prev_attributes[props.clientId] = props.attributes;
3038 3038
 										<?php
3039
-										}
3040
-										?>
3039
+										    }
3040
+										    ?>
3041 3041
 
3042 3042
 
3043 3043
 										// if AUI is active call the js init function
@@ -3056,32 +3056,32 @@  discard block
 block discarded – undo
3056 3056
 							}
3057 3057
 
3058 3058
 							<?php
3059
-							if(!empty($this->options['block-edit-js'])) {
3060
-								echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
3061
-							}
3059
+							    if(!empty($this->options['block-edit-js'])) {
3060
+								    echo  $this->options['block-edit-js'] ; // strings have to be in single quotes, may cause issues
3061
+							    }
3062 3062
 
3063 3063
 
3064 3064
 
3065 3065
 
3066
-							if(empty($this->options['block-save-return'])){
3067
-							?>
3066
+							    if(empty($this->options['block-save-return'])){
3067
+							    ?>
3068 3068
 								///////////////////////////////////////////////////////////////////////
3069 3069
 
3070 3070
 									 // build the shortcode.
3071 3071
 								shortcode = "[<?php echo $this->options['base_id'];?>";
3072 3072
 								<?php
3073 3073
 
3074
-								if(! empty( $this->arguments )){
3074
+								    if(! empty( $this->arguments )){
3075 3075
 
3076
-								foreach($this->arguments as $key => $args){
3077
-								   // if($args['type']=='tabs'){continue;}
3076
+								    foreach($this->arguments as $key => $args){
3077
+								       // if($args['type']=='tabs'){continue;}
3078 3078
 
3079
-								   // don't add metadata arguments
3080
-								   if (substr($key, 0, 9 ) === 'metadata_') {
3081
-									   continue;
3082
-								   }
3083
-								?>
3084
-								if (props.attributes.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3079
+								       // don't add metadata arguments
3080
+								       if (substr($key, 0, 9 ) === 'metadata_') {
3081
+									       continue;
3082
+								       }
3083
+								    ?>
3084
+    								if (props.attributes.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3085 3085
 									if ('<?php echo esc_attr( $key );?>' == 'html') {
3086 3086
 									} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
3087 3087
 										shortcode += props.attributes.<?php echo esc_attr( $key );?>.length && ( props.attributes.<?php echo esc_attr( $key );?>.x.length || props.attributes.<?php echo esc_attr( $key );?>.y.length ) ? " <?php echo esc_attr( $key );?>='{x:" + props.attributes.<?php echo esc_attr( $key );?>.x + ",y:"+props.attributes.<?php echo esc_attr( $key );?>.y +"}' " : "";
@@ -3091,10 +3091,10 @@  discard block
 block discarded – undo
3091 3091
 									}
3092 3092
 								}
3093 3093
 								<?php
3094
-								}
3095
-								}
3094
+								    }
3095
+								    }
3096 3096
 
3097
-								?>
3097
+								    ?>
3098 3098
 								shortcode += "]";
3099 3099
 
3100 3100
 								if(shortcode){
@@ -3106,17 +3106,17 @@  discard block
 block discarded – undo
3106 3106
 
3107 3107
 
3108 3108
 									<?php
3109
-									if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3110
-										echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3111
-									}
3112
-									?>
3109
+									    if(!empty($this->options['nested-block']) || !empty($this->arguments['html']) ){
3110
+										    echo "props.setAttributes({sd_shortcode_close: '[/".esc_attr( $this->options['base_id'] )."]'});";
3111
+									    }
3112
+									    ?>
3113 3113
 								}
3114 3114
 
3115 3115
 
3116 3116
 							///////////////////////////////////////////////////////////////////////
3117 3117
 							<?php
3118
-							} // end nested block check
3119
-							?>
3118
+							    } // end nested block check
3119
+							    ?>
3120 3120
 
3121 3121
 							return [
3122 3122
 
@@ -3140,10 +3140,10 @@  discard block
 block discarded – undo
3140 3140
 
3141 3141
 									<?php
3142 3142
 
3143
-									if(! empty( $this->arguments )){
3143
+									    if(! empty( $this->arguments )){
3144 3144
 
3145
-									if ( $show_advanced ) {
3146
-									?>
3145
+									    if ( $show_advanced ) {
3146
+									    ?>
3147 3147
 									el('div', {
3148 3148
 											style: {'padding-left': '16px','padding-right': '16px'}
3149 3149
 										},
@@ -3160,133 +3160,133 @@  discard block
 block discarded – undo
3160 3160
 									)
3161 3161
 									,
3162 3162
 									<?php
3163
-									}
3164
-
3165
-									$arguments = $this->group_arguments( $this->arguments );
3166
-									$block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3167
-
3168
-									// Do we have sections?
3169
-									$has_sections = $arguments == $this->arguments ? false : true;
3170
-
3171
-									if($has_sections){
3172
-									$panel_count = 0;
3173
-									$open_tab = '';
3174
-
3175
-									$open_tab_groups = array();
3176
-									$used_tabs = array();
3177
-
3178
-									foreach ( $arguments as $key => $args ) {
3179
-										$close_tab = false;
3180
-										$close_tabs = false;
3181
-
3182
-										 if ( ! empty( $block_group_tabs ) ) {
3183
-											foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3184
-												if ( in_array( $key, $tab_args['groups'] ) ) {
3185
-													$open_tab_groups[] = $key;
3186
-
3187
-													if ( $open_tab != $tab_name ) {
3188
-														$tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3189
-														$tab_args['tab']['open'] = true;
3190
-
3191
-														$this->block_tab_start( '', $tab_args );
3192
-														$open_tab = $tab_name;
3193
-														$used_tabs[] = $tab_name;
3194
-													}
3195
-
3196
-													if ( $open_tab_groups == $tab_args['groups'] ) {
3197
-														$close_tab = true;
3198
-														$open_tab_groups = array();
3199
-
3200
-														if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3201
-															$close_tabs = true;
3202
-														}
3203
-													}
3204
-												}
3205
-											}
3206
-										}
3207
-										?>
3163
+									    }
3164
+
3165
+									    $arguments = $this->group_arguments( $this->arguments );
3166
+									    $block_group_tabs = ! empty( $this->options['block_group_tabs'] ) ? $this->group_block_tabs( $this->options['block_group_tabs'], $arguments ) : array();
3167
+
3168
+									    // Do we have sections?
3169
+									    $has_sections = $arguments == $this->arguments ? false : true;
3170
+
3171
+									    if($has_sections){
3172
+									    $panel_count = 0;
3173
+									    $open_tab = '';
3174
+
3175
+									    $open_tab_groups = array();
3176
+									    $used_tabs = array();
3177
+
3178
+									    foreach ( $arguments as $key => $args ) {
3179
+										    $close_tab = false;
3180
+										    $close_tabs = false;
3181
+
3182
+										     if ( ! empty( $block_group_tabs ) ) {
3183
+											    foreach ( $block_group_tabs as $tab_name => $tab_args ) {
3184
+												    if ( in_array( $key, $tab_args['groups'] ) ) {
3185
+													    $open_tab_groups[] = $key;
3186
+
3187
+													    if ( $open_tab != $tab_name ) {
3188
+														    $tab_args['tab']['tabs_open'] = $open_tab == '' ? true : false;
3189
+														    $tab_args['tab']['open'] = true;
3190
+
3191
+														    $this->block_tab_start( '', $tab_args );
3192
+														    $open_tab = $tab_name;
3193
+														    $used_tabs[] = $tab_name;
3194
+													    }
3195
+
3196
+													    if ( $open_tab_groups == $tab_args['groups'] ) {
3197
+														    $close_tab = true;
3198
+														    $open_tab_groups = array();
3199
+
3200
+														    if ( $used_tabs == array_keys( $block_group_tabs ) ) {
3201
+															    $close_tabs = true;
3202
+														    }
3203
+													    }
3204
+												    }
3205
+											    }
3206
+										    }
3207
+										    ?>
3208 3208
 										el(wp.components.PanelBody, {
3209 3209
 												title: '<?php esc_attr_e( $key ); ?>',
3210 3210
 												initialOpen: <?php if ( $panel_count ) {
3211
-												echo "false";
3212
-											} else {
3213
-												echo "true";
3214
-											}?>
3215
-											},
3211
+												    echo "false";
3212
+											    } else {
3213
+												    echo "true";
3214
+											    }?>
3215
+    											},
3216 3216
 											<?php
3217
-											foreach ( $args as $k => $a ) {
3218
-												$this->block_tab_start( $k, $a );
3219
-												$this->block_row_start( $k, $a );
3220
-												$this->build_block_arguments( $k, $a );
3221
-												$this->block_row_end( $k, $a );
3222
-												$this->block_tab_end( $k, $a );
3223
-											}
3224
-											?>
3225
-										),
3217
+											    foreach ( $args as $k => $a ) {
3218
+												    $this->block_tab_start( $k, $a );
3219
+												    $this->block_row_start( $k, $a );
3220
+												    $this->build_block_arguments( $k, $a );
3221
+												    $this->block_row_end( $k, $a );
3222
+												    $this->block_tab_end( $k, $a );
3223
+											    }
3224
+											    ?>
3225
+    										),
3226 3226
 										<?php
3227
-										$panel_count ++;
3228
-
3229
-										if($close_tab || $close_tabs){
3230
-											$tab_args = array(
3231
-												'tab'	=> array(
3232
-													'tabs_close' => $close_tabs,
3233
-												'close' => true,
3234
-												)
3235
-
3236
-											);
3237
-											$this->block_tab_end( '', $tab_args );
3238
-//											echo '###close'; print_r($tab_args);
3239
-											$panel_count = 0;
3240
-										}
3241
-//
3242
-
3243
-									}
3244
-									}else {
3245
-									?>
3227
+										    $panel_count ++;
3228
+
3229
+										    if($close_tab || $close_tabs){
3230
+											    $tab_args = array(
3231
+												    'tab'	=> array(
3232
+													    'tabs_close' => $close_tabs,
3233
+												    'close' => true,
3234
+												    )
3235
+
3236
+											    );
3237
+											    $this->block_tab_end( '', $tab_args );
3238
+    //											echo '###close'; print_r($tab_args);
3239
+											    $panel_count = 0;
3240
+										    }
3241
+    //
3242
+
3243
+									    }
3244
+									    }else {
3245
+									    ?>
3246 3246
 									el(wp.components.PanelBody, {
3247 3247
 											title: '<?php esc_attr_e( "Settings", 'ayecode-connect' ); ?>',
3248 3248
 											initialOpen: true
3249 3249
 										},
3250 3250
 										<?php
3251
-										foreach ( $this->arguments as $key => $args ) {
3252
-											$this->block_row_start( $key, $args );
3253
-											$this->build_block_arguments( $key, $args );
3254
-											$this->block_row_end( $key, $args );
3255
-										}
3256
-										?>
3257
-									),
3251
+										    foreach ( $this->arguments as $key => $args ) {
3252
+											    $this->block_row_start( $key, $args );
3253
+											    $this->build_block_arguments( $key, $args );
3254
+											    $this->block_row_end( $key, $args );
3255
+										    }
3256
+										    ?>
3257
+    									),
3258 3258
 									<?php
3259
-									}
3259
+									    }
3260 3260
 
3261
-									}
3262
-									?>
3261
+									    }
3262
+									    ?>
3263 3263
 
3264 3264
 								),
3265 3265
 
3266 3266
 								<?php
3267
-								// If the user sets block-output array then build it
3268
-								if ( ! empty( $this->options['block-output'] ) ) {
3269
-								$this->block_element( $this->options['block-output'] );
3270
-							}elseif(!empty($this->options['block-edit-return'])){
3271
-								   echo $this->options['block-edit-return'];
3272
-							}else{
3273
-								// if no block-output is set then we try and get the shortcode html output via ajax.
3274
-								$block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3275
-								?>
3276
-								el('<?php echo esc_attr($block_edit_wrap_tag); ?>', wp.blockEditor.useBlockProps({
3267
+								    // If the user sets block-output array then build it
3268
+								    if ( ! empty( $this->options['block-output'] ) ) {
3269
+								    $this->block_element( $this->options['block-output'] );
3270
+							    }elseif(!empty($this->options['block-edit-return'])){
3271
+								       echo $this->options['block-edit-return'];
3272
+							    }else{
3273
+								    // if no block-output is set then we try and get the shortcode html output via ajax.
3274
+								    $block_edit_wrap_tag = !empty($this->options['block_edit_wrap_tag']) ? esc_attr($this->options['block_edit_wrap_tag']) : 'div';
3275
+								    ?>
3276
+    								el('<?php echo esc_attr($block_edit_wrap_tag); ?>', wp.blockEditor.useBlockProps({
3277 3277
 									dangerouslySetInnerHTML: {__html: onChangeContent()},
3278 3278
 									className: props.className,
3279 3279
 									<?php //if(isset($this->arguments['visibility_conditions'])){ echo 'dataVisibilityConditionSD: props.visibility_conditions ? true : false,';} //@todo we need to implement this in the other outputs also ?>
3280 3280
 									style: {'minHeight': '30px'}
3281 3281
 								}))
3282 3282
 								<?php
3283
-								}
3284
-								?>
3285
-							]; // end return
3283
+								    }
3284
+								    ?>
3285
+    							]; // end return
3286 3286
 
3287 3287
 							<?php
3288
-							} // end block-edit-raw else
3289
-							?>
3288
+							    } // end block-edit-raw else
3289
+							    ?>
3290 3290
 						},
3291 3291
 
3292 3292
 						// The "save" property must be specified and must be a valid function.
@@ -3300,17 +3300,17 @@  discard block
 block discarded – undo
3300 3300
 							$html = '';
3301 3301
 							<?php
3302 3302
 
3303
-							if(! empty( $this->arguments )){
3303
+							    if(! empty( $this->arguments )){
3304 3304
 
3305
-							foreach($this->arguments as $key => $args){
3306
-							   // if($args['type']=='tabs'){continue;}
3305
+							    foreach($this->arguments as $key => $args){
3306
+							       // if($args['type']=='tabs'){continue;}
3307 3307
 
3308
-							   // don't add metadata arguments
3309
-							   if (substr($key, 0, 9 ) === 'metadata_') {
3310
-								   continue;
3311
-							   }
3312
-							?>
3313
-							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3308
+							       // don't add metadata arguments
3309
+							       if (substr($key, 0, 9 ) === 'metadata_') {
3310
+								       continue;
3311
+							       }
3312
+							    ?>
3313
+    							if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) {
3314 3314
 								if ('<?php echo esc_attr( $key );?>' == 'html') {
3315 3315
 									$html = attr.<?php echo esc_attr( $key );?>;
3316 3316
 								} else if ('<?php echo esc_attr( $args['type'] );?>' == 'image_xy') {
@@ -3320,20 +3320,20 @@  discard block
 block discarded – undo
3320 3320
 								}
3321 3321
 							}
3322 3322
 							<?php
3323
-							}
3324
-							}
3323
+							    }
3324
+							    }
3325 3325
 
3326
-							?>
3326
+							    ?>
3327 3327
 							content += "]";
3328 3328
 							 content = '';
3329 3329
 
3330 3330
 							<?php
3331
-//                            if(!empty($this->options['nested-block'])){
3332
-//                                ?>
3331
+    //                            if(!empty($this->options['nested-block'])){
3332
+    //                                ?>
3333 3333
 //                                $html = 'el( InnerBlocks.Content )';
3334 3334
 //                                <?php
3335
-//                            }
3336
-							?>
3335
+    //                            }
3336
+							    ?>
3337 3337
 							// if has html element
3338 3338
 							if ($html) {
3339 3339
 								//content += $html + "[/<?php echo $this->options['base_id'];?>]";
@@ -3353,38 +3353,38 @@  discard block
 block discarded – undo
3353 3353
 							}
3354 3354
 
3355 3355
 							<?php
3356
-//							if(!empty($this->options['nested-block'])){
3357
-//                                ?x>
3358
-//                              return el(
3359
-//                                    'div',
3360
-//                                    { className: props.className,
3361
-//                                        style: {'minHeight': '300px','position':'relative','overflow':'hidden','backgroundImage': 'url(https://s.w.org/images/core/5.5/don-quixote-06.jpg)'}
3362
-//                                    },
3363
-//                                    el( InnerBlocks.Content ),
3364
-//                                    el('div', {dangerouslySetInnerHTML: {__html: content}, className: align})
3365
-//                                );
3366
-//                                <x?php
3367
-//							}else
3368
-
3369
-							if(!empty($this->options['block-output'])){
3370
-//                               echo "return";
3371
-//                               $this->block_element( $this->options['block-output'], true );
3372
-//                               echo ";";
3373
-
3374
-							   ?>
3356
+    //							if(!empty($this->options['nested-block'])){
3357
+    //                                ?x>
3358
+    //                              return el(
3359
+    //                                    'div',
3360
+    //                                    { className: props.className,
3361
+    //                                        style: {'minHeight': '300px','position':'relative','overflow':'hidden','backgroundImage': 'url(https://s.w.org/images/core/5.5/don-quixote-06.jpg)'}
3362
+    //                                    },
3363
+    //                                    el( InnerBlocks.Content ),
3364
+    //                                    el('div', {dangerouslySetInnerHTML: {__html: content}, className: align})
3365
+    //                                );
3366
+    //                                <x?php
3367
+    //							}else
3368
+
3369
+							    if(!empty($this->options['block-output'])){
3370
+    //                               echo "return";
3371
+    //                               $this->block_element( $this->options['block-output'], true );
3372
+    //                               echo ";";
3373
+
3374
+							       ?>
3375 3375
 							  return el(
3376 3376
 								   '',
3377 3377
 								   {},
3378 3378
 								  // el('', {dangerouslySetInnerHTML: {__html: content}}),
3379 3379
 								   <?php $this->block_element( $this->options['block-output'], true ); ?>
3380
-								  // el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3380
+    								  // el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3381 3381
 							   );
3382 3382
 								<?php
3383 3383
 
3384
-							}elseif(!empty($this->options['block-save-return'])){
3385
-								   echo 'return ' . $this->options['block-save-return'];
3386
-							}elseif(!empty($this->options['nested-block'])){
3387
-								?>
3384
+							    }elseif(!empty($this->options['block-save-return'])){
3385
+								       echo 'return ' . $this->options['block-save-return'];
3386
+							    }elseif(!empty($this->options['nested-block'])){
3387
+								    ?>
3388 3388
 							  return el(
3389 3389
 								   '',
3390 3390
 								   {},
@@ -3393,22 +3393,22 @@  discard block
 block discarded – undo
3393 3393
 								 //  el('', {dangerouslySetInnerHTML: {__html: "[/<?php echo $this->options['base_id'];?>]"}})
3394 3394
 							   );
3395 3395
 								<?php
3396
-							}elseif(!empty( $this->options['block-save-return'] ) ){
3397
-								echo "return ". $this->options['block-edit-return'].";";
3398
-							}elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3399
-							?>
3400
-							return content;
3396
+							    }elseif(!empty( $this->options['block-save-return'] ) ){
3397
+								    echo "return ". $this->options['block-edit-return'].";";
3398
+							    }elseif(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){
3399
+							    ?>
3400
+    							return content;
3401 3401
 							<?php
3402
-							}else{
3403
-							?>
3402
+							    }else{
3403
+							    ?>
3404 3404
 							var block_wrap = 'div';
3405 3405
 							if (attr.hasOwnProperty("block_wrap")) {
3406 3406
 								block_wrap = attr.block_wrap;
3407 3407
 							}
3408 3408
 							return el(block_wrap, wp.blockEditor.useBlockProps.save( {dangerouslySetInnerHTML: {__html: content}, className: align} ));
3409 3409
 							<?php
3410
-							}
3411
-							?>
3410
+							    }
3411
+							    ?>
3412 3412
 
3413 3413
 
3414 3414
 						}
@@ -3422,43 +3422,43 @@  discard block
 block discarded – undo
3422 3422
 				});
3423 3423
 			</script>
3424 3424
 			<?php
3425
-			$output = ob_get_clean();
3425
+			    $output = ob_get_clean();
3426 3426
 
3427
-			/*
3427
+			    /*
3428 3428
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
3429 3429
 			 */
3430 3430
 
3431
-			return str_replace( array(
3432
-				'<script>',
3433
-				'</script>'
3434
-			), '', $output );
3435
-		}
3431
+			    return str_replace( array(
3432
+				    '<script>',
3433
+				    '</script>'
3434
+			    ), '', $output );
3435
+		    }
3436 3436
 
3437 3437
 
3438 3438
 
3439
-		public function block_row_start($key, $args){
3439
+		    public function block_row_start($key, $args){
3440 3440
 
3441
-			// check for row
3442
-			if(!empty($args['row'])){
3441
+			    // check for row
3442
+			    if(!empty($args['row'])){
3443 3443
 
3444
-				if(!empty($args['row']['open'])){
3444
+				    if(!empty($args['row']['open'])){
3445 3445
 
3446
-				// element require
3447
-				$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3448
-				$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3449
-				$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3450
-				$device_type_icon = '';
3451
-				if($device_type=='Desktop'){
3452
-					$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3453
-				}elseif($device_type=='Tablet'){
3454
-					$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3455
-				}elseif($device_type=='Mobile'){
3456
-					$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3457
-				}
3458
-				echo $element_require;
3459
-				echo $device_type_require;
3446
+				    // element require
3447
+				    $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3448
+				    $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3449
+				    $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3450
+				    $device_type_icon = '';
3451
+				    if($device_type=='Desktop'){
3452
+					    $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3453
+				    }elseif($device_type=='Tablet'){
3454
+					    $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3455
+				    }elseif($device_type=='Mobile'){
3456
+					    $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3457
+				    }
3458
+				    echo $element_require;
3459
+				    echo $device_type_require;
3460 3460
 
3461
-					if(false){?><script><?php }?>
3461
+					    if(false){?><script><?php }?>
3462 3462
 						el('div', {
3463 3463
 								className: 'bsui components-base-control',
3464 3464
 							},
@@ -3469,15 +3469,15 @@  discard block
 block discarded – undo
3469 3469
 								},
3470 3470
 								el('span',{dangerouslySetInnerHTML: {__html: '<?php echo addslashes( $args['row']['title'] ) ?>'}}),
3471 3471
 								<?php if($device_type_icon){ ?>
3472
-									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)"}})
3472
+    									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)"}})
3473 3473
 								<?php
3474
-								}
3475
-								?>
3474
+								    }
3475
+								    ?>
3476 3476
 
3477 3477
 
3478 3478
 							),
3479 3479
 							<?php }?>
3480
-							<?php if(!empty($args['row']['desc'])){ ?>
3480
+    							<?php if(!empty($args['row']['desc'])){ ?>
3481 3481
 							el('p', {
3482 3482
 									className: 'components-base-control__help mb-0',
3483 3483
 								},
@@ -3496,51 +3496,51 @@  discard block
 block discarded – undo
3496 3496
 									},
3497 3497
 
3498 3498
 					<?php
3499
-					if(false){?></script><?php }
3500
-				}elseif(!empty($args['row']['close'])){
3501
-					if(false){?><script><?php }?>
3499
+					    if(false){?></script><?php }
3500
+				    }elseif(!empty($args['row']['close'])){
3501
+					    if(false){?><script><?php }?>
3502 3502
 						el(
3503 3503
 							'div',
3504 3504
 							{
3505 3505
 								className: 'col pl-0 ps-0',
3506 3506
 							},
3507 3507
 					<?php
3508
-					if(false){?></script><?php }
3509
-				}else{
3510
-					if(false){?><script><?php }?>
3508
+					    if(false){?></script><?php }
3509
+				    }else{
3510
+					    if(false){?><script><?php }?>
3511 3511
 						el(
3512 3512
 							'div',
3513 3513
 							{
3514 3514
 								className: 'col pl-0 ps-0 pr-2 pe-2',
3515 3515
 							},
3516 3516
 					<?php
3517
-					if(false){?></script><?php }
3518
-				}
3517
+					    if(false){?></script><?php }
3518
+				    }
3519 3519
 
3520
-			}
3520
+			    }
3521 3521
 
3522
-		}
3522
+		    }
3523 3523
 
3524
-		public function block_row_end($key, $args){
3524
+		    public function block_row_end($key, $args){
3525 3525
 
3526
-			if(!empty($args['row'])){
3527
-				// maybe close
3528
-				if(!empty($args['row']['close'])){
3529
-					echo "))";
3530
-				}
3526
+			    if(!empty($args['row'])){
3527
+				    // maybe close
3528
+				    if(!empty($args['row']['close'])){
3529
+					    echo "))";
3530
+				    }
3531 3531
 
3532
-				echo "),";
3533
-			}
3534
-		}
3532
+				    echo "),";
3533
+			    }
3534
+		    }
3535 3535
 
3536
-		public function block_tab_start($key, $args){
3536
+		    public function block_tab_start($key, $args){
3537 3537
 
3538
-			// check for row
3539
-			if(!empty($args['tab'])){
3538
+			    // check for row
3539
+			    if(!empty($args['tab'])){
3540 3540
 
3541
-				if(!empty($args['tab']['tabs_open'])){
3541
+				    if(!empty($args['tab']['tabs_open'])){
3542 3542
 
3543
-					if(false){?><script><?php }?>
3543
+					    if(false){?><script><?php }?>
3544 3544
 
3545 3545
 el('div',{className: 'bsui'},
3546 3546
 
@@ -3553,12 +3553,12 @@  discard block
 block discarded – undo
3553 3553
 										tabs: [
3554 3554
 
3555 3555
 					<?php
3556
-					if(false){?></script><?php }
3557
-				}
3556
+					    if(false){?></script><?php }
3557
+				    }
3558 3558
 
3559
-				if(!empty($args['tab']['open'])){
3559
+				    if(!empty($args['tab']['open'])){
3560 3560
 
3561
-					if(false){?><script><?php }?>
3561
+					    if(false){?><script><?php }?>
3562 3562
 							{
3563 3563
 												name: '<?php echo addslashes( esc_attr( $args['tab']['key']) ); ?>',
3564 3564
 												title: el('div', {dangerouslySetInnerHTML: {__html: '<?php echo addslashes( esc_attr( $args['tab']['title']) ); ?>'}}),
@@ -3567,125 +3567,125 @@  discard block
 block discarded – undo
3567 3567
 									className: 'components-base-control__help mb-0',
3568 3568
 									dangerouslySetInnerHTML: {__html:'<?php echo addslashes( $args['tab']['desc'] ); ?>'}
3569 3569
 								}),<?php }
3570
-					if(false){?></script><?php }
3571
-				}
3570
+					    if(false){?></script><?php }
3571
+				    }
3572 3572
 
3573
-			}
3573
+			    }
3574 3574
 
3575
-		}
3575
+		    }
3576 3576
 
3577
-		public function block_tab_end($key, $args){
3577
+		    public function block_tab_end($key, $args){
3578 3578
 
3579
-			if(!empty($args['tab'])){
3580
-				// maybe close
3581
-				if(!empty($args['tab']['close'])){
3582
-					echo ")}, /* tab close */";
3583
-				}
3579
+			    if(!empty($args['tab'])){
3580
+				    // maybe close
3581
+				    if(!empty($args['tab']['close'])){
3582
+					    echo ")}, /* tab close */";
3583
+				    }
3584 3584
 
3585
-				if(!empty($args['tab']['tabs_close'])){
3586
-					if(false){?><script><?php }?>
3585
+				    if(!empty($args['tab']['tabs_close'])){
3586
+					    if(false){?><script><?php }?>
3587 3587
 						]}, ( tab ) => {
3588 3588
 								return tab.content;
3589 3589
 							}
3590 3590
 						)), /* tabs close */
3591 3591
 					<?php if(false){ ?></script><?php }
3592
-				}
3593
-			}
3594
-		}
3595
-
3596
-		public function build_block_arguments( $key, $args ) {
3597
-			$custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3598
-			$options           = '';
3599
-			$extra             = '';
3600
-			$require           = '';
3601
-			$inside_elements   = '';
3602
-			$after_elements	   = '';
3603
-
3604
-			// `content` is a protected and special argument
3605
-			if ( $key == 'content' ) {
3606
-				return;
3607
-			}
3608
-
3609
-			$device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3610
-			$device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3611
-			$device_type_icon = '';
3612
-			if($device_type=='Desktop'){
3613
-				$device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3614
-			}elseif($device_type=='Tablet'){
3615
-				$device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3616
-			}elseif($device_type=='Mobile'){
3617
-				$device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3618
-			}
3619
-
3620
-			// icon
3621
-			$icon = '';
3622
-			if( !empty( $args['icon'] ) ){
3623
-				$icon .= "el('div', {";
3624
-									$icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3625
-									$icon .= "className: 'text-center',";
3626
-									$icon .= "title: '".addslashes( $args['title'] )."',";
3627
-								$icon .= "}),";
3628
-
3629
-				// blank title as its added to the icon.
3630
-				$args['title'] = '';
3631
-			}
3632
-
3633
-			// require advanced
3634
-			$require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3635
-
3636
-			// element require
3637
-			$element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3638
-
3639
-
3640
-			$onchange  = "props.setAttributes({ $key: $key } )";
3641
-			$onchangecomplete  = "";
3642
-			$value     = "props.attributes.$key";
3643
-			$text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3644
-			if ( in_array( $args['type'], $text_type ) ) {
3645
-				$type = 'TextControl';
3646
-				// Save numbers as numbers and not strings
3647
-				if ( $args['type'] == 'number' ) {
3648
-					$onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3649
-				}
3650
-
3651
-				if (substr($key, 0, 9 ) === 'metadata_') {
3652
-					$real_key = str_replace('metadata_','', $key );
3653
-					$onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3654
-					$value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3655
-				}
3656
-			}
3657
-//			else if ( $args['type'] == 'popup' ) {
3658
-//				$type = 'TextControl';
3659
-//				$args['type'] == 'text';
3660
-//				$after_elements .= "el( wp.components.Button, {
3661
-//                          className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
3662
-//                          onClick: function(){
3663
-//							  aui_modal('','<input id=\'zzz\' value= />');
3664
-//							  const source = document.getElementById('zzz');
3665
-//							  source.value = props.attributes.$key;
3666
-//							  source.addEventListener('input', function(e){props.setAttributes({ $key: e.target.value });});
3667
-//                          }
3668
-//                        },
3669
-//                        'test'
3670
-//                        ),";
3671
-//
3672
-//				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3673
-//			}
3674
-			else if ( $args['type'] == 'styleid' ) {
3675
-				$type = 'TextControl';
3676
-				$args['type'] == 'text';
3677
-				// Save numbers as numbers and not strings
3678
-				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3679
-			}else if ( $args['type'] == 'notice' ) {
3680
-
3681
-				$notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3682
-				$notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3683
-
3684
-				$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'}}))),";
3685
-				echo $notice_message ? $element_require . $notice : '';
3686
-				return;
3687
-			}
3688
-			/*
3592
+				    }
3593
+			    }
3594
+		    }
3595
+
3596
+		    public function build_block_arguments( $key, $args ) {
3597
+			    $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : '';
3598
+			    $options           = '';
3599
+			    $extra             = '';
3600
+			    $require           = '';
3601
+			    $inside_elements   = '';
3602
+			    $after_elements	   = '';
3603
+
3604
+			    // `content` is a protected and special argument
3605
+			    if ( $key == 'content' ) {
3606
+				    return;
3607
+			    }
3608
+
3609
+			    $device_type = ! empty( $args['device_type'] ) ? esc_attr($args['device_type']) : '';
3610
+			    $device_type_require = ! empty( $args['device_type'] ) ? " deviceType == '" . esc_attr($device_type) . "' && " : '';
3611
+			    $device_type_icon = '';
3612
+			    if($device_type=='Desktop'){
3613
+				    $device_type_icon = '<span class="dashicons dashicons-desktop" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3614
+			    }elseif($device_type=='Tablet'){
3615
+				    $device_type_icon = '<span class="dashicons dashicons-tablet" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3616
+			    }elseif($device_type=='Mobile'){
3617
+				    $device_type_icon = '<span class="dashicons dashicons-smartphone" style="font-size: 18px;" onclick="sd_show_view_options(this);"></span>';
3618
+			    }
3619
+
3620
+			    // icon
3621
+			    $icon = '';
3622
+			    if( !empty( $args['icon'] ) ){
3623
+				    $icon .= "el('div', {";
3624
+									    $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},";
3625
+									    $icon .= "className: 'text-center',";
3626
+									    $icon .= "title: '".addslashes( $args['title'] )."',";
3627
+								    $icon .= "}),";
3628
+
3629
+				    // blank title as its added to the icon.
3630
+				    $args['title'] = '';
3631
+			    }
3632
+
3633
+			    // require advanced
3634
+			    $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : "";
3635
+
3636
+			    // element require
3637
+			    $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : "";
3638
+
3639
+
3640
+			    $onchange  = "props.setAttributes({ $key: $key } )";
3641
+			    $onchangecomplete  = "";
3642
+			    $value     = "props.attributes.$key";
3643
+			    $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx','range' );
3644
+			    if ( in_array( $args['type'], $text_type ) ) {
3645
+				    $type = 'TextControl';
3646
+				    // Save numbers as numbers and not strings
3647
+				    if ( $args['type'] == 'number' ) {
3648
+					    $onchange = "props.setAttributes({ $key: $key ? Number($key) : '' } )";
3649
+				    }
3650
+
3651
+				    if (substr($key, 0, 9 ) === 'metadata_') {
3652
+					    $real_key = str_replace('metadata_','', $key );
3653
+					    $onchange = "props.setAttributes({ metadata: { $real_key: $key } } )";
3654
+					    $value     = "props.attributes.metadata && props.attributes.metadata.$real_key ? props.attributes.metadata.$real_key : ''";
3655
+				    }
3656
+			    }
3657
+    //			else if ( $args['type'] == 'popup' ) {
3658
+    //				$type = 'TextControl';
3659
+    //				$args['type'] == 'text';
3660
+    //				$after_elements .= "el( wp.components.Button, {
3661
+    //                          className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
3662
+    //                          onClick: function(){
3663
+    //							  aui_modal('','<input id=\'zzz\' value= />');
3664
+    //							  const source = document.getElementById('zzz');
3665
+    //							  source.value = props.attributes.$key;
3666
+    //							  source.addEventListener('input', function(e){props.setAttributes({ $key: e.target.value });});
3667
+    //                          }
3668
+    //                        },
3669
+    //                        'test'
3670
+    //                        ),";
3671
+    //
3672
+    //				$value     = "props.attributes.$key ? props.attributes.$key : ''";
3673
+    //			}
3674
+			    else if ( $args['type'] == 'styleid' ) {
3675
+				    $type = 'TextControl';
3676
+				    $args['type'] == 'text';
3677
+				    // Save numbers as numbers and not strings
3678
+				    $value     = "props.attributes.$key ? props.attributes.$key : ''";
3679
+			    }else if ( $args['type'] == 'notice' ) {
3680
+
3681
+				    $notice_message = !empty($args['desc']) ? addslashes($args['desc']) : '';
3682
+				    $notice_status = !empty($args['status']) ? esc_attr($args['status']) : 'info';
3683
+
3684
+				    $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'}}))),";
3685
+				    echo $notice_message ? $element_require . $notice : '';
3686
+				    return;
3687
+			    }
3688
+			    /*
3689 3689
 			 * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout
3690 3690
 						elseif($args['type']=='tabs'){
3691 3691
 							?>
@@ -3738,22 +3738,22 @@  discard block
 block discarded – undo
3738 3738
 							return;
3739 3739
 						}
3740 3740
 */
3741
-			elseif ( $args['type'] == 'color' ) {
3742
-				$type = 'ColorPicker';
3743
-				$onchange = "";
3744
-				$extra = "color: $value,";
3745
-				if(!empty($args['disable_alpha'])){
3746
-					$extra .= "disableAlpha: true,";
3747
-				}
3748
-				$onchangecomplete = "onChangeComplete: function($key) {
3741
+			    elseif ( $args['type'] == 'color' ) {
3742
+				    $type = 'ColorPicker';
3743
+				    $onchange = "";
3744
+				    $extra = "color: $value,";
3745
+				    if(!empty($args['disable_alpha'])){
3746
+					    $extra .= "disableAlpha: true,";
3747
+				    }
3748
+				    $onchangecomplete = "onChangeComplete: function($key) {
3749 3749
 				value =  $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex;
3750 3750
 						props.setAttributes({
3751 3751
 							$key: value
3752 3752
 						});
3753 3753
 					},";
3754
-			}elseif ( $args['type'] == 'gradient' ) {
3755
-				$type = 'GradientPicker';
3756
-				$extra .= "gradients: [{
3754
+			    }elseif ( $args['type'] == 'gradient' ) {
3755
+				    $type = 'GradientPicker';
3756
+				    $extra .= "gradients: [{
3757 3757
 			name: 'Vivid cyan blue to vivid purple',
3758 3758
 			gradient:
3759 3759
 				'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)',
@@ -3790,10 +3790,10 @@  discard block
 block discarded – undo
3790 3790
 			slug: 'cool-to-warm-spectrum',
3791 3791
 		}],";
3792 3792
 
3793
-			}elseif ( $args['type'] == 'image' ) {
3794
-//                print_r($args);
3793
+			    }elseif ( $args['type'] == 'image' ) {
3794
+    //                print_r($args);
3795 3795
 
3796
-				$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,{
3796
+				    $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,{
3797 3797
 							url:  props.attributes.{$key}_use_featured === true ? ''  : props.attributes.$key,
3798 3798
 							value: props.attributes.{$key}_xy.x !== undefined && props.attributes.{$key}_xy.x >= 0 ? props.attributes.{$key}_xy  : {x: 0.5,y: 0.5,},
3799 3799
 //                            value: props.attributes.{$key}_xy,
@@ -3814,16 +3814,16 @@  discard block
 block discarded – undo
3814 3814
 						}), ";
3815 3815
 
3816 3816
 
3817
-				$value = '""';
3818
-				$type = 'MediaUpload';
3819
-				$extra .= "onSelect: function(media){
3817
+				    $value = '""';
3818
+				    $type = 'MediaUpload';
3819
+				    $extra .= "onSelect: function(media){
3820 3820
 					  return props.setAttributes({
3821 3821
 						  $key: media.url,
3822 3822
 						  {$key}_id: media.id
3823 3823
 						});
3824 3824
 					  },";
3825
-				   $extra .= "type: 'image',";
3826
-				   $extra .= "render: function (obj) {
3825
+				       $extra .= "type: 'image',";
3826
+				       $extra .= "render: function (obj) {
3827 3827
 						return el( 'div',{},
3828 3828
 						( !props.attributes.$key && !props.attributes.{$key}_use_featured ) && el( wp.components.Button, {
3829 3829
 						  className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
@@ -3849,11 +3849,11 @@  discard block
 block discarded – undo
3849 3849
 
3850 3850
 
3851 3851
 					  }";
3852
-				$onchange = "";
3852
+				    $onchange = "";
3853 3853
 
3854
-				//$inside_elements = ",el('div',{},'file upload')";
3855
-			} else if ( $args['type'] == 'images' ) {
3856
-				$img_preview = "props.attributes.$key && (function() {
3854
+				    //$inside_elements = ",el('div',{},'file upload')";
3855
+			    } else if ( $args['type'] == 'images' ) {
3856
+				    $img_preview = "props.attributes.$key && (function() {
3857 3857
 	let uploads = JSON.parse('['+props.attributes.$key+']');
3858 3858
 	let images = [];
3859 3859
 	uploads.map((upload, index) => (
@@ -3880,9 +3880,9 @@  discard block
 block discarded – undo
3880 3880
 })(),";
3881 3881
 
3882 3882
 
3883
-				$value = '""';
3884
-				$type = 'MediaUpload';
3885
-				$extra .= "onSelect: function(media){
3883
+				    $value = '""';
3884
+				    $type = 'MediaUpload';
3885
+				    $extra .= "onSelect: function(media){
3886 3886
 	let slim_images = props.attributes.$key ? JSON.parse('['+props.attributes.$key+']') : [];
3887 3887
 	if(media.length){
3888 3888
 		for (var i=0; i < media.length; i++) {
@@ -3895,9 +3895,9 @@  discard block
 block discarded – undo
3895 3895
 	}
3896 3896
 	return props.setAttributes({ $key: slimImagesV});
3897 3897
 },";
3898
-				$extra .= "type: 'image',";
3899
-				$extra .= "multiple: true,";
3900
-				$extra .= "render: function (obj) {
3898
+				    $extra .= "type: 'image',";
3899
+				    $extra .= "multiple: true,";
3900
+				    $extra .= "render: function (obj) {
3901 3901
 	/* Init the sort */
3902 3902
 	enableDragSort('sd-sortable');
3903 3903
 	return el( 'div',{},
@@ -3924,40 +3924,40 @@  discard block
 block discarded – undo
3924 3924
 		)
3925 3925
 	)
3926 3926
 }";
3927
-				$onchange = "";
3928
-
3929
-				//$inside_elements = ",el('div',{},'file upload')";
3930
-			}
3931
-			elseif ( $args['type'] == 'checkbox' ) {
3932
-				$type = 'CheckboxControl';
3933
-				$extra .= "checked: props.attributes.$key,";
3934
-				$onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3935
-			} elseif ( $args['type'] == 'textarea' ) {
3936
-				$type = 'TextareaControl';
3937
-
3938
-			} elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3939
-				$type = 'SelectControl';
3940
-
3941
-				if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3942
-					$options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3943
-				}elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3944
-					$options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3945
-				}else {
3946
-
3947
-					if ( ! empty( $args['options'] ) ) {
3948
-						$options .= "options: [";
3949
-						foreach ( $args['options'] as $option_val => $option_label ) {
3950
-							$options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3951
-						}
3952
-						$options .= "],";
3953
-					}
3954
-				}
3955
-				if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3956
-					$extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3957
-				}
3958
-
3959
-				if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3960
-					$after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3927
+				    $onchange = "";
3928
+
3929
+				    //$inside_elements = ",el('div',{},'file upload')";
3930
+			    }
3931
+			    elseif ( $args['type'] == 'checkbox' ) {
3932
+				    $type = 'CheckboxControl';
3933
+				    $extra .= "checked: props.attributes.$key,";
3934
+				    $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )";
3935
+			    } elseif ( $args['type'] == 'textarea' ) {
3936
+				    $type = 'TextareaControl';
3937
+
3938
+			    } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) {
3939
+				    $type = 'SelectControl';
3940
+
3941
+				    if($args['name'] == 'category' && !empty($args['post_type_linked'])){
3942
+					    $options .= "options: taxonomies_".str_replace("-","_", $this->id).",";
3943
+				    }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){
3944
+					    $options .= "options: sort_by_".str_replace("-","_", $this->id).",";
3945
+				    }else {
3946
+
3947
+					    if ( ! empty( $args['options'] ) ) {
3948
+						    $options .= "options: [";
3949
+						    foreach ( $args['options'] as $option_val => $option_label ) {
3950
+							    $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . esc_js( addslashes( $option_label ) ) . "' },";
3951
+						    }
3952
+						    $options .= "],";
3953
+					    }
3954
+				    }
3955
+				    if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550
3956
+					    $extra .= ' multiple:true,style:{height:"auto",paddingRight:"8px","overflow-y":"auto"}, ';
3957
+				    }
3958
+
3959
+				    if($args['type'] == 'multiselect' ||  ( isset( $args['multiple'] ) && $args['multiple'] ) ){
3960
+					    $after_elements	 .= "props.attributes.$key && el( wp.components.Button, {
3961 3961
 									  className: 'components-button components-circular-option-picker__clear is-secondary is-small',
3962 3962
 									  style: {margin:'-8px 0 8px 0',display: 'block'},
3963 3963
 									  onClick: function(){
@@ -3968,56 +3968,56 @@  discard block
 block discarded – undo
3968 3968
 									},
3969 3969
 									'Clear'
3970 3970
 							),";
3971
-				}
3972
-			} elseif ( $args['type'] == 'tagselect' ) {
3973
-//				$type = 'FormTokenField';
3974
-//
3975
-//				if ( ! empty( $args['options'] ) ) {
3976
-//						$options .= "suggestions: [";
3977
-//						foreach ( $args['options'] as $option_val => $option_label ) {
3978
-//							$options .= "{ value: '" . esc_attr( $option_val ) . "', title: '" . addslashes( $option_label ) . "' },";
3979
-////							$options .= "'" . esc_attr( $option_val ) . "':'" . addslashes( $option_label ) . "',";
3980
-//						}
3981
-//						$options .= "],";
3982
-//				}
3983
-//
3984
-//				$onchangex  = "{ ( selectedItems ) => {
3985
-//						// Build array of selected posts.
3986
-//						let selectedPostsArray = [];
3987
-//						selectedPosts.map(
3988
-//							( postName ) => {
3989
-//								const matchingPost = posts.find( ( post ) => {
3990
-//									return post.title.raw === postName;
3991
-//
3992
-//								} );
3993
-//								if ( matchingPost !== undefined ) {
3994
-//									selectedPostsArray.push( matchingPost.id );
3995
-//								}
3996
-//							}
3997
-//						)
3998
-//
3999
-//						setAttributes( { selectedPosts: selectedPostsArray } );
4000
-//					} } ";
4001
-//				$onchange  = '';// "props.setAttributes({ $key: [ props.attributes.$key ] } )";
4002
-//
4003
-////				$options  = "";
4004
-//				$value     = "[]";
4005
-//				$extra .= ' __experimentalExpandOnFocus: true,';
4006
-
4007
-			} else if ( $args['type'] == 'alignment' ) {
4008
-				$type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
4009
-			} else if ( $args['type'] == 'margins' ) {
4010
-
4011
-			} else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
4012
-				$type = 'TextControl';
4013
-				$value = "(props.attributes.$key ? props.attributes.$key : '')";
4014
-				$args['type'] = 'text';
4015
-				$options .= 'disabled:true,';
4016
-				$bsvc_title = esc_attr( addslashes( $args['title'] ) );
4017
-				$bsvc_body = $this->block_visibility_fields( $args );
4018
-				// @TODO reset button
4019
-				$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>';
4020
-				$after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
3971
+				    }
3972
+			    } elseif ( $args['type'] == 'tagselect' ) {
3973
+    //				$type = 'FormTokenField';
3974
+    //
3975
+    //				if ( ! empty( $args['options'] ) ) {
3976
+    //						$options .= "suggestions: [";
3977
+    //						foreach ( $args['options'] as $option_val => $option_label ) {
3978
+    //							$options .= "{ value: '" . esc_attr( $option_val ) . "', title: '" . addslashes( $option_label ) . "' },";
3979
+    ////							$options .= "'" . esc_attr( $option_val ) . "':'" . addslashes( $option_label ) . "',";
3980
+    //						}
3981
+    //						$options .= "],";
3982
+    //				}
3983
+    //
3984
+    //				$onchangex  = "{ ( selectedItems ) => {
3985
+    //						// Build array of selected posts.
3986
+    //						let selectedPostsArray = [];
3987
+    //						selectedPosts.map(
3988
+    //							( postName ) => {
3989
+    //								const matchingPost = posts.find( ( post ) => {
3990
+    //									return post.title.raw === postName;
3991
+    //
3992
+    //								} );
3993
+    //								if ( matchingPost !== undefined ) {
3994
+    //									selectedPostsArray.push( matchingPost.id );
3995
+    //								}
3996
+    //							}
3997
+    //						)
3998
+    //
3999
+    //						setAttributes( { selectedPosts: selectedPostsArray } );
4000
+    //					} } ";
4001
+    //				$onchange  = '';// "props.setAttributes({ $key: [ props.attributes.$key ] } )";
4002
+    //
4003
+    ////				$options  = "";
4004
+    //				$value     = "[]";
4005
+    //				$extra .= ' __experimentalExpandOnFocus: true,';
4006
+
4007
+			    } else if ( $args['type'] == 'alignment' ) {
4008
+				    $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example
4009
+			    } else if ( $args['type'] == 'margins' ) {
4010
+
4011
+			    } else if ( $args['type'] == 'visibility_conditions' && ( function_exists( 'wp_is_block_theme' ) && wp_is_block_theme() ) ) {
4012
+				    $type = 'TextControl';
4013
+				    $value = "(props.attributes.$key ? props.attributes.$key : '')";
4014
+				    $args['type'] = 'text';
4015
+				    $options .= 'disabled:true,';
4016
+				    $bsvc_title = esc_attr( addslashes( $args['title'] ) );
4017
+				    $bsvc_body = $this->block_visibility_fields( $args );
4018
+				    // @TODO reset button
4019
+				    $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>';
4020
+				    $after_elements .= "el('div', {className: 'components-base-control bs-vc-button-wrap'}, el(wp.components.Button, {
4021 4021
 						className: 'components-button components-circular-option-picker__clear is-primary is-smallx',
4022 4022
 						onClick: function() {
4023 4023
 							var sValue = props.attributes." . $key . ";
@@ -4043,54 +4043,54 @@  discard block
 block discarded – undo
4043 4043
 					},
4044 4044
 					'" . addslashes( ! empty( $args['button_title'] ) ? $args['button_title'] : $args['title'] ) . "'
4045 4045
 				) ),";
4046
-			} else {
4047
-				return;// if we have not implemented the control then don't break the JS.
4048
-			}
4049
-
4050
-			// color input does not show the labels so we add them
4051
-			if($args['type']=='color'){
4052
-				// add show only if advanced
4053
-				echo $require_advanced;
4054
-				// add setting require if defined
4055
-				echo $element_require;
4056
-				echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
4057
-			}
4058
-
4059
-			// add show only if advanced
4060
-			echo $require_advanced;
4061
-			// add setting require if defined
4062
-			echo $element_require;
4063
-			echo $device_type_require;
4064
-
4065
-			// icon
4066
-			echo $icon;
4067
-			?>
4068
-			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
4046
+			    } else {
4047
+				    return;// if we have not implemented the control then don't break the JS.
4048
+			    }
4049
+
4050
+			    // color input does not show the labels so we add them
4051
+			    if($args['type']=='color'){
4052
+				    // add show only if advanced
4053
+				    echo $require_advanced;
4054
+				    // add setting require if defined
4055
+				    echo $element_require;
4056
+				    echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),";
4057
+			    }
4058
+
4059
+			    // add show only if advanced
4060
+			    echo $require_advanced;
4061
+			    // add setting require if defined
4062
+			    echo $element_require;
4063
+			    echo $device_type_require;
4064
+
4065
+			    // icon
4066
+			    echo $icon;
4067
+			    ?>
4068
+    			el( <?php echo $args['type'] == 'image' || $args['type'] == 'images' ? $type  : "wp.components.".$type; ?>, {
4069 4069
 			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
4070
-			} else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
4070
+			    } else { ?>'<?php echo addslashes( trim( esc_html( $args['title'] ) ) ); ?>'<?php } ?>,
4071 4071
 			help: <?php echo ( isset( $args['desc'] ) ? "el('span', {dangerouslySetInnerHTML: {__html: '" . trim( wp_kses_post( addslashes( $args['desc'] ) ) ) . "'}})" : "''" ); ?>,
4072 4072
 			value: <?php echo $value; ?>,
4073 4073
 			<?php if ( $type == 'TextControl' && $args['type'] != 'text' ) {
4074
-				echo "type: '" . addslashes( $args['type'] ) . "',";
4075
-			} ?>
4076
-			<?php if ( ! empty( $args['placeholder'] ) ) {
4077
-				echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
4078
-			} ?>
4079
-			<?php echo $options; ?>
4080
-			<?php echo $extra; ?>
4081
-			<?php echo $custom_attributes; ?>
4082
-			<?php echo $onchangecomplete; ?>
4083
-			<?php if ( $onchange ) { ?>
4084
-			onChange: function ( <?php echo $key; ?> ) {
4074
+				    echo "type: '" . addslashes( $args['type'] ) . "',";
4075
+			    } ?>
4076
+    			<?php if ( ! empty( $args['placeholder'] ) ) {
4077
+				    echo "placeholder: '" . esc_js( addslashes( trim( esc_html( $args['placeholder'] ) ) ) ) . "',";
4078
+			    } ?>
4079
+    			<?php echo $options; ?>
4080
+    			<?php echo $extra; ?>
4081
+    			<?php echo $custom_attributes; ?>
4082
+    			<?php echo $onchangecomplete; ?>
4083
+    			<?php if ( $onchange ) { ?>
4084
+    			onChange: function ( <?php echo $key; ?> ) {
4085 4085
 				<?php echo $onchange; ?>
4086
-			}
4086
+    			}
4087 4087
 			<?php } ?>
4088
-		} <?php echo $inside_elements; ?> ),
4088
+    		} <?php echo $inside_elements; ?> ),
4089 4089
 			<?php
4090
-			echo $after_elements;
4091
-		}
4090
+			    echo $after_elements;
4091
+		    }
4092 4092
 
4093
-		/**
4093
+		    /**
4094 4094
 		 * Convert an array of attributes to block string.
4095 4095
 		 *
4096 4096
 		 * @param $custom_attributes
@@ -4099,448 +4099,448 @@  discard block
 block discarded – undo
4099 4099
 		 *@todo there is prob a faster way to do this, also we could add some validation here.
4100 4100
 		 *
4101 4101
 		 */
4102
-		public function array_to_attributes( $custom_attributes, $html = false ) {
4103
-			$attributes = '';
4104
-			if ( ! empty( $custom_attributes ) ) {
4102
+		    public function array_to_attributes( $custom_attributes, $html = false ) {
4103
+			    $attributes = '';
4104
+			    if ( ! empty( $custom_attributes ) ) {
4105 4105
 
4106
-				foreach ( $custom_attributes as $key => $val ) {
4107
-					if(is_array($val)){
4108
-						$attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4109
-					}else{
4110
-						$attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4111
-					}
4112
-				}
4106
+				    foreach ( $custom_attributes as $key => $val ) {
4107
+					    if(is_array($val)){
4108
+						    $attributes .= $key.': {'.$this->array_to_attributes( $val, $html ).'},';
4109
+					    }else{
4110
+						    $attributes .= $html ?  " $key='$val' " : "'$key': '$val',";
4111
+					    }
4112
+				    }
4113 4113
 
4114
-			}
4114
+			    }
4115 4115
 
4116
-			return $attributes;
4117
-		}
4116
+			    return $attributes;
4117
+		    }
4118 4118
 
4119 4119
 
4120 4120
 
4121
-		/**
4121
+		    /**
4122 4122
 		 * A self looping function to create the output for JS block elements.
4123 4123
 		 *
4124 4124
 		 * This is what is output in the WP Editor visual view.
4125 4125
 		 *
4126 4126
 		 * @param $args
4127 4127
 		 */
4128
-		public function block_element( $args, $save = false ) {
4129
-
4130
-//            print_r($args);echo '###';exit;
4131
-
4132
-			if ( ! empty( $args ) ) {
4133
-				foreach ( $args as $element => $new_args ) {
4134
-
4135
-					if ( is_array( $new_args ) ) { // its an element
4128
+		    public function block_element( $args, $save = false ) {
4129
+
4130
+    //            print_r($args);echo '###';exit;
4131
+
4132
+			    if ( ! empty( $args ) ) {
4133
+				    foreach ( $args as $element => $new_args ) {
4134
+
4135
+					    if ( is_array( $new_args ) ) { // its an element
4136
+
4136 4137
 
4138
+						    if ( isset( $new_args['element'] ) ) {
4137 4139
 
4138
-						if ( isset( $new_args['element'] ) ) {
4139
-
4140
-							if ( isset( $new_args['element_require'] ) ) {
4141
-								echo str_replace( array(
4142
-										"'+",
4143
-										"+'"
4144
-									), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4145
-								unset( $new_args['element_require'] );
4146
-							}
4147
-
4148
-							if($new_args['element']=='InnerBlocks'){
4149
-								echo "\n el( InnerBlocks, {";
4150
-							}elseif($new_args['element']=='innerBlocksProps'){
4151
-								$element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4152
-							  //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4153
-//                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4154
-								echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4155
-								echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4156
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4157
-
4158
-								echo "} ), {";
4159
-								echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4160
-							//    echo '###';
4161
-
4162
-							  //  echo '###';
4163
-							}elseif($new_args['element']=='BlocksProps'){
4164
-
4165
-								if ( isset($new_args['if_inner_element']) ) {
4166
-									$element = $new_args['if_inner_element'];
4167
-								}else {
4168
-									$element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4169
-								}
4170
-
4171
-								unset($new_args['inner_element']);
4172
-								echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4173
-								echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4174
-
4175
-
4176
-							   // echo "} ),";
4177
-
4178
-							}else{
4179
-								echo "\n el( '" . $new_args['element'] . "', {";
4180
-							}
4181
-
4182
-
4183
-							// get the attributes
4184
-							foreach ( $new_args as $new_key => $new_value ) {
4185
-
4186
-
4187
-								if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4188
-									// do nothing
4189
-								} else {
4190
-									echo $this->block_element( array( $new_key => $new_value ),$save );
4191
-								}
4192
-							}
4193
-
4194
-							echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4195
-
4196
-							// get the content
4197
-							$first_item = 0;
4198
-							foreach ( $new_args as $new_key => $new_value ) {
4199
-								if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4200
-
4201
-									if ( $new_key === 'content' ) {
4202
-										echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4203
-									}else if ( $new_key === 'if_content' ) {
4204
-										echo  $this->block_props_replace(  $new_value  );
4205
-									}
4206
-
4207
-									if ( is_array( $new_value ) ) {
4208
-
4209
-										if ( isset( $new_value['element_require'] ) ) {
4210
-											echo str_replace( array(
4211
-													"'+",
4212
-													"+'"
4213
-												), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4214
-											unset( $new_value['element_require'] );
4215
-										}
4216
-
4217
-										if ( isset( $new_value['element_repeat'] ) ) {
4218
-											$x = 1;
4219
-											while ( $x <= absint( $new_value['element_repeat'] ) ) {
4220
-												$this->block_element( array( '' => $new_value ),$save );
4221
-												$x ++;
4222
-											}
4223
-										} else {
4224
-											$this->block_element( array( '' => $new_value ),$save );
4225
-										}
4226
-									}
4227
-									$first_item ++;
4228
-								}
4229
-							}
4230
-
4231
-							if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4232
-								echo "))";// end content
4233
-							}else{
4234
-								echo ")";// end content
4235
-							}
4236
-
4237
-
4238
-							echo ", \n";
4239
-
4240
-						}
4241
-					} else {
4242
-
4243
-						if ( substr( $element, 0, 3 ) === "if_" ) {
4244
-							$extra = '';
4245
-							if( strpos($new_args, '[%WrapClass%]') !== false ){
4246
-								$new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4247
-								$new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4248
-							}
4249
-							echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4250
-						} elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4251
-							$new_args = str_replace('[%WrapStyle%]','',$new_args);
4252
-							echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4253
-//                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4254
-						} elseif ( $element == 'style' ) {
4255
-							echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4256
-						} elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4257
-							$new_args = str_replace('[%WrapClass%]','',$new_args);
4258
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4259
-						} elseif ( $element == 'template' && $new_args ) {
4260
-							echo $element . ": $new_args,";
4261
-						} else {
4262
-							echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4263
-						}
4264
-
4265
-					}
4266
-				}
4267
-			}
4268
-		}
4269
-
4270
-		/**
4140
+							    if ( isset( $new_args['element_require'] ) ) {
4141
+								    echo str_replace( array(
4142
+										    "'+",
4143
+										    "+'"
4144
+									    ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " &&  ";
4145
+								    unset( $new_args['element_require'] );
4146
+							    }
4147
+
4148
+							    if($new_args['element']=='InnerBlocks'){
4149
+								    echo "\n el( InnerBlocks, {";
4150
+							    }elseif($new_args['element']=='innerBlocksProps'){
4151
+								    $element = isset($new_args['inner_element']) ? esc_attr($new_args['inner_element']) : 'div';
4152
+							      //  echo "\n el( 'section', wp.blockEditor.useInnerBlocksProps( blockProps, {";
4153
+    //                                echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4154
+								    echo $save ? "\n el( '$element', wp.blockEditor.useInnerBlocksProps.save( " : "\n el( '$element', wp.blockEditor.useInnerBlocksProps( ";
4155
+								    echo $save ? "wp.blockEditor.useBlockProps.save( {" : "wp.blockEditor.useBlockProps( {";
4156
+								    echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4157
+
4158
+								    echo "} ), {";
4159
+								    echo !empty($new_args['innerBlocksProps']) && !$save ? $this->block_element( $new_args['innerBlocksProps'],$save ) : '';
4160
+							    //    echo '###';
4161
+
4162
+							      //  echo '###';
4163
+							    }elseif($new_args['element']=='BlocksProps'){
4164
+
4165
+								    if ( isset($new_args['if_inner_element']) ) {
4166
+									    $element = $new_args['if_inner_element'];
4167
+								    }else {
4168
+									    $element = isset($new_args['inner_element']) ? "'".esc_attr($new_args['inner_element'])."'" : "'div'";
4169
+								    }
4170
+
4171
+								    unset($new_args['inner_element']);
4172
+								    echo $save ? "\n el( $element, wp.blockEditor.useBlockProps.save( {" : "\n el( $element, wp.blockEditor.useBlockProps( {";
4173
+								    echo !empty($new_args['blockProps']) ? $this->block_element( $new_args['blockProps'],$save ) : '';
4174
+
4175
+
4176
+							       // echo "} ),";
4177
+
4178
+							    }else{
4179
+								    echo "\n el( '" . $new_args['element'] . "', {";
4180
+							    }
4181
+
4182
+
4183
+							    // get the attributes
4184
+							    foreach ( $new_args as $new_key => $new_value ) {
4185
+
4186
+
4187
+								    if ( $new_key == 'element' || $new_key == 'content'|| $new_key == 'if_content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) {
4188
+									    // do nothing
4189
+								    } else {
4190
+									    echo $this->block_element( array( $new_key => $new_value ),$save );
4191
+								    }
4192
+							    }
4193
+
4194
+							    echo $new_args['element']=='BlocksProps' ? '} ),' : "},";// end attributes
4195
+
4196
+							    // get the content
4197
+							    $first_item = 0;
4198
+							    foreach ( $new_args as $new_key => $new_value ) {
4199
+								    if ( $new_key === 'content' || $new_key === 'if_content' || is_array( $new_value ) ) {
4200
+
4201
+									    if ( $new_key === 'content' ) {
4202
+										    echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'";
4203
+									    }else if ( $new_key === 'if_content' ) {
4204
+										    echo  $this->block_props_replace(  $new_value  );
4205
+									    }
4206
+
4207
+									    if ( is_array( $new_value ) ) {
4208
+
4209
+										    if ( isset( $new_value['element_require'] ) ) {
4210
+											    echo str_replace( array(
4211
+													    "'+",
4212
+													    "+'"
4213
+												    ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " &&  ";
4214
+											    unset( $new_value['element_require'] );
4215
+										    }
4216
+
4217
+										    if ( isset( $new_value['element_repeat'] ) ) {
4218
+											    $x = 1;
4219
+											    while ( $x <= absint( $new_value['element_repeat'] ) ) {
4220
+												    $this->block_element( array( '' => $new_value ),$save );
4221
+												    $x ++;
4222
+											    }
4223
+										    } else {
4224
+											    $this->block_element( array( '' => $new_value ),$save );
4225
+										    }
4226
+									    }
4227
+									    $first_item ++;
4228
+								    }
4229
+							    }
4230
+
4231
+							    if($new_args['element']=='innerBlocksProps' || $new_args['element']=='xBlocksProps'){
4232
+								    echo "))";// end content
4233
+							    }else{
4234
+								    echo ")";// end content
4235
+							    }
4236
+
4237
+
4238
+							    echo ", \n";
4239
+
4240
+						    }
4241
+					    } else {
4242
+
4243
+						    if ( substr( $element, 0, 3 ) === "if_" ) {
4244
+							    $extra = '';
4245
+							    if( strpos($new_args, '[%WrapClass%]') !== false ){
4246
+								    $new_args = str_replace('[%WrapClass%]"','" + sd_build_aui_class(props.attributes)',$new_args);
4247
+								    $new_args = str_replace('[%WrapClass%]','+ sd_build_aui_class(props.attributes)',$new_args);
4248
+							    }
4249
+							    echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ",";
4250
+						    } elseif ( $element == 'style' &&  strpos($new_args, '[%WrapStyle%]') !== false ) {
4251
+							    $new_args = str_replace('[%WrapStyle%]','',$new_args);
4252
+							    echo $element . ": {..." . $this->block_props_replace( $new_args ) . " , ...sd_build_aui_styles(props.attributes) },";
4253
+    //                            echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4254
+						    } elseif ( $element == 'style' ) {
4255
+							    echo $element . ": " . $this->block_props_replace( $new_args ) . ",";
4256
+						    } elseif ( ( $element == 'class' || $element == 'className'  ) &&  strpos($new_args, '[%WrapClass%]') !== false ) {
4257
+							    $new_args = str_replace('[%WrapClass%]','',$new_args);
4258
+							    echo $element . ": '" . $this->block_props_replace( $new_args ) . "' + sd_build_aui_class(props.attributes),";
4259
+						    } elseif ( $element == 'template' && $new_args ) {
4260
+							    echo $element . ": $new_args,";
4261
+						    } else {
4262
+							    echo $element . ": '" . $this->block_props_replace( $new_args ) . "',";
4263
+						    }
4264
+
4265
+					    }
4266
+				    }
4267
+			    }
4268
+		    }
4269
+
4270
+		    /**
4271 4271
 		 * Replace block attributes placeholders with the proper naming.
4272 4272
 		 *
4273 4273
 		 * @param $string
4274 4274
 		 *
4275 4275
 		 * @return mixed
4276 4276
 		 */
4277
-		public function block_props_replace( $string, $no_wrap = false ) {
4278
-			if ( $no_wrap ) {
4279
-				$string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4280
-			} else {
4281
-				$string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4282
-			}
4277
+		    public function block_props_replace( $string, $no_wrap = false ) {
4278
+			    if ( $no_wrap ) {
4279
+				    $string = str_replace( array( "[%", "%]", "%:checked]" ), array( "props.attributes.", "", "" ), $string );
4280
+			    } else {
4281
+				    $string = str_replace( array( "![%", "[%", "%]", "%:checked]" ), array( "'+!props.attributes.", "'+props.attributes.", "+'", "+'" ), $string );
4282
+			    }
4283 4283
 
4284
-			return $string;
4285
-		}
4284
+			    return $string;
4285
+		    }
4286 4286
 
4287
-		/**
4287
+		    /**
4288 4288
 		 * Outputs the content of the widget
4289 4289
 		 *
4290 4290
 		 * @param array $args
4291 4291
 		 * @param array $instance
4292 4292
 		 */
4293
-		public function widget( $args, $instance ) {
4294
-			if ( ! is_array( $args ) ) {
4295
-				$args = array();
4296
-			}
4297
-
4298
-			// Get the filtered values
4299
-			$argument_values = $this->argument_values( $instance );
4300
-			$argument_values = $this->string_to_bool( $argument_values );
4301
-			$output          = $this->output( $argument_values, $args );
4302
-
4303
-			$no_wrap = false;
4304
-			if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4305
-				$no_wrap = true;
4306
-			}
4307
-
4308
-			ob_start();
4309
-			if ( $output && ! $no_wrap ) {
4310
-
4311
-				$class_original = $this->options['widget_ops']['classname'];
4312
-				$class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4313
-
4314
-				// Before widget
4315
-				$before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4316
-				$before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4317
-				$before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4318
-				$before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4319
-
4320
-				// After widget
4321
-				$after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4322
-				$after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4323
-				$after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4324
-
4325
-				echo $before_widget;
4326
-				// elementor strips the widget wrapping div so we check for and add it back if needed
4327
-				if ( $this->is_elementor_widget_output() ) {
4328
-					// Filter class & attrs for elementor widget output.
4329
-					$class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4330
-					$class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4331
-
4332
-					$attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4333
-					$attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4334
-
4335
-					echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4336
-				}
4337
-				echo $this->output_title( $args, $instance );
4338
-				echo $output;
4339
-				if ( $this->is_elementor_widget_output() ) {
4340
-					echo "</span>";
4341
-				}
4342
-				echo $after_widget;
4343
-			} elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4344
-				$output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4345
-				echo $output;
4346
-			} elseif ( $output && $no_wrap ) {
4347
-				echo $output;
4348
-			}
4349
-			$output = ob_get_clean();
4350
-
4351
-			$output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4352
-
4353
-			echo $output;
4354
-		}
4355
-
4356
-		/**
4293
+		    public function widget( $args, $instance ) {
4294
+			    if ( ! is_array( $args ) ) {
4295
+				    $args = array();
4296
+			    }
4297
+
4298
+			    // Get the filtered values
4299
+			    $argument_values = $this->argument_values( $instance );
4300
+			    $argument_values = $this->string_to_bool( $argument_values );
4301
+			    $output          = $this->output( $argument_values, $args );
4302
+
4303
+			    $no_wrap = false;
4304
+			    if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) {
4305
+				    $no_wrap = true;
4306
+			    }
4307
+
4308
+			    ob_start();
4309
+			    if ( $output && ! $no_wrap ) {
4310
+
4311
+				    $class_original = $this->options['widget_ops']['classname'];
4312
+				    $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash();
4313
+
4314
+				    // Before widget
4315
+				    $before_widget = ! empty( $args['before_widget'] ) ? $args['before_widget'] : '';
4316
+				    $before_widget = $before_widget ? str_replace( $class_original, $class, $before_widget ) : $before_widget;
4317
+				    $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this );
4318
+				    $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this );
4319
+
4320
+				    // After widget
4321
+				    $after_widget = ! empty( $args['after_widget'] ) ? $args['after_widget'] : '';
4322
+				    $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this );
4323
+				    $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this );
4324
+
4325
+				    echo $before_widget;
4326
+				    // elementor strips the widget wrapping div so we check for and add it back if needed
4327
+				    if ( $this->is_elementor_widget_output() ) {
4328
+					    // Filter class & attrs for elementor widget output.
4329
+					    $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this );
4330
+					    $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this );
4331
+
4332
+					    $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this );
4333
+					    $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this );
4334
+
4335
+					    echo "<span class='" . esc_attr( $class  ) . "' " . $attrs . ">";
4336
+				    }
4337
+				    echo $this->output_title( $args, $instance );
4338
+				    echo $output;
4339
+				    if ( $this->is_elementor_widget_output() ) {
4340
+					    echo "</span>";
4341
+				    }
4342
+				    echo $after_widget;
4343
+			    } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty
4344
+				    $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" );
4345
+				    echo $output;
4346
+			    } elseif ( $output && $no_wrap ) {
4347
+				    echo $output;
4348
+			    }
4349
+			    $output = ob_get_clean();
4350
+
4351
+			    $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this );
4352
+
4353
+			    echo $output;
4354
+		    }
4355
+
4356
+		    /**
4357 4357
 		 * Tests if the current output is inside a elementor container.
4358 4358
 		 *
4359 4359
 		 * @return bool
4360 4360
 		 *@since 1.0.4
4361 4361
 		 */
4362
-		public function is_elementor_widget_output() {
4363
-			$result = false;
4364
-			if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4365
-				$result = true;
4366
-			}
4362
+		    public function is_elementor_widget_output() {
4363
+			    $result = false;
4364
+			    if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) {
4365
+				    $result = true;
4366
+			    }
4367 4367
 
4368
-			return $result;
4369
-		}
4368
+			    return $result;
4369
+		    }
4370 4370
 
4371
-		/**
4371
+		    /**
4372 4372
 		 * Tests if the current output is inside a elementor preview.
4373 4373
 		 *
4374 4374
 		 * @return bool
4375 4375
 		 *@since 1.0.4
4376 4376
 		 */
4377
-		public function is_elementor_preview() {
4378
-			$result = false;
4379
-			if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4380
-				$result = true;
4381
-			}
4377
+		    public function is_elementor_preview() {
4378
+			    $result = false;
4379
+			    if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) {
4380
+				    $result = true;
4381
+			    }
4382 4382
 
4383
-			return $result;
4384
-		}
4383
+			    return $result;
4384
+		    }
4385 4385
 
4386
-		/**
4386
+		    /**
4387 4387
 		 * Tests if the current output is inside a Divi preview.
4388 4388
 		 *
4389 4389
 		 * @return bool
4390 4390
 		 *@since 1.0.6
4391 4391
 		 */
4392
-		public function is_divi_preview() {
4393
-			$result = false;
4394
-			if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4395
-				$result = true;
4396
-			}
4392
+		    public function is_divi_preview() {
4393
+			    $result = false;
4394
+			    if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) {
4395
+				    $result = true;
4396
+			    }
4397 4397
 
4398
-			return $result;
4399
-		}
4398
+			    return $result;
4399
+		    }
4400 4400
 
4401
-		/**
4401
+		    /**
4402 4402
 		 * Tests if the current output is inside a Beaver builder preview.
4403 4403
 		 *
4404 4404
 		 * @return bool
4405 4405
 		 *@since 1.0.6
4406 4406
 		 */
4407
-		public function is_beaver_preview() {
4408
-			$result = false;
4409
-			if ( isset( $_REQUEST['fl_builder'] ) ) {
4410
-				$result = true;
4411
-			}
4407
+		    public function is_beaver_preview() {
4408
+			    $result = false;
4409
+			    if ( isset( $_REQUEST['fl_builder'] ) ) {
4410
+				    $result = true;
4411
+			    }
4412 4412
 
4413
-			return $result;
4414
-		}
4413
+			    return $result;
4414
+		    }
4415 4415
 
4416
-		/**
4416
+		    /**
4417 4417
 		 * Tests if the current output is inside a siteorigin builder preview.
4418 4418
 		 *
4419 4419
 		 * @return bool
4420 4420
 		 *@since 1.0.6
4421 4421
 		 */
4422
-		public function is_siteorigin_preview() {
4423
-			$result = false;
4424
-			if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4425
-				$result = true;
4426
-			}
4422
+		    public function is_siteorigin_preview() {
4423
+			    $result = false;
4424
+			    if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) {
4425
+				    $result = true;
4426
+			    }
4427 4427
 
4428
-			return $result;
4429
-		}
4428
+			    return $result;
4429
+		    }
4430 4430
 
4431
-		/**
4431
+		    /**
4432 4432
 		 * Tests if the current output is inside a cornerstone builder preview.
4433 4433
 		 *
4434 4434
 		 * @return bool
4435 4435
 		 *@since 1.0.8
4436 4436
 		 */
4437
-		public function is_cornerstone_preview() {
4438
-			$result = false;
4439
-			if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4440
-				$result = true;
4441
-			}
4437
+		    public function is_cornerstone_preview() {
4438
+			    $result = false;
4439
+			    if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) {
4440
+				    $result = true;
4441
+			    }
4442 4442
 
4443
-			return $result;
4444
-		}
4443
+			    return $result;
4444
+		    }
4445 4445
 
4446
-		/**
4446
+		    /**
4447 4447
 		 * Tests if the current output is inside a fusion builder preview.
4448 4448
 		 *
4449 4449
 		 * @return bool
4450 4450
 		 *@since 1.1.0
4451 4451
 		 */
4452
-		public function is_fusion_preview() {
4453
-			$result = false;
4454
-			if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4455
-				$result = true;
4456
-			}
4452
+		    public function is_fusion_preview() {
4453
+			    $result = false;
4454
+			    if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) {
4455
+				    $result = true;
4456
+			    }
4457 4457
 
4458
-			return $result;
4459
-		}
4458
+			    return $result;
4459
+		    }
4460 4460
 
4461
-		/**
4461
+		    /**
4462 4462
 		 * Tests if the current output is inside a Oxygen builder preview.
4463 4463
 		 *
4464 4464
 		 * @return bool
4465 4465
 		 *@since 1.0.18
4466 4466
 		 */
4467
-		public function is_oxygen_preview() {
4468
-			$result = false;
4469
-			if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4470
-				$result = true;
4471
-			}
4467
+		    public function is_oxygen_preview() {
4468
+			    $result = false;
4469
+			    if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) {
4470
+				    $result = true;
4471
+			    }
4472 4472
 
4473
-			return $result;
4474
-		}
4473
+			    return $result;
4474
+		    }
4475 4475
 
4476
-		/**
4476
+		    /**
4477 4477
 		 * Check for Kallyas theme Zion builder preview.
4478 4478
 		 *
4479 4479
 		 * @since 1.1.22
4480 4480
 		 *
4481 4481
 		 * @return bool True when preview page otherwise false.
4482 4482
 		 */
4483
-		public function is_kallyas_zion_preview() {
4484
-			$result = false;
4483
+		    public function is_kallyas_zion_preview() {
4484
+			    $result = false;
4485 4485
 
4486
-			if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4487
-				$result = true;
4488
-			}
4486
+			    if ( function_exists( 'znhg_kallyas_theme_config' ) && ! empty( $_REQUEST['zn_pb_edit'] ) ) {
4487
+				    $result = true;
4488
+			    }
4489 4489
 
4490
-			return $result;
4491
-		}
4490
+			    return $result;
4491
+		    }
4492 4492
 
4493
-		/**
4493
+		    /**
4494 4494
 		 * Check for Bricks theme builder preview.
4495 4495
 		 *
4496 4496
 		 * @since 1.1.31
4497 4497
 		 *
4498 4498
 		 * @return bool True when preview page otherwise false.
4499 4499
 		 */
4500
-		public function is_bricks_preview() {
4501
-			$result = false;
4500
+		    public function is_bricks_preview() {
4501
+			    $result = false;
4502 4502
 
4503
-			if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4504
-				$result = true;
4505
-			}
4503
+			    if ( function_exists( 'bricks_is_builder' ) && ( bricks_is_builder() || bricks_is_builder_call() ) ) {
4504
+				    $result = true;
4505
+			    }
4506 4506
 
4507
-			return $result;
4508
-		}
4507
+			    return $result;
4508
+		    }
4509 4509
 
4510
-		/**
4510
+		    /**
4511 4511
 		 * General function to check if we are in a preview situation.
4512 4512
 		 *
4513 4513
 		 * @return bool
4514 4514
 		 *@since 1.0.6
4515 4515
 		 */
4516
-		public function is_preview() {
4517
-			$preview = false;
4518
-			if ( $this->is_divi_preview() ) {
4519
-				$preview = true;
4520
-			} elseif ( $this->is_elementor_preview() ) {
4521
-				$preview = true;
4522
-			} elseif ( $this->is_beaver_preview() ) {
4523
-				$preview = true;
4524
-			} elseif ( $this->is_siteorigin_preview() ) {
4525
-				$preview = true;
4526
-			} elseif ( $this->is_cornerstone_preview() ) {
4527
-				$preview = true;
4528
-			} elseif ( $this->is_fusion_preview() ) {
4529
-				$preview = true;
4530
-			} elseif ( $this->is_oxygen_preview() ) {
4531
-				$preview = true;
4532
-			} elseif( $this->is_kallyas_zion_preview() ) {
4533
-				$preview = true;
4534
-			} elseif( $this->is_block_content_call() ) {
4535
-				$preview = true;
4536
-			} elseif( $this->is_bricks_preview() ) {
4537
-				$preview = true;
4538
-			}
4539
-
4540
-			return $preview;
4541
-		}
4542
-
4543
-		/**
4516
+		    public function is_preview() {
4517
+			    $preview = false;
4518
+			    if ( $this->is_divi_preview() ) {
4519
+				    $preview = true;
4520
+			    } elseif ( $this->is_elementor_preview() ) {
4521
+				    $preview = true;
4522
+			    } elseif ( $this->is_beaver_preview() ) {
4523
+				    $preview = true;
4524
+			    } elseif ( $this->is_siteorigin_preview() ) {
4525
+				    $preview = true;
4526
+			    } elseif ( $this->is_cornerstone_preview() ) {
4527
+				    $preview = true;
4528
+			    } elseif ( $this->is_fusion_preview() ) {
4529
+				    $preview = true;
4530
+			    } elseif ( $this->is_oxygen_preview() ) {
4531
+				    $preview = true;
4532
+			    } elseif( $this->is_kallyas_zion_preview() ) {
4533
+				    $preview = true;
4534
+			    } elseif( $this->is_block_content_call() ) {
4535
+				    $preview = true;
4536
+			    } elseif( $this->is_bricks_preview() ) {
4537
+				    $preview = true;
4538
+			    }
4539
+
4540
+			    return $preview;
4541
+		    }
4542
+
4543
+		    /**
4544 4544
 		 * Output the super title.
4545 4545
 		 *
4546 4546
 		 * @param $args
@@ -4548,174 +4548,174 @@  discard block
 block discarded – undo
4548 4548
 		 *
4549 4549
 		 * @return string
4550 4550
 		 */
4551
-		public function output_title( $args, $instance = array() ) {
4552
-			$output = '';
4553
-			if ( ! empty( $instance['title'] ) ) {
4554
-				/** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4555
-				$title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4556
-
4557
-				if ( empty( $instance['widget_title_tag'] ) ) {
4558
-					if ( ! isset( $args['before_title'] ) ) {
4559
-						$args['before_title'] = '';
4560
-					}
4561
-
4562
-					if ( ! isset( $args['after_title'] ) ) {
4563
-						$args['after_title'] = '';
4564
-					}
4565
-
4566
-					$output = $args['before_title'] . $title . $args['after_title'];
4567
-				} else {
4568
-					$tag 			= esc_attr( $instance['widget_title_tag'] );
4569
-					$allowed_tags 	= array( 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'span', 'div', 'p' );
4570
-					$title_tag      = in_array( $tag, $allowed_tags, true ) ? esc_attr( $tag ) : 'h2';
4571
-
4572
-					// classes
4573
-					$title_classes = array();
4574
-					$title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4575
-					$title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4576
-					$title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4577
-					$title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4578
-					$title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4579
-					$title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4580
-					$title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4581
-					$title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4582
-					$title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4583
-					$title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4584
-					$title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4585
-					$title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4586
-					$title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4587
-
4588
-					$class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4589
-					$output = "<$title_tag class='$class' >$title</$title_tag>";
4590
-				}
4591
-
4592
-			}
4593
-
4594
-			return $output;
4595
-		}
4596
-
4597
-		/**
4551
+		    public function output_title( $args, $instance = array() ) {
4552
+			    $output = '';
4553
+			    if ( ! empty( $instance['title'] ) ) {
4554
+				    /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */
4555
+				    $title  = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base );
4556
+
4557
+				    if ( empty( $instance['widget_title_tag'] ) ) {
4558
+					    if ( ! isset( $args['before_title'] ) ) {
4559
+						    $args['before_title'] = '';
4560
+					    }
4561
+
4562
+					    if ( ! isset( $args['after_title'] ) ) {
4563
+						    $args['after_title'] = '';
4564
+					    }
4565
+
4566
+					    $output = $args['before_title'] . $title . $args['after_title'];
4567
+				    } else {
4568
+					    $tag 			= esc_attr( $instance['widget_title_tag'] );
4569
+					    $allowed_tags 	= array( 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'span', 'div', 'p' );
4570
+					    $title_tag      = in_array( $tag, $allowed_tags, true ) ? esc_attr( $tag ) : 'h2';
4571
+
4572
+					    // classes
4573
+					    $title_classes = array();
4574
+					    $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : '';
4575
+					    $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : '';
4576
+					    $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : '';
4577
+					    $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : '';
4578
+					    $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : '';
4579
+					    $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : '';
4580
+					    $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : '';
4581
+					    $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : '';
4582
+					    $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : '';
4583
+					    $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : '';
4584
+					    $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : '';
4585
+					    $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : '';
4586
+					    $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : '';
4587
+
4588
+					    $class = !empty( $title_classes ) ? implode(" ",$title_classes) : '';
4589
+					    $output = "<$title_tag class='$class' >$title</$title_tag>";
4590
+				    }
4591
+
4592
+			    }
4593
+
4594
+			    return $output;
4595
+		    }
4596
+
4597
+		    /**
4598 4598
 		 * Outputs the options form inputs for the widget.
4599 4599
 		 *
4600 4600
 		 * @param array $instance The widget options.
4601 4601
 		 */
4602
-		public function form( $instance ) {
4602
+		    public function form( $instance ) {
4603 4603
 
4604
-			// set widget instance
4605
-			$this->instance = $instance;
4604
+			    // set widget instance
4605
+			    $this->instance = $instance;
4606 4606
 
4607
-			// set it as a SD widget
4608
-			echo $this->widget_advanced_toggle();
4607
+			    // set it as a SD widget
4608
+			    echo $this->widget_advanced_toggle();
4609 4609
 
4610
-			echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4611
-			$arguments_raw = $this->get_arguments();
4610
+			    echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>";
4611
+			    $arguments_raw = $this->get_arguments();
4612 4612
 
4613
-			if ( is_array( $arguments_raw ) ) {
4613
+			    if ( is_array( $arguments_raw ) ) {
4614 4614
 
4615
-				$arguments = $this->group_arguments( $arguments_raw );
4615
+				    $arguments = $this->group_arguments( $arguments_raw );
4616 4616
 
4617
-				// Do we have sections?
4618
-				$has_sections = $arguments == $arguments_raw ? false : true;
4617
+				    // Do we have sections?
4618
+				    $has_sections = $arguments == $arguments_raw ? false : true;
4619 4619
 
4620 4620
 
4621
-				if ( $has_sections ) {
4622
-					$panel_count = 0;
4623
-					foreach ( $arguments as $key => $args ) {
4621
+				    if ( $has_sections ) {
4622
+					    $panel_count = 0;
4623
+					    foreach ( $arguments as $key => $args ) {
4624 4624
 
4625
-						?>
4625
+						    ?>
4626 4626
 						<script>
4627 4627
 							//							jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle();
4628 4628
 						</script>
4629 4629
 						<?php
4630 4630
 
4631
-						$hide       = $panel_count ? ' style="display:none;" ' : '';
4632
-						$icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4633
-						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>";
4634
-						echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4631
+						    $hide       = $panel_count ? ' style="display:none;" ' : '';
4632
+						    $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down';
4633
+						    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>";
4634
+						    echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>";
4635 4635
 
4636
-						foreach ( $args as $k => $a ) {
4636
+						    foreach ( $args as $k => $a ) {
4637 4637
 
4638
-							$this->widget_inputs_row_start($k, $a);
4639
-							$this->widget_inputs( $a, $instance );
4640
-							$this->widget_inputs_row_end($k, $a);
4638
+							    $this->widget_inputs_row_start($k, $a);
4639
+							    $this->widget_inputs( $a, $instance );
4640
+							    $this->widget_inputs_row_end($k, $a);
4641 4641
 
4642
-						}
4642
+						    }
4643 4643
 
4644
-						echo "</div>";
4644
+						    echo "</div>";
4645 4645
 
4646
-						$panel_count ++;
4646
+						    $panel_count ++;
4647 4647
 
4648
-					}
4649
-				} else {
4650
-					foreach ( $arguments as $key => $args ) {
4651
-						$this->widget_inputs_row_start($key, $args);
4652
-						$this->widget_inputs( $args, $instance );
4653
-						$this->widget_inputs_row_end($key, $args);
4654
-					}
4655
-				}
4648
+					    }
4649
+				    } else {
4650
+					    foreach ( $arguments as $key => $args ) {
4651
+						    $this->widget_inputs_row_start($key, $args);
4652
+						    $this->widget_inputs( $args, $instance );
4653
+						    $this->widget_inputs_row_end($key, $args);
4654
+					    }
4655
+				    }
4656 4656
 
4657
-			}
4658
-		}
4657
+			    }
4658
+		    }
4659 4659
 
4660
-		public function widget_inputs_row_start( $key, $args ) {
4661
-			if ( ! empty( $args['row'] ) ) {
4662
-				// Maybe open
4663
-				if ( ! empty( $args['row']['open'] ) ) {
4664
-					?>
4665
-					<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'] ) : '' ); ?>'>
4660
+		    public function widget_inputs_row_start( $key, $args ) {
4661
+			    if ( ! empty( $args['row'] ) ) {
4662
+				    // Maybe open
4663
+				    if ( ! empty( $args['row']['open'] ) ) {
4664
+					    ?>
4665
+    					<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'] ) : '' ); ?>'>
4666 4666
 					<?php if ( ! empty( $args['row']['title'] ) ) { ?>
4667
-					<?php
4668
-						if ( isset( $args['row']['icon'] ) ) {
4669
-							$args['row']['icon'] = '';
4670
-						}
4671
-
4672
-						if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4673
-							$args['row']['device_type'] = $args['device_type'];
4674
-						}
4675
-					?>
4676
-					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4667
+    					<?php
4668
+						    if ( isset( $args['row']['icon'] ) ) {
4669
+							    $args['row']['icon'] = '';
4670
+						    }
4671
+
4672
+						    if ( ! isset( $args['row']['device_type'] ) && isset( $args['device_type'] ) ) {
4673
+							    $args['row']['device_type'] = $args['device_type'];
4674
+						    }
4675
+					    ?>
4676
+    					<label class="mb-0"><?php echo $this->widget_field_title( $args['row'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label>
4677 4677
 					<?php } ?>
4678
-					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4678
+    					<div class='row<?php echo ( ! empty( $args['row']['class'] ) ? ' ' . esc_attr( $args['row']['class'] ) : '' ); ?>'>
4679 4679
 					<div class='col pr-2'>
4680 4680
 					<?php
4681
-				} else if ( ! empty( $args['row']['close'] ) ) {
4682
-					echo "<div class='col pl-0 ps-0'>";
4683
-				} else {
4684
-					echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4685
-				}
4686
-			}
4687
-		}
4688
-
4689
-		public function widget_inputs_row_end( $key, $args ) {
4690
-			if ( ! empty( $args['row'] ) ) {
4691
-				// Maybe close
4692
-				if ( ! empty( $args['row']['close'] ) ) {
4693
-					echo "</div></div>";
4694
-				}
4695
-				echo "</div>";
4696
-			}
4697
-		}
4698
-
4699
-		/**
4681
+				    } else if ( ! empty( $args['row']['close'] ) ) {
4682
+					    echo "<div class='col pl-0 ps-0'>";
4683
+				    } else {
4684
+					    echo "<div class='col pl-0 ps-0 pr-2 pe-2'>";
4685
+				    }
4686
+			    }
4687
+		    }
4688
+
4689
+		    public function widget_inputs_row_end( $key, $args ) {
4690
+			    if ( ! empty( $args['row'] ) ) {
4691
+				    // Maybe close
4692
+				    if ( ! empty( $args['row']['close'] ) ) {
4693
+					    echo "</div></div>";
4694
+				    }
4695
+				    echo "</div>";
4696
+			    }
4697
+		    }
4698
+
4699
+		    /**
4700 4700
 		 * Get the hidden input that when added makes the advanced button show on widget settings.
4701 4701
 		 *
4702 4702
 		 * @return string
4703 4703
 		 */
4704
-		public function widget_advanced_toggle() {
4704
+		    public function widget_advanced_toggle() {
4705 4705
 
4706
-			$output = '';
4707
-			if ( $this->block_show_advanced() ) {
4708
-				$val = 1;
4709
-			} else {
4710
-				$val = 0;
4711
-			}
4706
+			    $output = '';
4707
+			    if ( $this->block_show_advanced() ) {
4708
+				    $val = 1;
4709
+			    } else {
4710
+				    $val = 0;
4711
+			    }
4712 4712
 
4713
-			$output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4713
+			    $output .= "<input type='hidden'  class='sd-show-advanced' value='$val' />";
4714 4714
 
4715
-			return $output;
4716
-		}
4715
+			    return $output;
4716
+		    }
4717 4717
 
4718
-		/**
4718
+		    /**
4719 4719
 		 * Convert require element.
4720 4720
 		 *
4721 4721
 		 * @param string $input Input element.
@@ -4724,67 +4724,67 @@  discard block
 block discarded – undo
4724 4724
 		 *@since 1.0.0
4725 4725
 		 *
4726 4726
 		 */
4727
-		public function convert_element_require( $input ) {
4728
-			$input = str_replace( "'", '"', $input );// we only want double quotes
4727
+		    public function convert_element_require( $input ) {
4728
+			    $input = str_replace( "'", '"', $input );// we only want double quotes
4729 4729
 
4730
-			$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4731
-				"jQuery(form).find('[data-argument=\"",
4732
-				"\"]').find('input,select,textarea').val()",
4733
-				"\"]').find('input:checked').val()"
4734
-			), $input ) );
4730
+			    $output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
4731
+				    "jQuery(form).find('[data-argument=\"",
4732
+				    "\"]').find('input,select,textarea').val()",
4733
+				    "\"]').find('input:checked').val()"
4734
+			    ), $input ) );
4735 4735
 
4736
-			return $output;
4737
-		}
4736
+			    return $output;
4737
+		    }
4738 4738
 
4739
-		/**
4739
+		    /**
4740 4740
 		 * Builds the inputs for the widget options.
4741 4741
 		 *
4742 4742
 		 * @param $args
4743 4743
 		 * @param $instance
4744 4744
 		 */
4745
-		public function widget_inputs( $args, $instance ) {
4746
-
4747
-			$class             = "";
4748
-			$element_require   = "";
4749
-			$custom_attributes = "";
4750
-
4751
-			// get value
4752
-			if ( isset( $instance[ $args['name'] ] ) ) {
4753
-				$value = $instance[ $args['name'] ];
4754
-			} elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4755
-				$value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4756
-			} else {
4757
-				$value = '';
4758
-			}
4759
-
4760
-			// get placeholder
4761
-			if ( ! empty( $args['placeholder'] ) ) {
4762
-				$placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4763
-			} else {
4764
-				$placeholder = '';
4765
-			}
4766
-
4767
-			// get if advanced
4768
-			if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4769
-				$class .= " sd-advanced-setting ";
4770
-			}
4771
-
4772
-			// element_require
4773
-			if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4774
-				$element_require = $args['element_require'];
4775
-			}
4776
-
4777
-			// custom_attributes
4778
-			if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4779
-				$custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4780
-			}
4781
-
4782
-			// before wrapper
4783
-			?>
4784
-			<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 );} ?>'>
4745
+		    public function widget_inputs( $args, $instance ) {
4746
+
4747
+			    $class             = "";
4748
+			    $element_require   = "";
4749
+			    $custom_attributes = "";
4750
+
4751
+			    // get value
4752
+			    if ( isset( $instance[ $args['name'] ] ) ) {
4753
+				    $value = $instance[ $args['name'] ];
4754
+			    } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) {
4755
+				    $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] );
4756
+			    } else {
4757
+				    $value = '';
4758
+			    }
4759
+
4760
+			    // get placeholder
4761
+			    if ( ! empty( $args['placeholder'] ) ) {
4762
+				    $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'";
4763
+			    } else {
4764
+				    $placeholder = '';
4765
+			    }
4766
+
4767
+			    // get if advanced
4768
+			    if ( isset( $args['advanced'] ) && $args['advanced'] ) {
4769
+				    $class .= " sd-advanced-setting ";
4770
+			    }
4771
+
4772
+			    // element_require
4773
+			    if ( isset( $args['element_require'] ) && $args['element_require'] ) {
4774
+				    $element_require = $args['element_require'];
4775
+			    }
4776
+
4777
+			    // custom_attributes
4778
+			    if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) {
4779
+				    $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true );
4780
+			    }
4781
+
4782
+			    // before wrapper
4783
+			    ?>
4784
+    			<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 );} ?>'>
4785 4785
 			<?php
4786
-			switch ( $args['type'] ) {
4787
-				//array('text','password','number','email','tel','url','color')
4786
+			    switch ( $args['type'] ) {
4787
+				    //array('text','password','number','email','tel','url','color')
4788 4788
 				case "text":
4789 4789
 				case "password":
4790 4790
 				case "number":
@@ -4848,7 +4848,7 @@  discard block
 block discarded – undo
4848 4848
 					break;
4849 4849
 				default:
4850 4850
 					echo "No input type found!"; // @todo we need to add more input types.
4851
-			}
4851
+			    }
4852 4852
 			// after wrapper
4853 4853
 			?></p><?php
4854 4854
 		}
Please login to merge, or discard this patch.