Passed
Push — master ( 4b094a...bf7929 )
by Brian
05:29 queued 53s
created
vendor/composer/InstalledVersions.php 1 patch
Indentation   +54 added lines, -54 removed lines patch added patch discarded remove patch
@@ -12,8 +12,8 @@  discard block
 block discarded – undo
12 12
 class InstalledVersions
13 13
 {
14 14
 private static $installed = array (
15
-  'root' => 
16
-  array (
15
+    'root' => 
16
+    array (
17 17
     'pretty_version' => 'dev-master',
18 18
     'version' => 'dev-master',
19 19
     'aliases' => 
@@ -21,87 +21,87 @@  discard block
 block discarded – undo
21 21
     ),
22 22
     'reference' => '4b094a9228b10d14ba32d30d478a694ed5bf34eb',
23 23
     'name' => 'ayecode/invoicing',
24
-  ),
25
-  'versions' => 
26
-  array (
24
+    ),
25
+    'versions' => 
26
+    array (
27 27
     'ayecode/ayecode-connect-helper' => 
28 28
     array (
29
-      'pretty_version' => '1.0.3',
30
-      'version' => '1.0.3.0',
31
-      'aliases' => 
32
-      array (
33
-      ),
34
-      'reference' => '1af7cdefdbd20d4443a3ab4834e4c1cd8fe57fb4',
29
+        'pretty_version' => '1.0.3',
30
+        'version' => '1.0.3.0',
31
+        'aliases' => 
32
+        array (
33
+        ),
34
+        'reference' => '1af7cdefdbd20d4443a3ab4834e4c1cd8fe57fb4',
35 35
     ),
36 36
     'ayecode/invoicing' => 
37 37
     array (
38
-      'pretty_version' => 'dev-master',
39
-      'version' => 'dev-master',
40
-      'aliases' => 
41
-      array (
42
-      ),
43
-      'reference' => '4b094a9228b10d14ba32d30d478a694ed5bf34eb',
38
+        'pretty_version' => 'dev-master',
39
+        'version' => 'dev-master',
40
+        'aliases' => 
41
+        array (
42
+        ),
43
+        'reference' => '4b094a9228b10d14ba32d30d478a694ed5bf34eb',
44 44
     ),
45 45
     'ayecode/wp-ayecode-ui' => 
46 46
     array (
47
-      'pretty_version' => '0.1.41',
48
-      'version' => '0.1.41.0',
49
-      'aliases' => 
50
-      array (
51
-      ),
52
-      'reference' => '5646d3060999d75b74c0d723e44fe84fce9d2a4b',
47
+        'pretty_version' => '0.1.41',
48
+        'version' => '0.1.41.0',
49
+        'aliases' => 
50
+        array (
51
+        ),
52
+        'reference' => '5646d3060999d75b74c0d723e44fe84fce9d2a4b',
53 53
     ),
54 54
     'ayecode/wp-font-awesome-settings' => 
55 55
     array (
56
-      'pretty_version' => '1.0.12',
57
-      'version' => '1.0.12.0',
58
-      'aliases' => 
59
-      array (
60
-      ),
61
-      'reference' => '754cca6fda775f3e0b56b90a810dfcaea62ea288',
56
+        'pretty_version' => '1.0.12',
57
+        'version' => '1.0.12.0',
58
+        'aliases' => 
59
+        array (
60
+        ),
61
+        'reference' => '754cca6fda775f3e0b56b90a810dfcaea62ea288',
62 62
     ),
63 63
     'ayecode/wp-super-duper' => 
64 64
     array (
65
-      'pretty_version' => '1.0.23',
66
-      'version' => '1.0.23.0',
67
-      'aliases' => 
68
-      array (
69
-      ),
70
-      'reference' => '9473c0b7cf3ef4c32374222994a3e4613cdaeb48',
65
+        'pretty_version' => '1.0.23',
66
+        'version' => '1.0.23.0',
67
+        'aliases' => 
68
+        array (
69
+        ),
70
+        'reference' => '9473c0b7cf3ef4c32374222994a3e4613cdaeb48',
71 71
     ),
72 72
     'composer/installers' => 
73 73
     array (
74
-      'pretty_version' => 'v1.10.0',
75
-      'version' => '1.10.0.0',
76
-      'aliases' => 
77
-      array (
78
-      ),
79
-      'reference' => '1a0357fccad9d1cc1ea0c9a05b8847fbccccb78d',
74
+        'pretty_version' => 'v1.10.0',
75
+        'version' => '1.10.0.0',
76
+        'aliases' => 
77
+        array (
78
+        ),
79
+        'reference' => '1a0357fccad9d1cc1ea0c9a05b8847fbccccb78d',
80 80
     ),
81 81
     'maxmind-db/reader' => 
82 82
     array (
83
-      'pretty_version' => 'v1.6.0',
84
-      'version' => '1.6.0.0',
85
-      'aliases' => 
86
-      array (
87
-      ),
88
-      'reference' => 'febd4920bf17c1da84cef58e56a8227dfb37fbe4',
83
+        'pretty_version' => 'v1.6.0',
84
+        'version' => '1.6.0.0',
85
+        'aliases' => 
86
+        array (
87
+        ),
88
+        'reference' => 'febd4920bf17c1da84cef58e56a8227dfb37fbe4',
89 89
     ),
90 90
     'roundcube/plugin-installer' => 
91 91
     array (
92
-      'replaced' => 
93
-      array (
92
+        'replaced' => 
93
+        array (
94 94
         0 => '*',
95
-      ),
95
+        ),
96 96
     ),
97 97
     'shama/baton' => 
98 98
     array (
99
-      'replaced' => 
100
-      array (
99
+        'replaced' => 
100
+        array (
101 101
         0 => '*',
102
-      ),
102
+        ),
103
+    ),
103 104
     ),
104
-  ),
105 105
 );
106 106
 
107 107
 
Please login to merge, or discard this patch.
vendor/composer/installers/src/Composer/Installers/OxidInstaller.php 1 patch
Indentation   +41 added lines, -41 removed lines patch added patch discarded remove patch
@@ -5,7 +5,7 @@  discard block
 block discarded – undo
5 5
 
6 6
 class OxidInstaller extends BaseInstaller
7 7
 {
8
-	const VENDOR_PATTERN = '/^modules\/(?P<vendor>.+)\/.+/';
8
+    const VENDOR_PATTERN = '/^modules\/(?P<vendor>.+)\/.+/';
9 9
 
10 10
     protected $locations = array(
11 11
         'module'    => 'modules/{$name}/',
@@ -13,47 +13,47 @@  discard block
 block discarded – undo
13 13
         'out'    => 'out/{$name}/',
14 14
     );
15 15
 
16
-	/**
17
-	 * getInstallPath
18
-	 *
19
-	 * @param PackageInterface $package
20
-	 * @param string $frameworkType
21
-	 * @return string
22
-	 */
23
-	public function getInstallPath(PackageInterface $package, $frameworkType = '')
24
-	{
25
-		$installPath = parent::getInstallPath($package, $frameworkType);
26
-		$type = $this->package->getType();
27
-		if ($type === 'oxid-module') {
28
-			$this->prepareVendorDirectory($installPath);
29
-		}
30
-		return $installPath;
31
-	}
16
+    /**
17
+     * getInstallPath
18
+     *
19
+     * @param PackageInterface $package
20
+     * @param string $frameworkType
21
+     * @return string
22
+     */
23
+    public function getInstallPath(PackageInterface $package, $frameworkType = '')
24
+    {
25
+        $installPath = parent::getInstallPath($package, $frameworkType);
26
+        $type = $this->package->getType();
27
+        if ($type === 'oxid-module') {
28
+            $this->prepareVendorDirectory($installPath);
29
+        }
30
+        return $installPath;
31
+    }
32 32
 
33
-	/**
34
-	 * prepareVendorDirectory
35
-	 *
36
-	 * Makes sure there is a vendormetadata.php file inside
37
-	 * the vendor folder if there is a vendor folder.
38
-	 *
39
-	 * @param string $installPath
40
-	 * @return void
41
-	 */
42
-	protected function prepareVendorDirectory($installPath)
43
-	{
44
-		$matches = '';
45
-		$hasVendorDirectory = preg_match(self::VENDOR_PATTERN, $installPath, $matches);
46
-		if (!$hasVendorDirectory) {
47
-			return;
48
-		}
33
+    /**
34
+     * prepareVendorDirectory
35
+     *
36
+     * Makes sure there is a vendormetadata.php file inside
37
+     * the vendor folder if there is a vendor folder.
38
+     *
39
+     * @param string $installPath
40
+     * @return void
41
+     */
42
+    protected function prepareVendorDirectory($installPath)
43
+    {
44
+        $matches = '';
45
+        $hasVendorDirectory = preg_match(self::VENDOR_PATTERN, $installPath, $matches);
46
+        if (!$hasVendorDirectory) {
47
+            return;
48
+        }
49 49
 
50
-		$vendorDirectory = $matches['vendor'];
51
-		$vendorPath = getcwd() . '/modules/' . $vendorDirectory;
52
-		if (!file_exists($vendorPath)) {
53
-			mkdir($vendorPath, 0755, true);
54
-		}
50
+        $vendorDirectory = $matches['vendor'];
51
+        $vendorPath = getcwd() . '/modules/' . $vendorDirectory;
52
+        if (!file_exists($vendorPath)) {
53
+            mkdir($vendorPath, 0755, true);
54
+        }
55 55
 
56
-		$vendorMetaDataPath = $vendorPath . '/vendormetadata.php';
57
-		touch($vendorMetaDataPath);
58
-	}
56
+        $vendorMetaDataPath = $vendorPath . '/vendormetadata.php';
57
+        touch($vendorMetaDataPath);
58
+    }
59 59
 }
Please login to merge, or discard this patch.
vendor/composer/installed.php 1 patch
Indentation   +54 added lines, -54 removed lines patch added patch discarded remove patch
@@ -1,6 +1,6 @@  discard block
 block discarded – undo
1 1
 <?php return array (
2
-  'root' => 
3
-  array (
2
+    'root' => 
3
+    array (
4 4
     'pretty_version' => 'dev-master',
5 5
     'version' => 'dev-master',
6 6
     'aliases' => 
@@ -8,85 +8,85 @@  discard block
 block discarded – undo
8 8
     ),
9 9
     'reference' => '4b094a9228b10d14ba32d30d478a694ed5bf34eb',
10 10
     'name' => 'ayecode/invoicing',
11
-  ),
12
-  'versions' => 
13
-  array (
11
+    ),
12
+    'versions' => 
13
+    array (
14 14
     'ayecode/ayecode-connect-helper' => 
15 15
     array (
16
-      'pretty_version' => '1.0.3',
17
-      'version' => '1.0.3.0',
18
-      'aliases' => 
19
-      array (
20
-      ),
21
-      'reference' => '1af7cdefdbd20d4443a3ab4834e4c1cd8fe57fb4',
16
+        'pretty_version' => '1.0.3',
17
+        'version' => '1.0.3.0',
18
+        'aliases' => 
19
+        array (
20
+        ),
21
+        'reference' => '1af7cdefdbd20d4443a3ab4834e4c1cd8fe57fb4',
22 22
     ),
23 23
     'ayecode/invoicing' => 
24 24
     array (
25
-      'pretty_version' => 'dev-master',
26
-      'version' => 'dev-master',
27
-      'aliases' => 
28
-      array (
29
-      ),
30
-      'reference' => '4b094a9228b10d14ba32d30d478a694ed5bf34eb',
25
+        'pretty_version' => 'dev-master',
26
+        'version' => 'dev-master',
27
+        'aliases' => 
28
+        array (
29
+        ),
30
+        'reference' => '4b094a9228b10d14ba32d30d478a694ed5bf34eb',
31 31
     ),
32 32
     'ayecode/wp-ayecode-ui' => 
33 33
     array (
34
-      'pretty_version' => '0.1.41',
35
-      'version' => '0.1.41.0',
36
-      'aliases' => 
37
-      array (
38
-      ),
39
-      'reference' => '5646d3060999d75b74c0d723e44fe84fce9d2a4b',
34
+        'pretty_version' => '0.1.41',
35
+        'version' => '0.1.41.0',
36
+        'aliases' => 
37
+        array (
38
+        ),
39
+        'reference' => '5646d3060999d75b74c0d723e44fe84fce9d2a4b',
40 40
     ),
41 41
     'ayecode/wp-font-awesome-settings' => 
42 42
     array (
43
-      'pretty_version' => '1.0.12',
44
-      'version' => '1.0.12.0',
45
-      'aliases' => 
46
-      array (
47
-      ),
48
-      'reference' => '754cca6fda775f3e0b56b90a810dfcaea62ea288',
43
+        'pretty_version' => '1.0.12',
44
+        'version' => '1.0.12.0',
45
+        'aliases' => 
46
+        array (
47
+        ),
48
+        'reference' => '754cca6fda775f3e0b56b90a810dfcaea62ea288',
49 49
     ),
50 50
     'ayecode/wp-super-duper' => 
51 51
     array (
52
-      'pretty_version' => '1.0.23',
53
-      'version' => '1.0.23.0',
54
-      'aliases' => 
55
-      array (
56
-      ),
57
-      'reference' => '9473c0b7cf3ef4c32374222994a3e4613cdaeb48',
52
+        'pretty_version' => '1.0.23',
53
+        'version' => '1.0.23.0',
54
+        'aliases' => 
55
+        array (
56
+        ),
57
+        'reference' => '9473c0b7cf3ef4c32374222994a3e4613cdaeb48',
58 58
     ),
59 59
     'composer/installers' => 
60 60
     array (
61
-      'pretty_version' => 'v1.10.0',
62
-      'version' => '1.10.0.0',
63
-      'aliases' => 
64
-      array (
65
-      ),
66
-      'reference' => '1a0357fccad9d1cc1ea0c9a05b8847fbccccb78d',
61
+        'pretty_version' => 'v1.10.0',
62
+        'version' => '1.10.0.0',
63
+        'aliases' => 
64
+        array (
65
+        ),
66
+        'reference' => '1a0357fccad9d1cc1ea0c9a05b8847fbccccb78d',
67 67
     ),
68 68
     'maxmind-db/reader' => 
69 69
     array (
70
-      'pretty_version' => 'v1.6.0',
71
-      'version' => '1.6.0.0',
72
-      'aliases' => 
73
-      array (
74
-      ),
75
-      'reference' => 'febd4920bf17c1da84cef58e56a8227dfb37fbe4',
70
+        'pretty_version' => 'v1.6.0',
71
+        'version' => '1.6.0.0',
72
+        'aliases' => 
73
+        array (
74
+        ),
75
+        'reference' => 'febd4920bf17c1da84cef58e56a8227dfb37fbe4',
76 76
     ),
77 77
     'roundcube/plugin-installer' => 
78 78
     array (
79
-      'replaced' => 
80
-      array (
79
+        'replaced' => 
80
+        array (
81 81
         0 => '*',
82
-      ),
82
+        ),
83 83
     ),
84 84
     'shama/baton' => 
85 85
     array (
86
-      'replaced' => 
87
-      array (
86
+        'replaced' => 
87
+        array (
88 88
         0 => '*',
89
-      ),
89
+        ),
90
+    ),
90 91
     ),
91
-  ),
92 92
 );
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/ayecode-ui-loader.php 1 patch
Indentation   +18 added lines, -18 removed lines patch added patch discarded remove patch
@@ -7,40 +7,40 @@
 block discarded – undo
7 7
  * Bail if we are not in WP.
8 8
  */
9 9
 if ( ! defined( 'ABSPATH' ) ) {
10
-	exit;
10
+    exit;
11 11
 }
12 12
 
13 13
 /**
14 14
  * Set the version only if its the current newest while loading.
15 15
  */
16 16
 add_action('after_setup_theme', function () {
17
-	global $ayecode_ui_version,$ayecode_ui_file_key;
18
-	$this_version = "0.1.41";
19
-	if(version_compare($this_version , $ayecode_ui_version, '>')){
20
-		$ayecode_ui_version = $this_version ;
21
-		$ayecode_ui_file_key = wp_hash( __FILE__ );
22
-	}
17
+    global $ayecode_ui_version,$ayecode_ui_file_key;
18
+    $this_version = "0.1.41";
19
+    if(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 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
-	}
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 39
 if(!function_exists('aui')){
40
-	function aui(){
41
-		if(!class_exists("AUI",false)){
42
-			return false;
43
-		}
44
-		return AUI::instance();
45
-	}
40
+    function aui(){
41
+        if(!class_exists("AUI",false)){
42
+            return false;
43
+        }
44
+        return AUI::instance();
45
+    }
46 46
 }
47 47
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/class-aui.php 1 patch
Indentation   +227 added lines, -227 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,231 +11,231 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI {
13 13
 
14
-	/**
15
-	 * Holds the class instance.
16
-	 *
17
-	 * @since 1.0.0
18
-	 * @var null
19
-	 */
20
-	private static $instance = null;
21
-
22
-	/**
23
-	 * Holds the current AUI version number.
24
-	 *
25
-	 * @var string $ver The current version number.
26
-	 */
27
-	public static $ver = '0.1.41';
28
-
29
-	public static $options = null;
30
-
31
-	/**
32
-	 * There can be only one.
33
-	 *
34
-	 * @since 1.0.0
35
-	 * @return AUI|null
36
-	 */
37
-	public static function instance() {
38
-		if ( self::$instance == null ) {
39
-			self::$instance = new AUI();
40
-		}
41
-
42
-		return self::$instance;
43
-	}
44
-
45
-	/**
46
-	 * AUI constructor.
47
-	 *
48
-	 * @since 1.0.0
49
-	 */
50
-	private function __construct() {
51
-		if ( function_exists( "__autoload" ) ) {
52
-			spl_autoload_register( "__autoload" );
53
-		}
54
-		spl_autoload_register( array( $this, 'autoload' ) );
55
-
56
-		// load options
57
-		self::$options = get_option('aui_options');
58
-	}
59
-
60
-	/**
61
-	 * Autoload any components on the fly.
62
-	 *
63
-	 * @since 1.0.0
64
-	 *
65
-	 * @param $classname
66
-	 */
67
-	private function autoload( $classname ) {
68
-		$class     = str_replace( '_', '-', strtolower( $classname ) );
69
-		$file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php';
70
-		if ( $file_path && is_readable( $file_path ) ) {
71
-			include_once( $file_path );
72
-		}
73
-	}
74
-
75
-	/**
76
-	 * Get the AUI options.
77
-	 *
78
-	 * @param $option
79
-	 *
80
-	 * @return string|void
81
-	 */
82
-	public function get_option( $option ){
83
-		$result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : '';
84
-
85
-		if ( ! $result && $option) {
86
-			if( $option == 'color_primary' ){
87
-				$result = AUI_PRIMARY_COLOR;
88
-			}elseif( $option == 'color_secondary' ){
89
-				$result = AUI_SECONDARY_COLOR;
90
-			}
91
-		}
92
-		return $result;
93
-	}
94
-
95
-	public function render( $items = array() ) {
96
-		$output = '';
97
-
98
-		if ( ! empty( $items ) ) {
99
-			foreach ( $items as $args ) {
100
-				$render = isset( $args['render'] ) ? $args['render'] : '';
101
-				if ( $render && method_exists( __CLASS__, $render ) ) {
102
-					$output .= $this->$render( $args );
103
-				}
104
-			}
105
-		}
106
-
107
-		return $output;
108
-	}
109
-
110
-	/**
111
-	 * Render and return a bootstrap alert component.
112
-	 *
113
-	 * @since 1.0.0
114
-	 *
115
-	 * @param array $args
116
-	 *
117
-	 * @return string The rendered component.
118
-	 */
119
-	public function alert( $args = array() ) {
120
-		return AUI_Component_Alert::get( $args );
121
-	}
122
-
123
-	/**
124
-	 * Render and return a bootstrap input component.
125
-	 *
126
-	 * @since 1.0.0
127
-	 *
128
-	 * @param array $args
129
-	 *
130
-	 * @return string The rendered component.
131
-	 */
132
-	public function input( $args = array() ) {
133
-		return AUI_Component_Input::input( $args );
134
-	}
135
-
136
-	/**
137
-	 * Render and return a bootstrap textarea component.
138
-	 *
139
-	 * @since 1.0.0
140
-	 *
141
-	 * @param array $args
142
-	 *
143
-	 * @return string The rendered component.
144
-	 */
145
-	public function textarea( $args = array() ) {
146
-		return AUI_Component_Input::textarea( $args );
147
-	}
148
-
149
-	/**
150
-	 * Render and return a bootstrap button component.
151
-	 *
152
-	 * @since 1.0.0
153
-	 *
154
-	 * @param array $args
155
-	 *
156
-	 * @return string The rendered component.
157
-	 */
158
-	public function button( $args = array() ) {
159
-		return AUI_Component_Button::get( $args );
160
-	}
161
-
162
-	/**
163
-	 * Render and return a bootstrap button component.
164
-	 *
165
-	 * @since 1.0.0
166
-	 *
167
-	 * @param array $args
168
-	 *
169
-	 * @return string The rendered component.
170
-	 */
171
-	public function badge( $args = array() ) {
172
-		$defaults = array(
173
-			'class' => 'badge badge-primary align-middle',
174
-		);
175
-
176
-		// maybe set type
177
-		if ( empty( $args['href'] ) ) {
178
-			$defaults['type'] = 'badge';
179
-		}
180
-
181
-		/**
182
-		 * Parse incoming $args into an array and merge it with $defaults
183
-		 */
184
-		$args = wp_parse_args( $args, $defaults );
185
-
186
-		return AUI_Component_Button::get( $args );
187
-	}
188
-
189
-	/**
190
-	 * Render and return a bootstrap dropdown component.
191
-	 *
192
-	 * @since 1.0.0
193
-	 *
194
-	 * @param array $args
195
-	 *
196
-	 * @return string The rendered component.
197
-	 */
198
-	public function dropdown( $args = array() ) {
199
-		return AUI_Component_Dropdown::get( $args );
200
-	}
201
-
202
-	/**
203
-	 * Render and return a bootstrap select component.
204
-	 *
205
-	 * @since 1.0.0
206
-	 *
207
-	 * @param array $args
208
-	 *
209
-	 * @return string The rendered component.
210
-	 */
211
-	public function select( $args = array() ) {
212
-		return AUI_Component_Input::select( $args );
213
-	}
214
-
215
-	/**
216
-	 * Render and return a bootstrap radio component.
217
-	 *
218
-	 * @since 1.0.0
219
-	 *
220
-	 * @param array $args
221
-	 *
222
-	 * @return string The rendered component.
223
-	 */
224
-	public function radio( $args = array() ) {
225
-		return AUI_Component_Input::radio( $args );
226
-	}
227
-
228
-	/**
229
-	 * Render and return a bootstrap pagination component.
230
-	 *
231
-	 * @since 1.0.0
232
-	 *
233
-	 * @param array $args
234
-	 *
235
-	 * @return string The rendered component.
236
-	 */
237
-	public function pagination( $args = array() ) {
238
-		return AUI_Component_Pagination::get( $args );
239
-	}
14
+    /**
15
+     * Holds the class instance.
16
+     *
17
+     * @since 1.0.0
18
+     * @var null
19
+     */
20
+    private static $instance = null;
21
+
22
+    /**
23
+     * Holds the current AUI version number.
24
+     *
25
+     * @var string $ver The current version number.
26
+     */
27
+    public static $ver = '0.1.41';
28
+
29
+    public static $options = null;
30
+
31
+    /**
32
+     * There can be only one.
33
+     *
34
+     * @since 1.0.0
35
+     * @return AUI|null
36
+     */
37
+    public static function instance() {
38
+        if ( self::$instance == null ) {
39
+            self::$instance = new AUI();
40
+        }
41
+
42
+        return self::$instance;
43
+    }
44
+
45
+    /**
46
+     * AUI constructor.
47
+     *
48
+     * @since 1.0.0
49
+     */
50
+    private function __construct() {
51
+        if ( function_exists( "__autoload" ) ) {
52
+            spl_autoload_register( "__autoload" );
53
+        }
54
+        spl_autoload_register( array( $this, 'autoload' ) );
55
+
56
+        // load options
57
+        self::$options = get_option('aui_options');
58
+    }
59
+
60
+    /**
61
+     * Autoload any components on the fly.
62
+     *
63
+     * @since 1.0.0
64
+     *
65
+     * @param $classname
66
+     */
67
+    private function autoload( $classname ) {
68
+        $class     = str_replace( '_', '-', strtolower( $classname ) );
69
+        $file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php';
70
+        if ( $file_path && is_readable( $file_path ) ) {
71
+            include_once( $file_path );
72
+        }
73
+    }
74
+
75
+    /**
76
+     * Get the AUI options.
77
+     *
78
+     * @param $option
79
+     *
80
+     * @return string|void
81
+     */
82
+    public function get_option( $option ){
83
+        $result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : '';
84
+
85
+        if ( ! $result && $option) {
86
+            if( $option == 'color_primary' ){
87
+                $result = AUI_PRIMARY_COLOR;
88
+            }elseif( $option == 'color_secondary' ){
89
+                $result = AUI_SECONDARY_COLOR;
90
+            }
91
+        }
92
+        return $result;
93
+    }
94
+
95
+    public function render( $items = array() ) {
96
+        $output = '';
97
+
98
+        if ( ! empty( $items ) ) {
99
+            foreach ( $items as $args ) {
100
+                $render = isset( $args['render'] ) ? $args['render'] : '';
101
+                if ( $render && method_exists( __CLASS__, $render ) ) {
102
+                    $output .= $this->$render( $args );
103
+                }
104
+            }
105
+        }
106
+
107
+        return $output;
108
+    }
109
+
110
+    /**
111
+     * Render and return a bootstrap alert component.
112
+     *
113
+     * @since 1.0.0
114
+     *
115
+     * @param array $args
116
+     *
117
+     * @return string The rendered component.
118
+     */
119
+    public function alert( $args = array() ) {
120
+        return AUI_Component_Alert::get( $args );
121
+    }
122
+
123
+    /**
124
+     * Render and return a bootstrap input component.
125
+     *
126
+     * @since 1.0.0
127
+     *
128
+     * @param array $args
129
+     *
130
+     * @return string The rendered component.
131
+     */
132
+    public function input( $args = array() ) {
133
+        return AUI_Component_Input::input( $args );
134
+    }
135
+
136
+    /**
137
+     * Render and return a bootstrap textarea component.
138
+     *
139
+     * @since 1.0.0
140
+     *
141
+     * @param array $args
142
+     *
143
+     * @return string The rendered component.
144
+     */
145
+    public function textarea( $args = array() ) {
146
+        return AUI_Component_Input::textarea( $args );
147
+    }
148
+
149
+    /**
150
+     * Render and return a bootstrap button component.
151
+     *
152
+     * @since 1.0.0
153
+     *
154
+     * @param array $args
155
+     *
156
+     * @return string The rendered component.
157
+     */
158
+    public function button( $args = array() ) {
159
+        return AUI_Component_Button::get( $args );
160
+    }
161
+
162
+    /**
163
+     * Render and return a bootstrap button component.
164
+     *
165
+     * @since 1.0.0
166
+     *
167
+     * @param array $args
168
+     *
169
+     * @return string The rendered component.
170
+     */
171
+    public function badge( $args = array() ) {
172
+        $defaults = array(
173
+            'class' => 'badge badge-primary align-middle',
174
+        );
175
+
176
+        // maybe set type
177
+        if ( empty( $args['href'] ) ) {
178
+            $defaults['type'] = 'badge';
179
+        }
180
+
181
+        /**
182
+         * Parse incoming $args into an array and merge it with $defaults
183
+         */
184
+        $args = wp_parse_args( $args, $defaults );
185
+
186
+        return AUI_Component_Button::get( $args );
187
+    }
188
+
189
+    /**
190
+     * Render and return a bootstrap dropdown component.
191
+     *
192
+     * @since 1.0.0
193
+     *
194
+     * @param array $args
195
+     *
196
+     * @return string The rendered component.
197
+     */
198
+    public function dropdown( $args = array() ) {
199
+        return AUI_Component_Dropdown::get( $args );
200
+    }
201
+
202
+    /**
203
+     * Render and return a bootstrap select component.
204
+     *
205
+     * @since 1.0.0
206
+     *
207
+     * @param array $args
208
+     *
209
+     * @return string The rendered component.
210
+     */
211
+    public function select( $args = array() ) {
212
+        return AUI_Component_Input::select( $args );
213
+    }
214
+
215
+    /**
216
+     * Render and return a bootstrap radio component.
217
+     *
218
+     * @since 1.0.0
219
+     *
220
+     * @param array $args
221
+     *
222
+     * @return string The rendered component.
223
+     */
224
+    public function radio( $args = array() ) {
225
+        return AUI_Component_Input::radio( $args );
226
+    }
227
+
228
+    /**
229
+     * Render and return a bootstrap pagination component.
230
+     *
231
+     * @since 1.0.0
232
+     *
233
+     * @param array $args
234
+     *
235
+     * @return string The rendered component.
236
+     */
237
+    public function pagination( $args = array() ) {
238
+        return AUI_Component_Pagination::get( $args );
239
+    }
240 240
 
241 241
 }
242 242
\ No newline at end of file
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-helper.php 1 patch
Indentation   +369 added lines, -369 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,372 +11,372 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI_Component_Helper {
13 13
 
14
-	/**
15
-	 * A component helper for generating a input name.
16
-	 *
17
-	 * @param $text
18
-	 * @param $multiple bool If the name is set to be multiple but no brackets found then we add some.
19
-	 *
20
-	 * @return string
21
-	 */
22
-	public static function name($text,$multiple = false){
23
-		$output = '';
24
-
25
-		if($text){
26
-			$is_multiple = strpos($text, '[') === false && $multiple  ? '[]' : '';
27
-			$output = ' name="'.esc_attr($text).$is_multiple.'" ';
28
-		}
29
-
30
-		return $output;
31
-	}
32
-
33
-	/**
34
-	 * A component helper for generating a item id.
35
-	 *
36
-	 * @param $text string The text to be used as the value.
37
-	 *
38
-	 * @return string The sanitized item.
39
-	 */
40
-	public static function id($text){
41
-		$output = '';
42
-
43
-		if($text){
44
-			$output = ' id="'.sanitize_html_class($text).'" ';
45
-		}
46
-
47
-		return $output;
48
-	}
49
-
50
-	/**
51
-	 * A component helper for generating a item title.
52
-	 *
53
-	 * @param $text string The text to be used as the value.
54
-	 *
55
-	 * @return string The sanitized item.
56
-	 */
57
-	public static function title($text){
58
-		$output = '';
59
-
60
-		if($text){
61
-			$output = ' title="'.esc_attr($text).'" ';
62
-		}
63
-
64
-		return $output;
65
-	}
66
-
67
-	/**
68
-	 * A component helper for generating a item value.
69
-	 *
70
-	 * @param $text string The text to be used as the value.
71
-	 *
72
-	 * @return string The sanitized item.
73
-	 */
74
-	public static function value($text){
75
-		$output = '';
76
-
77
-		if($text){
78
-			$output = ' value="'.sanitize_text_field($text).'" ';
79
-		}
80
-
81
-		return $output;
82
-	}
83
-
84
-	/**
85
-	 * A component helper for generating a item class attribute.
86
-	 *
87
-	 * @param $text string The text to be used as the value.
88
-	 *
89
-	 * @return string The sanitized item.
90
-	 */
91
-	public static function class_attr($text){
92
-		$output = '';
93
-
94
-		if($text){
95
-			$classes = self::esc_classes($text);
96
-			if(!empty($classes)){
97
-				$output = ' class="'.$classes.'" ';
98
-			}
99
-		}
100
-
101
-		return $output;
102
-	}
103
-
104
-	/**
105
-	 * Escape a string of classes.
106
-	 *
107
-	 * @param $text
108
-	 *
109
-	 * @return string
110
-	 */
111
-	public static function esc_classes($text){
112
-		$output = '';
113
-
114
-		if($text){
115
-			$classes = explode(" ",$text);
116
-			$classes = array_map("trim",$classes);
117
-			$classes = array_map("sanitize_html_class",$classes);
118
-			if(!empty($classes)){
119
-				$output = implode(" ",$classes);
120
-			}
121
-		}
122
-
123
-		return $output;
124
-
125
-	}
126
-
127
-	/**
128
-	 * @param $args
129
-	 *
130
-	 * @return string
131
-	 */
132
-	public static function data_attributes($args){
133
-		$output = '';
134
-
135
-		if(!empty($args)){
136
-
137
-			foreach($args as $key => $val){
138
-				if(substr( $key, 0, 5 ) === "data-"){
139
-					$output .= ' '.sanitize_html_class($key).'="'.esc_attr($val).'" ';
140
-				}
141
-			}
142
-		}
143
-
144
-		return $output;
145
-	}
146
-
147
-	/**
148
-	 * @param $args
149
-	 *
150
-	 * @return string
151
-	 */
152
-	public static function aria_attributes($args){
153
-		$output = '';
154
-
155
-		if(!empty($args)){
156
-
157
-			foreach($args as $key => $val){
158
-				if(substr( $key, 0, 5 ) === "aria-"){
159
-					$output .= ' '.sanitize_html_class($key).'="'.esc_attr($val).'" ';
160
-				}
161
-			}
162
-		}
163
-
164
-		return $output;
165
-	}
166
-
167
-	/**
168
-	 * Build a font awesome icon from a class.
169
-	 *
170
-	 * @param $class
171
-	 * @param bool $space_after
172
-	 * @param array $extra_attributes An array of extra attributes.
173
-	 *
174
-	 * @return string
175
-	 */
176
-	public static function icon($class,$space_after = false, $extra_attributes = array()){
177
-		$output = '';
178
-
179
-		if($class){
180
-			$classes = self::esc_classes($class);
181
-			if(!empty($classes)){
182
-				$output = '<i class="'.$classes.'" ';
183
-				// extra attributes
184
-				if(!empty($extra_attributes)){
185
-					$output .= AUI_Component_Helper::extra_attributes($extra_attributes);
186
-				}
187
-				$output .= '></i>';
188
-				if($space_after){
189
-					$output .= " ";
190
-				}
191
-			}
192
-		}
193
-
194
-		return $output;
195
-	}
196
-
197
-	/**
198
-	 * @param $args
199
-	 *
200
-	 * @return string
201
-	 */
202
-	public static function extra_attributes($args){
203
-		$output = '';
204
-
205
-		if(!empty($args)){
206
-
207
-			if( is_array($args) ){
208
-				foreach($args as $key => $val){
209
-					$output .= ' '.sanitize_html_class($key).'="'.esc_attr($val).'" ';
210
-				}
211
-			}else{
212
-				$output .= ' '.$args.' ';
213
-			}
214
-
215
-		}
216
-
217
-		return $output;
218
-	}
219
-
220
-	/**
221
-	 * @param $args
222
-	 *
223
-	 * @return string
224
-	 */
225
-	public static function help_text($text){
226
-		$output = '';
227
-
228
-		if($text){
229
-			$output .= '<small class="form-text text-muted">'.wp_kses_post($text).'</small>';
230
-		}
231
-
232
-
233
-		return $output;
234
-	}
235
-
236
-	/**
237
-	 * Replace element require context with JS.
238
-	 *
239
-	 * @param $input
240
-	 *
241
-	 * @return string|void
242
-	 */
243
-	public static function element_require( $input ) {
244
-
245
-		$input = str_replace( "'", '"', $input );// we only want double quotes
246
-
247
-		$output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
248
-			"jQuery(form).find('[data-argument=\"",
249
-			"\"]').find('input,select,textarea').val()",
250
-			"\"]').find('input:checked').val()",
251
-		), $input ) );
252
-
253
-		if($output){
254
-			$output = ' data-element-require="'.$output.'" ';
255
-		}
256
-
257
-		return $output;
258
-	}
259
-
260
-	/**
261
-	 * Returns an array of allowed HTML tags and attributes for a given context.
262
-	 *
263
-	 * @since 0.1.41
264
-	 *
265
-	 * @param string|array $context The context for which to retrieve tags. Allowed values are 'post',
266
-	 *                              'strip', 'data', 'entities', or the name of a field filter such as
267
-	 *                              'pre_user_description'.
268
-	 * @param array $input Input.
269
-	 * @return array Array of allowed HTML tags and their allowed attributes.
270
-	 */
271
-	public static function kses_allowed_html( $context = 'post', $input = array() ) {
272
-		$allowed_html = wp_kses_allowed_html( $context );
273
-
274
-		if ( is_array( $allowed_html ) ) {
275
-			// <iframe>
276
-			if ( ! isset( $allowed_html['iframe'] ) && $context == 'post' ) {
277
-				$allowed_html['iframe']     = array(
278
-					'class'        => true,
279
-					'id'           => true,
280
-					'src'          => true,
281
-					'width'        => true,
282
-					'height'       => true,
283
-					'frameborder'  => true,
284
-					'marginwidth'  => true,
285
-					'marginheight' => true,
286
-					'scrolling'    => true,
287
-					'style'        => true,
288
-					'title'        => true,
289
-					'allow'        => true,
290
-					'allowfullscreen' => true,
291
-					'data-*'       => true,
292
-				);
293
-			}
294
-		}
295
-
296
-		/**
297
-		 * Filters the allowed html tags.
298
-		 *
299
-		 * @since 0.1.41
300
-		 *
301
-		 * @param array[]|string $allowed_html Allowed html tags.
302
-		 * @param @param string|array $context The context for which to retrieve tags.
303
-		 * @param array $input Input field.
304
-		 */
305
-		return apply_filters( 'ayecode_ui_kses_allowed_html', $allowed_html, $context, $input );
306
-	}
307
-
308
-	/**
309
-	 * Filters content and keeps only allowable HTML elements.
310
-	 *
311
-	 * This function makes sure that only the allowed HTML element names, attribute
312
-	 * names and attribute values plus only sane HTML entities will occur in
313
-	 * $string. You have to remove any slashes from PHP's magic quotes before you
314
-	 * call this function.
315
-	 *
316
-	 * The default allowed protocols are 'http', 'https', 'ftp', 'mailto', 'news',
317
-	 * 'irc', 'gopher', 'nntp', 'feed', 'telnet, 'mms', 'rtsp' and 'svn'. This
318
-	 * covers all common link protocols, except for 'javascript' which should not
319
-	 * be allowed for untrusted users.
320
-	 *
321
-	 * @since 0.1.41
322
-	 *
323
-	 * @param string|array $value Content to filter through kses.
324
-	 * @param array  $input       Input Field.
325
-	 * @return string Filtered content with only allowed HTML elements.
326
-	 */
327
-	public static function _sanitize_html_field( $value, $input = array() ) {
328
-		if ( $value === '' ) {
329
-			return $value;
330
-		}
331
-
332
-		$allowed_html = self::kses_allowed_html( 'post', $input );
333
-
334
-		if ( ! is_array( $allowed_html ) ) {
335
-			$allowed_html = wp_kses_allowed_html( 'post' );
336
-		}
337
-
338
-		$filtered = trim( wp_unslash( $value ) );
339
-		$filtered = wp_kses( $filtered, $allowed_html );
340
-		$filtered = balanceTags( $filtered ); // Balances tags
341
-
342
-		return $filtered;
343
-	}
344
-
345
-	/**
346
-	 * Navigates through an array, object, or scalar, and removes slashes from the values.
347
-	 *
348
-	 * @since 0.1.41
349
-	 *
350
-	 * @param mixed $value The value to be stripped.
351
-	 * @param array  $input Input Field.
352
-	 * @return mixed Stripped value.
353
-	 */
354
-	public static function sanitize_html_field( $value, $input = array() ) {
355
-		$original = $value;
356
-
357
-		if ( is_array( $value ) ) {
358
-			foreach ( $value as $index => $item ) {
359
-				$value[ $index ] = self::_sanitize_html_field( $value, $input );
360
-			}
361
-		} elseif ( is_object( $value ) ) {
362
-			$object_vars = get_object_vars( $value );
363
-
364
-			foreach ( $object_vars as $property_name => $property_value ) {
365
-				$value->$property_name = self::_sanitize_html_field( $property_value, $input );
366
-			}
367
-		} else {
368
-			$value = self::_sanitize_html_field( $value, $input );
369
-		}
370
-
371
-		/**
372
-		 * Filters content and keeps only allowable HTML elements.
373
-		 *
374
-		 * @since 0.1.41
375
-		 *
376
-		 * @param string|array $value Content to filter through kses.
377
-		 * @param string|array $value Original content without filter.
378
-		 * @param array  $input       Input Field.
379
-		 */
380
-		return apply_filters( 'ayecode_ui_sanitize_html_field', $value, $original, $input );
381
-	}
14
+    /**
15
+     * A component helper for generating a input name.
16
+     *
17
+     * @param $text
18
+     * @param $multiple bool If the name is set to be multiple but no brackets found then we add some.
19
+     *
20
+     * @return string
21
+     */
22
+    public static function name($text,$multiple = false){
23
+        $output = '';
24
+
25
+        if($text){
26
+            $is_multiple = strpos($text, '[') === false && $multiple  ? '[]' : '';
27
+            $output = ' name="'.esc_attr($text).$is_multiple.'" ';
28
+        }
29
+
30
+        return $output;
31
+    }
32
+
33
+    /**
34
+     * A component helper for generating a item id.
35
+     *
36
+     * @param $text string The text to be used as the value.
37
+     *
38
+     * @return string The sanitized item.
39
+     */
40
+    public static function id($text){
41
+        $output = '';
42
+
43
+        if($text){
44
+            $output = ' id="'.sanitize_html_class($text).'" ';
45
+        }
46
+
47
+        return $output;
48
+    }
49
+
50
+    /**
51
+     * A component helper for generating a item title.
52
+     *
53
+     * @param $text string The text to be used as the value.
54
+     *
55
+     * @return string The sanitized item.
56
+     */
57
+    public static function title($text){
58
+        $output = '';
59
+
60
+        if($text){
61
+            $output = ' title="'.esc_attr($text).'" ';
62
+        }
63
+
64
+        return $output;
65
+    }
66
+
67
+    /**
68
+     * A component helper for generating a item value.
69
+     *
70
+     * @param $text string The text to be used as the value.
71
+     *
72
+     * @return string The sanitized item.
73
+     */
74
+    public static function value($text){
75
+        $output = '';
76
+
77
+        if($text){
78
+            $output = ' value="'.sanitize_text_field($text).'" ';
79
+        }
80
+
81
+        return $output;
82
+    }
83
+
84
+    /**
85
+     * A component helper for generating a item class attribute.
86
+     *
87
+     * @param $text string The text to be used as the value.
88
+     *
89
+     * @return string The sanitized item.
90
+     */
91
+    public static function class_attr($text){
92
+        $output = '';
93
+
94
+        if($text){
95
+            $classes = self::esc_classes($text);
96
+            if(!empty($classes)){
97
+                $output = ' class="'.$classes.'" ';
98
+            }
99
+        }
100
+
101
+        return $output;
102
+    }
103
+
104
+    /**
105
+     * Escape a string of classes.
106
+     *
107
+     * @param $text
108
+     *
109
+     * @return string
110
+     */
111
+    public static function esc_classes($text){
112
+        $output = '';
113
+
114
+        if($text){
115
+            $classes = explode(" ",$text);
116
+            $classes = array_map("trim",$classes);
117
+            $classes = array_map("sanitize_html_class",$classes);
118
+            if(!empty($classes)){
119
+                $output = implode(" ",$classes);
120
+            }
121
+        }
122
+
123
+        return $output;
124
+
125
+    }
126
+
127
+    /**
128
+     * @param $args
129
+     *
130
+     * @return string
131
+     */
132
+    public static function data_attributes($args){
133
+        $output = '';
134
+
135
+        if(!empty($args)){
136
+
137
+            foreach($args as $key => $val){
138
+                if(substr( $key, 0, 5 ) === "data-"){
139
+                    $output .= ' '.sanitize_html_class($key).'="'.esc_attr($val).'" ';
140
+                }
141
+            }
142
+        }
143
+
144
+        return $output;
145
+    }
146
+
147
+    /**
148
+     * @param $args
149
+     *
150
+     * @return string
151
+     */
152
+    public static function aria_attributes($args){
153
+        $output = '';
154
+
155
+        if(!empty($args)){
156
+
157
+            foreach($args as $key => $val){
158
+                if(substr( $key, 0, 5 ) === "aria-"){
159
+                    $output .= ' '.sanitize_html_class($key).'="'.esc_attr($val).'" ';
160
+                }
161
+            }
162
+        }
163
+
164
+        return $output;
165
+    }
166
+
167
+    /**
168
+     * Build a font awesome icon from a class.
169
+     *
170
+     * @param $class
171
+     * @param bool $space_after
172
+     * @param array $extra_attributes An array of extra attributes.
173
+     *
174
+     * @return string
175
+     */
176
+    public static function icon($class,$space_after = false, $extra_attributes = array()){
177
+        $output = '';
178
+
179
+        if($class){
180
+            $classes = self::esc_classes($class);
181
+            if(!empty($classes)){
182
+                $output = '<i class="'.$classes.'" ';
183
+                // extra attributes
184
+                if(!empty($extra_attributes)){
185
+                    $output .= AUI_Component_Helper::extra_attributes($extra_attributes);
186
+                }
187
+                $output .= '></i>';
188
+                if($space_after){
189
+                    $output .= " ";
190
+                }
191
+            }
192
+        }
193
+
194
+        return $output;
195
+    }
196
+
197
+    /**
198
+     * @param $args
199
+     *
200
+     * @return string
201
+     */
202
+    public static function extra_attributes($args){
203
+        $output = '';
204
+
205
+        if(!empty($args)){
206
+
207
+            if( is_array($args) ){
208
+                foreach($args as $key => $val){
209
+                    $output .= ' '.sanitize_html_class($key).'="'.esc_attr($val).'" ';
210
+                }
211
+            }else{
212
+                $output .= ' '.$args.' ';
213
+            }
214
+
215
+        }
216
+
217
+        return $output;
218
+    }
219
+
220
+    /**
221
+     * @param $args
222
+     *
223
+     * @return string
224
+     */
225
+    public static function help_text($text){
226
+        $output = '';
227
+
228
+        if($text){
229
+            $output .= '<small class="form-text text-muted">'.wp_kses_post($text).'</small>';
230
+        }
231
+
232
+
233
+        return $output;
234
+    }
235
+
236
+    /**
237
+     * Replace element require context with JS.
238
+     *
239
+     * @param $input
240
+     *
241
+     * @return string|void
242
+     */
243
+    public static function element_require( $input ) {
244
+
245
+        $input = str_replace( "'", '"', $input );// we only want double quotes
246
+
247
+        $output = esc_attr( str_replace( array( "[%", "%]", "%:checked]" ), array(
248
+            "jQuery(form).find('[data-argument=\"",
249
+            "\"]').find('input,select,textarea').val()",
250
+            "\"]').find('input:checked').val()",
251
+        ), $input ) );
252
+
253
+        if($output){
254
+            $output = ' data-element-require="'.$output.'" ';
255
+        }
256
+
257
+        return $output;
258
+    }
259
+
260
+    /**
261
+     * Returns an array of allowed HTML tags and attributes for a given context.
262
+     *
263
+     * @since 0.1.41
264
+     *
265
+     * @param string|array $context The context for which to retrieve tags. Allowed values are 'post',
266
+     *                              'strip', 'data', 'entities', or the name of a field filter such as
267
+     *                              'pre_user_description'.
268
+     * @param array $input Input.
269
+     * @return array Array of allowed HTML tags and their allowed attributes.
270
+     */
271
+    public static function kses_allowed_html( $context = 'post', $input = array() ) {
272
+        $allowed_html = wp_kses_allowed_html( $context );
273
+
274
+        if ( is_array( $allowed_html ) ) {
275
+            // <iframe>
276
+            if ( ! isset( $allowed_html['iframe'] ) && $context == 'post' ) {
277
+                $allowed_html['iframe']     = array(
278
+                    'class'        => true,
279
+                    'id'           => true,
280
+                    'src'          => true,
281
+                    'width'        => true,
282
+                    'height'       => true,
283
+                    'frameborder'  => true,
284
+                    'marginwidth'  => true,
285
+                    'marginheight' => true,
286
+                    'scrolling'    => true,
287
+                    'style'        => true,
288
+                    'title'        => true,
289
+                    'allow'        => true,
290
+                    'allowfullscreen' => true,
291
+                    'data-*'       => true,
292
+                );
293
+            }
294
+        }
295
+
296
+        /**
297
+         * Filters the allowed html tags.
298
+         *
299
+         * @since 0.1.41
300
+         *
301
+         * @param array[]|string $allowed_html Allowed html tags.
302
+         * @param @param string|array $context The context for which to retrieve tags.
303
+         * @param array $input Input field.
304
+         */
305
+        return apply_filters( 'ayecode_ui_kses_allowed_html', $allowed_html, $context, $input );
306
+    }
307
+
308
+    /**
309
+     * Filters content and keeps only allowable HTML elements.
310
+     *
311
+     * This function makes sure that only the allowed HTML element names, attribute
312
+     * names and attribute values plus only sane HTML entities will occur in
313
+     * $string. You have to remove any slashes from PHP's magic quotes before you
314
+     * call this function.
315
+     *
316
+     * The default allowed protocols are 'http', 'https', 'ftp', 'mailto', 'news',
317
+     * 'irc', 'gopher', 'nntp', 'feed', 'telnet, 'mms', 'rtsp' and 'svn'. This
318
+     * covers all common link protocols, except for 'javascript' which should not
319
+     * be allowed for untrusted users.
320
+     *
321
+     * @since 0.1.41
322
+     *
323
+     * @param string|array $value Content to filter through kses.
324
+     * @param array  $input       Input Field.
325
+     * @return string Filtered content with only allowed HTML elements.
326
+     */
327
+    public static function _sanitize_html_field( $value, $input = array() ) {
328
+        if ( $value === '' ) {
329
+            return $value;
330
+        }
331
+
332
+        $allowed_html = self::kses_allowed_html( 'post', $input );
333
+
334
+        if ( ! is_array( $allowed_html ) ) {
335
+            $allowed_html = wp_kses_allowed_html( 'post' );
336
+        }
337
+
338
+        $filtered = trim( wp_unslash( $value ) );
339
+        $filtered = wp_kses( $filtered, $allowed_html );
340
+        $filtered = balanceTags( $filtered ); // Balances tags
341
+
342
+        return $filtered;
343
+    }
344
+
345
+    /**
346
+     * Navigates through an array, object, or scalar, and removes slashes from the values.
347
+     *
348
+     * @since 0.1.41
349
+     *
350
+     * @param mixed $value The value to be stripped.
351
+     * @param array  $input Input Field.
352
+     * @return mixed Stripped value.
353
+     */
354
+    public static function sanitize_html_field( $value, $input = array() ) {
355
+        $original = $value;
356
+
357
+        if ( is_array( $value ) ) {
358
+            foreach ( $value as $index => $item ) {
359
+                $value[ $index ] = self::_sanitize_html_field( $value, $input );
360
+            }
361
+        } elseif ( is_object( $value ) ) {
362
+            $object_vars = get_object_vars( $value );
363
+
364
+            foreach ( $object_vars as $property_name => $property_value ) {
365
+                $value->$property_name = self::_sanitize_html_field( $property_value, $input );
366
+            }
367
+        } else {
368
+            $value = self::_sanitize_html_field( $value, $input );
369
+        }
370
+
371
+        /**
372
+         * Filters content and keeps only allowable HTML elements.
373
+         *
374
+         * @since 0.1.41
375
+         *
376
+         * @param string|array $value Content to filter through kses.
377
+         * @param string|array $value Original content without filter.
378
+         * @param array  $input       Input Field.
379
+         */
380
+        return apply_filters( 'ayecode_ui_sanitize_html_field', $value, $original, $input );
381
+    }
382 382
 }
383 383
\ No newline at end of file
Please login to merge, or discard this patch.
ayecode/wp-ayecode-ui/includes/components/class-aui-component-input.php 1 patch
Indentation   +1012 added lines, -1012 removed lines patch added patch discarded remove patch
@@ -1,7 +1,7 @@  discard block
 block discarded – undo
1 1
 <?php
2 2
 
3 3
 if ( ! defined( 'ABSPATH' ) ) {
4
-	exit; // Exit if accessed directly
4
+    exit; // Exit if accessed directly
5 5
 }
6 6
 
7 7
 /**
@@ -11,1022 +11,1022 @@  discard block
 block discarded – undo
11 11
  */
12 12
 class AUI_Component_Input {
13 13
 
14
-	/**
15
-	 * Build the component.
16
-	 *
17
-	 * @param array $args
18
-	 *
19
-	 * @return string The rendered component.
20
-	 */
21
-	public static function input($args = array()){
22
-		$defaults = array(
23
-			'type'       => 'text',
24
-			'name'       => '',
25
-			'class'      => '',
26
-			'wrap_class' => '',
27
-			'id'         => '',
28
-			'placeholder'=> '',
29
-			'title'      => '',
30
-			'value'      => '',
31
-			'required'   => false,
32
-			'label'      => '',
33
-			'label_after'=> false,
34
-			'label_class'=> '',
35
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
36
-			'help_text'  => '',
37
-			'validation_text'   => '',
38
-			'validation_pattern' => '',
39
-			'no_wrap'    => false,
40
-			'input_group_right' => '',
41
-			'input_group_left' => '',
42
-			'input_group_right_inside' => false, // forces the input group inside the input
43
-			'input_group_left_inside' => false, // forces the input group inside the input
44
-			'step'       => '',
45
-			'switch'     => false, // to show checkbox as a switch
46
-			'checked'   => false, // set a checkbox or radio as selected
47
-			'password_toggle' => true, // toggle view/hide password
48
-			'element_require'   => '', // [%element_id%] == "1"
49
-			'extra_attributes'  => array() // an array of extra attributes
50
-		);
51
-
52
-		/**
53
-		 * Parse incoming $args into an array and merge it with $defaults
54
-		 */
55
-		$args   = wp_parse_args( $args, $defaults );
56
-		$output = '';
57
-		if ( ! empty( $args['type'] ) ) {
58
-			// hidden label option needs to be empty
59
-			$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
60
-
61
-			$type = sanitize_html_class( $args['type'] );
62
-
63
-			$help_text = '';
64
-			$label = '';
65
-			$label_after = $args['label_after'];
66
-			$label_args = array(
67
-				'title'=> $args['label'],
68
-				'for'=> $args['id'],
69
-				'class' => $args['label_class']." ",
70
-				'label_type' => $args['label_type']
71
-			);
72
-
73
-			// floating labels need label after
74
-			if( $args['label_type'] == 'floating' && $type != 'checkbox' ){
75
-				$label_after = true;
76
-				$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
77
-			}
78
-
79
-			// Some special sauce for files
80
-			if($type=='file' ){
81
-				$label_after = true; // if type file we need the label after
82
-				$args['class'] .= ' custom-file-input ';
83
-			}elseif($type=='checkbox'){
84
-				$label_after = true; // if type file we need the label after
85
-				$args['class'] .= ' custom-control-input ';
86
-			}elseif($type=='datepicker' || $type=='timepicker'){
87
-				$type = 'text';
88
-				//$args['class'] .= ' aui-flatpickr bg-initial ';
89
-				$args['class'] .= ' bg-initial ';
90
-
91
-				$args['extra_attributes']['data-aui-init'] = 'flatpickr';
92
-				// enqueue the script
93
-				$aui_settings = AyeCode_UI_Settings::instance();
94
-				$aui_settings->enqueue_flatpickr();
95
-			}
96
-
97
-
98
-			// open/type
99
-			$output .= '<input type="' . $type . '" ';
100
-
101
-			// name
102
-			if(!empty($args['name'])){
103
-				$output .= ' name="'.esc_attr($args['name']).'" ';
104
-			}
105
-
106
-			// id
107
-			if(!empty($args['id'])){
108
-				$output .= ' id="'.sanitize_html_class($args['id']).'" ';
109
-			}
110
-
111
-			// placeholder
112
-			if(isset($args['placeholder']) && '' != $args['placeholder'] ){
113
-				$output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
114
-			}
115
-
116
-			// title
117
-			if(!empty($args['title'])){
118
-				$output .= ' title="'.esc_attr($args['title']).'" ';
119
-			}
120
-
121
-			// value
122
-			if(!empty($args['value'])){
123
-				$output .= ' value="'.sanitize_text_field($args['value']).'" ';
124
-			}
125
-
126
-			// checked, for radio and checkboxes
127
-			if( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ){
128
-				$output .= ' checked ';
129
-			}
130
-
131
-			// validation text
132
-			if(!empty($args['validation_text'])){
133
-				$output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
134
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
135
-			}
136
-
137
-			// validation_pattern
138
-			if(!empty($args['validation_pattern'])){
139
-				$output .= ' pattern="'.$args['validation_pattern'].'" ';
140
-			}
141
-
142
-			// step (for numbers)
143
-			if(!empty($args['step'])){
144
-				$output .= ' step="'.$args['step'].'" ';
145
-			}
146
-
147
-			// required
148
-			if(!empty($args['required'])){
149
-				$output .= ' required ';
150
-			}
151
-
152
-			// class
153
-			$class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
154
-			$output .= ' class="form-control '.$class.'" ';
155
-
156
-			// data-attributes
157
-			$output .= AUI_Component_Helper::data_attributes($args);
158
-
159
-			// extra attributes
160
-			if(!empty($args['extra_attributes'])){
161
-				$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
162
-			}
163
-
164
-			// close
165
-			$output .= ' >';
166
-
167
-
168
-			// label
169
-			if(!empty($args['label'])){
170
-				if($type == 'file'){$label_args['class'] .= 'custom-file-label';}
171
-				elseif($type == 'checkbox'){$label_args['class'] .= 'custom-control-label';}
172
-				$label = self::label( $label_args, $type );
173
-			}
174
-
175
-			// help text
176
-			if(!empty($args['help_text'])){
177
-				$help_text = AUI_Component_Helper::help_text($args['help_text']);
178
-			}
179
-
180
-
181
-			// set help text in the correct possition
182
-			if($label_after){
183
-				$output .= $label . $help_text;
184
-			}
185
-
186
-			// some input types need a separate wrap
187
-			if($type == 'file') {
188
-				$output = self::wrap( array(
189
-					'content' => $output,
190
-					'class'   => 'form-group custom-file'
191
-				) );
192
-			}elseif($type == 'checkbox'){
193
-				$wrap_class = $args['switch'] ? 'custom-switch' : 'custom-checkbox';
194
-				$output = self::wrap( array(
195
-					'content' => $output,
196
-					'class'   => 'custom-control '.$wrap_class
197
-				) );
198
-
199
-				if($args['label_type']=='horizontal'){
200
-					$output = '<div class="col-sm-2 col-form-label"></div><div class="col-sm-10">' . $output . '</div>';
201
-				}
202
-			}elseif($type == 'password' && $args['password_toggle'] && !$args['input_group_right']){
203
-
204
-
205
-				// allow password field to toggle view
206
-				$args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
14
+    /**
15
+     * Build the component.
16
+     *
17
+     * @param array $args
18
+     *
19
+     * @return string The rendered component.
20
+     */
21
+    public static function input($args = array()){
22
+        $defaults = array(
23
+            'type'       => 'text',
24
+            'name'       => '',
25
+            'class'      => '',
26
+            'wrap_class' => '',
27
+            'id'         => '',
28
+            'placeholder'=> '',
29
+            'title'      => '',
30
+            'value'      => '',
31
+            'required'   => false,
32
+            'label'      => '',
33
+            'label_after'=> false,
34
+            'label_class'=> '',
35
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
36
+            'help_text'  => '',
37
+            'validation_text'   => '',
38
+            'validation_pattern' => '',
39
+            'no_wrap'    => false,
40
+            'input_group_right' => '',
41
+            'input_group_left' => '',
42
+            'input_group_right_inside' => false, // forces the input group inside the input
43
+            'input_group_left_inside' => false, // forces the input group inside the input
44
+            'step'       => '',
45
+            'switch'     => false, // to show checkbox as a switch
46
+            'checked'   => false, // set a checkbox or radio as selected
47
+            'password_toggle' => true, // toggle view/hide password
48
+            'element_require'   => '', // [%element_id%] == "1"
49
+            'extra_attributes'  => array() // an array of extra attributes
50
+        );
51
+
52
+        /**
53
+         * Parse incoming $args into an array and merge it with $defaults
54
+         */
55
+        $args   = wp_parse_args( $args, $defaults );
56
+        $output = '';
57
+        if ( ! empty( $args['type'] ) ) {
58
+            // hidden label option needs to be empty
59
+            $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
60
+
61
+            $type = sanitize_html_class( $args['type'] );
62
+
63
+            $help_text = '';
64
+            $label = '';
65
+            $label_after = $args['label_after'];
66
+            $label_args = array(
67
+                'title'=> $args['label'],
68
+                'for'=> $args['id'],
69
+                'class' => $args['label_class']." ",
70
+                'label_type' => $args['label_type']
71
+            );
72
+
73
+            // floating labels need label after
74
+            if( $args['label_type'] == 'floating' && $type != 'checkbox' ){
75
+                $label_after = true;
76
+                $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
77
+            }
78
+
79
+            // Some special sauce for files
80
+            if($type=='file' ){
81
+                $label_after = true; // if type file we need the label after
82
+                $args['class'] .= ' custom-file-input ';
83
+            }elseif($type=='checkbox'){
84
+                $label_after = true; // if type file we need the label after
85
+                $args['class'] .= ' custom-control-input ';
86
+            }elseif($type=='datepicker' || $type=='timepicker'){
87
+                $type = 'text';
88
+                //$args['class'] .= ' aui-flatpickr bg-initial ';
89
+                $args['class'] .= ' bg-initial ';
90
+
91
+                $args['extra_attributes']['data-aui-init'] = 'flatpickr';
92
+                // enqueue the script
93
+                $aui_settings = AyeCode_UI_Settings::instance();
94
+                $aui_settings->enqueue_flatpickr();
95
+            }
96
+
97
+
98
+            // open/type
99
+            $output .= '<input type="' . $type . '" ';
100
+
101
+            // name
102
+            if(!empty($args['name'])){
103
+                $output .= ' name="'.esc_attr($args['name']).'" ';
104
+            }
105
+
106
+            // id
107
+            if(!empty($args['id'])){
108
+                $output .= ' id="'.sanitize_html_class($args['id']).'" ';
109
+            }
110
+
111
+            // placeholder
112
+            if(isset($args['placeholder']) && '' != $args['placeholder'] ){
113
+                $output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
114
+            }
115
+
116
+            // title
117
+            if(!empty($args['title'])){
118
+                $output .= ' title="'.esc_attr($args['title']).'" ';
119
+            }
120
+
121
+            // value
122
+            if(!empty($args['value'])){
123
+                $output .= ' value="'.sanitize_text_field($args['value']).'" ';
124
+            }
125
+
126
+            // checked, for radio and checkboxes
127
+            if( ( $type == 'checkbox' || $type == 'radio' ) && $args['checked'] ){
128
+                $output .= ' checked ';
129
+            }
130
+
131
+            // validation text
132
+            if(!empty($args['validation_text'])){
133
+                $output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
134
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
135
+            }
136
+
137
+            // validation_pattern
138
+            if(!empty($args['validation_pattern'])){
139
+                $output .= ' pattern="'.$args['validation_pattern'].'" ';
140
+            }
141
+
142
+            // step (for numbers)
143
+            if(!empty($args['step'])){
144
+                $output .= ' step="'.$args['step'].'" ';
145
+            }
146
+
147
+            // required
148
+            if(!empty($args['required'])){
149
+                $output .= ' required ';
150
+            }
151
+
152
+            // class
153
+            $class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
154
+            $output .= ' class="form-control '.$class.'" ';
155
+
156
+            // data-attributes
157
+            $output .= AUI_Component_Helper::data_attributes($args);
158
+
159
+            // extra attributes
160
+            if(!empty($args['extra_attributes'])){
161
+                $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
162
+            }
163
+
164
+            // close
165
+            $output .= ' >';
166
+
167
+
168
+            // label
169
+            if(!empty($args['label'])){
170
+                if($type == 'file'){$label_args['class'] .= 'custom-file-label';}
171
+                elseif($type == 'checkbox'){$label_args['class'] .= 'custom-control-label';}
172
+                $label = self::label( $label_args, $type );
173
+            }
174
+
175
+            // help text
176
+            if(!empty($args['help_text'])){
177
+                $help_text = AUI_Component_Helper::help_text($args['help_text']);
178
+            }
179
+
180
+
181
+            // set help text in the correct possition
182
+            if($label_after){
183
+                $output .= $label . $help_text;
184
+            }
185
+
186
+            // some input types need a separate wrap
187
+            if($type == 'file') {
188
+                $output = self::wrap( array(
189
+                    'content' => $output,
190
+                    'class'   => 'form-group custom-file'
191
+                ) );
192
+            }elseif($type == 'checkbox'){
193
+                $wrap_class = $args['switch'] ? 'custom-switch' : 'custom-checkbox';
194
+                $output = self::wrap( array(
195
+                    'content' => $output,
196
+                    'class'   => 'custom-control '.$wrap_class
197
+                ) );
198
+
199
+                if($args['label_type']=='horizontal'){
200
+                    $output = '<div class="col-sm-2 col-form-label"></div><div class="col-sm-10">' . $output . '</div>';
201
+                }
202
+            }elseif($type == 'password' && $args['password_toggle'] && !$args['input_group_right']){
203
+
204
+
205
+                // allow password field to toggle view
206
+                $args['input_group_right'] = '<span class="input-group-text c-pointer px-3" 
207 207
 onclick="var $el = jQuery(this).find(\'i\');$el.toggleClass(\'fa-eye fa-eye-slash\');
208 208
 var $eli = jQuery(this).parent().parent().find(\'input\');
209 209
 if($el.hasClass(\'fa-eye\'))
210 210
 {$eli.attr(\'type\',\'text\');}
211 211
 else{$eli.attr(\'type\',\'password\');}"
212 212
 ><i class="far fa-fw fa-eye-slash"></i></span>';
213
-			}
214
-
215
-			// input group wraps
216
-			if($args['input_group_left'] || $args['input_group_right']){
217
-				$w100 = strpos($args['class'], 'w-100') !== false ? ' w-100' : '';
218
-				if($args['input_group_left']){
219
-					$output = self::wrap( array(
220
-						'content' => $output,
221
-						'class'   => $args['input_group_left_inside'] ? 'input-group-inside position-relative'.$w100  : 'input-group',
222
-						'input_group_left' => $args['input_group_left'],
223
-						'input_group_left_inside'    => $args['input_group_left_inside']
224
-					) );
225
-				}
226
-				if($args['input_group_right']){
227
-					$output = self::wrap( array(
228
-						'content' => $output,
229
-						'class'   => $args['input_group_right_inside'] ? 'input-group-inside position-relative'.$w100 : 'input-group',
230
-						'input_group_right' => $args['input_group_right'],
231
-						'input_group_right_inside'    => $args['input_group_right_inside']
232
-					) );
233
-				}
234
-
235
-			}
236
-
237
-			if(!$label_after){
238
-				$output .= $help_text;
239
-			}
240
-
241
-
242
-			if($args['label_type']=='horizontal' && $type != 'checkbox'){
243
-				$output = self::wrap( array(
244
-					'content' => $output,
245
-					'class'   => 'col-sm-10',
246
-				) );
247
-			}
248
-
249
-			if(!$label_after){
250
-				$output = $label . $output;
251
-			}
252
-
253
-			// wrap
254
-			if(!$args['no_wrap']){
255
-
256
-				$form_group_class = $args['label_type']=='floating' && $type != 'checkbox' ? 'form-label-group' : 'form-group';
257
-				$wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
258
-				$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
259
-				$output = self::wrap(array(
260
-					'content' => $output,
261
-					'class'   => $wrap_class,
262
-					'element_require'   => $args['element_require'],
263
-					'argument_id'  => $args['id']
264
-				));
265
-			}
266
-
267
-
268
-
269
-		}
270
-
271
-		return $output;
272
-	}
273
-
274
-	/**
275
-	 * Build the component.
276
-	 *
277
-	 * @param array $args
278
-	 *
279
-	 * @return string The rendered component.
280
-	 */
281
-	public static function textarea($args = array()){
282
-		$defaults = array(
283
-			'name'       => '',
284
-			'class'      => '',
285
-			'wrap_class' => '',
286
-			'id'         => '',
287
-			'placeholder'=> '',
288
-			'title'      => '',
289
-			'value'      => '',
290
-			'required'   => false,
291
-			'label'      => '',
292
-			'label_after'=> false,
293
-			'label_class'      => '',
294
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
295
-			'help_text'  => '',
296
-			'validation_text'   => '',
297
-			'validation_pattern' => '',
298
-			'no_wrap'    => false,
299
-			'rows'      => '',
300
-			'wysiwyg'   => false,
301
-			'allow_tags' => false, // Allow HTML tags
302
-			'element_require'   => '', // [%element_id%] == "1"
303
-			'extra_attributes'  => array(), // an array of extra attributes
304
-		);
305
-
306
-		/**
307
-		 * Parse incoming $args into an array and merge it with $defaults
308
-		 */
309
-		$args   = wp_parse_args( $args, $defaults );
310
-		$output = '';
311
-
312
-		// hidden label option needs to be empty
313
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
314
-
315
-		// floating labels don't work with wysiwyg so set it as top
316
-		if($args['label_type'] == 'floating' && !empty($args['wysiwyg'])){
317
-			$args['label_type'] = 'top';
318
-		}
319
-
320
-		$label_after = $args['label_after'];
321
-
322
-		// floating labels need label after
323
-		if( $args['label_type'] == 'floating' && empty($args['wysiwyg']) ){
324
-			$label_after = true;
325
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
326
-		}
327
-
328
-		// label
329
-		if(!empty($args['label']) && is_array($args['label'])){
330
-		}elseif(!empty($args['label']) && !$label_after){
331
-			$label_args = array(
332
-				'title'=> $args['label'],
333
-				'for'=> $args['id'],
334
-				'class' => $args['label_class']." ",
335
-				'label_type' => $args['label_type']
336
-			);
337
-			$output .= self::label( $label_args );
338
-		}
339
-
340
-		// maybe horizontal label
341
-		if($args['label_type']=='horizontal'){
342
-			$output .= '<div class="col-sm-10">';
343
-		}
344
-
345
-		if(!empty($args['wysiwyg'])){
346
-			ob_start();
347
-			$content = $args['value'];
348
-			$editor_id = !empty($args['id']) ? sanitize_html_class($args['id']) : 'wp_editor';
349
-			$settings = array(
350
-				'textarea_rows' => !empty(absint($args['rows'])) ? absint($args['rows']) : 4,
351
-				'quicktags'     => false,
352
-				'media_buttons' => false,
353
-				'editor_class'  => 'form-control',
354
-				'textarea_name' => !empty($args['name']) ? sanitize_html_class($args['name']) : sanitize_html_class($args['id']),
355
-				'teeny'         => true,
356
-			);
357
-
358
-			// maybe set settings if array
359
-			if(is_array($args['wysiwyg'])){
360
-				$settings  = wp_parse_args( $args['wysiwyg'], $settings );
361
-			}
362
-
363
-			wp_editor( $content, $editor_id, $settings );
364
-			$output .= ob_get_clean();
365
-		}else{
366
-
367
-			// open
368
-			$output .= '<textarea ';
369
-
370
-			// name
371
-			if(!empty($args['name'])){
372
-				$output .= ' name="'.sanitize_html_class($args['name']).'" ';
373
-			}
374
-
375
-			// id
376
-			if(!empty($args['id'])){
377
-				$output .= ' id="'.sanitize_html_class($args['id']).'" ';
378
-			}
379
-
380
-			// placeholder
381
-			if(isset($args['placeholder']) && '' != $args['placeholder']){
382
-				$output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
383
-			}
384
-
385
-			// title
386
-			if(!empty($args['title'])){
387
-				$output .= ' title="'.esc_attr($args['title']).'" ';
388
-			}
389
-
390
-			// validation text
391
-			if(!empty($args['validation_text'])){
392
-				$output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
393
-				$output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
394
-			}
395
-
396
-			// validation_pattern
397
-			if(!empty($args['validation_pattern'])){
398
-				$output .= ' pattern="'.$args['validation_pattern'].'" ';
399
-			}
400
-
401
-			// required
402
-			if(!empty($args['required'])){
403
-				$output .= ' required ';
404
-			}
405
-
406
-			// rows
407
-			if(!empty($args['rows'])){
408
-				$output .= ' rows="'.absint($args['rows']).'" ';
409
-			}
410
-
411
-
412
-			// class
413
-			$class = !empty($args['class']) ? $args['class'] : '';
414
-			$output .= ' class="form-control '.$class.'" ';
415
-
416
-			// extra attributes
417
-			if(!empty($args['extra_attributes'])){
418
-				$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
419
-			}
420
-
421
-			// close tag
422
-			$output .= ' >';
423
-
424
-			// value
425
-			if ( ! empty( $args['value'] ) ) {
426
-				if ( ! empty( $args['allow_tags'] ) ) {
427
-					$output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
428
-				} else {
429
-					$output .= sanitize_textarea_field( $args['value'] );
430
-				}
431
-			}
432
-
433
-			// closing tag
434
-			$output .= '</textarea>';
435
-
436
-		}
437
-
438
-		if(!empty($args['label']) && $label_after){
439
-			$label_args = array(
440
-				'title'=> $args['label'],
441
-				'for'=> $args['id'],
442
-				'class' => $args['label_class']." ",
443
-				'label_type' => $args['label_type']
444
-			);
445
-			$output .= self::label( $label_args );
446
-		}
447
-
448
-		// help text
449
-		if(!empty($args['help_text'])){
450
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
451
-		}
452
-
453
-		// maybe horizontal label
454
-		if($args['label_type']=='horizontal'){
455
-			$output .= '</div>';
456
-		}
457
-
458
-
459
-		// wrap
460
-		if(!$args['no_wrap']){
461
-			$form_group_class = $args['label_type']=='floating' ? 'form-label-group' : 'form-group';
462
-			$wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
463
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
464
-			$output = self::wrap(array(
465
-				'content' => $output,
466
-				'class'   => $wrap_class,
467
-				'element_require'   => $args['element_require'],
468
-				'argument_id'  => $args['id']
469
-			));
470
-		}
471
-
472
-
473
-		return $output;
474
-	}
475
-
476
-	public static function label($args = array(), $type = ''){
477
-		//<label for="exampleInputEmail1">Email address</label>
478
-		$defaults = array(
479
-			'title'       => 'div',
480
-			'for'      => '',
481
-			'class'      => '',
482
-			'label_type'    => '', // empty = hidden, top, horizontal
483
-		);
484
-
485
-		/**
486
-		 * Parse incoming $args into an array and merge it with $defaults
487
-		 */
488
-		$args   = wp_parse_args( $args, $defaults );
489
-		$output = '';
490
-
491
-		if($args['title']){
492
-
493
-			// maybe hide labels //@todo set a global option for visibility class
494
-			if($type == 'file' || $type == 'checkbox' || $type == 'radio' || !empty($args['label_type']) ){
495
-				$class = $args['class'];
496
-			}else{
497
-				$class = 'sr-only '.$args['class'];
498
-			}
499
-
500
-			// maybe horizontal
501
-			if($args['label_type']=='horizontal' && $type != 'checkbox'){
502
-				$class .= ' col-sm-2 col-form-label';
503
-			}
504
-
505
-			// open
506
-			$output .= '<label ';
507
-
508
-			// for
509
-			if(!empty($args['for'])){
510
-				$output .= ' for="'.sanitize_text_field($args['for']).'" ';
511
-			}
512
-
513
-			// class
514
-			$class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
515
-			$output .= ' class="'.$class.'" ';
516
-
517
-			// close
518
-			$output .= '>';
519
-
520
-
521
-			// title, don't escape fully as can contain html
522
-			if(!empty($args['title'])){
523
-				$output .= wp_kses_post($args['title']);
524
-			}
525
-
526
-			// close wrap
527
-			$output .= '</label>';
528
-
529
-
530
-		}
531
-
532
-
533
-		return $output;
534
-	}
535
-
536
-	/**
537
-	 * Wrap some content in a HTML wrapper.
538
-	 *
539
-	 * @param array $args
540
-	 *
541
-	 * @return string
542
-	 */
543
-	public static function wrap($args = array()){
544
-		$defaults = array(
545
-			'type'       => 'div',
546
-			'class'      => 'form-group',
547
-			'content'   => '',
548
-			'input_group_left' => '',
549
-			'input_group_right' => '',
550
-			'input_group_left_inside' => false,
551
-			'input_group_right_inside' => false,
552
-			'element_require'   => '',
553
-			'argument_id'   => '',
554
-		);
555
-
556
-		/**
557
-		 * Parse incoming $args into an array and merge it with $defaults
558
-		 */
559
-		$args   = wp_parse_args( $args, $defaults );
560
-		$output = '';
561
-		if($args['type']){
562
-
563
-			// open
564
-			$output .= '<'.sanitize_html_class($args['type']);
565
-
566
-			// element require
567
-			if(!empty($args['element_require'])){
568
-				$output .= AUI_Component_Helper::element_require($args['element_require']);
569
-				$args['class'] .= " aui-conditional-field";
570
-			}
571
-
572
-			// argument_id
573
-			if( !empty($args['argument_id']) ){
574
-				$output .= ' data-argument="'.esc_attr($args['argument_id']).'"';
575
-			}
576
-
577
-			// class
578
-			$class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
579
-			$output .= ' class="'.$class.'" ';
580
-
581
-			// close wrap
582
-			$output .= ' >';
583
-
584
-
585
-			// Input group left
586
-			if(!empty($args['input_group_left'])){
587
-				$position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
588
-				$input_group_left = strpos($args['input_group_left'], '<') !== false ? $args['input_group_left'] : '<span class="input-group-text">'.$args['input_group_left'].'</span>';
589
-				$output .= '<div class="input-group-prepend '.$position_class.'">'.$input_group_left.'</div>';
590
-			}
591
-
592
-			// content
593
-			$output .= $args['content'];
594
-
595
-			// Input group right
596
-			if(!empty($args['input_group_right'])){
597
-				$position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
598
-				$input_group_right = strpos($args['input_group_right'], '<') !== false ? $args['input_group_right'] : '<span class="input-group-text">'.$args['input_group_right'].'</span>';
599
-				$output .= '<div class="input-group-append '.$position_class.'">'.$input_group_right.'</div>';
600
-			}
601
-
602
-
603
-			// close wrap
604
-			$output .= '</'.sanitize_html_class($args['type']).'>';
605
-
606
-
607
-		}else{
608
-			$output = $args['content'];
609
-		}
610
-
611
-		return $output;
612
-	}
613
-
614
-	/**
615
-	 * Build the component.
616
-	 *
617
-	 * @param array $args
618
-	 *
619
-	 * @return string The rendered component.
620
-	 */
621
-	public static function select($args = array()){
622
-		$defaults = array(
623
-			'class'      => '',
624
-			'wrap_class' => '',
625
-			'id'         => '',
626
-			'title'      => '',
627
-			'value'      => '', // can be an array or a string
628
-			'required'   => false,
629
-			'label'      => '',
630
-			'label_after'=> false,
631
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
632
-			'label_class'      => '',
633
-			'help_text'  => '',
634
-			'placeholder'=> '',
635
-			'options'    => array(), // array or string
636
-			'icon'       => '',
637
-			'multiple'   => false,
638
-			'select2'    => false,
639
-			'no_wrap'    => false,
640
-			'element_require'   => '', // [%element_id%] == "1"
641
-			'extra_attributes'  => array(), // an array of extra attributes
642
-		);
643
-
644
-		/**
645
-		 * Parse incoming $args into an array and merge it with $defaults
646
-		 */
647
-		$args   = wp_parse_args( $args, $defaults );
648
-		$output = '';
649
-
650
-		// for now lets hide floating labels
651
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'hidden';}
652
-
653
-		// hidden label option needs to be empty
654
-		$args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
655
-
656
-
657
-		$label_after = $args['label_after'];
658
-
659
-		// floating labels need label after
660
-		if( $args['label_type'] == 'floating' ){
661
-			$label_after = true;
662
-			$args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
663
-		}
664
-
665
-		// Maybe setup select2
666
-		$is_select2 = false;
667
-		if(!empty($args['select2'])){
668
-			$args['class'] .= ' aui-select2';
669
-			$is_select2 = true;
670
-		}elseif( strpos($args['class'], 'aui-select2') !== false){
671
-			$is_select2 = true;
672
-		}
673
-
674
-		// select2 tags
675
-		if( !empty($args['select2']) && $args['select2'] === 'tags'){ // triple equals needed here for some reason
676
-			$args['data-tags'] = 'true';
677
-			$args['data-token-separators'] = "[',']";
678
-			$args['multiple'] = true;
679
-		}
680
-
681
-		// select2 placeholder
682
-		if($is_select2 && isset($args['placeholder']) && '' != $args['placeholder'] && empty($args['data-placeholder'])){
683
-			$args['data-placeholder'] = esc_attr($args['placeholder']);
684
-			$args['data-allow-clear'] = isset($args['data-allow-clear']) ? (bool) $args['data-allow-clear'] : true;
685
-		}
686
-
687
-		// label
688
-		if(!empty($args['label']) && is_array($args['label'])){
689
-		}elseif(!empty($args['label']) && !$label_after){
690
-			$label_args = array(
691
-				'title'=> $args['label'],
692
-				'for'=> $args['id'],
693
-				'class' => $args['label_class']." ",
694
-				'label_type' => $args['label_type']
695
-			);
696
-			$output .= self::label($label_args);
697
-		}
698
-
699
-		// maybe horizontal label
700
-		if($args['label_type']=='horizontal'){
701
-			$output .= '<div class="col-sm-10">';
702
-		}
703
-
704
-		// open/type
705
-		$output .= '<select ';
706
-
707
-		// style
708
-		if($is_select2){
709
-			$output .= " style='width:100%;' ";
710
-		}
711
-
712
-		// element require
713
-		if(!empty($args['element_require'])){
714
-			$output .= AUI_Component_Helper::element_require($args['element_require']);
715
-			$args['class'] .= " aui-conditional-field";
716
-		}
717
-
718
-		// class
719
-		$class = !empty($args['class']) ? $args['class'] : '';
720
-		$output .= AUI_Component_Helper::class_attr('custom-select '.$class);
721
-
722
-		// name
723
-		if(!empty($args['name'])){
724
-			$output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
725
-		}
726
-
727
-		// id
728
-		if(!empty($args['id'])){
729
-			$output .= AUI_Component_Helper::id($args['id']);
730
-		}
731
-
732
-		// title
733
-		if(!empty($args['title'])){
734
-			$output .= AUI_Component_Helper::title($args['title']);
735
-		}
736
-
737
-		// data-attributes
738
-		$output .= AUI_Component_Helper::data_attributes($args);
739
-
740
-		// aria-attributes
741
-		$output .= AUI_Component_Helper::aria_attributes($args);
742
-
743
-		// extra attributes
744
-		if(!empty($args['extra_attributes'])){
745
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
746
-		}
747
-
748
-		// required
749
-		if(!empty($args['required'])){
750
-			$output .= ' required ';
751
-		}
752
-
753
-		// multiple
754
-		if(!empty($args['multiple'])){
755
-			$output .= ' multiple ';
756
-		}
757
-
758
-		// close opening tag
759
-		$output .= ' >';
760
-
761
-		// placeholder
762
-		if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
763
-			$output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
764
-		}elseif($is_select2 && !empty($args['placeholder'])){
765
-			$output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
766
-		}
767
-
768
-		// Options
769
-		if(!empty($args['options'])){
770
-
771
-			if(!is_array($args['options'])){
772
-				$output .= $args['options']; // not the preferred way but an option
773
-			}else{
774
-				foreach($args['options'] as $val => $name){
775
-					$selected = '';
776
-					if(is_array($name)){
777
-						if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
778
-							$option_label = isset($name['label']) ? $name['label'] : '';
779
-
780
-							$output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
781
-						} else {
782
-							$option_label = isset($name['label']) ? $name['label'] : '';
783
-							$option_value = isset($name['value']) ? $name['value'] : '';
784
-							if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
785
-								$selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
786
-							} elseif(!empty($args['value'])) {
787
-								$selected = selected($option_value,stripslashes_deep($args['value']), false);
788
-							}
789
-
790
-							$output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
791
-						}
792
-					}else{
793
-						if(!empty($args['value'])){
794
-							if(is_array($args['value'])){
795
-								$selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
796
-							} elseif(!empty($args['value'])) {
797
-								$selected = selected( $args['value'], $val, false);
798
-							}
799
-						}
800
-						$output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
801
-					}
802
-				}
803
-			}
804
-
805
-		}
806
-
807
-		// closing tag
808
-		$output .= '</select>';
809
-
810
-		if(!empty($args['label']) && $label_after){
811
-			$label_args = array(
812
-				'title'=> $args['label'],
813
-				'for'=> $args['id'],
814
-				'class' => $args['label_class']." ",
815
-				'label_type' => $args['label_type']
816
-			);
817
-			$output .= self::label($label_args);
818
-		}
819
-
820
-		// help text
821
-		if(!empty($args['help_text'])){
822
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
823
-		}
824
-
825
-		// maybe horizontal label
826
-		if($args['label_type']=='horizontal'){
827
-			$output .= '</div>';
828
-		}
829
-
830
-
831
-		// wrap
832
-		if(!$args['no_wrap']){
833
-			$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
834
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
835
-			$output = self::wrap(array(
836
-				'content' => $output,
837
-				'class'   => $wrap_class,
838
-				'element_require'   => $args['element_require'],
839
-				'argument_id'  => $args['id']
840
-			));
841
-		}
842
-
843
-
844
-		return $output;
845
-	}
846
-
847
-	/**
848
-	 * Build the component.
849
-	 *
850
-	 * @param array $args
851
-	 *
852
-	 * @return string The rendered component.
853
-	 */
854
-	public static function radio($args = array()){
855
-		$defaults = array(
856
-			'class'      => '',
857
-			'wrap_class' => '',
858
-			'id'         => '',
859
-			'title'      => '',
860
-			'horizontal' => false, // sets the lable horizontal
861
-			'value'      => '',
862
-			'label'      => '',
863
-			'label_class'=> '',
864
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
865
-			'inline'     => true,
866
-			'required'   => false,
867
-			'options'    => array(),
868
-			'icon'       => '',
869
-			'no_wrap'    => false,
870
-			'element_require'   => '', // [%element_id%] == "1"
871
-			'extra_attributes'  => array() // an array of extra attributes
872
-		);
873
-
874
-		/**
875
-		 * Parse incoming $args into an array and merge it with $defaults
876
-		 */
877
-		$args   = wp_parse_args( $args, $defaults );
878
-
879
-		// for now lets use horizontal for floating
880
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
881
-
882
-		$label_args = array(
883
-			'title'=> $args['label'],
884
-			'class' => $args['label_class']." pt-0 ",
885
-			'label_type' => $args['label_type']
886
-		);
887
-
888
-		$output = '';
889
-
890
-
891
-
892
-		// label before
893
-		if(!empty($args['label'])){
894
-			$output .= self::label( $label_args, 'radio' );
895
-		}
896
-
897
-		// maybe horizontal label
898
-		if($args['label_type']=='horizontal'){
899
-			$output .= '<div class="col-sm-10">';
900
-		}
901
-
902
-		if(!empty($args['options'])){
903
-			$count = 0;
904
-			foreach($args['options'] as $value => $label){
905
-				$option_args = $args;
906
-				$option_args['value'] = $value;
907
-				$option_args['label'] = $label;
908
-				$option_args['checked'] = $value == $args['value'] ? true : false;
909
-				$output .= self::radio_option($option_args,$count);
910
-				$count++;
911
-			}
912
-		}
913
-
914
-		// maybe horizontal label
915
-		if($args['label_type']=='horizontal'){
916
-			$output .= '</div>';
917
-		}
918
-
919
-
920
-		// wrap
921
-		$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
922
-		$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
923
-		$output = self::wrap(array(
924
-			'content' => $output,
925
-			'class'   => $wrap_class,
926
-			'element_require'   => $args['element_require'],
927
-			'argument_id'  => $args['id']
928
-		));
929
-
930
-
931
-		return $output;
932
-	}
933
-
934
-	/**
935
-	 * Build the component.
936
-	 *
937
-	 * @param array $args
938
-	 *
939
-	 * @return string The rendered component.
940
-	 */
941
-	public static function radio_option($args = array(),$count = ''){
942
-		$defaults = array(
943
-			'class'      => '',
944
-			'id'         => '',
945
-			'title'      => '',
946
-			'value'      => '',
947
-			'required'   => false,
948
-			'inline'     => true,
949
-			'label'      => '',
950
-			'options'    => array(),
951
-			'icon'       => '',
952
-			'no_wrap'    => false,
953
-			'extra_attributes'  => array() // an array of extra attributes
954
-		);
955
-
956
-		/**
957
-		 * Parse incoming $args into an array and merge it with $defaults
958
-		 */
959
-		$args   = wp_parse_args( $args, $defaults );
960
-
961
-		$output = '';
962
-
963
-		// open/type
964
-		$output .= '<input type="radio"';
965
-
966
-		// class
967
-		$output .= ' class="form-check-input" ';
968
-
969
-		// name
970
-		if(!empty($args['name'])){
971
-			$output .= AUI_Component_Helper::name($args['name']);
972
-		}
973
-
974
-		// id
975
-		if(!empty($args['id'])){
976
-			$output .= AUI_Component_Helper::id($args['id'].$count);
977
-		}
978
-
979
-		// title
980
-		if(!empty($args['title'])){
981
-			$output .= AUI_Component_Helper::title($args['title']);
982
-		}
983
-
984
-		// value
985
-		if(isset($args['value'])){
986
-			$output .= ' value="'.sanitize_text_field($args['value']).'" ';
987
-		}
988
-
989
-		// checked, for radio and checkboxes
990
-		if( $args['checked'] ){
991
-			$output .= ' checked ';
992
-		}
993
-
994
-		// data-attributes
995
-		$output .= AUI_Component_Helper::data_attributes($args);
996
-
997
-		// aria-attributes
998
-		$output .= AUI_Component_Helper::aria_attributes($args);
999
-
1000
-		// extra attributes
1001
-		if(!empty($args['extra_attributes'])){
1002
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1003
-		}
1004
-
1005
-		// required
1006
-		if(!empty($args['required'])){
1007
-			$output .= ' required ';
1008
-		}
1009
-
1010
-		// close opening tag
1011
-		$output .= ' >';
1012
-
1013
-		// label
1014
-		if(!empty($args['label']) && is_array($args['label'])){
1015
-		}elseif(!empty($args['label'])){
1016
-			$output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1017
-		}
1018
-
1019
-		// wrap
1020
-		if(!$args['no_wrap']){
1021
-			$wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1022
-			$output = self::wrap(array(
1023
-				'content' => $output,
1024
-				'class' => $wrap_class
1025
-			));
1026
-		}
1027
-
1028
-
1029
-		return $output;
1030
-	}
213
+            }
214
+
215
+            // input group wraps
216
+            if($args['input_group_left'] || $args['input_group_right']){
217
+                $w100 = strpos($args['class'], 'w-100') !== false ? ' w-100' : '';
218
+                if($args['input_group_left']){
219
+                    $output = self::wrap( array(
220
+                        'content' => $output,
221
+                        'class'   => $args['input_group_left_inside'] ? 'input-group-inside position-relative'.$w100  : 'input-group',
222
+                        'input_group_left' => $args['input_group_left'],
223
+                        'input_group_left_inside'    => $args['input_group_left_inside']
224
+                    ) );
225
+                }
226
+                if($args['input_group_right']){
227
+                    $output = self::wrap( array(
228
+                        'content' => $output,
229
+                        'class'   => $args['input_group_right_inside'] ? 'input-group-inside position-relative'.$w100 : 'input-group',
230
+                        'input_group_right' => $args['input_group_right'],
231
+                        'input_group_right_inside'    => $args['input_group_right_inside']
232
+                    ) );
233
+                }
234
+
235
+            }
236
+
237
+            if(!$label_after){
238
+                $output .= $help_text;
239
+            }
240
+
241
+
242
+            if($args['label_type']=='horizontal' && $type != 'checkbox'){
243
+                $output = self::wrap( array(
244
+                    'content' => $output,
245
+                    'class'   => 'col-sm-10',
246
+                ) );
247
+            }
248
+
249
+            if(!$label_after){
250
+                $output = $label . $output;
251
+            }
252
+
253
+            // wrap
254
+            if(!$args['no_wrap']){
255
+
256
+                $form_group_class = $args['label_type']=='floating' && $type != 'checkbox' ? 'form-label-group' : 'form-group';
257
+                $wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
258
+                $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
259
+                $output = self::wrap(array(
260
+                    'content' => $output,
261
+                    'class'   => $wrap_class,
262
+                    'element_require'   => $args['element_require'],
263
+                    'argument_id'  => $args['id']
264
+                ));
265
+            }
266
+
267
+
268
+
269
+        }
270
+
271
+        return $output;
272
+    }
273
+
274
+    /**
275
+     * Build the component.
276
+     *
277
+     * @param array $args
278
+     *
279
+     * @return string The rendered component.
280
+     */
281
+    public static function textarea($args = array()){
282
+        $defaults = array(
283
+            'name'       => '',
284
+            'class'      => '',
285
+            'wrap_class' => '',
286
+            'id'         => '',
287
+            'placeholder'=> '',
288
+            'title'      => '',
289
+            'value'      => '',
290
+            'required'   => false,
291
+            'label'      => '',
292
+            'label_after'=> false,
293
+            'label_class'      => '',
294
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
295
+            'help_text'  => '',
296
+            'validation_text'   => '',
297
+            'validation_pattern' => '',
298
+            'no_wrap'    => false,
299
+            'rows'      => '',
300
+            'wysiwyg'   => false,
301
+            'allow_tags' => false, // Allow HTML tags
302
+            'element_require'   => '', // [%element_id%] == "1"
303
+            'extra_attributes'  => array(), // an array of extra attributes
304
+        );
305
+
306
+        /**
307
+         * Parse incoming $args into an array and merge it with $defaults
308
+         */
309
+        $args   = wp_parse_args( $args, $defaults );
310
+        $output = '';
311
+
312
+        // hidden label option needs to be empty
313
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
314
+
315
+        // floating labels don't work with wysiwyg so set it as top
316
+        if($args['label_type'] == 'floating' && !empty($args['wysiwyg'])){
317
+            $args['label_type'] = 'top';
318
+        }
319
+
320
+        $label_after = $args['label_after'];
321
+
322
+        // floating labels need label after
323
+        if( $args['label_type'] == 'floating' && empty($args['wysiwyg']) ){
324
+            $label_after = true;
325
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
326
+        }
327
+
328
+        // label
329
+        if(!empty($args['label']) && is_array($args['label'])){
330
+        }elseif(!empty($args['label']) && !$label_after){
331
+            $label_args = array(
332
+                'title'=> $args['label'],
333
+                'for'=> $args['id'],
334
+                'class' => $args['label_class']." ",
335
+                'label_type' => $args['label_type']
336
+            );
337
+            $output .= self::label( $label_args );
338
+        }
339
+
340
+        // maybe horizontal label
341
+        if($args['label_type']=='horizontal'){
342
+            $output .= '<div class="col-sm-10">';
343
+        }
344
+
345
+        if(!empty($args['wysiwyg'])){
346
+            ob_start();
347
+            $content = $args['value'];
348
+            $editor_id = !empty($args['id']) ? sanitize_html_class($args['id']) : 'wp_editor';
349
+            $settings = array(
350
+                'textarea_rows' => !empty(absint($args['rows'])) ? absint($args['rows']) : 4,
351
+                'quicktags'     => false,
352
+                'media_buttons' => false,
353
+                'editor_class'  => 'form-control',
354
+                'textarea_name' => !empty($args['name']) ? sanitize_html_class($args['name']) : sanitize_html_class($args['id']),
355
+                'teeny'         => true,
356
+            );
357
+
358
+            // maybe set settings if array
359
+            if(is_array($args['wysiwyg'])){
360
+                $settings  = wp_parse_args( $args['wysiwyg'], $settings );
361
+            }
362
+
363
+            wp_editor( $content, $editor_id, $settings );
364
+            $output .= ob_get_clean();
365
+        }else{
366
+
367
+            // open
368
+            $output .= '<textarea ';
369
+
370
+            // name
371
+            if(!empty($args['name'])){
372
+                $output .= ' name="'.sanitize_html_class($args['name']).'" ';
373
+            }
374
+
375
+            // id
376
+            if(!empty($args['id'])){
377
+                $output .= ' id="'.sanitize_html_class($args['id']).'" ';
378
+            }
379
+
380
+            // placeholder
381
+            if(isset($args['placeholder']) && '' != $args['placeholder']){
382
+                $output .= ' placeholder="'.esc_attr($args['placeholder']).'" ';
383
+            }
384
+
385
+            // title
386
+            if(!empty($args['title'])){
387
+                $output .= ' title="'.esc_attr($args['title']).'" ';
388
+            }
389
+
390
+            // validation text
391
+            if(!empty($args['validation_text'])){
392
+                $output .= ' oninvalid="setCustomValidity(\''.esc_attr($args['validation_text']).'\')" ';
393
+                $output .= ' onchange="try{setCustomValidity(\'\')}catch(e){}" ';
394
+            }
395
+
396
+            // validation_pattern
397
+            if(!empty($args['validation_pattern'])){
398
+                $output .= ' pattern="'.$args['validation_pattern'].'" ';
399
+            }
400
+
401
+            // required
402
+            if(!empty($args['required'])){
403
+                $output .= ' required ';
404
+            }
405
+
406
+            // rows
407
+            if(!empty($args['rows'])){
408
+                $output .= ' rows="'.absint($args['rows']).'" ';
409
+            }
410
+
411
+
412
+            // class
413
+            $class = !empty($args['class']) ? $args['class'] : '';
414
+            $output .= ' class="form-control '.$class.'" ';
415
+
416
+            // extra attributes
417
+            if(!empty($args['extra_attributes'])){
418
+                $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
419
+            }
420
+
421
+            // close tag
422
+            $output .= ' >';
423
+
424
+            // value
425
+            if ( ! empty( $args['value'] ) ) {
426
+                if ( ! empty( $args['allow_tags'] ) ) {
427
+                    $output .= AUI_Component_Helper::sanitize_html_field( $args['value'], $args ); // Sanitize HTML.
428
+                } else {
429
+                    $output .= sanitize_textarea_field( $args['value'] );
430
+                }
431
+            }
432
+
433
+            // closing tag
434
+            $output .= '</textarea>';
435
+
436
+        }
437
+
438
+        if(!empty($args['label']) && $label_after){
439
+            $label_args = array(
440
+                'title'=> $args['label'],
441
+                'for'=> $args['id'],
442
+                'class' => $args['label_class']." ",
443
+                'label_type' => $args['label_type']
444
+            );
445
+            $output .= self::label( $label_args );
446
+        }
447
+
448
+        // help text
449
+        if(!empty($args['help_text'])){
450
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
451
+        }
452
+
453
+        // maybe horizontal label
454
+        if($args['label_type']=='horizontal'){
455
+            $output .= '</div>';
456
+        }
457
+
458
+
459
+        // wrap
460
+        if(!$args['no_wrap']){
461
+            $form_group_class = $args['label_type']=='floating' ? 'form-label-group' : 'form-group';
462
+            $wrap_class = $args['label_type']=='horizontal' ? $form_group_class . ' row' : $form_group_class;
463
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
464
+            $output = self::wrap(array(
465
+                'content' => $output,
466
+                'class'   => $wrap_class,
467
+                'element_require'   => $args['element_require'],
468
+                'argument_id'  => $args['id']
469
+            ));
470
+        }
471
+
472
+
473
+        return $output;
474
+    }
475
+
476
+    public static function label($args = array(), $type = ''){
477
+        //<label for="exampleInputEmail1">Email address</label>
478
+        $defaults = array(
479
+            'title'       => 'div',
480
+            'for'      => '',
481
+            'class'      => '',
482
+            'label_type'    => '', // empty = hidden, top, horizontal
483
+        );
484
+
485
+        /**
486
+         * Parse incoming $args into an array and merge it with $defaults
487
+         */
488
+        $args   = wp_parse_args( $args, $defaults );
489
+        $output = '';
490
+
491
+        if($args['title']){
492
+
493
+            // maybe hide labels //@todo set a global option for visibility class
494
+            if($type == 'file' || $type == 'checkbox' || $type == 'radio' || !empty($args['label_type']) ){
495
+                $class = $args['class'];
496
+            }else{
497
+                $class = 'sr-only '.$args['class'];
498
+            }
499
+
500
+            // maybe horizontal
501
+            if($args['label_type']=='horizontal' && $type != 'checkbox'){
502
+                $class .= ' col-sm-2 col-form-label';
503
+            }
504
+
505
+            // open
506
+            $output .= '<label ';
507
+
508
+            // for
509
+            if(!empty($args['for'])){
510
+                $output .= ' for="'.sanitize_text_field($args['for']).'" ';
511
+            }
512
+
513
+            // class
514
+            $class = $class ? AUI_Component_Helper::esc_classes( $class ) : '';
515
+            $output .= ' class="'.$class.'" ';
516
+
517
+            // close
518
+            $output .= '>';
519
+
520
+
521
+            // title, don't escape fully as can contain html
522
+            if(!empty($args['title'])){
523
+                $output .= wp_kses_post($args['title']);
524
+            }
525
+
526
+            // close wrap
527
+            $output .= '</label>';
528
+
529
+
530
+        }
531
+
532
+
533
+        return $output;
534
+    }
535
+
536
+    /**
537
+     * Wrap some content in a HTML wrapper.
538
+     *
539
+     * @param array $args
540
+     *
541
+     * @return string
542
+     */
543
+    public static function wrap($args = array()){
544
+        $defaults = array(
545
+            'type'       => 'div',
546
+            'class'      => 'form-group',
547
+            'content'   => '',
548
+            'input_group_left' => '',
549
+            'input_group_right' => '',
550
+            'input_group_left_inside' => false,
551
+            'input_group_right_inside' => false,
552
+            'element_require'   => '',
553
+            'argument_id'   => '',
554
+        );
555
+
556
+        /**
557
+         * Parse incoming $args into an array and merge it with $defaults
558
+         */
559
+        $args   = wp_parse_args( $args, $defaults );
560
+        $output = '';
561
+        if($args['type']){
562
+
563
+            // open
564
+            $output .= '<'.sanitize_html_class($args['type']);
565
+
566
+            // element require
567
+            if(!empty($args['element_require'])){
568
+                $output .= AUI_Component_Helper::element_require($args['element_require']);
569
+                $args['class'] .= " aui-conditional-field";
570
+            }
571
+
572
+            // argument_id
573
+            if( !empty($args['argument_id']) ){
574
+                $output .= ' data-argument="'.esc_attr($args['argument_id']).'"';
575
+            }
576
+
577
+            // class
578
+            $class = !empty($args['class']) ? AUI_Component_Helper::esc_classes( $args['class'] ) : '';
579
+            $output .= ' class="'.$class.'" ';
580
+
581
+            // close wrap
582
+            $output .= ' >';
583
+
584
+
585
+            // Input group left
586
+            if(!empty($args['input_group_left'])){
587
+                $position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
588
+                $input_group_left = strpos($args['input_group_left'], '<') !== false ? $args['input_group_left'] : '<span class="input-group-text">'.$args['input_group_left'].'</span>';
589
+                $output .= '<div class="input-group-prepend '.$position_class.'">'.$input_group_left.'</div>';
590
+            }
591
+
592
+            // content
593
+            $output .= $args['content'];
594
+
595
+            // Input group right
596
+            if(!empty($args['input_group_right'])){
597
+                $position_class = !empty($args['input_group_left_inside']) ? 'position-absolute h-100' : '';
598
+                $input_group_right = strpos($args['input_group_right'], '<') !== false ? $args['input_group_right'] : '<span class="input-group-text">'.$args['input_group_right'].'</span>';
599
+                $output .= '<div class="input-group-append '.$position_class.'">'.$input_group_right.'</div>';
600
+            }
601
+
602
+
603
+            // close wrap
604
+            $output .= '</'.sanitize_html_class($args['type']).'>';
605
+
606
+
607
+        }else{
608
+            $output = $args['content'];
609
+        }
610
+
611
+        return $output;
612
+    }
613
+
614
+    /**
615
+     * Build the component.
616
+     *
617
+     * @param array $args
618
+     *
619
+     * @return string The rendered component.
620
+     */
621
+    public static function select($args = array()){
622
+        $defaults = array(
623
+            'class'      => '',
624
+            'wrap_class' => '',
625
+            'id'         => '',
626
+            'title'      => '',
627
+            'value'      => '', // can be an array or a string
628
+            'required'   => false,
629
+            'label'      => '',
630
+            'label_after'=> false,
631
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
632
+            'label_class'      => '',
633
+            'help_text'  => '',
634
+            'placeholder'=> '',
635
+            'options'    => array(), // array or string
636
+            'icon'       => '',
637
+            'multiple'   => false,
638
+            'select2'    => false,
639
+            'no_wrap'    => false,
640
+            'element_require'   => '', // [%element_id%] == "1"
641
+            'extra_attributes'  => array(), // an array of extra attributes
642
+        );
643
+
644
+        /**
645
+         * Parse incoming $args into an array and merge it with $defaults
646
+         */
647
+        $args   = wp_parse_args( $args, $defaults );
648
+        $output = '';
649
+
650
+        // for now lets hide floating labels
651
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'hidden';}
652
+
653
+        // hidden label option needs to be empty
654
+        $args['label_type'] = $args['label_type'] == 'hidden' ? '' : $args['label_type'];
655
+
656
+
657
+        $label_after = $args['label_after'];
658
+
659
+        // floating labels need label after
660
+        if( $args['label_type'] == 'floating' ){
661
+            $label_after = true;
662
+            $args['placeholder'] = ' '; // set the placeholder not empty so the floating label works.
663
+        }
664
+
665
+        // Maybe setup select2
666
+        $is_select2 = false;
667
+        if(!empty($args['select2'])){
668
+            $args['class'] .= ' aui-select2';
669
+            $is_select2 = true;
670
+        }elseif( strpos($args['class'], 'aui-select2') !== false){
671
+            $is_select2 = true;
672
+        }
673
+
674
+        // select2 tags
675
+        if( !empty($args['select2']) && $args['select2'] === 'tags'){ // triple equals needed here for some reason
676
+            $args['data-tags'] = 'true';
677
+            $args['data-token-separators'] = "[',']";
678
+            $args['multiple'] = true;
679
+        }
680
+
681
+        // select2 placeholder
682
+        if($is_select2 && isset($args['placeholder']) && '' != $args['placeholder'] && empty($args['data-placeholder'])){
683
+            $args['data-placeholder'] = esc_attr($args['placeholder']);
684
+            $args['data-allow-clear'] = isset($args['data-allow-clear']) ? (bool) $args['data-allow-clear'] : true;
685
+        }
686
+
687
+        // label
688
+        if(!empty($args['label']) && is_array($args['label'])){
689
+        }elseif(!empty($args['label']) && !$label_after){
690
+            $label_args = array(
691
+                'title'=> $args['label'],
692
+                'for'=> $args['id'],
693
+                'class' => $args['label_class']." ",
694
+                'label_type' => $args['label_type']
695
+            );
696
+            $output .= self::label($label_args);
697
+        }
698
+
699
+        // maybe horizontal label
700
+        if($args['label_type']=='horizontal'){
701
+            $output .= '<div class="col-sm-10">';
702
+        }
703
+
704
+        // open/type
705
+        $output .= '<select ';
706
+
707
+        // style
708
+        if($is_select2){
709
+            $output .= " style='width:100%;' ";
710
+        }
711
+
712
+        // element require
713
+        if(!empty($args['element_require'])){
714
+            $output .= AUI_Component_Helper::element_require($args['element_require']);
715
+            $args['class'] .= " aui-conditional-field";
716
+        }
717
+
718
+        // class
719
+        $class = !empty($args['class']) ? $args['class'] : '';
720
+        $output .= AUI_Component_Helper::class_attr('custom-select '.$class);
721
+
722
+        // name
723
+        if(!empty($args['name'])){
724
+            $output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
725
+        }
726
+
727
+        // id
728
+        if(!empty($args['id'])){
729
+            $output .= AUI_Component_Helper::id($args['id']);
730
+        }
731
+
732
+        // title
733
+        if(!empty($args['title'])){
734
+            $output .= AUI_Component_Helper::title($args['title']);
735
+        }
736
+
737
+        // data-attributes
738
+        $output .= AUI_Component_Helper::data_attributes($args);
739
+
740
+        // aria-attributes
741
+        $output .= AUI_Component_Helper::aria_attributes($args);
742
+
743
+        // extra attributes
744
+        if(!empty($args['extra_attributes'])){
745
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
746
+        }
747
+
748
+        // required
749
+        if(!empty($args['required'])){
750
+            $output .= ' required ';
751
+        }
752
+
753
+        // multiple
754
+        if(!empty($args['multiple'])){
755
+            $output .= ' multiple ';
756
+        }
757
+
758
+        // close opening tag
759
+        $output .= ' >';
760
+
761
+        // placeholder
762
+        if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
763
+            $output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
764
+        }elseif($is_select2 && !empty($args['placeholder'])){
765
+            $output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
766
+        }
767
+
768
+        // Options
769
+        if(!empty($args['options'])){
770
+
771
+            if(!is_array($args['options'])){
772
+                $output .= $args['options']; // not the preferred way but an option
773
+            }else{
774
+                foreach($args['options'] as $val => $name){
775
+                    $selected = '';
776
+                    if(is_array($name)){
777
+                        if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
778
+                            $option_label = isset($name['label']) ? $name['label'] : '';
779
+
780
+                            $output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
781
+                        } else {
782
+                            $option_label = isset($name['label']) ? $name['label'] : '';
783
+                            $option_value = isset($name['value']) ? $name['value'] : '';
784
+                            if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
785
+                                $selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
786
+                            } elseif(!empty($args['value'])) {
787
+                                $selected = selected($option_value,stripslashes_deep($args['value']), false);
788
+                            }
789
+
790
+                            $output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
791
+                        }
792
+                    }else{
793
+                        if(!empty($args['value'])){
794
+                            if(is_array($args['value'])){
795
+                                $selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
796
+                            } elseif(!empty($args['value'])) {
797
+                                $selected = selected( $args['value'], $val, false);
798
+                            }
799
+                        }
800
+                        $output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
801
+                    }
802
+                }
803
+            }
804
+
805
+        }
806
+
807
+        // closing tag
808
+        $output .= '</select>';
809
+
810
+        if(!empty($args['label']) && $label_after){
811
+            $label_args = array(
812
+                'title'=> $args['label'],
813
+                'for'=> $args['id'],
814
+                'class' => $args['label_class']." ",
815
+                'label_type' => $args['label_type']
816
+            );
817
+            $output .= self::label($label_args);
818
+        }
819
+
820
+        // help text
821
+        if(!empty($args['help_text'])){
822
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
823
+        }
824
+
825
+        // maybe horizontal label
826
+        if($args['label_type']=='horizontal'){
827
+            $output .= '</div>';
828
+        }
829
+
830
+
831
+        // wrap
832
+        if(!$args['no_wrap']){
833
+            $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
834
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
835
+            $output = self::wrap(array(
836
+                'content' => $output,
837
+                'class'   => $wrap_class,
838
+                'element_require'   => $args['element_require'],
839
+                'argument_id'  => $args['id']
840
+            ));
841
+        }
842
+
843
+
844
+        return $output;
845
+    }
846
+
847
+    /**
848
+     * Build the component.
849
+     *
850
+     * @param array $args
851
+     *
852
+     * @return string The rendered component.
853
+     */
854
+    public static function radio($args = array()){
855
+        $defaults = array(
856
+            'class'      => '',
857
+            'wrap_class' => '',
858
+            'id'         => '',
859
+            'title'      => '',
860
+            'horizontal' => false, // sets the lable horizontal
861
+            'value'      => '',
862
+            'label'      => '',
863
+            'label_class'=> '',
864
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
865
+            'inline'     => true,
866
+            'required'   => false,
867
+            'options'    => array(),
868
+            'icon'       => '',
869
+            'no_wrap'    => false,
870
+            'element_require'   => '', // [%element_id%] == "1"
871
+            'extra_attributes'  => array() // an array of extra attributes
872
+        );
873
+
874
+        /**
875
+         * Parse incoming $args into an array and merge it with $defaults
876
+         */
877
+        $args   = wp_parse_args( $args, $defaults );
878
+
879
+        // for now lets use horizontal for floating
880
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
881
+
882
+        $label_args = array(
883
+            'title'=> $args['label'],
884
+            'class' => $args['label_class']." pt-0 ",
885
+            'label_type' => $args['label_type']
886
+        );
887
+
888
+        $output = '';
889
+
890
+
891
+
892
+        // label before
893
+        if(!empty($args['label'])){
894
+            $output .= self::label( $label_args, 'radio' );
895
+        }
896
+
897
+        // maybe horizontal label
898
+        if($args['label_type']=='horizontal'){
899
+            $output .= '<div class="col-sm-10">';
900
+        }
901
+
902
+        if(!empty($args['options'])){
903
+            $count = 0;
904
+            foreach($args['options'] as $value => $label){
905
+                $option_args = $args;
906
+                $option_args['value'] = $value;
907
+                $option_args['label'] = $label;
908
+                $option_args['checked'] = $value == $args['value'] ? true : false;
909
+                $output .= self::radio_option($option_args,$count);
910
+                $count++;
911
+            }
912
+        }
913
+
914
+        // maybe horizontal label
915
+        if($args['label_type']=='horizontal'){
916
+            $output .= '</div>';
917
+        }
918
+
919
+
920
+        // wrap
921
+        $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
922
+        $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
923
+        $output = self::wrap(array(
924
+            'content' => $output,
925
+            'class'   => $wrap_class,
926
+            'element_require'   => $args['element_require'],
927
+            'argument_id'  => $args['id']
928
+        ));
929
+
930
+
931
+        return $output;
932
+    }
933
+
934
+    /**
935
+     * Build the component.
936
+     *
937
+     * @param array $args
938
+     *
939
+     * @return string The rendered component.
940
+     */
941
+    public static function radio_option($args = array(),$count = ''){
942
+        $defaults = array(
943
+            'class'      => '',
944
+            'id'         => '',
945
+            'title'      => '',
946
+            'value'      => '',
947
+            'required'   => false,
948
+            'inline'     => true,
949
+            'label'      => '',
950
+            'options'    => array(),
951
+            'icon'       => '',
952
+            'no_wrap'    => false,
953
+            'extra_attributes'  => array() // an array of extra attributes
954
+        );
955
+
956
+        /**
957
+         * Parse incoming $args into an array and merge it with $defaults
958
+         */
959
+        $args   = wp_parse_args( $args, $defaults );
960
+
961
+        $output = '';
962
+
963
+        // open/type
964
+        $output .= '<input type="radio"';
965
+
966
+        // class
967
+        $output .= ' class="form-check-input" ';
968
+
969
+        // name
970
+        if(!empty($args['name'])){
971
+            $output .= AUI_Component_Helper::name($args['name']);
972
+        }
973
+
974
+        // id
975
+        if(!empty($args['id'])){
976
+            $output .= AUI_Component_Helper::id($args['id'].$count);
977
+        }
978
+
979
+        // title
980
+        if(!empty($args['title'])){
981
+            $output .= AUI_Component_Helper::title($args['title']);
982
+        }
983
+
984
+        // value
985
+        if(isset($args['value'])){
986
+            $output .= ' value="'.sanitize_text_field($args['value']).'" ';
987
+        }
988
+
989
+        // checked, for radio and checkboxes
990
+        if( $args['checked'] ){
991
+            $output .= ' checked ';
992
+        }
993
+
994
+        // data-attributes
995
+        $output .= AUI_Component_Helper::data_attributes($args);
996
+
997
+        // aria-attributes
998
+        $output .= AUI_Component_Helper::aria_attributes($args);
999
+
1000
+        // extra attributes
1001
+        if(!empty($args['extra_attributes'])){
1002
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1003
+        }
1004
+
1005
+        // required
1006
+        if(!empty($args['required'])){
1007
+            $output .= ' required ';
1008
+        }
1009
+
1010
+        // close opening tag
1011
+        $output .= ' >';
1012
+
1013
+        // label
1014
+        if(!empty($args['label']) && is_array($args['label'])){
1015
+        }elseif(!empty($args['label'])){
1016
+            $output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1017
+        }
1018
+
1019
+        // wrap
1020
+        if(!$args['no_wrap']){
1021
+            $wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1022
+            $output = self::wrap(array(
1023
+                'content' => $output,
1024
+                'class' => $wrap_class
1025
+            ));
1026
+        }
1027
+
1028
+
1029
+        return $output;
1030
+    }
1031 1031
 
1032 1032
 }
1033 1033
\ No newline at end of file
Please login to merge, or discard this patch.
vendor/ayecode/wp-ayecode-ui/includes/ayecode-ui-settings.php 1 patch
Indentation   +894 added lines, -894 removed lines patch added patch discarded remove patch
@@ -13,7 +13,7 @@  discard block
 block discarded – undo
13 13
  * Bail if we are not in WP.
14 14
  */
15 15
 if ( ! defined( 'ABSPATH' ) ) {
16
-	exit;
16
+    exit;
17 17
 }
18 18
 
19 19
 /**
@@ -21,202 +21,202 @@  discard block
 block discarded – undo
21 21
  */
22 22
 if ( ! class_exists( 'AyeCode_UI_Settings' ) ) {
23 23
 
24
-	/**
25
-	 * A Class to be able to change settings for Font Awesome.
26
-	 *
27
-	 * Class AyeCode_UI_Settings
28
-	 * @ver 1.0.0
29
-	 * @todo decide how to implement textdomain
30
-	 */
31
-	class AyeCode_UI_Settings {
32
-
33
-		/**
34
-		 * Class version version.
35
-		 *
36
-		 * @var string
37
-		 */
38
-		public $version = '1.0.1';
39
-
40
-		/**
41
-		 * Class textdomain.
42
-		 *
43
-		 * @var string
44
-		 */
45
-		public $textdomain = 'aui';
46
-
47
-		/**
48
-		 * Latest version of Bootstrap at time of publish published.
49
-		 *
50
-		 * @var string
51
-		 */
52
-		public $latest = "4.5.3";
53
-
54
-		/**
55
-		 * Current version of select2 being used.
56
-		 *
57
-		 * @var string
58
-		 */
59
-		public $select2_version = "4.0.11";
60
-
61
-		/**
62
-		 * The title.
63
-		 *
64
-		 * @var string
65
-		 */
66
-		public $name = 'AyeCode UI';
67
-
68
-		/**
69
-		 * The relative url to the assets.
70
-		 *
71
-		 * @var string
72
-		 */
73
-		public $url = '';
74
-
75
-		/**
76
-		 * Holds the settings values.
77
-		 *
78
-		 * @var array
79
-		 */
80
-		private $settings;
81
-
82
-		/**
83
-		 * AyeCode_UI_Settings instance.
84
-		 *
85
-		 * @access private
86
-		 * @since  1.0.0
87
-		 * @var    AyeCode_UI_Settings There can be only one!
88
-		 */
89
-		private static $instance = null;
90
-
91
-		/**
92
-		 * Main AyeCode_UI_Settings Instance.
93
-		 *
94
-		 * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
95
-		 *
96
-		 * @since 1.0.0
97
-		 * @static
98
-		 * @return AyeCode_UI_Settings - Main instance.
99
-		 */
100
-		public static function instance() {
101
-			if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
102
-
103
-				self::$instance = new AyeCode_UI_Settings;
104
-
105
-				add_action( 'init', array( self::$instance, 'init' ) ); // set settings
106
-
107
-				if ( is_admin() ) {
108
-					add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
109
-					add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
110
-
111
-					// Maybe show example page
112
-					add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
113
-				}
24
+    /**
25
+     * A Class to be able to change settings for Font Awesome.
26
+     *
27
+     * Class AyeCode_UI_Settings
28
+     * @ver 1.0.0
29
+     * @todo decide how to implement textdomain
30
+     */
31
+    class AyeCode_UI_Settings {
32
+
33
+        /**
34
+         * Class version version.
35
+         *
36
+         * @var string
37
+         */
38
+        public $version = '1.0.1';
39
+
40
+        /**
41
+         * Class textdomain.
42
+         *
43
+         * @var string
44
+         */
45
+        public $textdomain = 'aui';
46
+
47
+        /**
48
+         * Latest version of Bootstrap at time of publish published.
49
+         *
50
+         * @var string
51
+         */
52
+        public $latest = "4.5.3";
53
+
54
+        /**
55
+         * Current version of select2 being used.
56
+         *
57
+         * @var string
58
+         */
59
+        public $select2_version = "4.0.11";
60
+
61
+        /**
62
+         * The title.
63
+         *
64
+         * @var string
65
+         */
66
+        public $name = 'AyeCode UI';
67
+
68
+        /**
69
+         * The relative url to the assets.
70
+         *
71
+         * @var string
72
+         */
73
+        public $url = '';
74
+
75
+        /**
76
+         * Holds the settings values.
77
+         *
78
+         * @var array
79
+         */
80
+        private $settings;
81
+
82
+        /**
83
+         * AyeCode_UI_Settings instance.
84
+         *
85
+         * @access private
86
+         * @since  1.0.0
87
+         * @var    AyeCode_UI_Settings There can be only one!
88
+         */
89
+        private static $instance = null;
90
+
91
+        /**
92
+         * Main AyeCode_UI_Settings Instance.
93
+         *
94
+         * Ensures only one instance of AyeCode_UI_Settings is loaded or can be loaded.
95
+         *
96
+         * @since 1.0.0
97
+         * @static
98
+         * @return AyeCode_UI_Settings - Main instance.
99
+         */
100
+        public static function instance() {
101
+            if ( ! isset( self::$instance ) && ! ( self::$instance instanceof AyeCode_UI_Settings ) ) {
102
+
103
+                self::$instance = new AyeCode_UI_Settings;
104
+
105
+                add_action( 'init', array( self::$instance, 'init' ) ); // set settings
106
+
107
+                if ( is_admin() ) {
108
+                    add_action( 'admin_menu', array( self::$instance, 'menu_item' ) );
109
+                    add_action( 'admin_init', array( self::$instance, 'register_settings' ) );
110
+
111
+                    // Maybe show example page
112
+                    add_action( 'template_redirect', array( self::$instance,'maybe_show_examples' ) );
113
+                }
114 114
 
115
-				add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
116
-
117
-				do_action( 'ayecode_ui_settings_loaded' );
118
-			}
119
-
120
-			return self::$instance;
121
-		}
122
-
123
-		/**
124
-		 * Setup some constants.
125
-		 */
126
-		public function constants(){
127
-			define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be");
128
-			define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d');
129
-			if (!defined('AUI_PRIMARY_COLOR')) define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL);
130
-			if (!defined('AUI_SECONDARY_COLOR')) define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL);
131
-		}
132
-
133
-		/**
134
-		 * Initiate the settings and add the required action hooks.
135
-		 */
136
-		public function init() {
137
-			$this->constants();
138
-			$this->settings = $this->get_settings();
139
-			$this->url = $this->get_url();
140
-
141
-			/**
142
-			 * Maybe load CSS
143
-			 *
144
-			 * We load super early in case there is a theme version that might change the colors
145
-			 */
146
-			if ( $this->settings['css'] ) {
147
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
148
-			}
149
-			if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
150
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
151
-			}
152
-
153
-			// maybe load JS
154
-			if ( $this->settings['js'] ) {
155
-				$priority = $this->is_bs3_compat() ? 100 : 1;
156
-				add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
157
-			}
158
-			if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
159
-				add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
160
-			}
161
-
162
-			// Maybe set the HTML font size
163
-			if ( $this->settings['html_font_size'] ) {
164
-				add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
165
-			}
166
-
167
-
168
-		}
169
-
170
-		/**
171
-		 * Check if we should load the admin scripts or not.
172
-		 *
173
-		 * @return bool
174
-		 */
175
-		public function load_admin_scripts(){
176
-			$result = true;
177
-
178
-			if(!empty($this->settings['disable_admin'])){
179
-				$url_parts = explode("\n",$this->settings['disable_admin']);
180
-				foreach($url_parts as $part){
181
-					if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
182
-						return false; // return early, no point checking further
183
-					}
184
-				}
185
-			}
115
+                add_action( 'customize_register', array( self::$instance, 'customizer_settings' ));
116
+
117
+                do_action( 'ayecode_ui_settings_loaded' );
118
+            }
119
+
120
+            return self::$instance;
121
+        }
122
+
123
+        /**
124
+         * Setup some constants.
125
+         */
126
+        public function constants(){
127
+            define('AUI_PRIMARY_COLOR_ORIGINAL', "#1e73be");
128
+            define('AUI_SECONDARY_COLOR_ORIGINAL', '#6c757d');
129
+            if (!defined('AUI_PRIMARY_COLOR')) define('AUI_PRIMARY_COLOR', AUI_PRIMARY_COLOR_ORIGINAL);
130
+            if (!defined('AUI_SECONDARY_COLOR')) define('AUI_SECONDARY_COLOR', AUI_SECONDARY_COLOR_ORIGINAL);
131
+        }
132
+
133
+        /**
134
+         * Initiate the settings and add the required action hooks.
135
+         */
136
+        public function init() {
137
+            $this->constants();
138
+            $this->settings = $this->get_settings();
139
+            $this->url = $this->get_url();
140
+
141
+            /**
142
+             * Maybe load CSS
143
+             *
144
+             * We load super early in case there is a theme version that might change the colors
145
+             */
146
+            if ( $this->settings['css'] ) {
147
+                add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
148
+            }
149
+            if ( $this->settings['css_backend'] && $this->load_admin_scripts() ) {
150
+                add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_style' ), 1 );
151
+            }
152
+
153
+            // maybe load JS
154
+            if ( $this->settings['js'] ) {
155
+                $priority = $this->is_bs3_compat() ? 100 : 1;
156
+                add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ), $priority );
157
+            }
158
+            if ( $this->settings['js_backend'] && $this->load_admin_scripts() ) {
159
+                add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 1 );
160
+            }
161
+
162
+            // Maybe set the HTML font size
163
+            if ( $this->settings['html_font_size'] ) {
164
+                add_action( 'wp_footer', array( $this, 'html_font_size' ), 10 );
165
+            }
166
+
167
+
168
+        }
169
+
170
+        /**
171
+         * Check if we should load the admin scripts or not.
172
+         *
173
+         * @return bool
174
+         */
175
+        public function load_admin_scripts(){
176
+            $result = true;
177
+
178
+            if(!empty($this->settings['disable_admin'])){
179
+                $url_parts = explode("\n",$this->settings['disable_admin']);
180
+                foreach($url_parts as $part){
181
+                    if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
182
+                        return false; // return early, no point checking further
183
+                    }
184
+                }
185
+            }
186 186
 
187
-			return $result;
188
-		}
187
+            return $result;
188
+        }
189 189
 
190
-		/**
191
-		 * Add a html font size to the footer.
192
-		 */
193
-		public function html_font_size(){
194
-			$this->settings = $this->get_settings();
195
-			echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
196
-		}
190
+        /**
191
+         * Add a html font size to the footer.
192
+         */
193
+        public function html_font_size(){
194
+            $this->settings = $this->get_settings();
195
+            echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
196
+        }
197 197
 
198
-		/**
199
-		 * Adds the styles.
200
-		 */
201
-		public function enqueue_style() {
198
+        /**
199
+         * Adds the styles.
200
+         */
201
+        public function enqueue_style() {
202 202
 
203
-			$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
203
+            $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
204 204
 
205
-			$rtl = is_rtl() ? '-rtl' : '';
205
+            $rtl = is_rtl() ? '-rtl' : '';
206 206
 
207
-			if($this->settings[$css_setting]){
208
-				$compatibility = $this->settings[$css_setting]=='core' ? false : true;
209
-				$url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
210
-				wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
211
-				wp_enqueue_style( 'ayecode-ui' );
207
+            if($this->settings[$css_setting]){
208
+                $compatibility = $this->settings[$css_setting]=='core' ? false : true;
209
+                $url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
210
+                wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
211
+                wp_enqueue_style( 'ayecode-ui' );
212 212
 
213
-				// flatpickr
214
-				wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
213
+                // flatpickr
214
+                wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
215 215
 
216 216
 
217
-				// fix some wp-admin issues
218
-				if(is_admin()){
219
-					$custom_css = "
217
+                // fix some wp-admin issues
218
+                if(is_admin()){
219
+                    $custom_css = "
220 220
                 body{
221 221
                     background-color: #f1f1f1;
222 222
                     font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif;
@@ -252,29 +252,29 @@  discard block
 block discarded – undo
252 252
 				}
253 253
                 ";
254 254
 
255
-					// @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
256
-					$custom_css .= "
255
+                    // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
256
+                    $custom_css .= "
257 257
 						.edit-post-sidebar input[type=color].components-text-control__input{
258 258
 						    padding: 0;
259 259
 						}
260 260
 					";
261
-					wp_add_inline_style( 'ayecode-ui', $custom_css );
262
-				}
261
+                    wp_add_inline_style( 'ayecode-ui', $custom_css );
262
+                }
263 263
 
264
-				// custom changes
265
-				wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
264
+                // custom changes
265
+                wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
266 266
 
267
-			}
268
-		}
267
+            }
268
+        }
269 269
 
270
-		/**
271
-		 * Get inline script used if bootstrap enqueued
272
-		 *
273
-		 * If this remains small then its best to use this than to add another JS file.
274
-		 */
275
-		public function inline_script(){
276
-			ob_start();
277
-			?>
270
+        /**
271
+         * Get inline script used if bootstrap enqueued
272
+         *
273
+         * If this remains small then its best to use this than to add another JS file.
274
+         */
275
+        public function inline_script(){
276
+            ob_start();
277
+            ?>
278 278
 			<script>
279 279
 				
280 280
 				/**
@@ -766,27 +766,27 @@  discard block
 block discarded – undo
766 766
 				
767 767
 			</script>
768 768
 			<?php
769
-			$output = ob_get_clean();
769
+            $output = ob_get_clean();
770 770
 
771
-			/*
771
+            /*
772 772
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
773 773
 			 */
774
-			return str_replace( array(
775
-				'<script>',
776
-				'</script>'
777
-			), '', $output );
778
-		}
779
-
780
-
781
-		/**
782
-		 * JS to help with conflict issues with other plugins and themes using bootstrap v3.
783
-		 * 
784
-		 * @TODO we may need this when other conflicts arrise.
785
-		 * @return mixed
786
-		 */
787
-		public static function bs3_compat_js() {
788
-			ob_start();
789
-			?>
774
+            return str_replace( array(
775
+                '<script>',
776
+                '</script>'
777
+            ), '', $output );
778
+        }
779
+
780
+
781
+        /**
782
+         * JS to help with conflict issues with other plugins and themes using bootstrap v3.
783
+         * 
784
+         * @TODO we may need this when other conflicts arrise.
785
+         * @return mixed
786
+         */
787
+        public static function bs3_compat_js() {
788
+            ob_start();
789
+            ?>
790 790
 			<script>
791 791
 				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
792 792
 				/* With Avada builder */
@@ -794,20 +794,20 @@  discard block
 block discarded – undo
794 794
 				<?php } ?>
795 795
 			</script>
796 796
 			<?php
797
-			return str_replace( array(
798
-				'<script>',
799
-				'</script>'
800
-			), '', ob_get_clean());
801
-		}
802
-
803
-		/**
804
-		 * Get inline script used if bootstrap file browser enqueued.
805
-		 *
806
-		 * If this remains small then its best to use this than to add another JS file.
807
-		 */
808
-		public function inline_script_file_browser(){
809
-			ob_start();
810
-			?>
797
+            return str_replace( array(
798
+                '<script>',
799
+                '</script>'
800
+            ), '', ob_get_clean());
801
+        }
802
+
803
+        /**
804
+         * Get inline script used if bootstrap file browser enqueued.
805
+         *
806
+         * If this remains small then its best to use this than to add another JS file.
807
+         */
808
+        public function inline_script_file_browser(){
809
+            ob_start();
810
+            ?>
811 811
 			<script>
812 812
 				// run on doc ready
813 813
 				jQuery(document).ready(function () {
@@ -815,184 +815,184 @@  discard block
 block discarded – undo
815 815
 				});
816 816
 			</script>
817 817
 			<?php
818
-			$output = ob_get_clean();
818
+            $output = ob_get_clean();
819 819
 
820
-			/*
820
+            /*
821 821
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
822 822
 			 */
823
-			return str_replace( array(
824
-				'<script>',
825
-				'</script>'
826
-			), '', $output );
827
-		}
828
-
829
-		/**
830
-		 * Adds the Font Awesome JS.
831
-		 */
832
-		public function enqueue_scripts() {
833
-
834
-			$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
835
-
836
-			// select2
837
-			wp_register_script( 'select2', $this->url.'assets/js/select2.min.js', array('jquery'), $this->select2_version );
838
-
839
-			// flatpickr
840
-			wp_register_script( 'flatpickr', $this->url.'assets/js/flatpickr.min.js', array(), $this->latest );
841
-
842
-			// Bootstrap file browser
843
-			wp_register_script( 'aui-custom-file-input', $url = $this->url.'assets/js/bs-custom-file-input.min.js', array('jquery'), $this->select2_version );
844
-			wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
845
-
846
-			$load_inline = false;
847
-
848
-			if($this->settings[$js_setting]=='core-popper'){
849
-				// Bootstrap bundle
850
-				$url = $this->url.'assets/js/bootstrap.bundle.min.js';
851
-				wp_register_script( 'bootstrap-js-bundle', $url, array('select2','jquery'), $this->latest, $this->is_bs3_compat() );
852
-				// if in admin then add to footer for compatibility.
853
-				is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle');
854
-				$script = $this->inline_script();
855
-				wp_add_inline_script( 'bootstrap-js-bundle', $script );
856
-			}elseif($this->settings[$js_setting]=='popper'){
857
-				$url = $this->url.'assets/js/popper.min.js';
858
-				wp_register_script( 'bootstrap-js-popper', $url, array('select2','jquery'), $this->latest );
859
-				wp_enqueue_script( 'bootstrap-js-popper' );
860
-				$load_inline = true;
861
-			}else{
862
-				$load_inline = true;
863
-			}
864
-
865
-			// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
866
-			if($load_inline){
867
-				wp_register_script( 'bootstrap-dummy', '',array('select2','jquery') );
868
-				wp_enqueue_script( 'bootstrap-dummy' );
869
-				$script = $this->inline_script();
870
-				wp_add_inline_script( 'bootstrap-dummy', $script  );
871
-			}
872
-
873
-		}
874
-
875
-		/**
876
-		 * Enqueue flatpickr if called.
877
-		 */
878
-		public function enqueue_flatpickr(){
879
-			wp_enqueue_style( 'flatpickr' );
880
-			wp_enqueue_script( 'flatpickr' );
881
-		}
882
-
883
-		/**
884
-		 * Get the url path to the current folder.
885
-		 *
886
-		 * @return string
887
-		 */
888
-		public function get_url() {
889
-
890
-			$url = '';
891
-			// check if we are inside a plugin
892
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
893
-
894
-			// add check in-case user has changed wp-content dir name.
895
-			$wp_content_folder_name = basename(WP_CONTENT_DIR);
896
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
897
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
898
-
899
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
900
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
901
-			}
902
-
903
-			return $url;
904
-		}
905
-
906
-		/**
907
-		 * Register the database settings with WordPress.
908
-		 */
909
-		public function register_settings() {
910
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
911
-		}
912
-
913
-		/**
914
-		 * Add the WordPress settings menu item.
915
-		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
916
-		 */
917
-		public function menu_item() {
918
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
919
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
920
-				$this,
921
-				'settings_page'
922
-			) );
923
-		}
924
-
925
-		/**
926
-		 * Get a list of themes and their default JS settings.
927
-		 *
928
-		 * @return array
929
-		 */
930
-		public function theme_js_settings(){
931
-			return array(
932
-				'ayetheme' => 'popper',
933
-				'listimia' => 'required',
934
-				'listimia_backend' => 'core-popper',
935
-				'avada'    => 'required',
936
-			);
937
-		}
938
-
939
-		/**
940
-		 * Get the current Font Awesome output settings.
941
-		 *
942
-		 * @return array The array of settings.
943
-		 */
944
-		public function get_settings() {
945
-
946
-			$db_settings = get_option( 'ayecode-ui-settings' );
947
-			$js_default = 'core-popper';
948
-			$js_default_backend = $js_default;
949
-
950
-			// maybe set defaults (if no settings set)
951
-			if(empty($db_settings)){
952
-				$active_theme = strtolower( get_template() ); // active parent theme.
953
-				$theme_js_settings = self::theme_js_settings();
954
-				if(isset($theme_js_settings[$active_theme])){
955
-					$js_default = $theme_js_settings[$active_theme];
956
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
957
-				}
958
-			}
959
-
960
-			$defaults = array(
961
-				'css'       => 'compatibility', // core, compatibility
962
-				'js'        => $js_default, // js to load, core-popper, popper
963
-				'html_font_size'        => '16', // js to load, core-popper, popper
964
-				'css_backend'       => 'compatibility', // core, compatibility
965
-				'js_backend'        => $js_default_backend, // js to load, core-popper, popper
966
-				'disable_admin'     =>  '', // URL snippets to disable loading on admin
967
-			);
968
-
969
-			$settings = wp_parse_args( $db_settings, $defaults );
970
-
971
-			/**
972
-			 * Filter the Bootstrap settings.
973
-			 *
974
-			 * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
975
-			 */
976
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
977
-		}
978
-
979
-
980
-		/**
981
-		 * The settings page html output.
982
-		 */
983
-		public function settings_page() {
984
-			if ( ! current_user_can( 'manage_options' ) ) {
985
-				wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
986
-			}
987
-			?>
823
+            return str_replace( array(
824
+                '<script>',
825
+                '</script>'
826
+            ), '', $output );
827
+        }
828
+
829
+        /**
830
+         * Adds the Font Awesome JS.
831
+         */
832
+        public function enqueue_scripts() {
833
+
834
+            $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
835
+
836
+            // select2
837
+            wp_register_script( 'select2', $this->url.'assets/js/select2.min.js', array('jquery'), $this->select2_version );
838
+
839
+            // flatpickr
840
+            wp_register_script( 'flatpickr', $this->url.'assets/js/flatpickr.min.js', array(), $this->latest );
841
+
842
+            // Bootstrap file browser
843
+            wp_register_script( 'aui-custom-file-input', $url = $this->url.'assets/js/bs-custom-file-input.min.js', array('jquery'), $this->select2_version );
844
+            wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
845
+
846
+            $load_inline = false;
847
+
848
+            if($this->settings[$js_setting]=='core-popper'){
849
+                // Bootstrap bundle
850
+                $url = $this->url.'assets/js/bootstrap.bundle.min.js';
851
+                wp_register_script( 'bootstrap-js-bundle', $url, array('select2','jquery'), $this->latest, $this->is_bs3_compat() );
852
+                // if in admin then add to footer for compatibility.
853
+                is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle');
854
+                $script = $this->inline_script();
855
+                wp_add_inline_script( 'bootstrap-js-bundle', $script );
856
+            }elseif($this->settings[$js_setting]=='popper'){
857
+                $url = $this->url.'assets/js/popper.min.js';
858
+                wp_register_script( 'bootstrap-js-popper', $url, array('select2','jquery'), $this->latest );
859
+                wp_enqueue_script( 'bootstrap-js-popper' );
860
+                $load_inline = true;
861
+            }else{
862
+                $load_inline = true;
863
+            }
864
+
865
+            // Load needed inline scripts by faking the loading of a script if the main script is not being loaded
866
+            if($load_inline){
867
+                wp_register_script( 'bootstrap-dummy', '',array('select2','jquery') );
868
+                wp_enqueue_script( 'bootstrap-dummy' );
869
+                $script = $this->inline_script();
870
+                wp_add_inline_script( 'bootstrap-dummy', $script  );
871
+            }
872
+
873
+        }
874
+
875
+        /**
876
+         * Enqueue flatpickr if called.
877
+         */
878
+        public function enqueue_flatpickr(){
879
+            wp_enqueue_style( 'flatpickr' );
880
+            wp_enqueue_script( 'flatpickr' );
881
+        }
882
+
883
+        /**
884
+         * Get the url path to the current folder.
885
+         *
886
+         * @return string
887
+         */
888
+        public function get_url() {
889
+
890
+            $url = '';
891
+            // check if we are inside a plugin
892
+            $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
893
+
894
+            // add check in-case user has changed wp-content dir name.
895
+            $wp_content_folder_name = basename(WP_CONTENT_DIR);
896
+            $dir_parts = explode("/$wp_content_folder_name/",$file_dir);
897
+            $url_parts = explode("/$wp_content_folder_name/",plugins_url());
898
+
899
+            if(!empty($url_parts[0]) && !empty($dir_parts[1])){
900
+                $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
901
+            }
902
+
903
+            return $url;
904
+        }
905
+
906
+        /**
907
+         * Register the database settings with WordPress.
908
+         */
909
+        public function register_settings() {
910
+            register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
911
+        }
912
+
913
+        /**
914
+         * Add the WordPress settings menu item.
915
+         * @since 1.0.10 Calling function name direct will fail theme check so we don't.
916
+         */
917
+        public function menu_item() {
918
+            $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
919
+            call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
920
+                $this,
921
+                'settings_page'
922
+            ) );
923
+        }
924
+
925
+        /**
926
+         * Get a list of themes and their default JS settings.
927
+         *
928
+         * @return array
929
+         */
930
+        public function theme_js_settings(){
931
+            return array(
932
+                'ayetheme' => 'popper',
933
+                'listimia' => 'required',
934
+                'listimia_backend' => 'core-popper',
935
+                'avada'    => 'required',
936
+            );
937
+        }
938
+
939
+        /**
940
+         * Get the current Font Awesome output settings.
941
+         *
942
+         * @return array The array of settings.
943
+         */
944
+        public function get_settings() {
945
+
946
+            $db_settings = get_option( 'ayecode-ui-settings' );
947
+            $js_default = 'core-popper';
948
+            $js_default_backend = $js_default;
949
+
950
+            // maybe set defaults (if no settings set)
951
+            if(empty($db_settings)){
952
+                $active_theme = strtolower( get_template() ); // active parent theme.
953
+                $theme_js_settings = self::theme_js_settings();
954
+                if(isset($theme_js_settings[$active_theme])){
955
+                    $js_default = $theme_js_settings[$active_theme];
956
+                    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
957
+                }
958
+            }
959
+
960
+            $defaults = array(
961
+                'css'       => 'compatibility', // core, compatibility
962
+                'js'        => $js_default, // js to load, core-popper, popper
963
+                'html_font_size'        => '16', // js to load, core-popper, popper
964
+                'css_backend'       => 'compatibility', // core, compatibility
965
+                'js_backend'        => $js_default_backend, // js to load, core-popper, popper
966
+                'disable_admin'     =>  '', // URL snippets to disable loading on admin
967
+            );
968
+
969
+            $settings = wp_parse_args( $db_settings, $defaults );
970
+
971
+            /**
972
+             * Filter the Bootstrap settings.
973
+             *
974
+             * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
975
+             */
976
+            return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
977
+        }
978
+
979
+
980
+        /**
981
+         * The settings page html output.
982
+         */
983
+        public function settings_page() {
984
+            if ( ! current_user_can( 'manage_options' ) ) {
985
+                wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
986
+            }
987
+            ?>
988 988
 			<div class="wrap">
989 989
 				<h1><?php echo $this->name; ?></h1>
990 990
 				<p><?php _e("Here you can adjust settings if you are having compatibility issues.","aui");?></p>
991 991
 				<form method="post" action="options.php">
992 992
 					<?php
993
-					settings_fields( 'ayecode-ui-settings' );
994
-					do_settings_sections( 'ayecode-ui-settings' );
995
-					?>
993
+                    settings_fields( 'ayecode-ui-settings' );
994
+                    do_settings_sections( 'ayecode-ui-settings' );
995
+                    ?>
996 996
 
997 997
 					<h2><?php _e( 'Frontend', 'aui' ); ?></h2>
998 998
 					<table class="form-table wpbs-table-settings">
@@ -1072,60 +1072,60 @@  discard block
 block discarded – undo
1072 1072
 					</table>
1073 1073
 
1074 1074
 					<?php
1075
-					submit_button();
1076
-					?>
1075
+                    submit_button();
1076
+                    ?>
1077 1077
 				</form>
1078 1078
 
1079 1079
 				<div id="wpbs-version"><?php echo $this->version; ?></div>
1080 1080
 			</div>
1081 1081
 
1082 1082
 			<?php
1083
-		}
1084
-
1085
-		public function customizer_settings($wp_customize){
1086
-			$wp_customize->add_section('aui_settings', array(
1087
-				'title'    => __('AyeCode UI','aui'),
1088
-				'priority' => 120,
1089
-			));
1090
-
1091
-			//  =============================
1092
-			//  = Color Picker              =
1093
-			//  =============================
1094
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1095
-				'default'           => AUI_PRIMARY_COLOR,
1096
-				'sanitize_callback' => 'sanitize_hex_color',
1097
-				'capability'        => 'edit_theme_options',
1098
-				'type'              => 'option',
1099
-				'transport'         => 'refresh',
1100
-			));
1101
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1102
-				'label'    => __('Primary Color','aui'),
1103
-				'section'  => 'aui_settings',
1104
-				'settings' => 'aui_options[color_primary]',
1105
-			)));
1106
-
1107
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1108
-				'default'           => '#6c757d',
1109
-				'sanitize_callback' => 'sanitize_hex_color',
1110
-				'capability'        => 'edit_theme_options',
1111
-				'type'              => 'option',
1112
-				'transport'         => 'refresh',
1113
-			));
1114
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1115
-				'label'    => __('Secondary Color','aui'),
1116
-				'section'  => 'aui_settings',
1117
-				'settings' => 'aui_options[color_secondary]',
1118
-			)));
1119
-		}
1120
-
1121
-		/**
1122
-		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1123
-		 *
1124
-		 * @return mixed
1125
-		 */
1126
-		public static function bs3_compat_css() {
1127
-			ob_start();
1128
-			?>
1083
+        }
1084
+
1085
+        public function customizer_settings($wp_customize){
1086
+            $wp_customize->add_section('aui_settings', array(
1087
+                'title'    => __('AyeCode UI','aui'),
1088
+                'priority' => 120,
1089
+            ));
1090
+
1091
+            //  =============================
1092
+            //  = Color Picker              =
1093
+            //  =============================
1094
+            $wp_customize->add_setting('aui_options[color_primary]', array(
1095
+                'default'           => AUI_PRIMARY_COLOR,
1096
+                'sanitize_callback' => 'sanitize_hex_color',
1097
+                'capability'        => 'edit_theme_options',
1098
+                'type'              => 'option',
1099
+                'transport'         => 'refresh',
1100
+            ));
1101
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1102
+                'label'    => __('Primary Color','aui'),
1103
+                'section'  => 'aui_settings',
1104
+                'settings' => 'aui_options[color_primary]',
1105
+            )));
1106
+
1107
+            $wp_customize->add_setting('aui_options[color_secondary]', array(
1108
+                'default'           => '#6c757d',
1109
+                'sanitize_callback' => 'sanitize_hex_color',
1110
+                'capability'        => 'edit_theme_options',
1111
+                'type'              => 'option',
1112
+                'transport'         => 'refresh',
1113
+            ));
1114
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1115
+                'label'    => __('Secondary Color','aui'),
1116
+                'section'  => 'aui_settings',
1117
+                'settings' => 'aui_options[color_secondary]',
1118
+            )));
1119
+        }
1120
+
1121
+        /**
1122
+         * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1123
+         *
1124
+         * @return mixed
1125
+         */
1126
+        public static function bs3_compat_css() {
1127
+            ob_start();
1128
+            ?>
1129 1129
 			<style>
1130 1130
 			/* Bootstrap 3 compatibility */
1131 1131
 			body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1151,464 +1151,464 @@  discard block
 block discarded – undo
1151 1151
 			<?php } ?>
1152 1152
 			</style>
1153 1153
 			<?php
1154
-			return str_replace( array(
1155
-				'<style>',
1156
-				'</style>'
1157
-			), '', ob_get_clean());
1158
-		}
1154
+            return str_replace( array(
1155
+                '<style>',
1156
+                '</style>'
1157
+            ), '', ob_get_clean());
1158
+        }
1159 1159
 
1160 1160
 
1161
-		public static function custom_css($compatibility = true) {
1162
-			$settings = get_option('aui_options');
1161
+        public static function custom_css($compatibility = true) {
1162
+            $settings = get_option('aui_options');
1163 1163
 
1164
-			ob_start();
1164
+            ob_start();
1165 1165
 
1166
-			$primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1167
-			$secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1168
-				//AUI_PRIMARY_COLOR_ORIGINAL
1169
-			?>
1166
+            $primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1167
+            $secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1168
+                //AUI_PRIMARY_COLOR_ORIGINAL
1169
+            ?>
1170 1170
 			<style>
1171 1171
 				<?php
1172 1172
 
1173
-					// BS v3 compat
1174
-					if( self::is_bs3_compat() ){
1175
-					    echo self::bs3_compat_css();
1176
-					}
1173
+                    // BS v3 compat
1174
+                    if( self::is_bs3_compat() ){
1175
+                        echo self::bs3_compat_css();
1176
+                    }
1177 1177
 
1178
-					if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1179
-						echo self::css_primary($primary_color,$compatibility);
1180
-					}
1178
+                    if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1179
+                        echo self::css_primary($primary_color,$compatibility);
1180
+                    }
1181 1181
 
1182
-					if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1183
-						echo self::css_secondary($settings['color_secondary'],$compatibility);
1184
-					}
1182
+                    if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1183
+                        echo self::css_secondary($settings['color_secondary'],$compatibility);
1184
+                    }
1185 1185
                 ?>
1186 1186
 			</style>
1187 1187
 			<?php
1188 1188
 
1189 1189
 
1190
-			/*
1190
+            /*
1191 1191
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1192 1192
 			 */
1193
-			return str_replace( array(
1194
-				'<style>',
1195
-				'</style>'
1196
-			), '', ob_get_clean());
1197
-		}
1198
-
1199
-		/**
1200
-		 * Check if we should add booststrap 3 compatibility changes.
1201
-		 *
1202
-		 * @return bool
1203
-		 */
1204
-		public static function is_bs3_compat(){
1205
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1206
-		}
1207
-
1208
-		public static function css_primary($color_code,$compatibility){;
1209
-			$color_code = sanitize_hex_color($color_code);
1210
-			if(!$color_code){return '';}
1211
-			/**
1212
-			 * c = color, b = background color, o = border-color, f = fill
1213
-			 */
1214
-			$selectors = array(
1215
-				'a' => array('c'),
1216
-				'.btn-primary' => array('b','o'),
1217
-				'.btn-primary.disabled' => array('b','o'),
1218
-				'.btn-primary:disabled' => array('b','o'),
1219
-				'.btn-outline-primary' => array('c','o'),
1220
-				'.btn-outline-primary:hover' => array('b','o'),
1221
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1222
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1223
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1224
-				'.btn-link' => array('c'),
1225
-				'.dropdown-item.active' => array('b'),
1226
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1227
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1193
+            return str_replace( array(
1194
+                '<style>',
1195
+                '</style>'
1196
+            ), '', ob_get_clean());
1197
+        }
1198
+
1199
+        /**
1200
+         * Check if we should add booststrap 3 compatibility changes.
1201
+         *
1202
+         * @return bool
1203
+         */
1204
+        public static function is_bs3_compat(){
1205
+            return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1206
+        }
1207
+
1208
+        public static function css_primary($color_code,$compatibility){;
1209
+            $color_code = sanitize_hex_color($color_code);
1210
+            if(!$color_code){return '';}
1211
+            /**
1212
+             * c = color, b = background color, o = border-color, f = fill
1213
+             */
1214
+            $selectors = array(
1215
+                'a' => array('c'),
1216
+                '.btn-primary' => array('b','o'),
1217
+                '.btn-primary.disabled' => array('b','o'),
1218
+                '.btn-primary:disabled' => array('b','o'),
1219
+                '.btn-outline-primary' => array('c','o'),
1220
+                '.btn-outline-primary:hover' => array('b','o'),
1221
+                '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1222
+                '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1223
+                '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1224
+                '.btn-link' => array('c'),
1225
+                '.dropdown-item.active' => array('b'),
1226
+                '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1227
+                '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1228 1228
 //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1229 1229
 //				'.custom-range::-moz-range-thumb' => array('b'),
1230 1230
 //				'.custom-range::-ms-thumb' => array('b'),
1231
-				'.nav-pills .nav-link.active' => array('b'),
1232
-				'.nav-pills .show>.nav-link' => array('b'),
1233
-				'.page-link' => array('c'),
1234
-				'.page-item.active .page-link' => array('b','o'),
1235
-				'.badge-primary' => array('b'),
1236
-				'.alert-primary' => array('b','o'),
1237
-				'.progress-bar' => array('b'),
1238
-				'.list-group-item.active' => array('b','o'),
1239
-				'.bg-primary' => array('b','f'),
1240
-				'.btn-link.btn-primary' => array('c'),
1241
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1242
-			);
1243
-
1244
-			$important_selectors = array(
1245
-				'.bg-primary' => array('b','f'),
1246
-				'.border-primary' => array('o'),
1247
-				'.text-primary' => array('c'),
1248
-			);
1249
-
1250
-			$color = array();
1251
-			$color_i = array();
1252
-			$background = array();
1253
-			$background_i = array();
1254
-			$border = array();
1255
-			$border_i = array();
1256
-			$fill = array();
1257
-			$fill_i = array();
1258
-
1259
-			$output = '';
1260
-
1261
-			// build rules into each type
1262
-			foreach($selectors as $selector => $types){
1263
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1264
-				$types = array_combine($types,$types);
1265
-				if(isset($types['c'])){$color[] = $selector;}
1266
-				if(isset($types['b'])){$background[] = $selector;}
1267
-				if(isset($types['o'])){$border[] = $selector;}
1268
-				if(isset($types['f'])){$fill[] = $selector;}
1269
-			}
1270
-
1271
-			// build rules into each type
1272
-			foreach($important_selectors as $selector => $types){
1273
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1274
-				$types = array_combine($types,$types);
1275
-				if(isset($types['c'])){$color_i[] = $selector;}
1276
-				if(isset($types['b'])){$background_i[] = $selector;}
1277
-				if(isset($types['o'])){$border_i[] = $selector;}
1278
-				if(isset($types['f'])){$fill_i[] = $selector;}
1279
-			}
1280
-
1281
-			// add any color rules
1282
-			if(!empty($color)){
1283
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1284
-			}
1285
-			if(!empty($color_i)){
1286
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1287
-			}
1288
-
1289
-			// add any background color rules
1290
-			if(!empty($background)){
1291
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1292
-			}
1293
-			if(!empty($background_i)){
1294
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1295
-			}
1296
-
1297
-			// add any border color rules
1298
-			if(!empty($border)){
1299
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1300
-			}
1301
-			if(!empty($border_i)){
1302
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1303
-			}
1304
-
1305
-			// add any fill color rules
1306
-			if(!empty($fill)){
1307
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1308
-			}
1309
-			if(!empty($fill_i)){
1310
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1311
-			}
1312
-
1313
-
1314
-			$prefix = $compatibility ? ".bsui " : "";
1315
-
1316
-			// darken
1317
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1318
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1319
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1320
-
1321
-			// lighten
1322
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1323
-
1324
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1325
-			$op_25 = $color_code."40"; // 25% opacity
1326
-
1327
-
1328
-			// button states
1329
-			$output .= $prefix ." .btn-primary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1330
-			$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;} ";
1331
-			$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.";} ";
1332
-			$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;} ";
1333
-
1334
-
1335
-			// dropdown's
1336
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1337
-
1338
-
1339
-			// input states
1340
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1341
-
1342
-			// page link
1343
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1344
-
1345
-			return $output;
1346
-		}
1347
-
1348
-		public static function css_secondary($color_code,$compatibility){;
1349
-			$color_code = sanitize_hex_color($color_code);
1350
-			if(!$color_code){return '';}
1351
-			/**
1352
-			 * c = color, b = background color, o = border-color, f = fill
1353
-			 */
1354
-			$selectors = array(
1355
-				'.btn-secondary' => array('b','o'),
1356
-				'.btn-secondary.disabled' => array('b','o'),
1357
-				'.btn-secondary:disabled' => array('b','o'),
1358
-				'.btn-outline-secondary' => array('c','o'),
1359
-				'.btn-outline-secondary:hover' => array('b','o'),
1360
-				'.btn-outline-secondary.disabled' => array('c'),
1361
-				'.btn-outline-secondary:disabled' => array('c'),
1362
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1363
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1364
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1365
-				'.badge-secondary' => array('b'),
1366
-				'.alert-secondary' => array('b','o'),
1367
-				'.btn-link.btn-secondary' => array('c'),
1368
-			);
1369
-
1370
-			$important_selectors = array(
1371
-				'.bg-secondary' => array('b','f'),
1372
-				'.border-secondary' => array('o'),
1373
-				'.text-secondary' => array('c'),
1374
-			);
1375
-
1376
-			$color = array();
1377
-			$color_i = array();
1378
-			$background = array();
1379
-			$background_i = array();
1380
-			$border = array();
1381
-			$border_i = array();
1382
-			$fill = array();
1383
-			$fill_i = array();
1384
-
1385
-			$output = '';
1386
-
1387
-			// build rules into each type
1388
-			foreach($selectors as $selector => $types){
1389
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1390
-				$types = array_combine($types,$types);
1391
-				if(isset($types['c'])){$color[] = $selector;}
1392
-				if(isset($types['b'])){$background[] = $selector;}
1393
-				if(isset($types['o'])){$border[] = $selector;}
1394
-				if(isset($types['f'])){$fill[] = $selector;}
1395
-			}
1396
-
1397
-			// build rules into each type
1398
-			foreach($important_selectors as $selector => $types){
1399
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1400
-				$types = array_combine($types,$types);
1401
-				if(isset($types['c'])){$color_i[] = $selector;}
1402
-				if(isset($types['b'])){$background_i[] = $selector;}
1403
-				if(isset($types['o'])){$border_i[] = $selector;}
1404
-				if(isset($types['f'])){$fill_i[] = $selector;}
1405
-			}
1406
-
1407
-			// add any color rules
1408
-			if(!empty($color)){
1409
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1410
-			}
1411
-			if(!empty($color_i)){
1412
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1413
-			}
1414
-
1415
-			// add any background color rules
1416
-			if(!empty($background)){
1417
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1418
-			}
1419
-			if(!empty($background_i)){
1420
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1421
-			}
1422
-
1423
-			// add any border color rules
1424
-			if(!empty($border)){
1425
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1426
-			}
1427
-			if(!empty($border_i)){
1428
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1429
-			}
1430
-
1431
-			// add any fill color rules
1432
-			if(!empty($fill)){
1433
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1434
-			}
1435
-			if(!empty($fill_i)){
1436
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1437
-			}
1438
-
1439
-
1440
-			$prefix = $compatibility ? ".bsui " : "";
1441
-
1442
-			// darken
1443
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1444
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1445
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1446
-
1447
-			// lighten
1448
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1449
-
1450
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1451
-			$op_25 = $color_code."40"; // 25% opacity
1452
-
1453
-
1454
-			// button states
1455
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1456
-			$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;} ";
1457
-			$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.";} ";
1458
-			$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;} ";
1459
-
1460
-
1461
-			return $output;
1462
-		}
1463
-
1464
-		/**
1465
-		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
1466
-		 *
1467
-		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1468
-		 * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1469
-		 *
1470
-		 * @return  string
1471
-		 */
1472
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1473
-			$hexCode = ltrim($hexCode, '#');
1474
-
1475
-			if (strlen($hexCode) == 3) {
1476
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1477
-			}
1478
-
1479
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
1480
-
1481
-			foreach ($hexCode as & $color) {
1482
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1483
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
1484
-
1485
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1486
-			}
1487
-
1488
-			return '#' . implode($hexCode);
1489
-		}
1490
-
1491
-		/**
1492
-		 * Check if we should display examples.
1493
-		 */
1494
-		public function maybe_show_examples(){
1495
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1496
-				echo "<head>";
1497
-				wp_head();
1498
-				echo "</head>";
1499
-				echo "<body>";
1500
-				echo $this->get_examples();
1501
-				echo "</body>";
1502
-				exit;
1503
-			}
1504
-		}
1505
-
1506
-		/**
1507
-		 * Get developer examples.
1508
-		 *
1509
-		 * @return string
1510
-		 */
1511
-		public function get_examples(){
1512
-			$output = '';
1513
-
1514
-
1515
-			// open form
1516
-			$output .= "<form class='p-5 m-5 border rounded'>";
1517
-
1518
-			// input example
1519
-			$output .= aui()->input(array(
1520
-				'type'  =>  'text',
1521
-				'id'    =>  'text-example',
1522
-				'name'    =>  'text-example',
1523
-				'placeholder'   => 'text placeholder',
1524
-				'title'   => 'Text input example',
1525
-				'value' =>  '',
1526
-				'required'  => false,
1527
-				'help_text' => 'help text',
1528
-				'label' => 'Text input example label'
1529
-			));
1530
-
1531
-			// input example
1532
-			$output .= aui()->input(array(
1533
-				'type'  =>  'url',
1534
-				'id'    =>  'text-example2',
1535
-				'name'    =>  'text-example',
1536
-				'placeholder'   => 'url placeholder',
1537
-				'title'   => 'Text input example',
1538
-				'value' =>  '',
1539
-				'required'  => false,
1540
-				'help_text' => 'help text',
1541
-				'label' => 'Text input example label'
1542
-			));
1543
-
1544
-			// checkbox example
1545
-			$output .= aui()->input(array(
1546
-				'type'  =>  'checkbox',
1547
-				'id'    =>  'checkbox-example',
1548
-				'name'    =>  'checkbox-example',
1549
-				'placeholder'   => 'checkbox-example',
1550
-				'title'   => 'Checkbox example',
1551
-				'value' =>  '1',
1552
-				'checked'   => true,
1553
-				'required'  => false,
1554
-				'help_text' => 'help text',
1555
-				'label' => 'Checkbox checked'
1556
-			));
1557
-
1558
-			// checkbox example
1559
-			$output .= aui()->input(array(
1560
-				'type'  =>  'checkbox',
1561
-				'id'    =>  'checkbox-example2',
1562
-				'name'    =>  'checkbox-example2',
1563
-				'placeholder'   => 'checkbox-example',
1564
-				'title'   => 'Checkbox example',
1565
-				'value' =>  '1',
1566
-				'checked'   => false,
1567
-				'required'  => false,
1568
-				'help_text' => 'help text',
1569
-				'label' => 'Checkbox un-checked'
1570
-			));
1571
-
1572
-			// switch example
1573
-			$output .= aui()->input(array(
1574
-				'type'  =>  'checkbox',
1575
-				'id'    =>  'switch-example',
1576
-				'name'    =>  'switch-example',
1577
-				'placeholder'   => 'checkbox-example',
1578
-				'title'   => 'Switch example',
1579
-				'value' =>  '1',
1580
-				'checked'   => true,
1581
-				'switch'    => true,
1582
-				'required'  => false,
1583
-				'help_text' => 'help text',
1584
-				'label' => 'Switch on'
1585
-			));
1586
-
1587
-			// switch example
1588
-			$output .= aui()->input(array(
1589
-				'type'  =>  'checkbox',
1590
-				'id'    =>  'switch-example2',
1591
-				'name'    =>  'switch-example2',
1592
-				'placeholder'   => 'checkbox-example',
1593
-				'title'   => 'Switch example',
1594
-				'value' =>  '1',
1595
-				'checked'   => false,
1596
-				'switch'    => true,
1597
-				'required'  => false,
1598
-				'help_text' => 'help text',
1599
-				'label' => 'Switch off'
1600
-			));
1601
-
1602
-			// close form
1603
-			$output .= "</form>";
1604
-
1605
-			return $output;
1606
-		}
1607
-
1608
-	}
1609
-
1610
-	/**
1611
-	 * Run the class if found.
1612
-	 */
1613
-	AyeCode_UI_Settings::instance();
1231
+                '.nav-pills .nav-link.active' => array('b'),
1232
+                '.nav-pills .show>.nav-link' => array('b'),
1233
+                '.page-link' => array('c'),
1234
+                '.page-item.active .page-link' => array('b','o'),
1235
+                '.badge-primary' => array('b'),
1236
+                '.alert-primary' => array('b','o'),
1237
+                '.progress-bar' => array('b'),
1238
+                '.list-group-item.active' => array('b','o'),
1239
+                '.bg-primary' => array('b','f'),
1240
+                '.btn-link.btn-primary' => array('c'),
1241
+                '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1242
+            );
1243
+
1244
+            $important_selectors = array(
1245
+                '.bg-primary' => array('b','f'),
1246
+                '.border-primary' => array('o'),
1247
+                '.text-primary' => array('c'),
1248
+            );
1249
+
1250
+            $color = array();
1251
+            $color_i = array();
1252
+            $background = array();
1253
+            $background_i = array();
1254
+            $border = array();
1255
+            $border_i = array();
1256
+            $fill = array();
1257
+            $fill_i = array();
1258
+
1259
+            $output = '';
1260
+
1261
+            // build rules into each type
1262
+            foreach($selectors as $selector => $types){
1263
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1264
+                $types = array_combine($types,$types);
1265
+                if(isset($types['c'])){$color[] = $selector;}
1266
+                if(isset($types['b'])){$background[] = $selector;}
1267
+                if(isset($types['o'])){$border[] = $selector;}
1268
+                if(isset($types['f'])){$fill[] = $selector;}
1269
+            }
1270
+
1271
+            // build rules into each type
1272
+            foreach($important_selectors as $selector => $types){
1273
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1274
+                $types = array_combine($types,$types);
1275
+                if(isset($types['c'])){$color_i[] = $selector;}
1276
+                if(isset($types['b'])){$background_i[] = $selector;}
1277
+                if(isset($types['o'])){$border_i[] = $selector;}
1278
+                if(isset($types['f'])){$fill_i[] = $selector;}
1279
+            }
1280
+
1281
+            // add any color rules
1282
+            if(!empty($color)){
1283
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1284
+            }
1285
+            if(!empty($color_i)){
1286
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1287
+            }
1288
+
1289
+            // add any background color rules
1290
+            if(!empty($background)){
1291
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1292
+            }
1293
+            if(!empty($background_i)){
1294
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1295
+            }
1296
+
1297
+            // add any border color rules
1298
+            if(!empty($border)){
1299
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1300
+            }
1301
+            if(!empty($border_i)){
1302
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1303
+            }
1304
+
1305
+            // add any fill color rules
1306
+            if(!empty($fill)){
1307
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1308
+            }
1309
+            if(!empty($fill_i)){
1310
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1311
+            }
1312
+
1313
+
1314
+            $prefix = $compatibility ? ".bsui " : "";
1315
+
1316
+            // darken
1317
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1318
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1319
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1320
+
1321
+            // lighten
1322
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1323
+
1324
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1325
+            $op_25 = $color_code."40"; // 25% opacity
1326
+
1327
+
1328
+            // button states
1329
+            $output .= $prefix ." .btn-primary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1330
+            $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;} ";
1331
+            $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.";} ";
1332
+            $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;} ";
1333
+
1334
+
1335
+            // dropdown's
1336
+            $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1337
+
1338
+
1339
+            // input states
1340
+            $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1341
+
1342
+            // page link
1343
+            $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1344
+
1345
+            return $output;
1346
+        }
1347
+
1348
+        public static function css_secondary($color_code,$compatibility){;
1349
+            $color_code = sanitize_hex_color($color_code);
1350
+            if(!$color_code){return '';}
1351
+            /**
1352
+             * c = color, b = background color, o = border-color, f = fill
1353
+             */
1354
+            $selectors = array(
1355
+                '.btn-secondary' => array('b','o'),
1356
+                '.btn-secondary.disabled' => array('b','o'),
1357
+                '.btn-secondary:disabled' => array('b','o'),
1358
+                '.btn-outline-secondary' => array('c','o'),
1359
+                '.btn-outline-secondary:hover' => array('b','o'),
1360
+                '.btn-outline-secondary.disabled' => array('c'),
1361
+                '.btn-outline-secondary:disabled' => array('c'),
1362
+                '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1363
+                '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1364
+                '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1365
+                '.badge-secondary' => array('b'),
1366
+                '.alert-secondary' => array('b','o'),
1367
+                '.btn-link.btn-secondary' => array('c'),
1368
+            );
1369
+
1370
+            $important_selectors = array(
1371
+                '.bg-secondary' => array('b','f'),
1372
+                '.border-secondary' => array('o'),
1373
+                '.text-secondary' => array('c'),
1374
+            );
1375
+
1376
+            $color = array();
1377
+            $color_i = array();
1378
+            $background = array();
1379
+            $background_i = array();
1380
+            $border = array();
1381
+            $border_i = array();
1382
+            $fill = array();
1383
+            $fill_i = array();
1384
+
1385
+            $output = '';
1386
+
1387
+            // build rules into each type
1388
+            foreach($selectors as $selector => $types){
1389
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1390
+                $types = array_combine($types,$types);
1391
+                if(isset($types['c'])){$color[] = $selector;}
1392
+                if(isset($types['b'])){$background[] = $selector;}
1393
+                if(isset($types['o'])){$border[] = $selector;}
1394
+                if(isset($types['f'])){$fill[] = $selector;}
1395
+            }
1396
+
1397
+            // build rules into each type
1398
+            foreach($important_selectors as $selector => $types){
1399
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1400
+                $types = array_combine($types,$types);
1401
+                if(isset($types['c'])){$color_i[] = $selector;}
1402
+                if(isset($types['b'])){$background_i[] = $selector;}
1403
+                if(isset($types['o'])){$border_i[] = $selector;}
1404
+                if(isset($types['f'])){$fill_i[] = $selector;}
1405
+            }
1406
+
1407
+            // add any color rules
1408
+            if(!empty($color)){
1409
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1410
+            }
1411
+            if(!empty($color_i)){
1412
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1413
+            }
1414
+
1415
+            // add any background color rules
1416
+            if(!empty($background)){
1417
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1418
+            }
1419
+            if(!empty($background_i)){
1420
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1421
+            }
1422
+
1423
+            // add any border color rules
1424
+            if(!empty($border)){
1425
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1426
+            }
1427
+            if(!empty($border_i)){
1428
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1429
+            }
1430
+
1431
+            // add any fill color rules
1432
+            if(!empty($fill)){
1433
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1434
+            }
1435
+            if(!empty($fill_i)){
1436
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1437
+            }
1438
+
1439
+
1440
+            $prefix = $compatibility ? ".bsui " : "";
1441
+
1442
+            // darken
1443
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1444
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1445
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1446
+
1447
+            // lighten
1448
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1449
+
1450
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1451
+            $op_25 = $color_code."40"; // 25% opacity
1452
+
1453
+
1454
+            // button states
1455
+            $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1456
+            $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;} ";
1457
+            $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.";} ";
1458
+            $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;} ";
1459
+
1460
+
1461
+            return $output;
1462
+        }
1463
+
1464
+        /**
1465
+         * Increases or decreases the brightness of a color by a percentage of the current brightness.
1466
+         *
1467
+         * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1468
+         * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1469
+         *
1470
+         * @return  string
1471
+         */
1472
+        public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1473
+            $hexCode = ltrim($hexCode, '#');
1474
+
1475
+            if (strlen($hexCode) == 3) {
1476
+                $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1477
+            }
1478
+
1479
+            $hexCode = array_map('hexdec', str_split($hexCode, 2));
1480
+
1481
+            foreach ($hexCode as & $color) {
1482
+                $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1483
+                $adjustAmount = ceil($adjustableLimit * $adjustPercent);
1484
+
1485
+                $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1486
+            }
1487
+
1488
+            return '#' . implode($hexCode);
1489
+        }
1490
+
1491
+        /**
1492
+         * Check if we should display examples.
1493
+         */
1494
+        public function maybe_show_examples(){
1495
+            if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1496
+                echo "<head>";
1497
+                wp_head();
1498
+                echo "</head>";
1499
+                echo "<body>";
1500
+                echo $this->get_examples();
1501
+                echo "</body>";
1502
+                exit;
1503
+            }
1504
+        }
1505
+
1506
+        /**
1507
+         * Get developer examples.
1508
+         *
1509
+         * @return string
1510
+         */
1511
+        public function get_examples(){
1512
+            $output = '';
1513
+
1514
+
1515
+            // open form
1516
+            $output .= "<form class='p-5 m-5 border rounded'>";
1517
+
1518
+            // input example
1519
+            $output .= aui()->input(array(
1520
+                'type'  =>  'text',
1521
+                'id'    =>  'text-example',
1522
+                'name'    =>  'text-example',
1523
+                'placeholder'   => 'text placeholder',
1524
+                'title'   => 'Text input example',
1525
+                'value' =>  '',
1526
+                'required'  => false,
1527
+                'help_text' => 'help text',
1528
+                'label' => 'Text input example label'
1529
+            ));
1530
+
1531
+            // input example
1532
+            $output .= aui()->input(array(
1533
+                'type'  =>  'url',
1534
+                'id'    =>  'text-example2',
1535
+                'name'    =>  'text-example',
1536
+                'placeholder'   => 'url placeholder',
1537
+                'title'   => 'Text input example',
1538
+                'value' =>  '',
1539
+                'required'  => false,
1540
+                'help_text' => 'help text',
1541
+                'label' => 'Text input example label'
1542
+            ));
1543
+
1544
+            // checkbox example
1545
+            $output .= aui()->input(array(
1546
+                'type'  =>  'checkbox',
1547
+                'id'    =>  'checkbox-example',
1548
+                'name'    =>  'checkbox-example',
1549
+                'placeholder'   => 'checkbox-example',
1550
+                'title'   => 'Checkbox example',
1551
+                'value' =>  '1',
1552
+                'checked'   => true,
1553
+                'required'  => false,
1554
+                'help_text' => 'help text',
1555
+                'label' => 'Checkbox checked'
1556
+            ));
1557
+
1558
+            // checkbox example
1559
+            $output .= aui()->input(array(
1560
+                'type'  =>  'checkbox',
1561
+                'id'    =>  'checkbox-example2',
1562
+                'name'    =>  'checkbox-example2',
1563
+                'placeholder'   => 'checkbox-example',
1564
+                'title'   => 'Checkbox example',
1565
+                'value' =>  '1',
1566
+                'checked'   => false,
1567
+                'required'  => false,
1568
+                'help_text' => 'help text',
1569
+                'label' => 'Checkbox un-checked'
1570
+            ));
1571
+
1572
+            // switch example
1573
+            $output .= aui()->input(array(
1574
+                'type'  =>  'checkbox',
1575
+                'id'    =>  'switch-example',
1576
+                'name'    =>  'switch-example',
1577
+                'placeholder'   => 'checkbox-example',
1578
+                'title'   => 'Switch example',
1579
+                'value' =>  '1',
1580
+                'checked'   => true,
1581
+                'switch'    => true,
1582
+                'required'  => false,
1583
+                'help_text' => 'help text',
1584
+                'label' => 'Switch on'
1585
+            ));
1586
+
1587
+            // switch example
1588
+            $output .= aui()->input(array(
1589
+                'type'  =>  'checkbox',
1590
+                'id'    =>  'switch-example2',
1591
+                'name'    =>  'switch-example2',
1592
+                'placeholder'   => 'checkbox-example',
1593
+                'title'   => 'Switch example',
1594
+                'value' =>  '1',
1595
+                'checked'   => false,
1596
+                'switch'    => true,
1597
+                'required'  => false,
1598
+                'help_text' => 'help text',
1599
+                'label' => 'Switch off'
1600
+            ));
1601
+
1602
+            // close form
1603
+            $output .= "</form>";
1604
+
1605
+            return $output;
1606
+        }
1607
+
1608
+    }
1609
+
1610
+    /**
1611
+     * Run the class if found.
1612
+     */
1613
+    AyeCode_UI_Settings::instance();
1614 1614
 }
1615 1615
\ No newline at end of file
Please login to merge, or discard this patch.