Passed
Push — master ( b57ad0...153405 )
by Brian
04:24
created
ayecode/wp-ayecode-ui/includes/components/class-aui-component-input.php 1 patch
Indentation   +1021 added lines, -1021 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,1031 +11,1031 @@  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="'.esc_attr($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
-		// Set hidden input to save empty value for multiselect.
705
-		if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
706
-			$output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
707
-		}
708
-
709
-		// open/type
710
-		$output .= '<select ';
711
-
712
-		// style
713
-		if($is_select2){
714
-			$output .= " style='width:100%;' ";
715
-		}
716
-
717
-		// element require
718
-		if(!empty($args['element_require'])){
719
-			$output .= AUI_Component_Helper::element_require($args['element_require']);
720
-			$args['class'] .= " aui-conditional-field";
721
-		}
722
-
723
-		// class
724
-		$class = !empty($args['class']) ? $args['class'] : '';
725
-		$output .= AUI_Component_Helper::class_attr('custom-select '.$class);
726
-
727
-		// name
728
-		if(!empty($args['name'])){
729
-			$output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
730
-		}
731
-
732
-		// id
733
-		if(!empty($args['id'])){
734
-			$output .= AUI_Component_Helper::id($args['id']);
735
-		}
736
-
737
-		// title
738
-		if(!empty($args['title'])){
739
-			$output .= AUI_Component_Helper::title($args['title']);
740
-		}
741
-
742
-		// data-attributes
743
-		$output .= AUI_Component_Helper::data_attributes($args);
744
-
745
-		// aria-attributes
746
-		$output .= AUI_Component_Helper::aria_attributes($args);
747
-
748
-		// extra attributes
749
-		if(!empty($args['extra_attributes'])){
750
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
751
-		}
752
-
753
-		// required
754
-		if(!empty($args['required'])){
755
-			$output .= ' required ';
756
-		}
757
-
758
-		// multiple
759
-		if(!empty($args['multiple'])){
760
-			$output .= ' multiple ';
761
-		}
762
-
763
-		// close opening tag
764
-		$output .= ' >';
765
-
766
-		// placeholder
767
-		if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
768
-			$output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
769
-		}elseif($is_select2 && !empty($args['placeholder'])){
770
-			$output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
771
-		}
772
-
773
-		// Options
774
-		if(!empty($args['options'])){
775
-
776
-			if(!is_array($args['options'])){
777
-				$output .= $args['options']; // not the preferred way but an option
778
-			}else{
779
-				foreach($args['options'] as $val => $name){
780
-					$selected = '';
781
-					if(is_array($name)){
782
-						if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
783
-							$option_label = isset($name['label']) ? $name['label'] : '';
784
-
785
-							$output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
786
-						} else {
787
-							$option_label = isset($name['label']) ? $name['label'] : '';
788
-							$option_value = isset($name['value']) ? $name['value'] : '';
789
-							if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
790
-								$selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
791
-							} elseif(!empty($args['value'])) {
792
-								$selected = selected($option_value,stripslashes_deep($args['value']), false);
793
-							}
794
-
795
-							$output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
796
-						}
797
-					}else{
798
-						if(!empty($args['value'])){
799
-							if(is_array($args['value'])){
800
-								$selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
801
-							} elseif(!empty($args['value'])) {
802
-								$selected = selected( $args['value'], $val, false);
803
-							}
804
-						}
805
-						$output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
806
-					}
807
-				}
808
-			}
809
-
810
-		}
811
-
812
-		// closing tag
813
-		$output .= '</select>';
814
-
815
-		if(!empty($args['label']) && $label_after){
816
-			$label_args = array(
817
-				'title'=> $args['label'],
818
-				'for'=> $args['id'],
819
-				'class' => $args['label_class']." ",
820
-				'label_type' => $args['label_type']
821
-			);
822
-			$output .= self::label($label_args);
823
-		}
824
-
825
-		// help text
826
-		if(!empty($args['help_text'])){
827
-			$output .= AUI_Component_Helper::help_text($args['help_text']);
828
-		}
829
-
830
-		// maybe horizontal label
831
-		if($args['label_type']=='horizontal'){
832
-			$output .= '</div>';
833
-		}
834
-
835
-
836
-		// wrap
837
-		if(!$args['no_wrap']){
838
-			$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
839
-			$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
840
-			$output = self::wrap(array(
841
-				'content' => $output,
842
-				'class'   => $wrap_class,
843
-				'element_require'   => $args['element_require'],
844
-				'argument_id'  => $args['id']
845
-			));
846
-		}
847
-
848
-
849
-		return $output;
850
-	}
851
-
852
-	/**
853
-	 * Build the component.
854
-	 *
855
-	 * @param array $args
856
-	 *
857
-	 * @return string The rendered component.
858
-	 */
859
-	public static function radio($args = array()){
860
-		$defaults = array(
861
-			'class'      => '',
862
-			'wrap_class' => '',
863
-			'id'         => '',
864
-			'title'      => '',
865
-			'horizontal' => false, // sets the lable horizontal
866
-			'value'      => '',
867
-			'label'      => '',
868
-			'label_class'=> '',
869
-			'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
870
-			'help_text'  => '',
871
-			'inline'     => true,
872
-			'required'   => false,
873
-			'options'    => array(),
874
-			'icon'       => '',
875
-			'no_wrap'    => false,
876
-			'element_require'   => '', // [%element_id%] == "1"
877
-			'extra_attributes'  => array() // an array of extra attributes
878
-		);
879
-
880
-		/**
881
-		 * Parse incoming $args into an array and merge it with $defaults
882
-		 */
883
-		$args   = wp_parse_args( $args, $defaults );
884
-
885
-		// for now lets use horizontal for floating
886
-		if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
887
-
888
-		$label_args = array(
889
-			'title'=> $args['label'],
890
-			'class' => $args['label_class']." pt-0 ",
891
-			'label_type' => $args['label_type']
892
-		);
893
-
894
-		$output = '';
895
-
896
-
897
-
898
-		// label before
899
-		if(!empty($args['label'])){
900
-			$output .= self::label( $label_args, 'radio' );
901
-		}
902
-
903
-		// maybe horizontal label
904
-		if($args['label_type']=='horizontal'){
905
-			$output .= '<div class="col-sm-10">';
906
-		}
907
-
908
-		if(!empty($args['options'])){
909
-			$count = 0;
910
-			foreach($args['options'] as $value => $label){
911
-				$option_args = $args;
912
-				$option_args['value'] = $value;
913
-				$option_args['label'] = $label;
914
-				$option_args['checked'] = $value == $args['value'] ? true : false;
915
-				$output .= self::radio_option($option_args,$count);
916
-				$count++;
917
-			}
918
-		}
919
-
920
-		// help text
921
-		$help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
922
-		$output .= $help_text;
923
-
924
-		// maybe horizontal label
925
-		if($args['label_type']=='horizontal'){
926
-			$output .= '</div>';
927
-		}
928
-
929
-		// wrap
930
-		$wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
931
-		$wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
932
-		$output = self::wrap(array(
933
-			'content' => $output,
934
-			'class'   => $wrap_class,
935
-			'element_require'   => $args['element_require'],
936
-			'argument_id'  => $args['id']
937
-		));
938
-
939
-
940
-		return $output;
941
-	}
942
-
943
-	/**
944
-	 * Build the component.
945
-	 *
946
-	 * @param array $args
947
-	 *
948
-	 * @return string The rendered component.
949
-	 */
950
-	public static function radio_option($args = array(),$count = ''){
951
-		$defaults = array(
952
-			'class'      => '',
953
-			'id'         => '',
954
-			'title'      => '',
955
-			'value'      => '',
956
-			'required'   => false,
957
-			'inline'     => true,
958
-			'label'      => '',
959
-			'options'    => array(),
960
-			'icon'       => '',
961
-			'no_wrap'    => false,
962
-			'extra_attributes'  => array() // an array of extra attributes
963
-		);
964
-
965
-		/**
966
-		 * Parse incoming $args into an array and merge it with $defaults
967
-		 */
968
-		$args   = wp_parse_args( $args, $defaults );
969
-
970
-		$output = '';
971
-
972
-		// open/type
973
-		$output .= '<input type="radio"';
974
-
975
-		// class
976
-		$output .= ' class="form-check-input" ';
977
-
978
-		// name
979
-		if(!empty($args['name'])){
980
-			$output .= AUI_Component_Helper::name($args['name']);
981
-		}
982
-
983
-		// id
984
-		if(!empty($args['id'])){
985
-			$output .= AUI_Component_Helper::id($args['id'].$count);
986
-		}
987
-
988
-		// title
989
-		if(!empty($args['title'])){
990
-			$output .= AUI_Component_Helper::title($args['title']);
991
-		}
992
-
993
-		// value
994
-		if(isset($args['value'])){
995
-			$output .= ' value="'.sanitize_text_field($args['value']).'" ';
996
-		}
997
-
998
-		// checked, for radio and checkboxes
999
-		if( $args['checked'] ){
1000
-			$output .= ' checked ';
1001
-		}
1002
-
1003
-		// data-attributes
1004
-		$output .= AUI_Component_Helper::data_attributes($args);
1005
-
1006
-		// aria-attributes
1007
-		$output .= AUI_Component_Helper::aria_attributes($args);
1008
-
1009
-		// extra attributes
1010
-		if(!empty($args['extra_attributes'])){
1011
-			$output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1012
-		}
1013
-
1014
-		// required
1015
-		if(!empty($args['required'])){
1016
-			$output .= ' required ';
1017
-		}
1018
-
1019
-		// close opening tag
1020
-		$output .= ' >';
1021
-
1022
-		// label
1023
-		if(!empty($args['label']) && is_array($args['label'])){
1024
-		}elseif(!empty($args['label'])){
1025
-			$output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1026
-		}
1027
-
1028
-		// wrap
1029
-		if(!$args['no_wrap']){
1030
-			$wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1031
-			$output = self::wrap(array(
1032
-				'content' => $output,
1033
-				'class' => $wrap_class
1034
-			));
1035
-		}
1036
-
1037
-
1038
-		return $output;
1039
-	}
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="'.esc_attr($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
+        // Set hidden input to save empty value for multiselect.
705
+        if ( ! empty( $args['multiple'] ) && ! empty( $args['name'] ) ) {
706
+            $output .= '<input type="hidden" ' . AUI_Component_Helper::name( $args['name'] ) . ' value=""/>';
707
+        }
708
+
709
+        // open/type
710
+        $output .= '<select ';
711
+
712
+        // style
713
+        if($is_select2){
714
+            $output .= " style='width:100%;' ";
715
+        }
716
+
717
+        // element require
718
+        if(!empty($args['element_require'])){
719
+            $output .= AUI_Component_Helper::element_require($args['element_require']);
720
+            $args['class'] .= " aui-conditional-field";
721
+        }
722
+
723
+        // class
724
+        $class = !empty($args['class']) ? $args['class'] : '';
725
+        $output .= AUI_Component_Helper::class_attr('custom-select '.$class);
726
+
727
+        // name
728
+        if(!empty($args['name'])){
729
+            $output .= AUI_Component_Helper::name($args['name'],$args['multiple']);
730
+        }
731
+
732
+        // id
733
+        if(!empty($args['id'])){
734
+            $output .= AUI_Component_Helper::id($args['id']);
735
+        }
736
+
737
+        // title
738
+        if(!empty($args['title'])){
739
+            $output .= AUI_Component_Helper::title($args['title']);
740
+        }
741
+
742
+        // data-attributes
743
+        $output .= AUI_Component_Helper::data_attributes($args);
744
+
745
+        // aria-attributes
746
+        $output .= AUI_Component_Helper::aria_attributes($args);
747
+
748
+        // extra attributes
749
+        if(!empty($args['extra_attributes'])){
750
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
751
+        }
752
+
753
+        // required
754
+        if(!empty($args['required'])){
755
+            $output .= ' required ';
756
+        }
757
+
758
+        // multiple
759
+        if(!empty($args['multiple'])){
760
+            $output .= ' multiple ';
761
+        }
762
+
763
+        // close opening tag
764
+        $output .= ' >';
765
+
766
+        // placeholder
767
+        if(isset($args['placeholder']) && '' != $args['placeholder'] && !$is_select2){
768
+            $output .= '<option value="" disabled selected hidden>'.esc_attr($args['placeholder']).'</option>';
769
+        }elseif($is_select2 && !empty($args['placeholder'])){
770
+            $output .= "<option></option>"; // select2 needs an empty select to fill the placeholder
771
+        }
772
+
773
+        // Options
774
+        if(!empty($args['options'])){
775
+
776
+            if(!is_array($args['options'])){
777
+                $output .= $args['options']; // not the preferred way but an option
778
+            }else{
779
+                foreach($args['options'] as $val => $name){
780
+                    $selected = '';
781
+                    if(is_array($name)){
782
+                        if (isset($name['optgroup']) && ($name['optgroup'] == 'start' || $name['optgroup'] == 'end')) {
783
+                            $option_label = isset($name['label']) ? $name['label'] : '';
784
+
785
+                            $output .= $name['optgroup'] == 'start' ? '<optgroup label="' . esc_attr($option_label) . '">' : '</optgroup>';
786
+                        } else {
787
+                            $option_label = isset($name['label']) ? $name['label'] : '';
788
+                            $option_value = isset($name['value']) ? $name['value'] : '';
789
+                            if(!empty($args['multiple']) && !empty($args['value']) && is_array($args['value']) ){
790
+                                $selected = in_array($option_value, stripslashes_deep($args['value'])) ? "selected" : "";
791
+                            } elseif(!empty($args['value'])) {
792
+                                $selected = selected($option_value,stripslashes_deep($args['value']), false);
793
+                            }
794
+
795
+                            $output .= '<option value="' . esc_attr($option_value) . '" ' . $selected . '>' . $option_label . '</option>';
796
+                        }
797
+                    }else{
798
+                        if(!empty($args['value'])){
799
+                            if(is_array($args['value'])){
800
+                                $selected = in_array($val,$args['value']) ? 'selected="selected"' : '';
801
+                            } elseif(!empty($args['value'])) {
802
+                                $selected = selected( $args['value'], $val, false);
803
+                            }
804
+                        }
805
+                        $output .= '<option value="'.esc_attr($val).'" '.$selected.'>'.esc_attr($name).'</option>';
806
+                    }
807
+                }
808
+            }
809
+
810
+        }
811
+
812
+        // closing tag
813
+        $output .= '</select>';
814
+
815
+        if(!empty($args['label']) && $label_after){
816
+            $label_args = array(
817
+                'title'=> $args['label'],
818
+                'for'=> $args['id'],
819
+                'class' => $args['label_class']." ",
820
+                'label_type' => $args['label_type']
821
+            );
822
+            $output .= self::label($label_args);
823
+        }
824
+
825
+        // help text
826
+        if(!empty($args['help_text'])){
827
+            $output .= AUI_Component_Helper::help_text($args['help_text']);
828
+        }
829
+
830
+        // maybe horizontal label
831
+        if($args['label_type']=='horizontal'){
832
+            $output .= '</div>';
833
+        }
834
+
835
+
836
+        // wrap
837
+        if(!$args['no_wrap']){
838
+            $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
839
+            $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
840
+            $output = self::wrap(array(
841
+                'content' => $output,
842
+                'class'   => $wrap_class,
843
+                'element_require'   => $args['element_require'],
844
+                'argument_id'  => $args['id']
845
+            ));
846
+        }
847
+
848
+
849
+        return $output;
850
+    }
851
+
852
+    /**
853
+     * Build the component.
854
+     *
855
+     * @param array $args
856
+     *
857
+     * @return string The rendered component.
858
+     */
859
+    public static function radio($args = array()){
860
+        $defaults = array(
861
+            'class'      => '',
862
+            'wrap_class' => '',
863
+            'id'         => '',
864
+            'title'      => '',
865
+            'horizontal' => false, // sets the lable horizontal
866
+            'value'      => '',
867
+            'label'      => '',
868
+            'label_class'=> '',
869
+            'label_type' => '', // sets the label type, default: hidden. Options: hidden, top, horizontal, floating
870
+            'help_text'  => '',
871
+            'inline'     => true,
872
+            'required'   => false,
873
+            'options'    => array(),
874
+            'icon'       => '',
875
+            'no_wrap'    => false,
876
+            'element_require'   => '', // [%element_id%] == "1"
877
+            'extra_attributes'  => array() // an array of extra attributes
878
+        );
879
+
880
+        /**
881
+         * Parse incoming $args into an array and merge it with $defaults
882
+         */
883
+        $args   = wp_parse_args( $args, $defaults );
884
+
885
+        // for now lets use horizontal for floating
886
+        if( $args['label_type'] == 'floating' ){$args['label_type'] = 'horizontal';}
887
+
888
+        $label_args = array(
889
+            'title'=> $args['label'],
890
+            'class' => $args['label_class']." pt-0 ",
891
+            'label_type' => $args['label_type']
892
+        );
893
+
894
+        $output = '';
895
+
896
+
897
+
898
+        // label before
899
+        if(!empty($args['label'])){
900
+            $output .= self::label( $label_args, 'radio' );
901
+        }
902
+
903
+        // maybe horizontal label
904
+        if($args['label_type']=='horizontal'){
905
+            $output .= '<div class="col-sm-10">';
906
+        }
907
+
908
+        if(!empty($args['options'])){
909
+            $count = 0;
910
+            foreach($args['options'] as $value => $label){
911
+                $option_args = $args;
912
+                $option_args['value'] = $value;
913
+                $option_args['label'] = $label;
914
+                $option_args['checked'] = $value == $args['value'] ? true : false;
915
+                $output .= self::radio_option($option_args,$count);
916
+                $count++;
917
+            }
918
+        }
919
+
920
+        // help text
921
+        $help_text = ! empty( $args['help_text'] ) ? AUI_Component_Helper::help_text( $args['help_text'] ) : '';
922
+        $output .= $help_text;
923
+
924
+        // maybe horizontal label
925
+        if($args['label_type']=='horizontal'){
926
+            $output .= '</div>';
927
+        }
928
+
929
+        // wrap
930
+        $wrap_class = $args['label_type']=='horizontal' ? 'form-group row' : 'form-group';
931
+        $wrap_class = !empty($args['wrap_class']) ? $wrap_class." ".$args['wrap_class'] : $wrap_class;
932
+        $output = self::wrap(array(
933
+            'content' => $output,
934
+            'class'   => $wrap_class,
935
+            'element_require'   => $args['element_require'],
936
+            'argument_id'  => $args['id']
937
+        ));
938
+
939
+
940
+        return $output;
941
+    }
942
+
943
+    /**
944
+     * Build the component.
945
+     *
946
+     * @param array $args
947
+     *
948
+     * @return string The rendered component.
949
+     */
950
+    public static function radio_option($args = array(),$count = ''){
951
+        $defaults = array(
952
+            'class'      => '',
953
+            'id'         => '',
954
+            'title'      => '',
955
+            'value'      => '',
956
+            'required'   => false,
957
+            'inline'     => true,
958
+            'label'      => '',
959
+            'options'    => array(),
960
+            'icon'       => '',
961
+            'no_wrap'    => false,
962
+            'extra_attributes'  => array() // an array of extra attributes
963
+        );
964
+
965
+        /**
966
+         * Parse incoming $args into an array and merge it with $defaults
967
+         */
968
+        $args   = wp_parse_args( $args, $defaults );
969
+
970
+        $output = '';
971
+
972
+        // open/type
973
+        $output .= '<input type="radio"';
974
+
975
+        // class
976
+        $output .= ' class="form-check-input" ';
977
+
978
+        // name
979
+        if(!empty($args['name'])){
980
+            $output .= AUI_Component_Helper::name($args['name']);
981
+        }
982
+
983
+        // id
984
+        if(!empty($args['id'])){
985
+            $output .= AUI_Component_Helper::id($args['id'].$count);
986
+        }
987
+
988
+        // title
989
+        if(!empty($args['title'])){
990
+            $output .= AUI_Component_Helper::title($args['title']);
991
+        }
992
+
993
+        // value
994
+        if(isset($args['value'])){
995
+            $output .= ' value="'.sanitize_text_field($args['value']).'" ';
996
+        }
997
+
998
+        // checked, for radio and checkboxes
999
+        if( $args['checked'] ){
1000
+            $output .= ' checked ';
1001
+        }
1002
+
1003
+        // data-attributes
1004
+        $output .= AUI_Component_Helper::data_attributes($args);
1005
+
1006
+        // aria-attributes
1007
+        $output .= AUI_Component_Helper::aria_attributes($args);
1008
+
1009
+        // extra attributes
1010
+        if(!empty($args['extra_attributes'])){
1011
+            $output .= AUI_Component_Helper::extra_attributes($args['extra_attributes']);
1012
+        }
1013
+
1014
+        // required
1015
+        if(!empty($args['required'])){
1016
+            $output .= ' required ';
1017
+        }
1018
+
1019
+        // close opening tag
1020
+        $output .= ' >';
1021
+
1022
+        // label
1023
+        if(!empty($args['label']) && is_array($args['label'])){
1024
+        }elseif(!empty($args['label'])){
1025
+            $output .= self::label(array('title'=>$args['label'],'for'=>$args['id'].$count,'class'=>'form-check-label'),'radio');
1026
+        }
1027
+
1028
+        // wrap
1029
+        if(!$args['no_wrap']){
1030
+            $wrap_class = $args['inline'] ? 'form-check form-check-inline' : 'form-check';
1031
+            $output = self::wrap(array(
1032
+                'content' => $output,
1033
+                'class' => $wrap_class
1034
+            ));
1035
+        }
1036
+
1037
+
1038
+        return $output;
1039
+    }
1040 1040
 
1041 1041
 }
1042 1042
\ 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   +1223 added lines, -1223 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,236 +21,236 @@  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 = '0.1.51';
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
-
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
-			// check if specifically disabled
179
-			if(!empty($this->settings['disable_admin'])){
180
-				$url_parts = explode("\n",$this->settings['disable_admin']);
181
-				foreach($url_parts as $part){
182
-					if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
183
-						return false; // return early, no point checking further
184
-					}
185
-				}
186
-			}
187
-
188
-			return $result;
189
-		}
190
-
191
-		/**
192
-		 * Add a html font size to the footer.
193
-		 */
194
-		public function html_font_size(){
195
-			$this->settings = $this->get_settings();
196
-			echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
197
-		}
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 = '0.1.51';
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
+                }
198 114
 
199
-		/**
200
-		 * Check if the current admin screen should load scripts.
201
-		 * 
202
-		 * @return bool
203
-		 */
204
-		public function is_aui_screen(){
205
-			$load = false;
206
-			// check if we should load or not
207
-			if ( is_admin() ) {
208
-				// Only enable on set pages
209
-				$aui_screens = array(
210
-					'page',
211
-					'post',
212
-					'settings_page_ayecode-ui-settings',
213
-					'appearance_page_gutenberg-widgets'
214
-				);
215
-				$screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
216
-
217
-				$screen = get_current_screen();
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
+            // check if specifically disabled
179
+            if(!empty($this->settings['disable_admin'])){
180
+                $url_parts = explode("\n",$this->settings['disable_admin']);
181
+                foreach($url_parts as $part){
182
+                    if( strpos($_SERVER['REQUEST_URI'], trim($part)) !== false ){
183
+                        return false; // return early, no point checking further
184
+                    }
185
+                }
186
+            }
187
+
188
+            return $result;
189
+        }
190
+
191
+        /**
192
+         * Add a html font size to the footer.
193
+         */
194
+        public function html_font_size(){
195
+            $this->settings = $this->get_settings();
196
+            echo "<style>html{font-size:".absint($this->settings['html_font_size'])."px;}</style>";
197
+        }
198
+
199
+        /**
200
+         * Check if the current admin screen should load scripts.
201
+         * 
202
+         * @return bool
203
+         */
204
+        public function is_aui_screen(){
205
+            $load = false;
206
+            // check if we should load or not
207
+            if ( is_admin() ) {
208
+                // Only enable on set pages
209
+                $aui_screens = array(
210
+                    'page',
211
+                    'post',
212
+                    'settings_page_ayecode-ui-settings',
213
+                    'appearance_page_gutenberg-widgets'
214
+                );
215
+                $screen_ids = apply_filters( 'aui_screen_ids', $aui_screens );
216
+
217
+                $screen = get_current_screen();
218 218
 
219 219
 //				echo '###'.$screen->id;
220 220
 				
221
-				if ( $screen && in_array( $screen->id, $screen_ids ) ) {
222
-					$load = true;
223
-				}
224
-			}
221
+                if ( $screen && in_array( $screen->id, $screen_ids ) ) {
222
+                    $load = true;
223
+                }
224
+            }
225 225
 
226
-			return $load;
227
-		}
226
+            return $load;
227
+        }
228 228
 
229
-		/**
230
-		 * Adds the styles.
231
-		 */
232
-		public function enqueue_style() {
229
+        /**
230
+         * Adds the styles.
231
+         */
232
+        public function enqueue_style() {
233 233
 
234
-			if( is_admin() && !$this->is_aui_screen()){
235
-				// don't add wp-admin scripts if not requested to
236
-			}else{
237
-				$css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
234
+            if( is_admin() && !$this->is_aui_screen()){
235
+                // don't add wp-admin scripts if not requested to
236
+            }else{
237
+                $css_setting = current_action() == 'wp_enqueue_scripts' ? 'css' : 'css_backend';
238 238
 
239
-				$rtl = is_rtl() ? '-rtl' : '';
239
+                $rtl = is_rtl() ? '-rtl' : '';
240 240
 
241
-				if($this->settings[$css_setting]){
242
-					$compatibility = $this->settings[$css_setting]=='core' ? false : true;
243
-					$url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
244
-					wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
245
-					wp_enqueue_style( 'ayecode-ui' );
241
+                if($this->settings[$css_setting]){
242
+                    $compatibility = $this->settings[$css_setting]=='core' ? false : true;
243
+                    $url = $this->settings[$css_setting]=='core' ? $this->url.'assets/css/ayecode-ui'.$rtl.'.css' : $this->url.'assets/css/ayecode-ui-compatibility'.$rtl.'.css';
244
+                    wp_register_style( 'ayecode-ui', $url, array(), $this->latest );
245
+                    wp_enqueue_style( 'ayecode-ui' );
246 246
 
247
-					// flatpickr
248
-					wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
247
+                    // flatpickr
248
+                    wp_register_style( 'flatpickr', $this->url.'assets/css/flatpickr.min.css', array(), $this->latest );
249 249
 
250 250
 
251
-					// fix some wp-admin issues
252
-					if(is_admin()){
253
-						$custom_css = "
251
+                    // fix some wp-admin issues
252
+                    if(is_admin()){
253
+                        $custom_css = "
254 254
                 body{
255 255
                     background-color: #f1f1f1;
256 256
                     font-family: -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif;
@@ -292,35 +292,35 @@  discard block
 block discarded – undo
292 292
 				}
293 293
                 ";
294 294
 
295
-						// @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
296
-						$custom_css .= "
295
+                        // @todo, remove once fixed :: fix for this bug https://github.com/WordPress/gutenberg/issues/14377
296
+                        $custom_css .= "
297 297
 						.edit-post-sidebar input[type=color].components-text-control__input{
298 298
 						    padding: 0;
299 299
 						}
300 300
 					";
301
-						wp_add_inline_style( 'ayecode-ui', $custom_css );
302
-					}
301
+                        wp_add_inline_style( 'ayecode-ui', $custom_css );
302
+                    }
303 303
 
304
-					// custom changes
305
-					wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
304
+                    // custom changes
305
+                    wp_add_inline_style( 'ayecode-ui', self::custom_css($compatibility) );
306 306
 
307
-				}
308
-			}
307
+                }
308
+            }
309 309
 
310 310
 
311
-		}
311
+        }
312
+
313
+        /**
314
+         * Get inline script used if bootstrap enqueued
315
+         *
316
+         * If this remains small then its best to use this than to add another JS file.
317
+         */
318
+        public function inline_script() {
319
+            // Flatpickr calendar locale
320
+            $flatpickr_locale = self::flatpickr_locale();
312 321
 
313
-		/**
314
-		 * Get inline script used if bootstrap enqueued
315
-		 *
316
-		 * If this remains small then its best to use this than to add another JS file.
317
-		 */
318
-		public function inline_script() {
319
-			// Flatpickr calendar locale
320
-			$flatpickr_locale = self::flatpickr_locale();
321
-
322
-			ob_start();
323
-			?>
322
+            ob_start();
323
+            ?>
324 324
 			<script>
325 325
 				/**
326 326
 				 * An AUI bootstrap adaptation of GreedyNav.js ( by Luke Jackson ).
@@ -1009,29 +1009,29 @@  discard block
 block discarded – undo
1009 1009
 				});
1010 1010
 			</script>
1011 1011
 			<?php
1012
-			$output = ob_get_clean();
1012
+            $output = ob_get_clean();
1013 1013
 
1014 1014
 
1015 1015
 
1016
-			/*
1016
+            /*
1017 1017
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1018 1018
 			 */
1019
-			return str_replace( array(
1020
-				'<script>',
1021
-				'</script>'
1022
-			), '', self::minify_js($output) );
1023
-		}
1024
-
1025
-
1026
-		/**
1027
-		 * JS to help with conflict issues with other plugins and themes using bootstrap v3.
1028
-		 *
1029
-		 * @TODO we may need this when other conflicts arrise.
1030
-		 * @return mixed
1031
-		 */
1032
-		public static function bs3_compat_js() {
1033
-			ob_start();
1034
-			?>
1019
+            return str_replace( array(
1020
+                '<script>',
1021
+                '</script>'
1022
+            ), '', self::minify_js($output) );
1023
+        }
1024
+
1025
+
1026
+        /**
1027
+         * JS to help with conflict issues with other plugins and themes using bootstrap v3.
1028
+         *
1029
+         * @TODO we may need this when other conflicts arrise.
1030
+         * @return mixed
1031
+         */
1032
+        public static function bs3_compat_js() {
1033
+            ob_start();
1034
+            ?>
1035 1035
 			<script>
1036 1036
 				<?php if( defined( 'FUSION_BUILDER_VERSION' ) ){ ?>
1037 1037
 				/* With Avada builder */
@@ -1039,20 +1039,20 @@  discard block
 block discarded – undo
1039 1039
 				<?php } ?>
1040 1040
 			</script>
1041 1041
 			<?php
1042
-			return str_replace( array(
1043
-				'<script>',
1044
-				'</script>'
1045
-			), '', ob_get_clean());
1046
-		}
1047
-
1048
-		/**
1049
-		 * Get inline script used if bootstrap file browser enqueued.
1050
-		 *
1051
-		 * If this remains small then its best to use this than to add another JS file.
1052
-		 */
1053
-		public function inline_script_file_browser(){
1054
-			ob_start();
1055
-			?>
1042
+            return str_replace( array(
1043
+                '<script>',
1044
+                '</script>'
1045
+            ), '', ob_get_clean());
1046
+        }
1047
+
1048
+        /**
1049
+         * Get inline script used if bootstrap file browser enqueued.
1050
+         *
1051
+         * If this remains small then its best to use this than to add another JS file.
1052
+         */
1053
+        public function inline_script_file_browser(){
1054
+            ob_start();
1055
+            ?>
1056 1056
 			<script>
1057 1057
 				// run on doc ready
1058 1058
 				jQuery(document).ready(function () {
@@ -1060,192 +1060,192 @@  discard block
 block discarded – undo
1060 1060
 				});
1061 1061
 			</script>
1062 1062
 			<?php
1063
-			$output = ob_get_clean();
1063
+            $output = ob_get_clean();
1064 1064
 
1065
-			/*
1065
+            /*
1066 1066
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1067 1067
 			 */
1068
-			return str_replace( array(
1069
-				'<script>',
1070
-				'</script>'
1071
-			), '', $output );
1072
-		}
1073
-
1074
-		/**
1075
-		 * Adds the Font Awesome JS.
1076
-		 */
1077
-		public function enqueue_scripts() {
1078
-
1079
-			if( is_admin() && !$this->is_aui_screen()){
1080
-				// don't add wp-admin scripts if not requested to
1081
-			}else {
1082
-
1083
-				$js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
1084
-
1085
-				// select2
1086
-				wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
1087
-
1088
-				// flatpickr
1089
-				wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->latest );
1090
-
1091
-				// Bootstrap file browser
1092
-				wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
1093
-				wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
1094
-
1095
-				$load_inline = false;
1096
-
1097
-				if ( $this->settings[ $js_setting ] == 'core-popper' ) {
1098
-					// Bootstrap bundle
1099
-					$url = $this->url . 'assets/js/bootstrap.bundle.min.js';
1100
-					wp_register_script( 'bootstrap-js-bundle', $url, array(
1101
-						'select2',
1102
-						'jquery'
1103
-					), $this->latest, $this->is_bs3_compat() );
1104
-					// if in admin then add to footer for compatibility.
1105
-					is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
1106
-					$script = $this->inline_script();
1107
-					wp_add_inline_script( 'bootstrap-js-bundle', $script );
1108
-				} elseif ( $this->settings[ $js_setting ] == 'popper' ) {
1109
-					$url = $this->url . 'assets/js/popper.min.js';
1110
-					wp_register_script( 'bootstrap-js-popper', $url, array( 'select2', 'jquery' ), $this->latest );
1111
-					wp_enqueue_script( 'bootstrap-js-popper' );
1112
-					$load_inline = true;
1113
-				} else {
1114
-					$load_inline = true;
1115
-				}
1116
-
1117
-				// Load needed inline scripts by faking the loading of a script if the main script is not being loaded
1118
-				if ( $load_inline ) {
1119
-					wp_register_script( 'bootstrap-dummy', '', array( 'select2', 'jquery' ) );
1120
-					wp_enqueue_script( 'bootstrap-dummy' );
1121
-					$script = $this->inline_script();
1122
-					wp_add_inline_script( 'bootstrap-dummy', $script );
1123
-				}
1124
-			}
1125
-
1126
-		}
1127
-
1128
-		/**
1129
-		 * Enqueue flatpickr if called.
1130
-		 */
1131
-		public function enqueue_flatpickr(){
1132
-			wp_enqueue_style( 'flatpickr' );
1133
-			wp_enqueue_script( 'flatpickr' );
1134
-		}
1135
-
1136
-		/**
1137
-		 * Get the url path to the current folder.
1138
-		 *
1139
-		 * @return string
1140
-		 */
1141
-		public function get_url() {
1142
-
1143
-			$url = '';
1144
-			// check if we are inside a plugin
1145
-			$file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
1146
-
1147
-			// add check in-case user has changed wp-content dir name.
1148
-			$wp_content_folder_name = basename(WP_CONTENT_DIR);
1149
-			$dir_parts = explode("/$wp_content_folder_name/",$file_dir);
1150
-			$url_parts = explode("/$wp_content_folder_name/",plugins_url());
1151
-
1152
-			if(!empty($url_parts[0]) && !empty($dir_parts[1])){
1153
-				$url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
1154
-			}
1155
-
1156
-			return $url;
1157
-		}
1158
-
1159
-		/**
1160
-		 * Register the database settings with WordPress.
1161
-		 */
1162
-		public function register_settings() {
1163
-			register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
1164
-		}
1165
-
1166
-		/**
1167
-		 * Add the WordPress settings menu item.
1168
-		 * @since 1.0.10 Calling function name direct will fail theme check so we don't.
1169
-		 */
1170
-		public function menu_item() {
1171
-			$menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
1172
-			call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
1173
-				$this,
1174
-				'settings_page'
1175
-			) );
1176
-		}
1177
-
1178
-		/**
1179
-		 * Get a list of themes and their default JS settings.
1180
-		 *
1181
-		 * @return array
1182
-		 */
1183
-		public function theme_js_settings(){
1184
-			return array(
1185
-				'ayetheme' => 'popper',
1186
-				'listimia' => 'required',
1187
-				'listimia_backend' => 'core-popper',
1188
-				//'avada'    => 'required', // removed as we now add compatibility
1189
-			);
1190
-		}
1191
-
1192
-		/**
1193
-		 * Get the current Font Awesome output settings.
1194
-		 *
1195
-		 * @return array The array of settings.
1196
-		 */
1197
-		public function get_settings() {
1198
-
1199
-			$db_settings = get_option( 'ayecode-ui-settings' );
1200
-			$js_default = 'core-popper';
1201
-			$js_default_backend = $js_default;
1202
-
1203
-			// maybe set defaults (if no settings set)
1204
-			if(empty($db_settings)){
1205
-				$active_theme = strtolower( get_template() ); // active parent theme.
1206
-				$theme_js_settings = self::theme_js_settings();
1207
-				if(isset($theme_js_settings[$active_theme])){
1208
-					$js_default = $theme_js_settings[$active_theme];
1209
-					$js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
1210
-				}
1211
-			}
1212
-
1213
-			$defaults = array(
1214
-				'css'       => 'compatibility', // core, compatibility
1215
-				'js'        => $js_default, // js to load, core-popper, popper
1216
-				'html_font_size'        => '16', // js to load, core-popper, popper
1217
-				'css_backend'       => 'compatibility', // core, compatibility
1218
-				'js_backend'        => $js_default_backend, // js to load, core-popper, popper
1219
-				'disable_admin'     =>  '', // URL snippets to disable loading on admin
1220
-			);
1221
-
1222
-			$settings = wp_parse_args( $db_settings, $defaults );
1223
-
1224
-			/**
1225
-			 * Filter the Bootstrap settings.
1226
-			 *
1227
-			 * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
1228
-			 */
1229
-			return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
1230
-		}
1231
-
1068
+            return str_replace( array(
1069
+                '<script>',
1070
+                '</script>'
1071
+            ), '', $output );
1072
+        }
1073
+
1074
+        /**
1075
+         * Adds the Font Awesome JS.
1076
+         */
1077
+        public function enqueue_scripts() {
1078
+
1079
+            if( is_admin() && !$this->is_aui_screen()){
1080
+                // don't add wp-admin scripts if not requested to
1081
+            }else {
1082
+
1083
+                $js_setting = current_action() == 'wp_enqueue_scripts' ? 'js' : 'js_backend';
1084
+
1085
+                // select2
1086
+                wp_register_script( 'select2', $this->url . 'assets/js/select2.min.js', array( 'jquery' ), $this->select2_version );
1087
+
1088
+                // flatpickr
1089
+                wp_register_script( 'flatpickr', $this->url . 'assets/js/flatpickr.min.js', array(), $this->latest );
1090
+
1091
+                // Bootstrap file browser
1092
+                wp_register_script( 'aui-custom-file-input', $url = $this->url . 'assets/js/bs-custom-file-input.min.js', array( 'jquery' ), $this->select2_version );
1093
+                wp_add_inline_script( 'aui-custom-file-input', $this->inline_script_file_browser() );
1094
+
1095
+                $load_inline = false;
1096
+
1097
+                if ( $this->settings[ $js_setting ] == 'core-popper' ) {
1098
+                    // Bootstrap bundle
1099
+                    $url = $this->url . 'assets/js/bootstrap.bundle.min.js';
1100
+                    wp_register_script( 'bootstrap-js-bundle', $url, array(
1101
+                        'select2',
1102
+                        'jquery'
1103
+                    ), $this->latest, $this->is_bs3_compat() );
1104
+                    // if in admin then add to footer for compatibility.
1105
+                    is_admin() ? wp_enqueue_script( 'bootstrap-js-bundle', '', null, null, true ) : wp_enqueue_script( 'bootstrap-js-bundle' );
1106
+                    $script = $this->inline_script();
1107
+                    wp_add_inline_script( 'bootstrap-js-bundle', $script );
1108
+                } elseif ( $this->settings[ $js_setting ] == 'popper' ) {
1109
+                    $url = $this->url . 'assets/js/popper.min.js';
1110
+                    wp_register_script( 'bootstrap-js-popper', $url, array( 'select2', 'jquery' ), $this->latest );
1111
+                    wp_enqueue_script( 'bootstrap-js-popper' );
1112
+                    $load_inline = true;
1113
+                } else {
1114
+                    $load_inline = true;
1115
+                }
1232 1116
 
1233
-		/**
1234
-		 * The settings page html output.
1235
-		 */
1236
-		public function settings_page() {
1237
-			if ( ! current_user_can( 'manage_options' ) ) {
1238
-				wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
1239
-			}
1240
-			?>
1117
+                // Load needed inline scripts by faking the loading of a script if the main script is not being loaded
1118
+                if ( $load_inline ) {
1119
+                    wp_register_script( 'bootstrap-dummy', '', array( 'select2', 'jquery' ) );
1120
+                    wp_enqueue_script( 'bootstrap-dummy' );
1121
+                    $script = $this->inline_script();
1122
+                    wp_add_inline_script( 'bootstrap-dummy', $script );
1123
+                }
1124
+            }
1125
+
1126
+        }
1127
+
1128
+        /**
1129
+         * Enqueue flatpickr if called.
1130
+         */
1131
+        public function enqueue_flatpickr(){
1132
+            wp_enqueue_style( 'flatpickr' );
1133
+            wp_enqueue_script( 'flatpickr' );
1134
+        }
1135
+
1136
+        /**
1137
+         * Get the url path to the current folder.
1138
+         *
1139
+         * @return string
1140
+         */
1141
+        public function get_url() {
1142
+
1143
+            $url = '';
1144
+            // check if we are inside a plugin
1145
+            $file_dir = str_replace( "/includes","", wp_normalize_path( dirname( __FILE__ ) ) );
1146
+
1147
+            // add check in-case user has changed wp-content dir name.
1148
+            $wp_content_folder_name = basename(WP_CONTENT_DIR);
1149
+            $dir_parts = explode("/$wp_content_folder_name/",$file_dir);
1150
+            $url_parts = explode("/$wp_content_folder_name/",plugins_url());
1151
+
1152
+            if(!empty($url_parts[0]) && !empty($dir_parts[1])){
1153
+                $url = trailingslashit( $url_parts[0]."/$wp_content_folder_name/".$dir_parts[1] );
1154
+            }
1155
+
1156
+            return $url;
1157
+        }
1158
+
1159
+        /**
1160
+         * Register the database settings with WordPress.
1161
+         */
1162
+        public function register_settings() {
1163
+            register_setting( 'ayecode-ui-settings', 'ayecode-ui-settings' );
1164
+        }
1165
+
1166
+        /**
1167
+         * Add the WordPress settings menu item.
1168
+         * @since 1.0.10 Calling function name direct will fail theme check so we don't.
1169
+         */
1170
+        public function menu_item() {
1171
+            $menu_function = 'add' . '_' . 'options' . '_' . 'page'; // won't pass theme check if function name present in theme
1172
+            call_user_func( $menu_function, $this->name, $this->name, 'manage_options', 'ayecode-ui-settings', array(
1173
+                $this,
1174
+                'settings_page'
1175
+            ) );
1176
+        }
1177
+
1178
+        /**
1179
+         * Get a list of themes and their default JS settings.
1180
+         *
1181
+         * @return array
1182
+         */
1183
+        public function theme_js_settings(){
1184
+            return array(
1185
+                'ayetheme' => 'popper',
1186
+                'listimia' => 'required',
1187
+                'listimia_backend' => 'core-popper',
1188
+                //'avada'    => 'required', // removed as we now add compatibility
1189
+            );
1190
+        }
1191
+
1192
+        /**
1193
+         * Get the current Font Awesome output settings.
1194
+         *
1195
+         * @return array The array of settings.
1196
+         */
1197
+        public function get_settings() {
1198
+
1199
+            $db_settings = get_option( 'ayecode-ui-settings' );
1200
+            $js_default = 'core-popper';
1201
+            $js_default_backend = $js_default;
1202
+
1203
+            // maybe set defaults (if no settings set)
1204
+            if(empty($db_settings)){
1205
+                $active_theme = strtolower( get_template() ); // active parent theme.
1206
+                $theme_js_settings = self::theme_js_settings();
1207
+                if(isset($theme_js_settings[$active_theme])){
1208
+                    $js_default = $theme_js_settings[$active_theme];
1209
+                    $js_default_backend = isset($theme_js_settings[$active_theme."_backend"]) ? $theme_js_settings[$active_theme."_backend"] : $js_default;
1210
+                }
1211
+            }
1212
+
1213
+            $defaults = array(
1214
+                'css'       => 'compatibility', // core, compatibility
1215
+                'js'        => $js_default, // js to load, core-popper, popper
1216
+                'html_font_size'        => '16', // js to load, core-popper, popper
1217
+                'css_backend'       => 'compatibility', // core, compatibility
1218
+                'js_backend'        => $js_default_backend, // js to load, core-popper, popper
1219
+                'disable_admin'     =>  '', // URL snippets to disable loading on admin
1220
+            );
1221
+
1222
+            $settings = wp_parse_args( $db_settings, $defaults );
1223
+
1224
+            /**
1225
+             * Filter the Bootstrap settings.
1226
+             *
1227
+             * @todo if we add this filer people might use it and then it defeates the purpose of this class :/
1228
+             */
1229
+            return $this->settings = apply_filters( 'ayecode-ui-settings', $settings, $db_settings, $defaults );
1230
+        }
1231
+
1232
+
1233
+        /**
1234
+         * The settings page html output.
1235
+         */
1236
+        public function settings_page() {
1237
+            if ( ! current_user_can( 'manage_options' ) ) {
1238
+                wp_die( __( 'You do not have sufficient permissions to access this page.', 'aui' ) );
1239
+            }
1240
+            ?>
1241 1241
 			<div class="wrap">
1242 1242
 				<h1><?php echo $this->name; ?></h1>
1243 1243
 				<p><?php _e("Here you can adjust settings if you are having compatibility issues.",'aui');?></p>
1244 1244
 				<form method="post" action="options.php">
1245 1245
 					<?php
1246
-					settings_fields( 'ayecode-ui-settings' );
1247
-					do_settings_sections( 'ayecode-ui-settings' );
1248
-					?>
1246
+                    settings_fields( 'ayecode-ui-settings' );
1247
+                    do_settings_sections( 'ayecode-ui-settings' );
1248
+                    ?>
1249 1249
 
1250 1250
 					<h2><?php _e( 'Frontend', 'aui' ); ?></h2>
1251 1251
 					<table class="form-table wpbs-table-settings">
@@ -1325,60 +1325,60 @@  discard block
 block discarded – undo
1325 1325
 					</table>
1326 1326
 
1327 1327
 					<?php
1328
-					submit_button();
1329
-					?>
1328
+                    submit_button();
1329
+                    ?>
1330 1330
 				</form>
1331 1331
 
1332 1332
 				<div id="wpbs-version"><?php echo $this->version; ?></div>
1333 1333
 			</div>
1334 1334
 
1335 1335
 			<?php
1336
-		}
1337
-
1338
-		public function customizer_settings($wp_customize){
1339
-			$wp_customize->add_section('aui_settings', array(
1340
-				'title'    => __('AyeCode UI','aui'),
1341
-				'priority' => 120,
1342
-			));
1343
-
1344
-			//  =============================
1345
-			//  = Color Picker              =
1346
-			//  =============================
1347
-			$wp_customize->add_setting('aui_options[color_primary]', array(
1348
-				'default'           => AUI_PRIMARY_COLOR,
1349
-				'sanitize_callback' => 'sanitize_hex_color',
1350
-				'capability'        => 'edit_theme_options',
1351
-				'type'              => 'option',
1352
-				'transport'         => 'refresh',
1353
-			));
1354
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1355
-				'label'    => __('Primary Color','aui'),
1356
-				'section'  => 'aui_settings',
1357
-				'settings' => 'aui_options[color_primary]',
1358
-			)));
1359
-
1360
-			$wp_customize->add_setting('aui_options[color_secondary]', array(
1361
-				'default'           => '#6c757d',
1362
-				'sanitize_callback' => 'sanitize_hex_color',
1363
-				'capability'        => 'edit_theme_options',
1364
-				'type'              => 'option',
1365
-				'transport'         => 'refresh',
1366
-			));
1367
-			$wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1368
-				'label'    => __('Secondary Color','aui'),
1369
-				'section'  => 'aui_settings',
1370
-				'settings' => 'aui_options[color_secondary]',
1371
-			)));
1372
-		}
1373
-
1374
-		/**
1375
-		 * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1376
-		 *
1377
-		 * @return mixed
1378
-		 */
1379
-		public static function bs3_compat_css() {
1380
-			ob_start();
1381
-			?>
1336
+        }
1337
+
1338
+        public function customizer_settings($wp_customize){
1339
+            $wp_customize->add_section('aui_settings', array(
1340
+                'title'    => __('AyeCode UI','aui'),
1341
+                'priority' => 120,
1342
+            ));
1343
+
1344
+            //  =============================
1345
+            //  = Color Picker              =
1346
+            //  =============================
1347
+            $wp_customize->add_setting('aui_options[color_primary]', array(
1348
+                'default'           => AUI_PRIMARY_COLOR,
1349
+                'sanitize_callback' => 'sanitize_hex_color',
1350
+                'capability'        => 'edit_theme_options',
1351
+                'type'              => 'option',
1352
+                'transport'         => 'refresh',
1353
+            ));
1354
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_primary', array(
1355
+                'label'    => __('Primary Color','aui'),
1356
+                'section'  => 'aui_settings',
1357
+                'settings' => 'aui_options[color_primary]',
1358
+            )));
1359
+
1360
+            $wp_customize->add_setting('aui_options[color_secondary]', array(
1361
+                'default'           => '#6c757d',
1362
+                'sanitize_callback' => 'sanitize_hex_color',
1363
+                'capability'        => 'edit_theme_options',
1364
+                'type'              => 'option',
1365
+                'transport'         => 'refresh',
1366
+            ));
1367
+            $wp_customize->add_control( new WP_Customize_Color_Control($wp_customize, 'color_secondary', array(
1368
+                'label'    => __('Secondary Color','aui'),
1369
+                'section'  => 'aui_settings',
1370
+                'settings' => 'aui_options[color_secondary]',
1371
+            )));
1372
+        }
1373
+
1374
+        /**
1375
+         * CSS to help with conflict issues with other plugins and themes using bootstrap v3.
1376
+         *
1377
+         * @return mixed
1378
+         */
1379
+        public static function bs3_compat_css() {
1380
+            ob_start();
1381
+            ?>
1382 1382
 			<style>
1383 1383
 			/* Bootstrap 3 compatibility */
1384 1384
 			body.modal-open .modal-backdrop.show:not(.in) {opacity:0.5;}
@@ -1404,579 +1404,579 @@  discard block
 block discarded – undo
1404 1404
 			<?php } ?>
1405 1405
 			</style>
1406 1406
 			<?php
1407
-			return str_replace( array(
1408
-				'<style>',
1409
-				'</style>'
1410
-			), '', self::minify_css( ob_get_clean() ) );
1411
-		}
1407
+            return str_replace( array(
1408
+                '<style>',
1409
+                '</style>'
1410
+            ), '', self::minify_css( ob_get_clean() ) );
1411
+        }
1412 1412
 
1413 1413
 
1414
-		public static function custom_css($compatibility = true) {
1415
-			$settings = get_option('aui_options');
1414
+        public static function custom_css($compatibility = true) {
1415
+            $settings = get_option('aui_options');
1416 1416
 
1417
-			ob_start();
1417
+            ob_start();
1418 1418
 
1419
-			$primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1420
-			$secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1421
-				//AUI_PRIMARY_COLOR_ORIGINAL
1422
-			?>
1419
+            $primary_color = !empty($settings['color_primary']) ? $settings['color_primary'] : AUI_PRIMARY_COLOR;
1420
+            $secondary_color = !empty($settings['color_secondary']) ? $settings['color_secondary'] : AUI_SECONDARY_COLOR;
1421
+                //AUI_PRIMARY_COLOR_ORIGINAL
1422
+            ?>
1423 1423
 			<style>
1424 1424
 				<?php
1425 1425
 
1426
-					// BS v3 compat
1427
-					if( self::is_bs3_compat() ){
1428
-					    echo self::bs3_compat_css();
1429
-					}
1426
+                    // BS v3 compat
1427
+                    if( self::is_bs3_compat() ){
1428
+                        echo self::bs3_compat_css();
1429
+                    }
1430 1430
 
1431
-					if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1432
-						echo self::css_primary($primary_color,$compatibility);
1433
-					}
1431
+                    if(!is_admin() && $primary_color != AUI_PRIMARY_COLOR_ORIGINAL){
1432
+                        echo self::css_primary($primary_color,$compatibility);
1433
+                    }
1434 1434
 
1435
-					if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1436
-						echo self::css_secondary($settings['color_secondary'],$compatibility);
1437
-					}
1435
+                    if(!is_admin() && $secondary_color != AUI_SECONDARY_COLOR_ORIGINAL){
1436
+                        echo self::css_secondary($settings['color_secondary'],$compatibility);
1437
+                    }
1438 1438
 
1439
-					// Set admin bar z-index lower when modal is open.
1440
-					echo ' body.modal-open #wpadminbar{z-index:999}';
1439
+                    // Set admin bar z-index lower when modal is open.
1440
+                    echo ' body.modal-open #wpadminbar{z-index:999}';
1441 1441
                 ?>
1442 1442
 			</style>
1443 1443
 			<?php
1444 1444
 
1445 1445
 
1446
-			/*
1446
+            /*
1447 1447
 			 * We only add the <script> tags for code highlighting, so we strip them from the output.
1448 1448
 			 */
1449
-			return str_replace( array(
1450
-				'<style>',
1451
-				'</style>'
1452
-			), '', self::minify_css( ob_get_clean() ) );
1453
-		}
1454
-
1455
-		/**
1456
-		 * Check if we should add booststrap 3 compatibility changes.
1457
-		 *
1458
-		 * @return bool
1459
-		 */
1460
-		public static function is_bs3_compat(){
1461
-			return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1462
-		}
1463
-
1464
-		public static function css_primary($color_code,$compatibility){;
1465
-			$color_code = sanitize_hex_color($color_code);
1466
-			if(!$color_code){return '';}
1467
-			/**
1468
-			 * c = color, b = background color, o = border-color, f = fill
1469
-			 */
1470
-			$selectors = array(
1471
-				'a' => array('c'),
1472
-				'.btn-primary' => array('b','o'),
1473
-				'.btn-primary.disabled' => array('b','o'),
1474
-				'.btn-primary:disabled' => array('b','o'),
1475
-				'.btn-outline-primary' => array('c','o'),
1476
-				'.btn-outline-primary:hover' => array('b','o'),
1477
-				'.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1478
-				'.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1479
-				'.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1480
-				'.btn-link' => array('c'),
1481
-				'.dropdown-item.active' => array('b'),
1482
-				'.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1483
-				'.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1449
+            return str_replace( array(
1450
+                '<style>',
1451
+                '</style>'
1452
+            ), '', self::minify_css( ob_get_clean() ) );
1453
+        }
1454
+
1455
+        /**
1456
+         * Check if we should add booststrap 3 compatibility changes.
1457
+         *
1458
+         * @return bool
1459
+         */
1460
+        public static function is_bs3_compat(){
1461
+            return defined('AYECODE_UI_BS3_COMPAT') || defined('SVQ_THEME_VERSION') || defined('FUSION_BUILDER_VERSION');
1462
+        }
1463
+
1464
+        public static function css_primary($color_code,$compatibility){;
1465
+            $color_code = sanitize_hex_color($color_code);
1466
+            if(!$color_code){return '';}
1467
+            /**
1468
+             * c = color, b = background color, o = border-color, f = fill
1469
+             */
1470
+            $selectors = array(
1471
+                'a' => array('c'),
1472
+                '.btn-primary' => array('b','o'),
1473
+                '.btn-primary.disabled' => array('b','o'),
1474
+                '.btn-primary:disabled' => array('b','o'),
1475
+                '.btn-outline-primary' => array('c','o'),
1476
+                '.btn-outline-primary:hover' => array('b','o'),
1477
+                '.btn-outline-primary:not(:disabled):not(.disabled).active' => array('b','o'),
1478
+                '.btn-outline-primary:not(:disabled):not(.disabled):active' => array('b','o'),
1479
+                '.show>.btn-outline-primary.dropdown-toggle' => array('b','o'),
1480
+                '.btn-link' => array('c'),
1481
+                '.dropdown-item.active' => array('b'),
1482
+                '.custom-control-input:checked~.custom-control-label::before' => array('b','o'),
1483
+                '.custom-checkbox .custom-control-input:indeterminate~.custom-control-label::before' => array('b','o'),
1484 1484
 //				'.custom-range::-webkit-slider-thumb' => array('b'), // these break the inline rules...
1485 1485
 //				'.custom-range::-moz-range-thumb' => array('b'),
1486 1486
 //				'.custom-range::-ms-thumb' => array('b'),
1487
-				'.nav-pills .nav-link.active' => array('b'),
1488
-				'.nav-pills .show>.nav-link' => array('b'),
1489
-				'.page-link' => array('c'),
1490
-				'.page-item.active .page-link' => array('b','o'),
1491
-				'.badge-primary' => array('b'),
1492
-				'.alert-primary' => array('b','o'),
1493
-				'.progress-bar' => array('b'),
1494
-				'.list-group-item.active' => array('b','o'),
1495
-				'.bg-primary' => array('b','f'),
1496
-				'.btn-link.btn-primary' => array('c'),
1497
-				'.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1498
-			);
1499
-
1500
-			$important_selectors = array(
1501
-				'.bg-primary' => array('b','f'),
1502
-				'.border-primary' => array('o'),
1503
-				'.text-primary' => array('c'),
1504
-			);
1505
-
1506
-			$color = array();
1507
-			$color_i = array();
1508
-			$background = array();
1509
-			$background_i = array();
1510
-			$border = array();
1511
-			$border_i = array();
1512
-			$fill = array();
1513
-			$fill_i = array();
1514
-
1515
-			$output = '';
1516
-
1517
-			// build rules into each type
1518
-			foreach($selectors as $selector => $types){
1519
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1520
-				$types = array_combine($types,$types);
1521
-				if(isset($types['c'])){$color[] = $selector;}
1522
-				if(isset($types['b'])){$background[] = $selector;}
1523
-				if(isset($types['o'])){$border[] = $selector;}
1524
-				if(isset($types['f'])){$fill[] = $selector;}
1525
-			}
1526
-
1527
-			// build rules into each type
1528
-			foreach($important_selectors as $selector => $types){
1529
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1530
-				$types = array_combine($types,$types);
1531
-				if(isset($types['c'])){$color_i[] = $selector;}
1532
-				if(isset($types['b'])){$background_i[] = $selector;}
1533
-				if(isset($types['o'])){$border_i[] = $selector;}
1534
-				if(isset($types['f'])){$fill_i[] = $selector;}
1535
-			}
1536
-
1537
-			// add any color rules
1538
-			if(!empty($color)){
1539
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1540
-			}
1541
-			if(!empty($color_i)){
1542
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1543
-			}
1544
-
1545
-			// add any background color rules
1546
-			if(!empty($background)){
1547
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1548
-			}
1549
-			if(!empty($background_i)){
1550
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1551
-			}
1552
-
1553
-			// add any border color rules
1554
-			if(!empty($border)){
1555
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1556
-			}
1557
-			if(!empty($border_i)){
1558
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1559
-			}
1560
-
1561
-			// add any fill color rules
1562
-			if(!empty($fill)){
1563
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1564
-			}
1565
-			if(!empty($fill_i)){
1566
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1567
-			}
1568
-
1569
-
1570
-			$prefix = $compatibility ? ".bsui " : "";
1571
-
1572
-			// darken
1573
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1574
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1575
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1576
-
1577
-			// lighten
1578
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1579
-
1580
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1581
-			$op_25 = $color_code."40"; // 25% opacity
1582
-
1583
-
1584
-			// button states
1585
-			$output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1586
-			$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;} ";
1587
-			$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.";} ";
1588
-			$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;} ";
1589
-
1590
-
1591
-			// dropdown's
1592
-			$output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1593
-
1594
-
1595
-			// input states
1596
-			$output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1597
-
1598
-			// page link
1599
-			$output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1600
-
1601
-			return $output;
1602
-		}
1603
-
1604
-		public static function css_secondary($color_code,$compatibility){;
1605
-			$color_code = sanitize_hex_color($color_code);
1606
-			if(!$color_code){return '';}
1607
-			/**
1608
-			 * c = color, b = background color, o = border-color, f = fill
1609
-			 */
1610
-			$selectors = array(
1611
-				'.btn-secondary' => array('b','o'),
1612
-				'.btn-secondary.disabled' => array('b','o'),
1613
-				'.btn-secondary:disabled' => array('b','o'),
1614
-				'.btn-outline-secondary' => array('c','o'),
1615
-				'.btn-outline-secondary:hover' => array('b','o'),
1616
-				'.btn-outline-secondary.disabled' => array('c'),
1617
-				'.btn-outline-secondary:disabled' => array('c'),
1618
-				'.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1619
-				'.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1620
-				'.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1621
-				'.badge-secondary' => array('b'),
1622
-				'.alert-secondary' => array('b','o'),
1623
-				'.btn-link.btn-secondary' => array('c'),
1624
-			);
1625
-
1626
-			$important_selectors = array(
1627
-				'.bg-secondary' => array('b','f'),
1628
-				'.border-secondary' => array('o'),
1629
-				'.text-secondary' => array('c'),
1630
-			);
1631
-
1632
-			$color = array();
1633
-			$color_i = array();
1634
-			$background = array();
1635
-			$background_i = array();
1636
-			$border = array();
1637
-			$border_i = array();
1638
-			$fill = array();
1639
-			$fill_i = array();
1640
-
1641
-			$output = '';
1642
-
1643
-			// build rules into each type
1644
-			foreach($selectors as $selector => $types){
1645
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1646
-				$types = array_combine($types,$types);
1647
-				if(isset($types['c'])){$color[] = $selector;}
1648
-				if(isset($types['b'])){$background[] = $selector;}
1649
-				if(isset($types['o'])){$border[] = $selector;}
1650
-				if(isset($types['f'])){$fill[] = $selector;}
1651
-			}
1652
-
1653
-			// build rules into each type
1654
-			foreach($important_selectors as $selector => $types){
1655
-				$selector = $compatibility ? ".bsui ".$selector : $selector;
1656
-				$types = array_combine($types,$types);
1657
-				if(isset($types['c'])){$color_i[] = $selector;}
1658
-				if(isset($types['b'])){$background_i[] = $selector;}
1659
-				if(isset($types['o'])){$border_i[] = $selector;}
1660
-				if(isset($types['f'])){$fill_i[] = $selector;}
1661
-			}
1662
-
1663
-			// add any color rules
1664
-			if(!empty($color)){
1665
-				$output .= implode(",",$color) . "{color: $color_code;} ";
1666
-			}
1667
-			if(!empty($color_i)){
1668
-				$output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1669
-			}
1670
-
1671
-			// add any background color rules
1672
-			if(!empty($background)){
1673
-				$output .= implode(",",$background) . "{background-color: $color_code;} ";
1674
-			}
1675
-			if(!empty($background_i)){
1676
-				$output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1677
-			}
1678
-
1679
-			// add any border color rules
1680
-			if(!empty($border)){
1681
-				$output .= implode(",",$border) . "{border-color: $color_code;} ";
1682
-			}
1683
-			if(!empty($border_i)){
1684
-				$output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1685
-			}
1686
-
1687
-			// add any fill color rules
1688
-			if(!empty($fill)){
1689
-				$output .= implode(",",$fill) . "{fill: $color_code;} ";
1690
-			}
1691
-			if(!empty($fill_i)){
1692
-				$output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1693
-			}
1694
-
1695
-
1696
-			$prefix = $compatibility ? ".bsui " : "";
1697
-
1698
-			// darken
1699
-			$darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1700
-			$darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1701
-			$darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1702
-
1703
-			// lighten
1704
-			$lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1705
-
1706
-			// opacity see https://css-tricks.com/8-digit-hex-codes/
1707
-			$op_25 = $color_code."40"; // 25% opacity
1708
-
1709
-
1710
-			// button states
1711
-			$output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1712
-			$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;} ";
1713
-			$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.";} ";
1714
-			$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;} ";
1715
-
1716
-
1717
-			return $output;
1718
-		}
1719
-
1720
-		/**
1721
-		 * Increases or decreases the brightness of a color by a percentage of the current brightness.
1722
-		 *
1723
-		 * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1724
-		 * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1725
-		 *
1726
-		 * @return  string
1727
-		 */
1728
-		public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1729
-			$hexCode = ltrim($hexCode, '#');
1730
-
1731
-			if (strlen($hexCode) == 3) {
1732
-				$hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1733
-			}
1734
-
1735
-			$hexCode = array_map('hexdec', str_split($hexCode, 2));
1736
-
1737
-			foreach ($hexCode as & $color) {
1738
-				$adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1739
-				$adjustAmount = ceil($adjustableLimit * $adjustPercent);
1740
-
1741
-				$color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1742
-			}
1743
-
1744
-			return '#' . implode($hexCode);
1745
-		}
1746
-
1747
-		/**
1748
-		 * Check if we should display examples.
1749
-		 */
1750
-		public function maybe_show_examples(){
1751
-			if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1752
-				echo "<head>";
1753
-				wp_head();
1754
-				echo "</head>";
1755
-				echo "<body>";
1756
-				echo $this->get_examples();
1757
-				echo "</body>";
1758
-				exit;
1759
-			}
1760
-		}
1761
-
1762
-		/**
1763
-		 * Get developer examples.
1764
-		 *
1765
-		 * @return string
1766
-		 */
1767
-		public function get_examples(){
1768
-			$output = '';
1769
-
1770
-
1771
-			// open form
1772
-			$output .= "<form class='p-5 m-5 border rounded'>";
1773
-
1774
-			// input example
1775
-			$output .= aui()->input(array(
1776
-				'type'  =>  'text',
1777
-				'id'    =>  'text-example',
1778
-				'name'    =>  'text-example',
1779
-				'placeholder'   => 'text placeholder',
1780
-				'title'   => 'Text input example',
1781
-				'value' =>  '',
1782
-				'required'  => false,
1783
-				'help_text' => 'help text',
1784
-				'label' => 'Text input example label'
1785
-			));
1786
-
1787
-			// input example
1788
-			$output .= aui()->input(array(
1789
-				'type'  =>  'url',
1790
-				'id'    =>  'text-example2',
1791
-				'name'    =>  'text-example',
1792
-				'placeholder'   => 'url placeholder',
1793
-				'title'   => 'Text input example',
1794
-				'value' =>  '',
1795
-				'required'  => false,
1796
-				'help_text' => 'help text',
1797
-				'label' => 'Text input example label'
1798
-			));
1799
-
1800
-			// checkbox example
1801
-			$output .= aui()->input(array(
1802
-				'type'  =>  'checkbox',
1803
-				'id'    =>  'checkbox-example',
1804
-				'name'    =>  'checkbox-example',
1805
-				'placeholder'   => 'checkbox-example',
1806
-				'title'   => 'Checkbox example',
1807
-				'value' =>  '1',
1808
-				'checked'   => true,
1809
-				'required'  => false,
1810
-				'help_text' => 'help text',
1811
-				'label' => 'Checkbox checked'
1812
-			));
1813
-
1814
-			// checkbox example
1815
-			$output .= aui()->input(array(
1816
-				'type'  =>  'checkbox',
1817
-				'id'    =>  'checkbox-example2',
1818
-				'name'    =>  'checkbox-example2',
1819
-				'placeholder'   => 'checkbox-example',
1820
-				'title'   => 'Checkbox example',
1821
-				'value' =>  '1',
1822
-				'checked'   => false,
1823
-				'required'  => false,
1824
-				'help_text' => 'help text',
1825
-				'label' => 'Checkbox un-checked'
1826
-			));
1827
-
1828
-			// switch example
1829
-			$output .= aui()->input(array(
1830
-				'type'  =>  'checkbox',
1831
-				'id'    =>  'switch-example',
1832
-				'name'    =>  'switch-example',
1833
-				'placeholder'   => 'checkbox-example',
1834
-				'title'   => 'Switch example',
1835
-				'value' =>  '1',
1836
-				'checked'   => true,
1837
-				'switch'    => true,
1838
-				'required'  => false,
1839
-				'help_text' => 'help text',
1840
-				'label' => 'Switch on'
1841
-			));
1842
-
1843
-			// switch example
1844
-			$output .= aui()->input(array(
1845
-				'type'  =>  'checkbox',
1846
-				'id'    =>  'switch-example2',
1847
-				'name'    =>  'switch-example2',
1848
-				'placeholder'   => 'checkbox-example',
1849
-				'title'   => 'Switch example',
1850
-				'value' =>  '1',
1851
-				'checked'   => false,
1852
-				'switch'    => true,
1853
-				'required'  => false,
1854
-				'help_text' => 'help text',
1855
-				'label' => 'Switch off'
1856
-			));
1857
-
1858
-			// close form
1859
-			$output .= "</form>";
1860
-
1861
-			return $output;
1862
-		}
1863
-
1864
-		/**
1865
-		 * Calendar params.
1866
-		 *
1867
-		 * @since 0.1.44
1868
-		 *
1869
-		 * @return array Calendar params.
1870
-		 */
1871
-		public static function calendar_params() {
1872
-			$params = array(
1873
-				'month_long_1' => __( 'January', 'aui' ),
1874
-				'month_long_2' => __( 'February', 'aui' ),
1875
-				'month_long_3' => __( 'March', 'aui' ),
1876
-				'month_long_4' => __( 'April', 'aui' ),
1877
-				'month_long_5' => __( 'May', 'aui' ),
1878
-				'month_long_6' => __( 'June', 'aui' ),
1879
-				'month_long_7' => __( 'July', 'aui' ),
1880
-				'month_long_8' => __( 'August', 'aui' ),
1881
-				'month_long_9' => __( 'September', 'aui' ),
1882
-				'month_long_10' => __( 'October', 'aui' ),
1883
-				'month_long_11' => __( 'November', 'aui' ),
1884
-				'month_long_12' => __( 'December', 'aui' ),
1885
-				'month_s_1' => _x( 'Jan', 'January abbreviation', 'aui' ),
1886
-				'month_s_2' => _x( 'Feb', 'February abbreviation', 'aui' ),
1887
-				'month_s_3' => _x( 'Mar', 'March abbreviation', 'aui' ),
1888
-				'month_s_4' => _x( 'Apr', 'April abbreviation', 'aui' ),
1889
-				'month_s_5' => _x( 'May', 'May abbreviation', 'aui' ),
1890
-				'month_s_6' => _x( 'Jun', 'June abbreviation', 'aui' ),
1891
-				'month_s_7' => _x( 'Jul', 'July abbreviation', 'aui' ),
1892
-				'month_s_8' => _x( 'Aug', 'August abbreviation', 'aui' ),
1893
-				'month_s_9' => _x( 'Sep', 'September abbreviation', 'aui' ),
1894
-				'month_s_10' => _x( 'Oct', 'October abbreviation', 'aui' ),
1895
-				'month_s_11' => _x( 'Nov', 'November abbreviation', 'aui' ),
1896
-				'month_s_12' => _x( 'Dec', 'December abbreviation', 'aui' ),
1897
-				'day_s1_1' => _x( 'S', 'Sunday initial', 'aui' ),
1898
-				'day_s1_2' => _x( 'M', 'Monday initial', 'aui' ),
1899
-				'day_s1_3' => _x( 'T', 'Tuesday initial', 'aui' ),
1900
-				'day_s1_4' => _x( 'W', 'Wednesday initial', 'aui' ),
1901
-				'day_s1_5' => _x( 'T', 'Friday initial', 'aui' ),
1902
-				'day_s1_6' => _x( 'F', 'Thursday initial', 'aui' ),
1903
-				'day_s1_7' => _x( 'S', 'Saturday initial', 'aui' ),
1904
-				'day_s2_1' => __( 'Su', 'aui' ),
1905
-				'day_s2_2' => __( 'Mo', 'aui' ),
1906
-				'day_s2_3' => __( 'Tu', 'aui' ),
1907
-				'day_s2_4' => __( 'We', 'aui' ),
1908
-				'day_s2_5' => __( 'Th', 'aui' ),
1909
-				'day_s2_6' => __( 'Fr', 'aui' ),
1910
-				'day_s2_7' => __( 'Sa', 'aui' ),
1911
-				'day_s3_1' => __( 'Sun', 'aui' ),
1912
-				'day_s3_2' => __( 'Mon', 'aui' ),
1913
-				'day_s3_3' => __( 'Tue', 'aui' ),
1914
-				'day_s3_4' => __( 'Wed', 'aui' ),
1915
-				'day_s3_5' => __( 'Thu', 'aui' ),
1916
-				'day_s3_6' => __( 'Fri', 'aui' ),
1917
-				'day_s3_7' => __( 'Sat', 'aui' ),
1918
-				'day_s5_1' => __( 'Sunday', 'aui' ),
1919
-				'day_s5_2' => __( 'Monday', 'aui' ),
1920
-				'day_s5_3' => __( 'Tuesday', 'aui' ),
1921
-				'day_s5_4' => __( 'Wednesday', 'aui' ),
1922
-				'day_s5_5' => __( 'Thursday', 'aui' ),
1923
-				'day_s5_6' => __( 'Friday', 'aui' ),
1924
-				'day_s5_7' => __( 'Saturday', 'aui' ),
1925
-				'am_lower' => __( 'am', 'aui' ),
1926
-				'pm_lower' => __( 'pm', 'aui' ),
1927
-				'am_upper' => __( 'AM', 'aui' ),
1928
-				'pm_upper' => __( 'PM', 'aui' ),
1929
-				'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
1930
-				'time_24hr' => false,
1931
-				'year' => __( 'Year', 'aui' ),
1932
-				'hour' => __( 'Hour', 'aui' ),
1933
-				'minute' => __( 'Minute', 'aui' ),
1934
-				'weekAbbreviation' => __( 'Wk', 'aui' ),
1935
-				'rangeSeparator' => __( ' to ', 'aui' ),
1936
-				'scrollTitle' => __( 'Scroll to increment', 'aui' ),
1937
-				'toggleTitle' => __( 'Click to toggle', 'aui' )
1938
-			);
1939
-
1940
-			return apply_filters( 'ayecode_ui_calendar_params', $params );
1941
-		}
1942
-
1943
-		/**
1944
-		 * Flatpickr calendar localize.
1945
-		 *
1946
-		 * @since 0.1.44
1947
-		 *
1948
-		 * @return string Calendar locale.
1949
-		 */
1950
-		public static function flatpickr_locale() {
1951
-			$params = self::calendar_params();
1952
-
1953
-			if ( is_string( $params ) ) {
1954
-				$params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
1955
-			} else {
1956
-				foreach ( (array) $params as $key => $value ) {
1957
-					if ( ! is_scalar( $value ) ) {
1958
-						continue;
1959
-					}
1960
-
1961
-					$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
1962
-				}
1963
-			}
1487
+                '.nav-pills .nav-link.active' => array('b'),
1488
+                '.nav-pills .show>.nav-link' => array('b'),
1489
+                '.page-link' => array('c'),
1490
+                '.page-item.active .page-link' => array('b','o'),
1491
+                '.badge-primary' => array('b'),
1492
+                '.alert-primary' => array('b','o'),
1493
+                '.progress-bar' => array('b'),
1494
+                '.list-group-item.active' => array('b','o'),
1495
+                '.bg-primary' => array('b','f'),
1496
+                '.btn-link.btn-primary' => array('c'),
1497
+                '.select2-container .select2-results__option--highlighted.select2-results__option[aria-selected=true]' => array('b'),
1498
+            );
1499
+
1500
+            $important_selectors = array(
1501
+                '.bg-primary' => array('b','f'),
1502
+                '.border-primary' => array('o'),
1503
+                '.text-primary' => array('c'),
1504
+            );
1505
+
1506
+            $color = array();
1507
+            $color_i = array();
1508
+            $background = array();
1509
+            $background_i = array();
1510
+            $border = array();
1511
+            $border_i = array();
1512
+            $fill = array();
1513
+            $fill_i = array();
1514
+
1515
+            $output = '';
1516
+
1517
+            // build rules into each type
1518
+            foreach($selectors as $selector => $types){
1519
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1520
+                $types = array_combine($types,$types);
1521
+                if(isset($types['c'])){$color[] = $selector;}
1522
+                if(isset($types['b'])){$background[] = $selector;}
1523
+                if(isset($types['o'])){$border[] = $selector;}
1524
+                if(isset($types['f'])){$fill[] = $selector;}
1525
+            }
1526
+
1527
+            // build rules into each type
1528
+            foreach($important_selectors as $selector => $types){
1529
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1530
+                $types = array_combine($types,$types);
1531
+                if(isset($types['c'])){$color_i[] = $selector;}
1532
+                if(isset($types['b'])){$background_i[] = $selector;}
1533
+                if(isset($types['o'])){$border_i[] = $selector;}
1534
+                if(isset($types['f'])){$fill_i[] = $selector;}
1535
+            }
1536
+
1537
+            // add any color rules
1538
+            if(!empty($color)){
1539
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1540
+            }
1541
+            if(!empty($color_i)){
1542
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1543
+            }
1544
+
1545
+            // add any background color rules
1546
+            if(!empty($background)){
1547
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1548
+            }
1549
+            if(!empty($background_i)){
1550
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1551
+            }
1552
+
1553
+            // add any border color rules
1554
+            if(!empty($border)){
1555
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1556
+            }
1557
+            if(!empty($border_i)){
1558
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1559
+            }
1560
+
1561
+            // add any fill color rules
1562
+            if(!empty($fill)){
1563
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1564
+            }
1565
+            if(!empty($fill_i)){
1566
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1567
+            }
1568
+
1569
+
1570
+            $prefix = $compatibility ? ".bsui " : "";
1571
+
1572
+            // darken
1573
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1574
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1575
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1576
+
1577
+            // lighten
1578
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1579
+
1580
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1581
+            $op_25 = $color_code."40"; // 25% opacity
1582
+
1583
+
1584
+            // button states
1585
+            $output .= $prefix ." .btn-primary:hover, $prefix .btn-primary:focus, $prefix .btn-primary.focus{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1586
+            $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;} ";
1587
+            $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.";} ";
1588
+            $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;} ";
1589
+
1590
+
1591
+            // dropdown's
1592
+            $output .= $prefix ." .dropdown-item.active, $prefix .dropdown-item:active{background-color: $color_code;} ";
1593
+
1594
+
1595
+            // input states
1596
+            $output .= $prefix ." .form-control:focus{border-color: ".$lighten_25.";box-shadow: 0 0 0 0.2rem $op_25;} ";
1597
+
1598
+            // page link
1599
+            $output .= $prefix ." .page-link:focus{box-shadow: 0 0 0 0.2rem $op_25;} ";
1600
+
1601
+            return $output;
1602
+        }
1603
+
1604
+        public static function css_secondary($color_code,$compatibility){;
1605
+            $color_code = sanitize_hex_color($color_code);
1606
+            if(!$color_code){return '';}
1607
+            /**
1608
+             * c = color, b = background color, o = border-color, f = fill
1609
+             */
1610
+            $selectors = array(
1611
+                '.btn-secondary' => array('b','o'),
1612
+                '.btn-secondary.disabled' => array('b','o'),
1613
+                '.btn-secondary:disabled' => array('b','o'),
1614
+                '.btn-outline-secondary' => array('c','o'),
1615
+                '.btn-outline-secondary:hover' => array('b','o'),
1616
+                '.btn-outline-secondary.disabled' => array('c'),
1617
+                '.btn-outline-secondary:disabled' => array('c'),
1618
+                '.btn-outline-secondary:not(:disabled):not(.disabled):active' => array('b','o'),
1619
+                '.btn-outline-secondary:not(:disabled):not(.disabled).active' => array('b','o'),
1620
+                '.btn-outline-secondary.dropdown-toggle' => array('b','o'),
1621
+                '.badge-secondary' => array('b'),
1622
+                '.alert-secondary' => array('b','o'),
1623
+                '.btn-link.btn-secondary' => array('c'),
1624
+            );
1625
+
1626
+            $important_selectors = array(
1627
+                '.bg-secondary' => array('b','f'),
1628
+                '.border-secondary' => array('o'),
1629
+                '.text-secondary' => array('c'),
1630
+            );
1631
+
1632
+            $color = array();
1633
+            $color_i = array();
1634
+            $background = array();
1635
+            $background_i = array();
1636
+            $border = array();
1637
+            $border_i = array();
1638
+            $fill = array();
1639
+            $fill_i = array();
1640
+
1641
+            $output = '';
1642
+
1643
+            // build rules into each type
1644
+            foreach($selectors as $selector => $types){
1645
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1646
+                $types = array_combine($types,$types);
1647
+                if(isset($types['c'])){$color[] = $selector;}
1648
+                if(isset($types['b'])){$background[] = $selector;}
1649
+                if(isset($types['o'])){$border[] = $selector;}
1650
+                if(isset($types['f'])){$fill[] = $selector;}
1651
+            }
1652
+
1653
+            // build rules into each type
1654
+            foreach($important_selectors as $selector => $types){
1655
+                $selector = $compatibility ? ".bsui ".$selector : $selector;
1656
+                $types = array_combine($types,$types);
1657
+                if(isset($types['c'])){$color_i[] = $selector;}
1658
+                if(isset($types['b'])){$background_i[] = $selector;}
1659
+                if(isset($types['o'])){$border_i[] = $selector;}
1660
+                if(isset($types['f'])){$fill_i[] = $selector;}
1661
+            }
1662
+
1663
+            // add any color rules
1664
+            if(!empty($color)){
1665
+                $output .= implode(",",$color) . "{color: $color_code;} ";
1666
+            }
1667
+            if(!empty($color_i)){
1668
+                $output .= implode(",",$color_i) . "{color: $color_code !important;} ";
1669
+            }
1670
+
1671
+            // add any background color rules
1672
+            if(!empty($background)){
1673
+                $output .= implode(",",$background) . "{background-color: $color_code;} ";
1674
+            }
1675
+            if(!empty($background_i)){
1676
+                $output .= implode(",",$background_i) . "{background-color: $color_code !important;} ";
1677
+            }
1678
+
1679
+            // add any border color rules
1680
+            if(!empty($border)){
1681
+                $output .= implode(",",$border) . "{border-color: $color_code;} ";
1682
+            }
1683
+            if(!empty($border_i)){
1684
+                $output .= implode(",",$border_i) . "{border-color: $color_code !important;} ";
1685
+            }
1686
+
1687
+            // add any fill color rules
1688
+            if(!empty($fill)){
1689
+                $output .= implode(",",$fill) . "{fill: $color_code;} ";
1690
+            }
1691
+            if(!empty($fill_i)){
1692
+                $output .= implode(",",$fill_i) . "{fill: $color_code !important;} ";
1693
+            }
1694
+
1695
+
1696
+            $prefix = $compatibility ? ".bsui " : "";
1697
+
1698
+            // darken
1699
+            $darker_075 = self::css_hex_lighten_darken($color_code,"-0.075");
1700
+            $darker_10 = self::css_hex_lighten_darken($color_code,"-0.10");
1701
+            $darker_125 = self::css_hex_lighten_darken($color_code,"-0.125");
1702
+
1703
+            // lighten
1704
+            $lighten_25 = self::css_hex_lighten_darken($color_code,"0.25");
1705
+
1706
+            // opacity see https://css-tricks.com/8-digit-hex-codes/
1707
+            $op_25 = $color_code."40"; // 25% opacity
1708
+
1709
+
1710
+            // button states
1711
+            $output .= $prefix ." .btn-secondary:hover{background-color: ".$darker_075.";    border-color: ".$darker_10.";} ";
1712
+            $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;} ";
1713
+            $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.";} ";
1714
+            $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;} ";
1715
+
1716
+
1717
+            return $output;
1718
+        }
1719
+
1720
+        /**
1721
+         * Increases or decreases the brightness of a color by a percentage of the current brightness.
1722
+         *
1723
+         * @param   string  $hexCode        Supported formats: `#FFF`, `#FFFFFF`, `FFF`, `FFFFFF`
1724
+         * @param   float   $adjustPercent  A number between -1 and 1. E.g. 0.3 = 30% lighter; -0.4 = 40% darker.
1725
+         *
1726
+         * @return  string
1727
+         */
1728
+        public static function css_hex_lighten_darken($hexCode, $adjustPercent) {
1729
+            $hexCode = ltrim($hexCode, '#');
1730
+
1731
+            if (strlen($hexCode) == 3) {
1732
+                $hexCode = $hexCode[0] . $hexCode[0] . $hexCode[1] . $hexCode[1] . $hexCode[2] . $hexCode[2];
1733
+            }
1734
+
1735
+            $hexCode = array_map('hexdec', str_split($hexCode, 2));
1736
+
1737
+            foreach ($hexCode as & $color) {
1738
+                $adjustableLimit = $adjustPercent < 0 ? $color : 255 - $color;
1739
+                $adjustAmount = ceil($adjustableLimit * $adjustPercent);
1740
+
1741
+                $color = str_pad(dechex($color + $adjustAmount), 2, '0', STR_PAD_LEFT);
1742
+            }
1743
+
1744
+            return '#' . implode($hexCode);
1745
+        }
1746
+
1747
+        /**
1748
+         * Check if we should display examples.
1749
+         */
1750
+        public function maybe_show_examples(){
1751
+            if(current_user_can('manage_options') && isset($_REQUEST['preview-aui'])){
1752
+                echo "<head>";
1753
+                wp_head();
1754
+                echo "</head>";
1755
+                echo "<body>";
1756
+                echo $this->get_examples();
1757
+                echo "</body>";
1758
+                exit;
1759
+            }
1760
+        }
1761
+
1762
+        /**
1763
+         * Get developer examples.
1764
+         *
1765
+         * @return string
1766
+         */
1767
+        public function get_examples(){
1768
+            $output = '';
1769
+
1770
+
1771
+            // open form
1772
+            $output .= "<form class='p-5 m-5 border rounded'>";
1773
+
1774
+            // input example
1775
+            $output .= aui()->input(array(
1776
+                'type'  =>  'text',
1777
+                'id'    =>  'text-example',
1778
+                'name'    =>  'text-example',
1779
+                'placeholder'   => 'text placeholder',
1780
+                'title'   => 'Text input example',
1781
+                'value' =>  '',
1782
+                'required'  => false,
1783
+                'help_text' => 'help text',
1784
+                'label' => 'Text input example label'
1785
+            ));
1786
+
1787
+            // input example
1788
+            $output .= aui()->input(array(
1789
+                'type'  =>  'url',
1790
+                'id'    =>  'text-example2',
1791
+                'name'    =>  'text-example',
1792
+                'placeholder'   => 'url placeholder',
1793
+                'title'   => 'Text input example',
1794
+                'value' =>  '',
1795
+                'required'  => false,
1796
+                'help_text' => 'help text',
1797
+                'label' => 'Text input example label'
1798
+            ));
1799
+
1800
+            // checkbox example
1801
+            $output .= aui()->input(array(
1802
+                'type'  =>  'checkbox',
1803
+                'id'    =>  'checkbox-example',
1804
+                'name'    =>  'checkbox-example',
1805
+                'placeholder'   => 'checkbox-example',
1806
+                'title'   => 'Checkbox example',
1807
+                'value' =>  '1',
1808
+                'checked'   => true,
1809
+                'required'  => false,
1810
+                'help_text' => 'help text',
1811
+                'label' => 'Checkbox checked'
1812
+            ));
1813
+
1814
+            // checkbox example
1815
+            $output .= aui()->input(array(
1816
+                'type'  =>  'checkbox',
1817
+                'id'    =>  'checkbox-example2',
1818
+                'name'    =>  'checkbox-example2',
1819
+                'placeholder'   => 'checkbox-example',
1820
+                'title'   => 'Checkbox example',
1821
+                'value' =>  '1',
1822
+                'checked'   => false,
1823
+                'required'  => false,
1824
+                'help_text' => 'help text',
1825
+                'label' => 'Checkbox un-checked'
1826
+            ));
1827
+
1828
+            // switch example
1829
+            $output .= aui()->input(array(
1830
+                'type'  =>  'checkbox',
1831
+                'id'    =>  'switch-example',
1832
+                'name'    =>  'switch-example',
1833
+                'placeholder'   => 'checkbox-example',
1834
+                'title'   => 'Switch example',
1835
+                'value' =>  '1',
1836
+                'checked'   => true,
1837
+                'switch'    => true,
1838
+                'required'  => false,
1839
+                'help_text' => 'help text',
1840
+                'label' => 'Switch on'
1841
+            ));
1842
+
1843
+            // switch example
1844
+            $output .= aui()->input(array(
1845
+                'type'  =>  'checkbox',
1846
+                'id'    =>  'switch-example2',
1847
+                'name'    =>  'switch-example2',
1848
+                'placeholder'   => 'checkbox-example',
1849
+                'title'   => 'Switch example',
1850
+                'value' =>  '1',
1851
+                'checked'   => false,
1852
+                'switch'    => true,
1853
+                'required'  => false,
1854
+                'help_text' => 'help text',
1855
+                'label' => 'Switch off'
1856
+            ));
1857
+
1858
+            // close form
1859
+            $output .= "</form>";
1860
+
1861
+            return $output;
1862
+        }
1863
+
1864
+        /**
1865
+         * Calendar params.
1866
+         *
1867
+         * @since 0.1.44
1868
+         *
1869
+         * @return array Calendar params.
1870
+         */
1871
+        public static function calendar_params() {
1872
+            $params = array(
1873
+                'month_long_1' => __( 'January', 'aui' ),
1874
+                'month_long_2' => __( 'February', 'aui' ),
1875
+                'month_long_3' => __( 'March', 'aui' ),
1876
+                'month_long_4' => __( 'April', 'aui' ),
1877
+                'month_long_5' => __( 'May', 'aui' ),
1878
+                'month_long_6' => __( 'June', 'aui' ),
1879
+                'month_long_7' => __( 'July', 'aui' ),
1880
+                'month_long_8' => __( 'August', 'aui' ),
1881
+                'month_long_9' => __( 'September', 'aui' ),
1882
+                'month_long_10' => __( 'October', 'aui' ),
1883
+                'month_long_11' => __( 'November', 'aui' ),
1884
+                'month_long_12' => __( 'December', 'aui' ),
1885
+                'month_s_1' => _x( 'Jan', 'January abbreviation', 'aui' ),
1886
+                'month_s_2' => _x( 'Feb', 'February abbreviation', 'aui' ),
1887
+                'month_s_3' => _x( 'Mar', 'March abbreviation', 'aui' ),
1888
+                'month_s_4' => _x( 'Apr', 'April abbreviation', 'aui' ),
1889
+                'month_s_5' => _x( 'May', 'May abbreviation', 'aui' ),
1890
+                'month_s_6' => _x( 'Jun', 'June abbreviation', 'aui' ),
1891
+                'month_s_7' => _x( 'Jul', 'July abbreviation', 'aui' ),
1892
+                'month_s_8' => _x( 'Aug', 'August abbreviation', 'aui' ),
1893
+                'month_s_9' => _x( 'Sep', 'September abbreviation', 'aui' ),
1894
+                'month_s_10' => _x( 'Oct', 'October abbreviation', 'aui' ),
1895
+                'month_s_11' => _x( 'Nov', 'November abbreviation', 'aui' ),
1896
+                'month_s_12' => _x( 'Dec', 'December abbreviation', 'aui' ),
1897
+                'day_s1_1' => _x( 'S', 'Sunday initial', 'aui' ),
1898
+                'day_s1_2' => _x( 'M', 'Monday initial', 'aui' ),
1899
+                'day_s1_3' => _x( 'T', 'Tuesday initial', 'aui' ),
1900
+                'day_s1_4' => _x( 'W', 'Wednesday initial', 'aui' ),
1901
+                'day_s1_5' => _x( 'T', 'Friday initial', 'aui' ),
1902
+                'day_s1_6' => _x( 'F', 'Thursday initial', 'aui' ),
1903
+                'day_s1_7' => _x( 'S', 'Saturday initial', 'aui' ),
1904
+                'day_s2_1' => __( 'Su', 'aui' ),
1905
+                'day_s2_2' => __( 'Mo', 'aui' ),
1906
+                'day_s2_3' => __( 'Tu', 'aui' ),
1907
+                'day_s2_4' => __( 'We', 'aui' ),
1908
+                'day_s2_5' => __( 'Th', 'aui' ),
1909
+                'day_s2_6' => __( 'Fr', 'aui' ),
1910
+                'day_s2_7' => __( 'Sa', 'aui' ),
1911
+                'day_s3_1' => __( 'Sun', 'aui' ),
1912
+                'day_s3_2' => __( 'Mon', 'aui' ),
1913
+                'day_s3_3' => __( 'Tue', 'aui' ),
1914
+                'day_s3_4' => __( 'Wed', 'aui' ),
1915
+                'day_s3_5' => __( 'Thu', 'aui' ),
1916
+                'day_s3_6' => __( 'Fri', 'aui' ),
1917
+                'day_s3_7' => __( 'Sat', 'aui' ),
1918
+                'day_s5_1' => __( 'Sunday', 'aui' ),
1919
+                'day_s5_2' => __( 'Monday', 'aui' ),
1920
+                'day_s5_3' => __( 'Tuesday', 'aui' ),
1921
+                'day_s5_4' => __( 'Wednesday', 'aui' ),
1922
+                'day_s5_5' => __( 'Thursday', 'aui' ),
1923
+                'day_s5_6' => __( 'Friday', 'aui' ),
1924
+                'day_s5_7' => __( 'Saturday', 'aui' ),
1925
+                'am_lower' => __( 'am', 'aui' ),
1926
+                'pm_lower' => __( 'pm', 'aui' ),
1927
+                'am_upper' => __( 'AM', 'aui' ),
1928
+                'pm_upper' => __( 'PM', 'aui' ),
1929
+                'firstDayOfWeek' => (int) get_option( 'start_of_week' ),
1930
+                'time_24hr' => false,
1931
+                'year' => __( 'Year', 'aui' ),
1932
+                'hour' => __( 'Hour', 'aui' ),
1933
+                'minute' => __( 'Minute', 'aui' ),
1934
+                'weekAbbreviation' => __( 'Wk', 'aui' ),
1935
+                'rangeSeparator' => __( ' to ', 'aui' ),
1936
+                'scrollTitle' => __( 'Scroll to increment', 'aui' ),
1937
+                'toggleTitle' => __( 'Click to toggle', 'aui' )
1938
+            );
1939
+
1940
+            return apply_filters( 'ayecode_ui_calendar_params', $params );
1941
+        }
1942
+
1943
+        /**
1944
+         * Flatpickr calendar localize.
1945
+         *
1946
+         * @since 0.1.44
1947
+         *
1948
+         * @return string Calendar locale.
1949
+         */
1950
+        public static function flatpickr_locale() {
1951
+            $params = self::calendar_params();
1952
+
1953
+            if ( is_string( $params ) ) {
1954
+                $params = html_entity_decode( $params, ENT_QUOTES, 'UTF-8' );
1955
+            } else {
1956
+                foreach ( (array) $params as $key => $value ) {
1957
+                    if ( ! is_scalar( $value ) ) {
1958
+                        continue;
1959
+                    }
1960
+
1961
+                    $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
1962
+                }
1963
+            }
1964 1964
 
1965
-			$day_s3 = array();
1966
-			$day_s5 = array();
1965
+            $day_s3 = array();
1966
+            $day_s5 = array();
1967 1967
 
1968
-			for ( $i = 1; $i <= 7; $i ++ ) {
1969
-				$day_s3[] = addslashes( $params[ 'day_s3_' . $i ] );
1970
-				$day_s5[] = addslashes( $params[ 'day_s3_' . $i ] );
1971
-			}
1968
+            for ( $i = 1; $i <= 7; $i ++ ) {
1969
+                $day_s3[] = addslashes( $params[ 'day_s3_' . $i ] );
1970
+                $day_s5[] = addslashes( $params[ 'day_s3_' . $i ] );
1971
+            }
1972 1972
 
1973
-			$month_s = array();
1974
-			$month_long = array();
1973
+            $month_s = array();
1974
+            $month_long = array();
1975 1975
 
1976
-			for ( $i = 1; $i <= 12; $i ++ ) {
1977
-				$month_s[] = addslashes( $params[ 'month_s_' . $i ] );
1978
-				$month_long[] = addslashes( $params[ 'month_long_' . $i ] );
1979
-			}
1976
+            for ( $i = 1; $i <= 12; $i ++ ) {
1977
+                $month_s[] = addslashes( $params[ 'month_s_' . $i ] );
1978
+                $month_long[] = addslashes( $params[ 'month_long_' . $i ] );
1979
+            }
1980 1980
 
1981 1981
 ob_start();
1982 1982
 if ( 0 ) { ?><script><?php } ?>
@@ -2018,184 +2018,184 @@  discard block
 block discarded – undo
2018 2018
 }
2019 2019
 <?php if ( 0 ) { ?></script><?php } ?>
2020 2020
 <?php
2021
-			$locale = ob_get_clean();
2022
-
2023
-			return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2024
-		}
2025
-
2026
-		/**
2027
-		 * Select2 JS params.
2028
-		 *
2029
-		 * @since 0.1.44
2030
-		 *
2031
-		 * @return array Select2 JS params.
2032
-		 */
2033
-		public static function select2_params() {
2034
-			$params = array(
2035
-				'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'aui' ),
2036
-				'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'aui' ),
2037
-				'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'aui' ),
2038
-				'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'aui' ),
2039
-				'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'aui' ),
2040
-				'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'aui' ),
2041
-				'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'aui' ),
2042
-				'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'aui' ),
2043
-				'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'aui' ),
2044
-				'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'aui' ),
2045
-				'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'aui' )
2046
-			);
2047
-
2048
-			return apply_filters( 'ayecode_ui_select2_params', $params );
2049
-		}
2050
-
2051
-		/**
2052
-		 * Select2 JS localize.
2053
-		 *
2054
-		 * @since 0.1.44
2055
-		 *
2056
-		 * @return string Select2 JS locale.
2057
-		 */
2058
-		public static function select2_locale() {
2059
-			$params = self::select2_params();
2060
-
2061
-			foreach ( (array) $params as $key => $value ) {
2062
-				if ( ! is_scalar( $value ) ) {
2063
-					continue;
2064
-				}
2065
-
2066
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2067
-			}
2068
-
2069
-			$locale = json_encode( $params );
2070
-
2071
-			return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2072
-		}
2073
-
2074
-		/**
2075
-		 * Time ago JS localize.
2076
-		 *
2077
-		 * @since 0.1.47
2078
-		 *
2079
-		 * @return string Time ago JS locale.
2080
-		 */
2081
-		public static function timeago_locale() {
2082
-			$params = array(
2083
-				'prefix_ago' => '',
2084
-				'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'aui' ),
2085
-				'prefix_after' => _x( 'after', 'time ago', 'aui' ) . ' ',
2086
-				'suffix_after' => '',
2087
-				'seconds' => _x( 'less than a minute', 'time ago', 'aui' ),
2088
-				'minute' => _x( 'about a minute', 'time ago', 'aui' ),
2089
-				'minutes' => _x( '%d minutes', 'time ago', 'aui' ),
2090
-				'hour' => _x( 'about an hour', 'time ago', 'aui' ),
2091
-				'hours' => _x( 'about %d hours', 'time ago', 'aui' ),
2092
-				'day' => _x( 'a day', 'time ago', 'aui' ),
2093
-				'days' => _x( '%d days', 'time ago', 'aui' ),
2094
-				'month' => _x( 'about a month', 'time ago', 'aui' ),
2095
-				'months' => _x( '%d months', 'time ago', 'aui' ),
2096
-				'year' => _x( 'about a year', 'time ago', 'aui' ),
2097
-				'years' => _x( '%d years', 'time ago', 'aui' ),
2098
-			);
2099
-
2100
-			$params = apply_filters( 'ayecode_ui_timeago_params', $params );
2101
-
2102
-			foreach ( (array) $params as $key => $value ) {
2103
-				if ( ! is_scalar( $value ) ) {
2104
-					continue;
2105
-				}
2106
-
2107
-				$params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2108
-			}
2109
-
2110
-			$locale = json_encode( $params );
2111
-
2112
-			return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2113
-		}
2114
-
2115
-		/**
2116
-		 * JavaScript Minifier
2117
-		 *
2118
-		 * @param $input
2119
-		 *
2120
-		 * @return mixed
2121
-		 */
2122
-		public static function minify_js($input) {
2123
-			if(trim($input) === "") return $input;
2124
-			return preg_replace(
2125
-				array(
2126
-					// Remove comment(s)
2127
-					'#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2128
-					// Remove white-space(s) outside the string and regex
2129
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2130
-					// Remove the last semicolon
2131
-					'#;+\}#',
2132
-					// Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2133
-					'#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2134
-					// --ibid. From `foo['bar']` to `foo.bar`
2135
-					'#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2136
-				),
2137
-				array(
2138
-					'$1',
2139
-					'$1$2',
2140
-					'}',
2141
-					'$1$3',
2142
-					'$1.$3'
2143
-				),
2144
-				$input);
2145
-		}
2021
+            $locale = ob_get_clean();
2022
+
2023
+            return apply_filters( 'ayecode_ui_flatpickr_locale', trim( $locale ) );
2024
+        }
2025
+
2026
+        /**
2027
+         * Select2 JS params.
2028
+         *
2029
+         * @since 0.1.44
2030
+         *
2031
+         * @return array Select2 JS params.
2032
+         */
2033
+        public static function select2_params() {
2034
+            $params = array(
2035
+                'i18n_select_state_text'    => esc_attr__( 'Select an option&hellip;', 'aui' ),
2036
+                'i18n_no_matches'           => _x( 'No matches found', 'enhanced select', 'aui' ),
2037
+                'i18n_ajax_error'           => _x( 'Loading failed', 'enhanced select', 'aui' ),
2038
+                'i18n_input_too_short_1'    => _x( 'Please enter 1 or more characters', 'enhanced select', 'aui' ),
2039
+                'i18n_input_too_short_n'    => _x( 'Please enter %item% or more characters', 'enhanced select', 'aui' ),
2040
+                'i18n_input_too_long_1'     => _x( 'Please delete 1 character', 'enhanced select', 'aui' ),
2041
+                'i18n_input_too_long_n'     => _x( 'Please delete %item% characters', 'enhanced select', 'aui' ),
2042
+                'i18n_selection_too_long_1' => _x( 'You can only select 1 item', 'enhanced select', 'aui' ),
2043
+                'i18n_selection_too_long_n' => _x( 'You can only select %item% items', 'enhanced select', 'aui' ),
2044
+                'i18n_load_more'            => _x( 'Loading more results&hellip;', 'enhanced select', 'aui' ),
2045
+                'i18n_searching'            => _x( 'Searching&hellip;', 'enhanced select', 'aui' )
2046
+            );
2047
+
2048
+            return apply_filters( 'ayecode_ui_select2_params', $params );
2049
+        }
2050
+
2051
+        /**
2052
+         * Select2 JS localize.
2053
+         *
2054
+         * @since 0.1.44
2055
+         *
2056
+         * @return string Select2 JS locale.
2057
+         */
2058
+        public static function select2_locale() {
2059
+            $params = self::select2_params();
2060
+
2061
+            foreach ( (array) $params as $key => $value ) {
2062
+                if ( ! is_scalar( $value ) ) {
2063
+                    continue;
2064
+                }
2146 2065
 
2147
-		/**
2148
-		 * Minify CSS
2149
-		 *
2150
-		 * @param $input
2151
-		 *
2152
-		 * @return mixed
2153
-		 */
2154
-		public static function minify_css($input) {
2155
-			if(trim($input) === "") return $input;
2156
-			return preg_replace(
2157
-				array(
2158
-					// Remove comment(s)
2159
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2160
-					// Remove unused white-space(s)
2161
-					'#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2162
-					// Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2163
-					'#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2164
-					// Replace `:0 0 0 0` with `:0`
2165
-					'#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2166
-					// Replace `background-position:0` with `background-position:0 0`
2167
-					'#(background-position):0(?=[;\}])#si',
2168
-					// Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2169
-					'#(?<=[\s:,\-])0+\.(\d+)#s',
2170
-					// Minify string value
2171
-					'#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2172
-					'#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2173
-					// Minify HEX color code
2174
-					'#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2175
-					// Replace `(border|outline):none` with `(border|outline):0`
2176
-					'#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2177
-					// Remove empty selector(s)
2178
-					'#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2179
-				),
2180
-				array(
2181
-					'$1',
2182
-					'$1$2$3$4$5$6$7',
2183
-					'$1',
2184
-					':0',
2185
-					'$1:0 0',
2186
-					'.$1',
2187
-					'$1$3',
2188
-					'$1$2$4$5',
2189
-					'$1$2$3',
2190
-					'$1:0',
2191
-					'$1$2'
2192
-				),
2193
-				$input);
2194
-		}
2195
-	}
2066
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2067
+            }
2068
+
2069
+            $locale = json_encode( $params );
2070
+
2071
+            return apply_filters( 'ayecode_ui_select2_locale', trim( $locale ) );
2072
+        }
2073
+
2074
+        /**
2075
+         * Time ago JS localize.
2076
+         *
2077
+         * @since 0.1.47
2078
+         *
2079
+         * @return string Time ago JS locale.
2080
+         */
2081
+        public static function timeago_locale() {
2082
+            $params = array(
2083
+                'prefix_ago' => '',
2084
+                'suffix_ago' => ' ' . _x( 'ago', 'time ago', 'aui' ),
2085
+                'prefix_after' => _x( 'after', 'time ago', 'aui' ) . ' ',
2086
+                'suffix_after' => '',
2087
+                'seconds' => _x( 'less than a minute', 'time ago', 'aui' ),
2088
+                'minute' => _x( 'about a minute', 'time ago', 'aui' ),
2089
+                'minutes' => _x( '%d minutes', 'time ago', 'aui' ),
2090
+                'hour' => _x( 'about an hour', 'time ago', 'aui' ),
2091
+                'hours' => _x( 'about %d hours', 'time ago', 'aui' ),
2092
+                'day' => _x( 'a day', 'time ago', 'aui' ),
2093
+                'days' => _x( '%d days', 'time ago', 'aui' ),
2094
+                'month' => _x( 'about a month', 'time ago', 'aui' ),
2095
+                'months' => _x( '%d months', 'time ago', 'aui' ),
2096
+                'year' => _x( 'about a year', 'time ago', 'aui' ),
2097
+                'years' => _x( '%d years', 'time ago', 'aui' ),
2098
+            );
2099
+
2100
+            $params = apply_filters( 'ayecode_ui_timeago_params', $params );
2101
+
2102
+            foreach ( (array) $params as $key => $value ) {
2103
+                if ( ! is_scalar( $value ) ) {
2104
+                    continue;
2105
+                }
2196 2106
 
2197
-	/**
2198
-	 * Run the class if found.
2199
-	 */
2200
-	AyeCode_UI_Settings::instance();
2107
+                $params[ $key ] = html_entity_decode( (string) $value, ENT_QUOTES, 'UTF-8' );
2108
+            }
2109
+
2110
+            $locale = json_encode( $params );
2111
+
2112
+            return apply_filters( 'ayecode_ui_timeago_locale', trim( $locale ) );
2113
+        }
2114
+
2115
+        /**
2116
+         * JavaScript Minifier
2117
+         *
2118
+         * @param $input
2119
+         *
2120
+         * @return mixed
2121
+         */
2122
+        public static function minify_js($input) {
2123
+            if(trim($input) === "") return $input;
2124
+            return preg_replace(
2125
+                array(
2126
+                    // Remove comment(s)
2127
+                    '#\s*("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')\s*|\s*\/\*(?!\!|@cc_on)(?>[\s\S]*?\*\/)\s*|\s*(?<![\:\=])\/\/.*(?=[\n\r]|$)|^\s*|\s*$#',
2128
+                    // Remove white-space(s) outside the string and regex
2129
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/)|\/(?!\/)[^\n\r]*?\/(?=[\s.,;]|[gimuy]|$))|\s*([!%&*\(\)\-=+\[\]\{\}|;:,.<>?\/])\s*#s',
2130
+                    // Remove the last semicolon
2131
+                    '#;+\}#',
2132
+                    // Minify object attribute(s) except JSON attribute(s). From `{'foo':'bar'}` to `{foo:'bar'}`
2133
+                    '#([\{,])([\'])(\d+|[a-z_][a-z0-9_]*)\2(?=\:)#i',
2134
+                    // --ibid. From `foo['bar']` to `foo.bar`
2135
+                    '#([a-z0-9_\)\]])\[([\'"])([a-z_][a-z0-9_]*)\2\]#i'
2136
+                ),
2137
+                array(
2138
+                    '$1',
2139
+                    '$1$2',
2140
+                    '}',
2141
+                    '$1$3',
2142
+                    '$1.$3'
2143
+                ),
2144
+                $input);
2145
+        }
2146
+
2147
+        /**
2148
+         * Minify CSS
2149
+         *
2150
+         * @param $input
2151
+         *
2152
+         * @return mixed
2153
+         */
2154
+        public static function minify_css($input) {
2155
+            if(trim($input) === "") return $input;
2156
+            return preg_replace(
2157
+                array(
2158
+                    // Remove comment(s)
2159
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')|\/\*(?!\!)(?>.*?\*\/)|^\s*|\s*$#s',
2160
+                    // Remove unused white-space(s)
2161
+                    '#("(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\'|\/\*(?>.*?\*\/))|\s*+;\s*+(})\s*+|\s*+([*$~^|]?+=|[{};,>~]|\s(?![0-9\.])|!important\b)\s*+|([[(:])\s++|\s++([])])|\s++(:)\s*+(?!(?>[^{}"\']++|"(?:[^"\\\]++|\\\.)*+"|\'(?:[^\'\\\\]++|\\\.)*+\')*+{)|^\s++|\s++\z|(\s)\s+#si',
2162
+                    // Replace `0(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)` with `0`
2163
+                    '#(?<=[\s:])(0)(cm|em|ex|in|mm|pc|pt|px|vh|vw|%)#si',
2164
+                    // Replace `:0 0 0 0` with `:0`
2165
+                    '#:(0\s+0|0\s+0\s+0\s+0)(?=[;\}]|\!important)#i',
2166
+                    // Replace `background-position:0` with `background-position:0 0`
2167
+                    '#(background-position):0(?=[;\}])#si',
2168
+                    // Replace `0.6` with `.6`, but only when preceded by `:`, `,`, `-` or a white-space
2169
+                    '#(?<=[\s:,\-])0+\.(\d+)#s',
2170
+                    // Minify string value
2171
+                    '#(\/\*(?>.*?\*\/))|(?<!content\:)([\'"])([a-z_][a-z0-9\-_]*?)\2(?=[\s\{\}\];,])#si',
2172
+                    '#(\/\*(?>.*?\*\/))|(\burl\()([\'"])([^\s]+?)\3(\))#si',
2173
+                    // Minify HEX color code
2174
+                    '#(?<=[\s:,\-]\#)([a-f0-6]+)\1([a-f0-6]+)\2([a-f0-6]+)\3#i',
2175
+                    // Replace `(border|outline):none` with `(border|outline):0`
2176
+                    '#(?<=[\{;])(border|outline):none(?=[;\}\!])#',
2177
+                    // Remove empty selector(s)
2178
+                    '#(\/\*(?>.*?\*\/))|(^|[\{\}])(?:[^\s\{\}]+)\{\}#s'
2179
+                ),
2180
+                array(
2181
+                    '$1',
2182
+                    '$1$2$3$4$5$6$7',
2183
+                    '$1',
2184
+                    ':0',
2185
+                    '$1:0 0',
2186
+                    '.$1',
2187
+                    '$1$3',
2188
+                    '$1$2$4$5',
2189
+                    '$1$2$3',
2190
+                    '$1:0',
2191
+                    '$1$2'
2192
+                ),
2193
+                $input);
2194
+        }
2195
+    }
2196
+
2197
+    /**
2198
+     * Run the class if found.
2199
+     */
2200
+    AyeCode_UI_Settings::instance();
2201 2201
 }
2202 2202
\ No newline at end of file
Please login to merge, or discard this patch.
includes/admin/register-settings.php 1 patch
Indentation   +295 added lines, -295 removed lines patch added patch discarded remove patch
@@ -196,11 +196,11 @@  discard block
 block discarded – undo
196 196
     $cb      = "wpinv_{$option['type']}_callback";
197 197
     $section = "wpinv_settings_{$tab}_$section";
198 198
 
199
-	if ( isset( $option['desc'] ) && ! empty( $option['help-tip'] ) ) {
200
-		$tip   = wpinv_clean( $option['desc'] );
201
-		$name .= "<span class='dashicons dashicons-editor-help wpi-help-tip' title='$tip'></span>";
202
-		unset( $option['desc'] );
203
-	}
199
+    if ( isset( $option['desc'] ) && ! empty( $option['help-tip'] ) ) {
200
+        $tip   = wpinv_clean( $option['desc'] );
201
+        $name .= "<span class='dashicons dashicons-editor-help wpi-help-tip' title='$tip'></span>";
202
+        unset( $option['desc'] );
203
+    }
204 204
 
205 205
     // Loop through all tabs.
206 206
     add_settings_field(
@@ -227,9 +227,9 @@  discard block
 block discarded – undo
227 227
             'faux'        => isset( $option['faux'] )        ? $option['faux']        : false,
228 228
             'onchange'    => isset( $option['onchange'] )   ? $option['onchange']     : '',
229 229
             'custom'      => isset( $option['custom'] )     ? $option['custom']       : '',
230
-			'default_content' => isset( $option['default_content'] )     ? $option['default_content']       : '',
231
-			'class'       => isset( $option['class'] )     ? $option['class']         : '',
232
-			'style'       => isset( $option['style'] )     ? $option['style']         : '',
230
+            'default_content' => isset( $option['default_content'] )     ? $option['default_content']       : '',
231
+            'class'       => isset( $option['class'] )     ? $option['class']         : '',
232
+            'style'       => isset( $option['style'] )     ? $option['style']         : '',
233 233
             'cols'        => isset( $option['cols'] ) && (int) $option['cols'] > 0 ? (int) $option['cols'] : 50,
234 234
             'rows'        => isset( $option['rows'] ) && (int) $option['rows'] > 0 ? (int) $option['rows'] : 5,
235 235
         )
@@ -243,7 +243,7 @@  discard block
 block discarded – undo
243 243
  * @return array
244 244
  */
245 245
 function wpinv_get_registered_settings() {
246
-	return array_filter( apply_filters( 'wpinv_registered_settings', wpinv_get_data( 'admin-settings' ) ) );
246
+    return array_filter( apply_filters( 'wpinv_registered_settings', wpinv_get_data( 'admin-settings' ) ) );
247 247
 }
248 248
 
249 249
 /**
@@ -262,11 +262,11 @@  discard block
 block discarded – undo
262 262
  */
263 263
 function wpinv_settings_sanitize( $input = array() ) {
264 264
 
265
-	$wpinv_options = wpinv_get_options();
266
-	$raw_referrer  = wp_get_raw_referer();
265
+    $wpinv_options = wpinv_get_options();
266
+    $raw_referrer  = wp_get_raw_referer();
267 267
 
268 268
     if ( empty( $raw_referrer ) ) {
269
-		return array_merge( $wpinv_options, $input );
269
+        return array_merge( $wpinv_options, $input );
270 270
     }
271 271
 
272 272
     wp_parse_str( $raw_referrer, $referrer );
@@ -291,10 +291,10 @@  discard block
 block discarded – undo
291 291
         }
292 292
 
293 293
         // General filter
294
-		$input[ $key ] = apply_filters( 'wpinv_settings_sanitize', $input[ $key ], $key );
294
+        $input[ $key ] = apply_filters( 'wpinv_settings_sanitize', $input[ $key ], $key );
295 295
 
296
-		// Key specific filter.
297
-		$input[ $key ] = apply_filters( "wpinv_settings_sanitize_$key", $input[ $key ] );
296
+        // Key specific filter.
297
+        $input[ $key ] = apply_filters( "wpinv_settings_sanitize_$key", $input[ $key ] );
298 298
     }
299 299
 
300 300
     // Loop through the whitelist and unset any that are empty for the tab being saved
@@ -337,14 +337,14 @@  discard block
 block discarded – undo
337 337
 
338 338
     foreach ( $new_rates as $rate ) {
339 339
 
340
-		$rate['rate']    = wpinv_sanitize_amount( $rate['rate'] );
341
-		$rate['name']    = sanitize_text_field( $rate['name'] );
342
-		$rate['state']   = sanitize_text_field( $rate['state'] );
343
-		$rate['country'] = sanitize_text_field( $rate['country'] );
344
-		$rate['global']  = empty( $rate['state'] );
345
-		$tax_rates[]     = $rate;
340
+        $rate['rate']    = wpinv_sanitize_amount( $rate['rate'] );
341
+        $rate['name']    = sanitize_text_field( $rate['name'] );
342
+        $rate['state']   = sanitize_text_field( $rate['state'] );
343
+        $rate['country'] = sanitize_text_field( $rate['country'] );
344
+        $rate['global']  = empty( $rate['state'] );
345
+        $tax_rates[]     = $rate;
346 346
 
347
-	}
347
+    }
348 348
 
349 349
     update_option( 'wpinv_tax_rates', $tax_rates );
350 350
 
@@ -357,11 +357,11 @@  discard block
 block discarded – undo
357 357
     $tabs['general']  = __( 'General', 'invoicing' );
358 358
     $tabs['gateways'] = __( 'Payment Gateways', 'invoicing' );
359 359
     $tabs['taxes']    = __( 'Taxes', 'invoicing' );
360
-	$tabs['emails']   = __( 'Emails', 'invoicing' );
360
+    $tabs['emails']   = __( 'Emails', 'invoicing' );
361 361
 
362
-	if ( count( getpaid_get_integration_settings() ) > 0 ) {
363
-		$tabs['integrations'] = __( 'Integrations', 'invoicing' );
364
-	}
362
+    if ( count( getpaid_get_integration_settings() ) > 0 ) {
363
+        $tabs['integrations'] = __( 'Integrations', 'invoicing' );
364
+    }
365 365
 
366 366
     $tabs['privacy']  = __( 'Privacy', 'invoicing' );
367 367
     $tabs['misc']     = __( 'Misc', 'invoicing' );
@@ -399,14 +399,14 @@  discard block
 block discarded – undo
399 399
         ) ),
400 400
         'taxes' => apply_filters( 'wpinv_settings_sections_taxes', array(
401 401
             'main'  => __( 'Tax Settings', 'invoicing' ),
402
-			'rates' => __( 'Tax Rates', 'invoicing' ),
403
-			'vat'   => __( 'EU VAT Settings', 'invoicing' )
402
+            'rates' => __( 'Tax Rates', 'invoicing' ),
403
+            'vat'   => __( 'EU VAT Settings', 'invoicing' )
404 404
         ) ),
405 405
         'emails' => apply_filters( 'wpinv_settings_sections_emails', array(
406 406
             'main' => __( 'Email Settings', 'invoicing' ),
407
-		) ),
407
+        ) ),
408 408
 
409
-		'integrations' => wp_list_pluck( getpaid_get_integration_settings(), 'label', 'id' ),
409
+        'integrations' => wp_list_pluck( getpaid_get_integration_settings(), 'label', 'id' ),
410 410
 
411 411
         'privacy' => apply_filters( 'wpinv_settings_sections_privacy', array(
412 412
             'main' => __( 'Privacy policy', 'invoicing' ),
@@ -426,48 +426,48 @@  discard block
 block discarded – undo
426 426
 }
427 427
 
428 428
 function wpinv_get_pages( $with_slug = false, $default_label = NULL ) {
429
-	$pages_options = array();
429
+    $pages_options = array();
430 430
 
431
-	if( $default_label !== NULL && $default_label !== false ) {
432
-		$pages_options = array( '' => $default_label ); // Blank option
433
-	}
431
+    if( $default_label !== NULL && $default_label !== false ) {
432
+        $pages_options = array( '' => $default_label ); // Blank option
433
+    }
434 434
 
435
-	$pages = get_pages();
436
-	if ( $pages ) {
437
-		foreach ( $pages as $page ) {
438
-			$title = $with_slug ? $page->post_title . ' (' . $page->post_name . ')' : $page->post_title;
435
+    $pages = get_pages();
436
+    if ( $pages ) {
437
+        foreach ( $pages as $page ) {
438
+            $title = $with_slug ? $page->post_title . ' (' . $page->post_name . ')' : $page->post_title;
439 439
             $pages_options[ $page->ID ] = $title;
440
-		}
441
-	}
440
+        }
441
+    }
442 442
 
443
-	return $pages_options;
443
+    return $pages_options;
444 444
 }
445 445
 
446 446
 function wpinv_header_callback( $args ) {
447
-	if ( !empty( $args['desc'] ) ) {
447
+    if ( !empty( $args['desc'] ) ) {
448 448
         echo $args['desc'];
449 449
     }
450 450
 }
451 451
 
452 452
 function wpinv_hidden_callback( $args ) {
453 453
 
454
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
455
-	$value   = wpinv_get_option( $args['id'], $std );
454
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
455
+    $value   = wpinv_get_option( $args['id'], $std );
456 456
 
457
-	if ( isset( $args['set_value'] ) ) {
458
-		$value = $args['set_value'];
459
-	}
457
+    if ( isset( $args['set_value'] ) ) {
458
+        $value = $args['set_value'];
459
+    }
460 460
 
461
-	if ( isset( $args['faux'] ) && true === $args['faux'] ) {
462
-		$args['readonly'] = true;
463
-		$name  = '';
464
-	} else {
465
-		$name = 'name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"';
466
-	}
461
+    if ( isset( $args['faux'] ) && true === $args['faux'] ) {
462
+        $args['readonly'] = true;
463
+        $name  = '';
464
+    } else {
465
+        $name = 'name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"';
466
+    }
467 467
 
468
-	$html = '<input type="hidden" id="wpinv_settings[' . wpinv_sanitize_key( $args['id'] ) . ']" ' . $name . ' value="' . esc_attr( stripslashes( $value ) ) . '" />';
468
+    $html = '<input type="hidden" id="wpinv_settings[' . wpinv_sanitize_key( $args['id'] ) . ']" ' . $name . ' value="' . esc_attr( stripslashes( $value ) ) . '" />';
469 469
     
470
-	echo $html;
470
+    echo $html;
471 471
 }
472 472
 
473 473
 /**
@@ -475,12 +475,12 @@  discard block
 block discarded – undo
475 475
  */
476 476
 function wpinv_checkbox_callback( $args ) {
477 477
 
478
-	$std = isset( $args['std'] ) ? $args['std'] : '';
479
-	$std = wpinv_get_option( $args['id'], $std );
480
-	$id  = esc_attr( $args['id'] );
478
+    $std = isset( $args['std'] ) ? $args['std'] : '';
479
+    $std = wpinv_get_option( $args['id'], $std );
480
+    $id  = esc_attr( $args['id'] );
481 481
 
482
-	getpaid_hidden_field( "wpinv_settings[$id]", '0' );
483
-	?>
482
+    getpaid_hidden_field( "wpinv_settings[$id]", '0' );
483
+    ?>
484 484
 		<fieldset>
485 485
 			<label>
486 486
 				<input id="wpinv-settings-<?php echo $id; ?>" name="wpinv_settings[<?php echo $id; ?>]" <?php checked( empty( $std ), false ); ?> value="1" type="checkbox">
@@ -492,75 +492,75 @@  discard block
 block discarded – undo
492 492
 
493 493
 function wpinv_multicheck_callback( $args ) {
494 494
 
495
-	$sanitize_id = wpinv_sanitize_key( $args['id'] );
496
-	$class = !empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
495
+    $sanitize_id = wpinv_sanitize_key( $args['id'] );
496
+    $class = !empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
497 497
 
498
-	if ( ! empty( $args['options'] ) ) {
498
+    if ( ! empty( $args['options'] ) ) {
499 499
 
500
-		$std     = isset( $args['std'] ) ? $args['std'] : array();
501
-		$value   = wpinv_get_option( $args['id'], $std );
500
+        $std     = isset( $args['std'] ) ? $args['std'] : array();
501
+        $value   = wpinv_get_option( $args['id'], $std );
502 502
 
503
-		echo '<div class="wpi-mcheck-rows wpi-mcheck-' . $sanitize_id . $class . '">';
503
+        echo '<div class="wpi-mcheck-rows wpi-mcheck-' . $sanitize_id . $class . '">';
504 504
         foreach( $args['options'] as $key => $option ):
505
-			$sanitize_key = wpinv_sanitize_key( $key );
506
-			if ( in_array( $sanitize_key, $value ) ) { 
507
-				$enabled = $sanitize_key;
508
-			} else { 
509
-				$enabled = NULL; 
510
-			}
511
-			echo '<div class="wpi-mcheck-row"><input name="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" id="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" type="checkbox" value="' . esc_attr( $sanitize_key ) . '" ' . checked( $sanitize_key, $enabled, false ) . '/>&nbsp;';
512
-			echo '<label for="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']">' . wp_kses_post( $option ) . '</label></div>';
513
-		endforeach;
514
-		echo '</div>';
515
-		echo '<p class="description">' . $args['desc'] . '</p>';
516
-	}
505
+            $sanitize_key = wpinv_sanitize_key( $key );
506
+            if ( in_array( $sanitize_key, $value ) ) { 
507
+                $enabled = $sanitize_key;
508
+            } else { 
509
+                $enabled = NULL; 
510
+            }
511
+            echo '<div class="wpi-mcheck-row"><input name="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" id="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" type="checkbox" value="' . esc_attr( $sanitize_key ) . '" ' . checked( $sanitize_key, $enabled, false ) . '/>&nbsp;';
512
+            echo '<label for="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']">' . wp_kses_post( $option ) . '</label></div>';
513
+        endforeach;
514
+        echo '</div>';
515
+        echo '<p class="description">' . $args['desc'] . '</p>';
516
+    }
517 517
 }
518 518
 
519 519
 function wpinv_payment_icons_callback( $args ) {
520 520
     
521 521
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
522
-	$value   = wpinv_get_option( $args['id'], false);
522
+    $value   = wpinv_get_option( $args['id'], false);
523 523
 
524
-	if ( ! empty( $args['options'] ) ) {
525
-		foreach( $args['options'] as $key => $option ) {
524
+    if ( ! empty( $args['options'] ) ) {
525
+        foreach( $args['options'] as $key => $option ) {
526 526
             $sanitize_key = wpinv_sanitize_key( $key );
527 527
             
528
-			if( empty( $value ) ) {
529
-				$enabled = $option;
530
-			} else {
531
-				$enabled = NULL;
532
-			}
533
-
534
-			echo '<label for="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" style="margin-right:10px;line-height:16px;height:16px;display:inline-block;">';
535
-
536
-				echo '<input name="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" id="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" type="checkbox" value="' . esc_attr( $option ) . '" ' . checked( $option, $enabled, false ) . '/>&nbsp;';
537
-
538
-				if ( wpinv_string_is_image_url( $key ) ) {
539
-					echo '<img class="payment-icon" src="' . esc_url( $key ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
540
-				} else {
541
-					$card = strtolower( str_replace( ' ', '', $option ) );
542
-
543
-					if ( has_filter( 'wpinv_accepted_payment_' . $card . '_image' ) ) {
544
-						$image = apply_filters( 'wpinv_accepted_payment_' . $card . '_image', '' );
545
-					} else {
546
-						$image       = wpinv_locate_template( 'images' . DIRECTORY_SEPARATOR . 'icons' . DIRECTORY_SEPARATOR . $card . '.gif', false );
547
-						$content_dir = WP_CONTENT_DIR;
548
-
549
-						if ( function_exists( 'wp_normalize_path' ) ) {
550
-							// Replaces backslashes with forward slashes for Windows systems
551
-							$image = wp_normalize_path( $image );
552
-							$content_dir = wp_normalize_path( $content_dir );
553
-						}
554
-
555
-						$image = str_replace( $content_dir, content_url(), $image );
556
-					}
557
-
558
-					echo '<img class="payment-icon" src="' . esc_url( $image ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
559
-				}
560
-			echo $option . '</label>';
561
-		}
562
-		echo '<p class="description" style="margin-top:16px;">' . wp_kses_post( $args['desc'] ) . '</p>';
563
-	}
528
+            if( empty( $value ) ) {
529
+                $enabled = $option;
530
+            } else {
531
+                $enabled = NULL;
532
+            }
533
+
534
+            echo '<label for="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" style="margin-right:10px;line-height:16px;height:16px;display:inline-block;">';
535
+
536
+                echo '<input name="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" id="wpinv_settings[' . $sanitize_id . '][' . $sanitize_key . ']" type="checkbox" value="' . esc_attr( $option ) . '" ' . checked( $option, $enabled, false ) . '/>&nbsp;';
537
+
538
+                if ( wpinv_string_is_image_url( $key ) ) {
539
+                    echo '<img class="payment-icon" src="' . esc_url( $key ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
540
+                } else {
541
+                    $card = strtolower( str_replace( ' ', '', $option ) );
542
+
543
+                    if ( has_filter( 'wpinv_accepted_payment_' . $card . '_image' ) ) {
544
+                        $image = apply_filters( 'wpinv_accepted_payment_' . $card . '_image', '' );
545
+                    } else {
546
+                        $image       = wpinv_locate_template( 'images' . DIRECTORY_SEPARATOR . 'icons' . DIRECTORY_SEPARATOR . $card . '.gif', false );
547
+                        $content_dir = WP_CONTENT_DIR;
548
+
549
+                        if ( function_exists( 'wp_normalize_path' ) ) {
550
+                            // Replaces backslashes with forward slashes for Windows systems
551
+                            $image = wp_normalize_path( $image );
552
+                            $content_dir = wp_normalize_path( $content_dir );
553
+                        }
554
+
555
+                        $image = str_replace( $content_dir, content_url(), $image );
556
+                    }
557
+
558
+                    echo '<img class="payment-icon" src="' . esc_url( $image ) . '" style="width:32px;height:24px;position:relative;top:6px;margin-right:5px;"/>';
559
+                }
560
+            echo $option . '</label>';
561
+        }
562
+        echo '<p class="description" style="margin-top:16px;">' . wp_kses_post( $args['desc'] ) . '</p>';
563
+    }
564 564
 }
565 565
 
566 566
 /**
@@ -568,9 +568,9 @@  discard block
 block discarded – undo
568 568
  */
569 569
 function wpinv_radio_callback( $args ) {
570 570
 
571
-	$std = isset( $args['std'] ) ? $args['std'] : '';
572
-	$std = wpinv_get_option( $args['id'], $std );
573
-	?>
571
+    $std = isset( $args['std'] ) ? $args['std'] : '';
572
+    $std = wpinv_get_option( $args['id'], $std );
573
+    ?>
574 574
 		<fieldset>
575 575
 			<ul id="wpinv-settings-<?php echo esc_attr( $args['id'] ); ?>" style="margin-top: 0;">
576 576
 				<?php foreach( $args['options'] as $key => $option ) : ?>
@@ -584,7 +584,7 @@  discard block
 block discarded – undo
584 584
 			</ul>
585 585
 		</fieldset>
586 586
 	<?php
587
-	getpaid_settings_description_callback( $args );
587
+    getpaid_settings_description_callback( $args );
588 588
 }
589 589
 
590 590
 /**
@@ -592,10 +592,10 @@  discard block
 block discarded – undo
592 592
  */
593 593
 function getpaid_settings_description_callback( $args ) {
594 594
 
595
-	if ( ! empty( $args['desc'] ) ) {
596
-		$description = wp_kses_post( $args['desc'] );
597
-		echo "<p class='description'>$description</p>";
598
-	}
595
+    if ( ! empty( $args['desc'] ) ) {
596
+        $description = wp_kses_post( $args['desc'] );
597
+        echo "<p class='description'>$description</p>";
598
+    }
599 599
 
600 600
 }
601 601
 
@@ -604,7 +604,7 @@  discard block
 block discarded – undo
604 604
  */
605 605
 function wpinv_gateways_callback() {
606 606
 
607
-	?>
607
+    ?>
608 608
 		</td>
609 609
 	</tr>
610 610
 	<tr class="bsui">
@@ -618,22 +618,22 @@  discard block
 block discarded – undo
618 618
     
619 619
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
620 620
     $class = !empty( $args['class'] ) ? ' ' . esc_attr( $args['class'] ) : '';
621
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
622
-	$value   = wpinv_get_option( $args['id'], $std );
621
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
622
+    $value   = wpinv_get_option( $args['id'], $std );
623 623
 
624
-	echo '<select name="wpinv_settings[' . $sanitize_id . ']"" id="wpinv_settings[' . $sanitize_id . ']" class="'.$class.'" >';
624
+    echo '<select name="wpinv_settings[' . $sanitize_id . ']"" id="wpinv_settings[' . $sanitize_id . ']" class="'.$class.'" >';
625 625
 
626
-	foreach ( $args['options'] as $key => $option ) :
627
-		if ( isset( $args['selected'] ) && $args['selected'] !== null && $args['selected'] !== false ) {
626
+    foreach ( $args['options'] as $key => $option ) :
627
+        if ( isset( $args['selected'] ) && $args['selected'] !== null && $args['selected'] !== false ) {
628 628
             $selected = selected( $key, $args['selected'], false );
629 629
         } else {
630 630
             $selected = selected( $key, $value, false );
631 631
         }
632
-		echo '<option value="' . wpinv_sanitize_key( $key ) . '"' . $selected . '>' . esc_html( $option['admin_label'] ) . '</option>';
633
-	endforeach;
632
+        echo '<option value="' . wpinv_sanitize_key( $key ) . '"' . $selected . '>' . esc_html( $option['admin_label'] ) . '</option>';
633
+    endforeach;
634 634
 
635
-	echo '</select>';
636
-	echo '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
635
+    echo '</select>';
636
+    echo '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
637 637
 }
638 638
 
639 639
 /**
@@ -644,29 +644,29 @@  discard block
 block discarded – undo
644 644
  */
645 645
 function wpinv_settings_attrs_helper( $args ) {
646 646
 
647
-	$value        = isset( $args['std'] ) ? $args['std'] : '';
648
-	$id           = esc_attr( $args['id'] );
649
-	$placeholder  = esc_attr( $args['placeholder'] );
647
+    $value        = isset( $args['std'] ) ? $args['std'] : '';
648
+    $id           = esc_attr( $args['id'] );
649
+    $placeholder  = esc_attr( $args['placeholder'] );
650 650
 
651
-	if ( ! empty( $args['faux'] ) ) {
652
-		$args['readonly'] = true;
653
-		$name             = '';
654
-	} else {
655
-		$value  = wpinv_get_option( $args['id'], $value );
656
-		$name   = "wpinv_settings[$id]";
657
-	}
651
+    if ( ! empty( $args['faux'] ) ) {
652
+        $args['readonly'] = true;
653
+        $name             = '';
654
+    } else {
655
+        $value  = wpinv_get_option( $args['id'], $value );
656
+        $name   = "wpinv_settings[$id]";
657
+    }
658 658
 
659
-	$value    = is_scalar( $value ) ? esc_attr( $value ) : '';
660
-	$class    = esc_attr( $args['class'] );
661
-	$style    = esc_attr( $args['style'] );
662
-	$readonly = empty( $args['readonly'] ) ? '' : 'readonly onclick="this.select()"';
659
+    $value    = is_scalar( $value ) ? esc_attr( $value ) : '';
660
+    $class    = esc_attr( $args['class'] );
661
+    $style    = esc_attr( $args['style'] );
662
+    $readonly = empty( $args['readonly'] ) ? '' : 'readonly onclick="this.select()"';
663 663
 
664
-	$onchange = '';
664
+    $onchange = '';
665 665
     if ( ! empty( $args['onchange'] ) ) {
666 666
         $onchange = ' onchange="' . esc_attr( $args['onchange'] ) . '"';
667
-	}
667
+    }
668 668
 
669
-	return "name='$name' id='wpinv-settings-$id' style='$style' value='$value' class='$class' placeholder='$placeholder' data-placeholder='$placeholder' $onchange $readonly";
669
+    return "name='$name' id='wpinv-settings-$id' style='$style' value='$value' class='$class' placeholder='$placeholder' data-placeholder='$placeholder' $onchange $readonly";
670 670
 }
671 671
 
672 672
 /**
@@ -674,11 +674,11 @@  discard block
 block discarded – undo
674 674
  */
675 675
 function wpinv_text_callback( $args ) {
676 676
 
677
-	$desc = wp_kses_post( $args['desc'] );
678
-	$desc = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
679
-	$attr = wpinv_settings_attrs_helper( $args );
677
+    $desc = wp_kses_post( $args['desc'] );
678
+    $desc = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
679
+    $attr = wpinv_settings_attrs_helper( $args );
680 680
 
681
-	?>
681
+    ?>
682 682
 		<label style="width: 100%;">
683 683
 			<input type="text" <?php echo $attr; ?>>
684 684
 			<?php echo $desc; ?>
@@ -692,14 +692,14 @@  discard block
 block discarded – undo
692 692
  */
693 693
 function wpinv_number_callback( $args ) {
694 694
 
695
-	$desc = wp_kses_post( $args['desc'] );
696
-	$desc = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
697
-	$attr = wpinv_settings_attrs_helper( $args );
698
-	$max  = intval( $args['max'] );
699
-	$min  = intval( $args['min'] );
700
-	$step = floatval( $args['step'] );
695
+    $desc = wp_kses_post( $args['desc'] );
696
+    $desc = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
697
+    $attr = wpinv_settings_attrs_helper( $args );
698
+    $max  = intval( $args['max'] );
699
+    $min  = intval( $args['min'] );
700
+    $step = floatval( $args['step'] );
701 701
 
702
-	?>
702
+    ?>
703 703
 		<label style="width: 100%;">
704 704
 			<input type="number" step="<?php echo $step; ?>" max="<?php echo $max; ?>" min="<?php echo $min; ?>" <?php echo $attr; ?>>
705 705
 			<?php echo $desc; ?>
@@ -711,36 +711,36 @@  discard block
 block discarded – undo
711 711
 function wpinv_textarea_callback( $args ) {
712 712
     
713 713
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
714
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
715
-	$value   = wpinv_get_option( $args['id'], $std );
714
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
715
+    $value   = wpinv_get_option( $args['id'], $std );
716 716
 
717 717
     $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
718 718
     $class = ( isset( $args['class'] ) && ! is_null( $args['class'] ) ) ? $args['class'] : 'large-text';
719 719
 
720
-	$html = '<textarea class="' . sanitize_html_class( $class ) . ' txtarea-' . sanitize_html_class( $size ) . ' wpi-' . esc_attr( sanitize_html_class( $sanitize_id ) ) . ' " cols="' . $args['cols'] . '" rows="' . $args['rows'] . '" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
721
-	$html .= '<br /><label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
720
+    $html = '<textarea class="' . sanitize_html_class( $class ) . ' txtarea-' . sanitize_html_class( $size ) . ' wpi-' . esc_attr( sanitize_html_class( $sanitize_id ) ) . ' " cols="' . $args['cols'] . '" rows="' . $args['rows'] . '" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
721
+    $html .= '<br /><label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
722 722
 
723
-	echo $html;
723
+    echo $html;
724 724
 }
725 725
 
726 726
 function wpinv_password_callback( $args ) {
727 727
     
728 728
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
729
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
730
-	$value   = wpinv_get_option( $args['id'], $std );
729
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
730
+    $value   = wpinv_get_option( $args['id'], $std );
731 731
 
732
-	$size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
733
-	$html = '<input type="password" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '"/>';
734
-	$html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
732
+    $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
733
+    $html = '<input type="password" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '"/>';
734
+    $html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
735 735
 
736
-	echo $html;
736
+    echo $html;
737 737
 }
738 738
 
739 739
 function wpinv_missing_callback($args) {
740
-	printf(
741
-		__( 'The callback function used for the %s setting is missing.', 'invoicing' ),
742
-		'<strong>' . $args['id'] . '</strong>'
743
-	);
740
+    printf(
741
+        __( 'The callback function used for the %s setting is missing.', 'invoicing' ),
742
+        '<strong>' . $args['id'] . '</strong>'
743
+    );
744 744
 }
745 745
 
746 746
 /**
@@ -748,14 +748,14 @@  discard block
 block discarded – undo
748 748
  */
749 749
 function wpinv_select_callback( $args ) {
750 750
 
751
-	$desc   = wp_kses_post( $args['desc'] );
752
-	$desc   = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
753
-	$attr   = wpinv_settings_attrs_helper( $args );
754
-	$value  = isset( $args['std'] ) ? $args['std'] : '';
755
-	$value  = wpinv_get_option( $args['id'], $value );
756
-	$rand   = uniqid( 'random_id' );
751
+    $desc   = wp_kses_post( $args['desc'] );
752
+    $desc   = empty( $desc ) ? '' : "<p class='description'>$desc</p>";
753
+    $attr   = wpinv_settings_attrs_helper( $args );
754
+    $value  = isset( $args['std'] ) ? $args['std'] : '';
755
+    $value  = wpinv_get_option( $args['id'], $value );
756
+    $rand   = uniqid( 'random_id' );
757 757
 
758
-	?>
758
+    ?>
759 759
 		<label style="width: 100%;">
760 760
 			<select <?php echo $attr; ?>>
761 761
 				<?php foreach ( $args['options'] as $option => $name ) : ?>
@@ -788,104 +788,104 @@  discard block
 block discarded – undo
788 788
 function wpinv_color_select_callback( $args ) {
789 789
     
790 790
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
791
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
792
-	$value   = wpinv_get_option( $args['id'], $std );
791
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
792
+    $value   = wpinv_get_option( $args['id'], $std );
793 793
 
794
-	$html = '<select id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"/>';
794
+    $html = '<select id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"/>';
795 795
 
796
-	foreach ( $args['options'] as $option => $color ) {
797
-		$selected = selected( $option, $value, false );
798
-		$html .= '<option value="' . esc_attr( $option ) . '" ' . $selected . '>' . esc_html( $color['label'] ) . '</option>';
799
-	}
796
+    foreach ( $args['options'] as $option => $color ) {
797
+        $selected = selected( $option, $value, false );
798
+        $html .= '<option value="' . esc_attr( $option ) . '" ' . $selected . '>' . esc_html( $color['label'] ) . '</option>';
799
+    }
800 800
 
801
-	$html .= '</select>';
802
-	$html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
801
+    $html .= '</select>';
802
+    $html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
803 803
 
804
-	echo $html;
804
+    echo $html;
805 805
 }
806 806
 
807 807
 function wpinv_rich_editor_callback( $args ) {
808
-	global $wp_version;
808
+    global $wp_version;
809 809
     
810 810
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
811 811
 
812
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
813
-	$value   = wpinv_get_option( $args['id'], $std );
812
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
813
+    $value   = wpinv_get_option( $args['id'], $std );
814 814
 	
815
-	if ( ! empty( $args['allow_blank'] ) && empty( $value ) ) {
816
-		$value = $std;
817
-	}
815
+    if ( ! empty( $args['allow_blank'] ) && empty( $value ) ) {
816
+        $value = $std;
817
+    }
818 818
 
819
-	$rows = isset( $args['size'] ) ? $args['size'] : 20;
819
+    $rows = isset( $args['size'] ) ? $args['size'] : 20;
820 820
 
821
-	$html = '<div class="getpaid-settings-editor-input">';
822
-	if ( $wp_version >= 3.3 && function_exists( 'wp_editor' ) ) {
823
-		ob_start();
824
-		wp_editor( stripslashes( $value ), 'wpinv_settings_' . esc_attr( $args['id'] ), array( 'textarea_name' => 'wpinv_settings[' . esc_attr( $args['id'] ) . ']', 'textarea_rows' => absint( $rows ), 'media_buttons' => false ) );
825
-		$html .= ob_get_clean();
826
-	} else {
827
-		$html .= '<textarea class="large-text" rows="10" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="wpi-' . esc_attr( sanitize_html_class( $args['id'] ) ) . '">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
828
-	}
821
+    $html = '<div class="getpaid-settings-editor-input">';
822
+    if ( $wp_version >= 3.3 && function_exists( 'wp_editor' ) ) {
823
+        ob_start();
824
+        wp_editor( stripslashes( $value ), 'wpinv_settings_' . esc_attr( $args['id'] ), array( 'textarea_name' => 'wpinv_settings[' . esc_attr( $args['id'] ) . ']', 'textarea_rows' => absint( $rows ), 'media_buttons' => false ) );
825
+        $html .= ob_get_clean();
826
+    } else {
827
+        $html .= '<textarea class="large-text" rows="10" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" class="wpi-' . esc_attr( sanitize_html_class( $args['id'] ) ) . '">' . esc_textarea( stripslashes( $value ) ) . '</textarea>';
828
+    }
829 829
 
830
-	$html .= '</div><br/><label for="wpinv_settings[' . $sanitize_id . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
830
+    $html .= '</div><br/><label for="wpinv_settings[' . $sanitize_id . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
831 831
 
832
-	echo $html;
832
+    echo $html;
833 833
 }
834 834
 
835 835
 function wpinv_upload_callback( $args ) {
836 836
     
837 837
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
838 838
 
839
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
840
-	$value   = wpinv_get_option( $args['id'], $std );
839
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
840
+    $value   = wpinv_get_option( $args['id'], $std );
841 841
 
842
-	$size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
843
-	$html = '<input type="text" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( stripslashes( $value ) ) . '"/>';
844
-	$html .= '<span>&nbsp;<input type="button" class="wpinv_settings_upload_button button-secondary" value="' . __( 'Upload File', 'invoicing' ) . '"/></span>';
845
-	$html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
842
+    $size = ( isset( $args['size'] ) && ! is_null( $args['size'] ) ) ? $args['size'] : 'regular';
843
+    $html = '<input type="text" class="' . sanitize_html_class( $size ) . '-text" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( stripslashes( $value ) ) . '"/>';
844
+    $html .= '<span>&nbsp;<input type="button" class="wpinv_settings_upload_button button-secondary" value="' . __( 'Upload File', 'invoicing' ) . '"/></span>';
845
+    $html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> ' . wp_kses_post( $args['desc'] ) . '</label>';
846 846
 
847
-	echo $html;
847
+    echo $html;
848 848
 }
849 849
 
850 850
 function wpinv_color_callback( $args ) {
851 851
 
852
-	$std         = isset( $args['std'] ) ? $args['std'] : '';
853
-	$value       = wpinv_get_option( $args['id'], $std );
852
+    $std         = isset( $args['std'] ) ? $args['std'] : '';
853
+    $value       = wpinv_get_option( $args['id'], $std );
854 854
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
855 855
 
856
-	$html = '<input type="text" class="wpinv-color-picker" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '" data-default-color="' . esc_attr( $std ) . '" />';
857
-	$html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
856
+    $html = '<input type="text" class="wpinv-color-picker" id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']" value="' . esc_attr( $value ) . '" data-default-color="' . esc_attr( $std ) . '" />';
857
+    $html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
858 858
 
859
-	echo $html;
859
+    echo $html;
860 860
 }
861 861
 
862 862
 function wpinv_country_states_callback($args) {
863 863
 
864
-	$std     = isset( $args['std'] ) ? $args['std'] : '';
865
-	$value   = wpinv_get_option( $args['id'], $std );
864
+    $std     = isset( $args['std'] ) ? $args['std'] : '';
865
+    $value   = wpinv_get_option( $args['id'], $std );
866 866
 
867 867
     $sanitize_id = wpinv_sanitize_key( $args['id'] );
868 868
 
869
-	if ( isset( $args['placeholder'] ) ) {
870
-		$placeholder = $args['placeholder'];
871
-	} else {
872
-		$placeholder = '';
873
-	}
869
+    if ( isset( $args['placeholder'] ) ) {
870
+        $placeholder = $args['placeholder'];
871
+    } else {
872
+        $placeholder = '';
873
+    }
874 874
 
875
-	$states = wpinv_get_country_states();
875
+    $states = wpinv_get_country_states();
876 876
 
877
-	$class = empty( $states ) ? ' class="wpinv-no-states"' : ' class="wpi_select2"';
878
-	$html = '<select id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"' . $class . 'data-placeholder="' . esc_html( $placeholder ) . '"/>';
877
+    $class = empty( $states ) ? ' class="wpinv-no-states"' : ' class="wpi_select2"';
878
+    $html = '<select id="wpinv_settings[' . $sanitize_id . ']" name="wpinv_settings[' . esc_attr( $args['id'] ) . ']"' . $class . 'data-placeholder="' . esc_html( $placeholder ) . '"/>';
879 879
 
880
-	foreach ( $states as $option => $name ) {
881
-		$selected = selected( $option, $value, false );
882
-		$html .= '<option value="' . esc_attr( $option ) . '" ' . $selected . '>' . esc_html( $name ) . '</option>';
883
-	}
880
+    foreach ( $states as $option => $name ) {
881
+        $selected = selected( $option, $value, false );
882
+        $html .= '<option value="' . esc_attr( $option ) . '" ' . $selected . '>' . esc_html( $name ) . '</option>';
883
+    }
884 884
 
885
-	$html .= '</select>';
886
-	$html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
885
+    $html .= '</select>';
886
+    $html .= '<label for="wpinv_settings[' . $sanitize_id . ']"> '  . wp_kses_post( $args['desc'] ) . '</label>';
887 887
 
888
-	echo $html;
888
+    echo $html;
889 889
 }
890 890
 
891 891
 /**
@@ -893,7 +893,7 @@  discard block
 block discarded – undo
893 893
  */
894 894
 function wpinv_tax_rates_callback() {
895 895
 	
896
-	?>
896
+    ?>
897 897
 		</td>
898 898
 	</tr>
899 899
 	<tr class="bsui">
@@ -908,17 +908,17 @@  discard block
 block discarded – undo
908 908
  * Displays a tax rate' edit row.
909 909
  */
910 910
 function wpinv_tax_rate_callback( $tax_rate, $key, $echo = true ) {
911
-	ob_start();
911
+    ob_start();
912 912
 
913
-	$key                      = sanitize_key( $key );
914
-	$tax_rate['reduced_rate'] = empty( $tax_rate['reduced_rate'] ) ? 0 : $tax_rate['reduced_rate'];
915
-	include plugin_dir_path( __FILE__ ) . 'views/html-tax-rate-edit.php';
913
+    $key                      = sanitize_key( $key );
914
+    $tax_rate['reduced_rate'] = empty( $tax_rate['reduced_rate'] ) ? 0 : $tax_rate['reduced_rate'];
915
+    include plugin_dir_path( __FILE__ ) . 'views/html-tax-rate-edit.php';
916 916
 
917
-	if ( $echo ) {
918
-		echo ob_get_clean();
919
-	} else {
920
-		return ob_get_clean(); 
921
-	}
917
+    if ( $echo ) {
918
+        echo ob_get_clean();
919
+    } else {
920
+        return ob_get_clean(); 
921
+    }
922 922
 
923 923
 }
924 924
 
@@ -946,14 +946,14 @@  discard block
 block discarded – undo
946 946
                 </td>
947 947
                 <td>
948 948
 					<a href="<?php
949
-						echo esc_url(
950
-							wp_nonce_url(
951
-								add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
952
-								'getpaid-nonce',
953
-								'getpaid-nonce'
954
-							)
955
-						);
956
-					?>" class="button button-primary"><?php _e('Run', 'invoicing');?></a>
949
+                        echo esc_url(
950
+                            wp_nonce_url(
951
+                                add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
952
+                                'getpaid-nonce',
953
+                                'getpaid-nonce'
954
+                            )
955
+                        );
956
+                    ?>" class="button button-primary"><?php _e('Run', 'invoicing');?></a>
957 957
                 </td>
958 958
             </tr>
959 959
 			<tr>
@@ -963,14 +963,14 @@  discard block
 block discarded – undo
963 963
                 </td>
964 964
                 <td>
965 965
 					<a href="<?php
966
-						echo esc_url(
967
-							wp_nonce_url(
968
-								add_query_arg( 'getpaid-admin-action', 'create_missing_tables' ),
969
-								'getpaid-nonce',
970
-								'getpaid-nonce'
971
-							)
972
-						);
973
-					?>" class="button button-primary"><?php _e('Run', 'invoicing');?></a>
966
+                        echo esc_url(
967
+                            wp_nonce_url(
968
+                                add_query_arg( 'getpaid-admin-action', 'create_missing_tables' ),
969
+                                'getpaid-nonce',
970
+                                'getpaid-nonce'
971
+                            )
972
+                        );
973
+                    ?>" class="button button-primary"><?php _e('Run', 'invoicing');?></a>
974 974
                 </td>
975 975
             </tr>
976 976
 			<tr>
@@ -980,14 +980,14 @@  discard block
 block discarded – undo
980 980
                 </td>
981 981
                 <td>
982 982
 					<a href="<?php
983
-						echo esc_url(
984
-							wp_nonce_url(
985
-								add_query_arg( 'getpaid-admin-action', 'migrate_old_invoices' ),
986
-								'getpaid-nonce',
987
-								'getpaid-nonce'
988
-							)
989
-						);
990
-					?>" class="button button-primary"><?php _e('Run', 'invoicing');?></a>
983
+                        echo esc_url(
984
+                            wp_nonce_url(
985
+                                add_query_arg( 'getpaid-admin-action', 'migrate_old_invoices' ),
986
+                                'getpaid-nonce',
987
+                                'getpaid-nonce'
988
+                            )
989
+                        );
990
+                    ?>" class="button button-primary"><?php _e('Run', 'invoicing');?></a>
991 991
                 </td>
992 992
             </tr>
993 993
 
@@ -998,14 +998,14 @@  discard block
 block discarded – undo
998 998
                 </td>
999 999
                 <td>
1000 1000
 					<a href="<?php
1001
-						echo esc_url(
1002
-							wp_nonce_url(
1003
-								add_query_arg( 'getpaid-admin-action', 'recalculate_discounts' ),
1004
-								'getpaid-nonce',
1005
-								'getpaid-nonce'
1006
-							)
1007
-						);
1008
-					?>" class="button button-primary"><?php _e( 'Run', 'invoicing' );?></a>
1001
+                        echo esc_url(
1002
+                            wp_nonce_url(
1003
+                                add_query_arg( 'getpaid-admin-action', 'recalculate_discounts' ),
1004
+                                'getpaid-nonce',
1005
+                                'getpaid-nonce'
1006
+                            )
1007
+                        );
1008
+                    ?>" class="button button-primary"><?php _e( 'Run', 'invoicing' );?></a>
1009 1009
                 </td>
1010 1010
             </tr>
1011 1011
 
@@ -1019,19 +1019,19 @@  discard block
 block discarded – undo
1019 1019
 
1020 1020
 
1021 1021
 function wpinv_descriptive_text_callback( $args ) {
1022
-	echo wp_kses_post( $args['desc'] );
1022
+    echo wp_kses_post( $args['desc'] );
1023 1023
 }
1024 1024
 
1025 1025
 function wpinv_raw_html_callback( $args ) {
1026
-	echo $args['desc'];
1026
+    echo $args['desc'];
1027 1027
 }
1028 1028
 
1029 1029
 function wpinv_hook_callback( $args ) {
1030
-	do_action( 'wpinv_' . $args['id'], $args );
1030
+    do_action( 'wpinv_' . $args['id'], $args );
1031 1031
 }
1032 1032
 
1033 1033
 function wpinv_set_settings_cap() {
1034
-	return wpinv_get_capability();
1034
+    return wpinv_get_capability();
1035 1035
 }
1036 1036
 add_filter( 'option_page_capability_wpinv_settings', 'wpinv_set_settings_cap' );
1037 1037
 
@@ -1055,15 +1055,15 @@  discard block
 block discarded – undo
1055 1055
  */
1056 1056
 function wpinv_get_merge_tags_help_text( $subscription = false ) {
1057 1057
 
1058
-	$url  = $subscription ? 'https://gist.github.com/picocodes/3d213982d57c34edf7a46fd3f0e8583e' : 'https://gist.github.com/picocodes/43bdc4d4bbba844534b2722e2af0b58f';
1059
-	$link = sprintf(
1060
-		'<strong><a href="%s" target="_blank">%s</a></strong>',
1061
-		$url,
1062
-		esc_html__( 'View available merge tags.', 'wpinv-quotes' )
1063
-	);
1058
+    $url  = $subscription ? 'https://gist.github.com/picocodes/3d213982d57c34edf7a46fd3f0e8583e' : 'https://gist.github.com/picocodes/43bdc4d4bbba844534b2722e2af0b58f';
1059
+    $link = sprintf(
1060
+        '<strong><a href="%s" target="_blank">%s</a></strong>',
1061
+        $url,
1062
+        esc_html__( 'View available merge tags.', 'wpinv-quotes' )
1063
+    );
1064 1064
 
1065
-	$description = esc_html__( 'The content of the email (Merge Tags and HTML are allowed).', 'invoicing' );
1065
+    $description = esc_html__( 'The content of the email (Merge Tags and HTML are allowed).', 'invoicing' );
1066 1066
 
1067
-	return "$description $link";
1067
+    return "$description $link";
1068 1068
 
1069 1069
 }
Please login to merge, or discard this patch.
includes/class-getpaid-daily-maintenance.php 1 patch
Indentation   +140 added lines, -140 removed lines patch added patch discarded remove patch
@@ -12,145 +12,145 @@
 block discarded – undo
12 12
  */
13 13
 class GetPaid_Daily_Maintenance {
14 14
 
15
-	/**
16
-	 * Class constructor.
17
-	 */
18
-	public function __construct(){
19
-
20
-		// Clear deprecated events.
21
-		add_action( 'wp', array( $this, 'maybe_clear_deprecated_events' ) );
22
-
23
-		// (Maybe) schedule a cron that runs daily.
24
-		add_action( 'wp', array( $this, 'maybe_create_scheduled_event' ) );
25
-
26
-		// Fired everyday at 7 a.m (this might vary for sites with few visitors)
27
-		add_action( 'getpaid_daily_maintenance', array( $this, 'log_cron_run' ) );
28
-		add_action( 'getpaid_daily_maintenance', array( $this, 'backwards_compat' ) );
29
-		add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_expire_subscriptions' ) );
30
-		add_action( 'getpaid_daily_maintenance', array( $this, 'check_renewing_subscriptions' ) );
31
-		add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_update_geoip_databases' ) );
32
-
33
-	}
34
-
35
-	/**
36
-	 * Schedules a cron to run every day at 7 a.m
37
-	 *
38
-	 */
39
-	public function maybe_create_scheduled_event() {
40
-
41
-		if ( ! wp_next_scheduled( 'getpaid_daily_maintenance' ) ) {
42
-			$timestamp = strtotime( 'tomorrow 07:00:00', current_time( 'timestamp' ) );
43
-			wp_schedule_event( $timestamp, 'daily', 'getpaid_daily_maintenance' );
44
-		}
45
-
46
-	}
47
-
48
-	/**
49
-	 * Clears deprecated events.
50
-	 *
51
-	 */
52
-	public function maybe_clear_deprecated_events() {
53
-
54
-		if ( ! get_option( 'wpinv_cleared_old_events' ) ) {
55
-			wp_clear_scheduled_hook( 'wpinv_register_schedule_event_twicedaily' );
56
-			wp_clear_scheduled_hook( 'wpinv_register_schedule_event_daily' );
57
-			update_option( 'wpinv_cleared_old_events', 1 );
58
-		}
59
-
60
-	}
61
-
62
-	/**
63
-	 * Fires the old hook for backwards compatibility.
64
-	 *
65
-	 */
66
-	public function backwards_compat() {
67
-		do_action( 'wpinv_register_schedule_event_daily' );
68
-	}
69
-
70
-	/**
71
-	 * Checks for subscriptions that are scheduled to renew.
72
-	 *
73
-	 */
74
-	public function check_renewing_subscriptions() {
75
-
76
-		// Fetch subscriptions that expire today.
77
-		$args  = array(
78
-			'number'             => -1,
79
-			'count_total'        => false,
80
-			'status'             => 'trialling active',
81
-			'date_expires_query' => array(
82
-				array(
83
-					'year'          => date( 'Y', current_time( 'timestamp' ) ),
84
-					'month'         => date( 'n', current_time( 'timestamp' ) ),
85
-					'day'           => date( 'j', current_time( 'timestamp' ) ),
86
-					'compare'       => '=',
87
-				),
88
-			),
89
-		);
90
-
91
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
92
-
93
-		foreach ( $subscriptions->get_results() as $subscription ) {
94
-
95
-			/** @var WPInv_Subscription $subscription */
96
-			if ( $subscription->is_last_renewal() ) {
97
-				$subscription->complete();
98
-			} else {
99
-				do_action( 'getpaid_should_renew_subscription', $subscription );
100
-			}
101
-
102
-		}
103
-
104
-	}
105
-
106
-	/**
107
-	 * Expires expired subscriptions.
108
-	 *
109
-	 */
110
-	public function maybe_expire_subscriptions() {
111
-
112
-		// Fetch expired subscriptions (skips those that expire today).
113
-		$args  = array(
114
-			'number'             => -1,
115
-			'count_total'        => false,
116
-			'status'             => 'trialling active failing cancelled',
117
-			'date_expires_query' => array(
118
-				'before'    => 'yesterday',
119
-				'inclusive' => false,
120
-			),
121
-		);
122
-
123
-		$subscriptions = new GetPaid_Subscriptions_Query( $args );
124
-
125
-		foreach ( $subscriptions->get_results() as $subscription ) {
126
-			if ( apply_filters( 'getpaid_daily_maintenance_should_expire_subscription', true, $subscription ) ) {
127
-				$subscription->set_status( 'expired' );
128
-				$subscription->save();
129
-			}
130
-		}
131
-
132
-	}
133
-
134
-	/**
135
-	 * Logs cron runs.
136
-	 *
137
-	 */
138
-	public function log_cron_run() {
139
-		wpinv_error_log( 'GetPaid Daily Cron', false );
140
-	}
141
-
142
-	/**
143
-	 * Updates GeoIP databases.
144
-	 *
145
-	 */
146
-	public function maybe_update_geoip_databases() {
147
-		$updated = get_transient( 'getpaid_updated_geoip_databases' );
148
-
149
-		if ( false === $updated ) {
150
-			set_transient( 'getpaid_updated_geoip_databases', 1, 15 * DAY_IN_SECONDS );
151
-			do_action( 'getpaid_update_geoip_databases' );
152
-		}
153
-
154
-	}
15
+    /**
16
+     * Class constructor.
17
+     */
18
+    public function __construct(){
19
+
20
+        // Clear deprecated events.
21
+        add_action( 'wp', array( $this, 'maybe_clear_deprecated_events' ) );
22
+
23
+        // (Maybe) schedule a cron that runs daily.
24
+        add_action( 'wp', array( $this, 'maybe_create_scheduled_event' ) );
25
+
26
+        // Fired everyday at 7 a.m (this might vary for sites with few visitors)
27
+        add_action( 'getpaid_daily_maintenance', array( $this, 'log_cron_run' ) );
28
+        add_action( 'getpaid_daily_maintenance', array( $this, 'backwards_compat' ) );
29
+        add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_expire_subscriptions' ) );
30
+        add_action( 'getpaid_daily_maintenance', array( $this, 'check_renewing_subscriptions' ) );
31
+        add_action( 'getpaid_daily_maintenance', array( $this, 'maybe_update_geoip_databases' ) );
32
+
33
+    }
34
+
35
+    /**
36
+     * Schedules a cron to run every day at 7 a.m
37
+     *
38
+     */
39
+    public function maybe_create_scheduled_event() {
40
+
41
+        if ( ! wp_next_scheduled( 'getpaid_daily_maintenance' ) ) {
42
+            $timestamp = strtotime( 'tomorrow 07:00:00', current_time( 'timestamp' ) );
43
+            wp_schedule_event( $timestamp, 'daily', 'getpaid_daily_maintenance' );
44
+        }
45
+
46
+    }
47
+
48
+    /**
49
+     * Clears deprecated events.
50
+     *
51
+     */
52
+    public function maybe_clear_deprecated_events() {
53
+
54
+        if ( ! get_option( 'wpinv_cleared_old_events' ) ) {
55
+            wp_clear_scheduled_hook( 'wpinv_register_schedule_event_twicedaily' );
56
+            wp_clear_scheduled_hook( 'wpinv_register_schedule_event_daily' );
57
+            update_option( 'wpinv_cleared_old_events', 1 );
58
+        }
59
+
60
+    }
61
+
62
+    /**
63
+     * Fires the old hook for backwards compatibility.
64
+     *
65
+     */
66
+    public function backwards_compat() {
67
+        do_action( 'wpinv_register_schedule_event_daily' );
68
+    }
69
+
70
+    /**
71
+     * Checks for subscriptions that are scheduled to renew.
72
+     *
73
+     */
74
+    public function check_renewing_subscriptions() {
75
+
76
+        // Fetch subscriptions that expire today.
77
+        $args  = array(
78
+            'number'             => -1,
79
+            'count_total'        => false,
80
+            'status'             => 'trialling active',
81
+            'date_expires_query' => array(
82
+                array(
83
+                    'year'          => date( 'Y', current_time( 'timestamp' ) ),
84
+                    'month'         => date( 'n', current_time( 'timestamp' ) ),
85
+                    'day'           => date( 'j', current_time( 'timestamp' ) ),
86
+                    'compare'       => '=',
87
+                ),
88
+            ),
89
+        );
90
+
91
+        $subscriptions = new GetPaid_Subscriptions_Query( $args );
92
+
93
+        foreach ( $subscriptions->get_results() as $subscription ) {
94
+
95
+            /** @var WPInv_Subscription $subscription */
96
+            if ( $subscription->is_last_renewal() ) {
97
+                $subscription->complete();
98
+            } else {
99
+                do_action( 'getpaid_should_renew_subscription', $subscription );
100
+            }
101
+
102
+        }
103
+
104
+    }
105
+
106
+    /**
107
+     * Expires expired subscriptions.
108
+     *
109
+     */
110
+    public function maybe_expire_subscriptions() {
111
+
112
+        // Fetch expired subscriptions (skips those that expire today).
113
+        $args  = array(
114
+            'number'             => -1,
115
+            'count_total'        => false,
116
+            'status'             => 'trialling active failing cancelled',
117
+            'date_expires_query' => array(
118
+                'before'    => 'yesterday',
119
+                'inclusive' => false,
120
+            ),
121
+        );
122
+
123
+        $subscriptions = new GetPaid_Subscriptions_Query( $args );
124
+
125
+        foreach ( $subscriptions->get_results() as $subscription ) {
126
+            if ( apply_filters( 'getpaid_daily_maintenance_should_expire_subscription', true, $subscription ) ) {
127
+                $subscription->set_status( 'expired' );
128
+                $subscription->save();
129
+            }
130
+        }
131
+
132
+    }
133
+
134
+    /**
135
+     * Logs cron runs.
136
+     *
137
+     */
138
+    public function log_cron_run() {
139
+        wpinv_error_log( 'GetPaid Daily Cron', false );
140
+    }
141
+
142
+    /**
143
+     * Updates GeoIP databases.
144
+     *
145
+     */
146
+    public function maybe_update_geoip_databases() {
147
+        $updated = get_transient( 'getpaid_updated_geoip_databases' );
148
+
149
+        if ( false === $updated ) {
150
+            set_transient( 'getpaid_updated_geoip_databases', 1, 15 * DAY_IN_SECONDS );
151
+            do_action( 'getpaid_update_geoip_databases' );
152
+        }
153
+
154
+    }
155 155
 
156 156
 }
Please login to merge, or discard this patch.
invoicing.php 1 patch
Indentation   +4 added lines, -4 removed lines patch added patch discarded remove patch
@@ -19,16 +19,16 @@  discard block
 block discarded – undo
19 19
 
20 20
 // Define constants.
21 21
 if ( ! defined( 'WPINV_PLUGIN_FILE' ) ) {
22
-	define( 'WPINV_PLUGIN_FILE', __FILE__ );
22
+    define( 'WPINV_PLUGIN_FILE', __FILE__ );
23 23
 }
24 24
 
25 25
 if ( ! defined( 'WPINV_VERSION' ) ) {
26
-	define( 'WPINV_VERSION', '2.3.8' );
26
+    define( 'WPINV_VERSION', '2.3.8' );
27 27
 }
28 28
 
29 29
 // Include the main Invoicing class.
30 30
 if ( ! class_exists( 'WPInv_Plugin', false ) ) {
31
-	require_once plugin_dir_path( WPINV_PLUGIN_FILE ) . 'includes/class-wpinv.php';
31
+    require_once plugin_dir_path( WPINV_PLUGIN_FILE ) . 'includes/class-wpinv.php';
32 32
 }
33 33
 
34 34
 /**
@@ -43,7 +43,7 @@  discard block
 block discarded – undo
43 43
         $GLOBALS['invoicing'] = new WPInv_Plugin();
44 44
     }
45 45
 
46
-	return $GLOBALS['invoicing'];
46
+    return $GLOBALS['invoicing'];
47 47
 }
48 48
 
49 49
 /**
Please login to merge, or discard this patch.
includes/wpinv-subscription.php 1 patch
Indentation   +1035 added lines, -1035 removed lines patch added patch discarded remove patch
@@ -15,125 +15,125 @@  discard block
 block discarded – undo
15 15
  */
16 16
 class WPInv_Subscription extends GetPaid_Data {
17 17
 
18
-	/**
19
-	 * Which data store to load.
20
-	 *
21
-	 * @var string
22
-	 */
23
-	protected $data_store_name = 'subscription';
24
-
25
-	/**
26
-	 * This is the name of this object type.
27
-	 *
28
-	 * @var string
29
-	 */
30
-	protected $object_type = 'subscription';
31
-
32
-	/**
33
-	 * Item Data array. This is the core item data exposed in APIs.
34
-	 *
35
-	 * @since 1.0.19
36
-	 * @var array
37
-	 */
38
-	protected $data = array(
39
-		'customer_id'       => 0,
40
-		'frequency'         => 1,
41
-		'period'            => 'D',
42
-		'initial_amount'    => null,
43
-		'recurring_amount'  => null,
44
-		'bill_times'        => 0,
45
-		'transaction_id'    => '',
46
-		'parent_payment_id' => null,
47
-		'product_id'        => 0,
48
-		'created'           => '0000-00-00 00:00:00',
49
-		'expiration'        => '0000-00-00 00:00:00',
50
-		'trial_period'      => '',
51
-		'status'            => 'pending',
52
-		'profile_id'        => '',
53
-		'gateway'           => '',
54
-		'customer'          => '',
55
-	);
56
-
57
-	/**
58
-	 * Stores the status transition information.
59
-	 *
60
-	 * @since 1.0.19
61
-	 * @var bool
62
-	 */
63
-	protected $status_transition = false;
64
-
65
-	/**
66
-	 * Get the subscription if ID is passed, otherwise the subscription is new and empty.
67
-	 *
68
-	 * @param  int|string|object|WPInv_Subscription $subscription Subscription id, profile_id, or object to read.
69
-	 * @param  bool $deprecated
70
-	 */
71
-	function __construct( $subscription = 0, $deprecated = false ) {
72
-
73
-		parent::__construct( $subscription );
74
-
75
-		if ( ! $deprecated && ! empty( $subscription ) && is_numeric( $subscription ) ) {
76
-			$this->set_id( $subscription );
77
-		} elseif ( $subscription instanceof self ) {
78
-			$this->set_id( $subscription->get_id() );
79
-		} elseif ( $deprecated && $subscription_id = self::get_subscription_id_by_field( $subscription, 'profile_id' ) ) {
80
-			$this->set_id( $subscription_id );
81
-		} elseif ( ! empty( $subscription->id ) ) {
82
-			$this->set_id( $subscription->id );
83
-		} else {
84
-			$this->set_object_read( true );
85
-		}
86
-
87
-		// Load the datastore.
88
-		$this->data_store = GetPaid_Data_Store::load( $this->data_store_name );
89
-
90
-		if ( $this->get_id() > 0 ) {
91
-			$this->data_store->read( $this );
92
-		}
93
-
94
-	}
95
-
96
-	/**
97
-	 * Given an invoice id, profile id, transaction id, it returns the subscription's id.
98
-	 *
99
-	 *
100
-	 * @static
101
-	 * @param string $value
102
-	 * @param string $field Either invoice_id, transaction_id or profile_id.
103
-	 * @since 1.0.19
104
-	 * @return int
105
-	 */
106
-	public static function get_subscription_id_by_field( $value, $field = 'profile_id' ) {
18
+    /**
19
+     * Which data store to load.
20
+     *
21
+     * @var string
22
+     */
23
+    protected $data_store_name = 'subscription';
24
+
25
+    /**
26
+     * This is the name of this object type.
27
+     *
28
+     * @var string
29
+     */
30
+    protected $object_type = 'subscription';
31
+
32
+    /**
33
+     * Item Data array. This is the core item data exposed in APIs.
34
+     *
35
+     * @since 1.0.19
36
+     * @var array
37
+     */
38
+    protected $data = array(
39
+        'customer_id'       => 0,
40
+        'frequency'         => 1,
41
+        'period'            => 'D',
42
+        'initial_amount'    => null,
43
+        'recurring_amount'  => null,
44
+        'bill_times'        => 0,
45
+        'transaction_id'    => '',
46
+        'parent_payment_id' => null,
47
+        'product_id'        => 0,
48
+        'created'           => '0000-00-00 00:00:00',
49
+        'expiration'        => '0000-00-00 00:00:00',
50
+        'trial_period'      => '',
51
+        'status'            => 'pending',
52
+        'profile_id'        => '',
53
+        'gateway'           => '',
54
+        'customer'          => '',
55
+    );
56
+
57
+    /**
58
+     * Stores the status transition information.
59
+     *
60
+     * @since 1.0.19
61
+     * @var bool
62
+     */
63
+    protected $status_transition = false;
64
+
65
+    /**
66
+     * Get the subscription if ID is passed, otherwise the subscription is new and empty.
67
+     *
68
+     * @param  int|string|object|WPInv_Subscription $subscription Subscription id, profile_id, or object to read.
69
+     * @param  bool $deprecated
70
+     */
71
+    function __construct( $subscription = 0, $deprecated = false ) {
72
+
73
+        parent::__construct( $subscription );
74
+
75
+        if ( ! $deprecated && ! empty( $subscription ) && is_numeric( $subscription ) ) {
76
+            $this->set_id( $subscription );
77
+        } elseif ( $subscription instanceof self ) {
78
+            $this->set_id( $subscription->get_id() );
79
+        } elseif ( $deprecated && $subscription_id = self::get_subscription_id_by_field( $subscription, 'profile_id' ) ) {
80
+            $this->set_id( $subscription_id );
81
+        } elseif ( ! empty( $subscription->id ) ) {
82
+            $this->set_id( $subscription->id );
83
+        } else {
84
+            $this->set_object_read( true );
85
+        }
86
+
87
+        // Load the datastore.
88
+        $this->data_store = GetPaid_Data_Store::load( $this->data_store_name );
89
+
90
+        if ( $this->get_id() > 0 ) {
91
+            $this->data_store->read( $this );
92
+        }
93
+
94
+    }
95
+
96
+    /**
97
+     * Given an invoice id, profile id, transaction id, it returns the subscription's id.
98
+     *
99
+     *
100
+     * @static
101
+     * @param string $value
102
+     * @param string $field Either invoice_id, transaction_id or profile_id.
103
+     * @since 1.0.19
104
+     * @return int
105
+     */
106
+    public static function get_subscription_id_by_field( $value, $field = 'profile_id' ) {
107 107
         global $wpdb;
108 108
 
109
-		// Trim the value.
110
-		$value = trim( $value );
109
+        // Trim the value.
110
+        $value = trim( $value );
111 111
 
112
-		if ( empty( $value ) ) {
113
-			return 0;
114
-		}
112
+        if ( empty( $value ) ) {
113
+            return 0;
114
+        }
115 115
 
116
-		if ( 'invoice_id' == $field ) {
117
-			$field = 'parent_payment_id';
118
-		}
116
+        if ( 'invoice_id' == $field ) {
117
+            $field = 'parent_payment_id';
118
+        }
119 119
 
120 120
         // Valid fields.
121 121
         $fields = array(
122
-			'parent_payment_id',
123
-			'transaction_id',
124
-			'profile_id'
125
-		);
126
-
127
-		// Ensure a field has been passed.
128
-		if ( empty( $field ) || ! in_array( $field, $fields ) ) {
129
-			return 0;
130
-		}
131
-
132
-		// Maybe retrieve from the cache.
133
-		$subscription_id   = wp_cache_get( $value, "getpaid_subscription_{$field}s_to_subscription_ids" );
134
-		if ( ! empty( $subscription_id ) ) {
135
-			return $subscription_id;
136
-		}
122
+            'parent_payment_id',
123
+            'transaction_id',
124
+            'profile_id'
125
+        );
126
+
127
+        // Ensure a field has been passed.
128
+        if ( empty( $field ) || ! in_array( $field, $fields ) ) {
129
+            return 0;
130
+        }
131
+
132
+        // Maybe retrieve from the cache.
133
+        $subscription_id   = wp_cache_get( $value, "getpaid_subscription_{$field}s_to_subscription_ids" );
134
+        if ( ! empty( $subscription_id ) ) {
135
+            return $subscription_id;
136
+        }
137 137
 
138 138
         // Fetch from the db.
139 139
         $table            = $wpdb->prefix . 'wpinv_subscriptions';
@@ -141,34 +141,34 @@  discard block
 block discarded – undo
141 141
             $wpdb->prepare( "SELECT `id` FROM $table WHERE `$field`=%s LIMIT 1", $value )
142 142
         );
143 143
 
144
-		if ( empty( $subscription_id ) ) {
145
-			return 0;
146
-		}
144
+        if ( empty( $subscription_id ) ) {
145
+            return 0;
146
+        }
147 147
 
148
-		// Update the cache with our data.
149
-		wp_cache_set( $value, $subscription_id, "getpaid_subscription_{$field}s_to_subscription_ids" );
148
+        // Update the cache with our data.
149
+        wp_cache_set( $value, $subscription_id, "getpaid_subscription_{$field}s_to_subscription_ids" );
150 150
 
151
-		return $subscription_id;
152
-	}
151
+        return $subscription_id;
152
+    }
153 153
 
154
-	/**
154
+    /**
155 155
      * Clears the subscription's cache.
156 156
      */
157 157
     public function clear_cache() {
158
-		wp_cache_delete( $this->get_parent_payment_id(), 'getpaid_subscription_parent_payment_ids_to_subscription_ids' );
159
-		wp_cache_delete( $this->get_transaction_id(), 'getpaid_subscription_transaction_ids_to_subscription_ids' );
160
-		wp_cache_delete( $this->get_profile_id(), 'getpaid_subscription_profile_ids_to_subscription_ids' );
161
-		wp_cache_delete( $this->get_id(), 'getpaid_subscriptions' );
162
-	}
158
+        wp_cache_delete( $this->get_parent_payment_id(), 'getpaid_subscription_parent_payment_ids_to_subscription_ids' );
159
+        wp_cache_delete( $this->get_transaction_id(), 'getpaid_subscription_transaction_ids_to_subscription_ids' );
160
+        wp_cache_delete( $this->get_profile_id(), 'getpaid_subscription_profile_ids_to_subscription_ids' );
161
+        wp_cache_delete( $this->get_id(), 'getpaid_subscriptions' );
162
+    }
163 163
 
164
-	/**
164
+    /**
165 165
      * Checks if a subscription key is set.
166 166
      */
167 167
     public function _isset( $key ) {
168 168
         return isset( $this->data[$key] ) || method_exists( $this, "get_$key" );
169
-	}
169
+    }
170 170
 
171
-	/*
171
+    /*
172 172
 	|--------------------------------------------------------------------------
173 173
 	| CRUD methods
174 174
 	|--------------------------------------------------------------------------
@@ -177,545 +177,545 @@  discard block
 block discarded – undo
177 177
 	|
178 178
     */
179 179
 
180
-	/*
181
-	|--------------------------------------------------------------------------
182
-	| Getters
183
-	|--------------------------------------------------------------------------
184
-	*/
180
+    /*
181
+	|--------------------------------------------------------------------------
182
+	| Getters
183
+	|--------------------------------------------------------------------------
184
+	*/
185
+
186
+    /**
187
+     * Get customer id.
188
+     *
189
+     * @since 1.0.19
190
+     * @param  string $context View or edit context.
191
+     * @return int
192
+     */
193
+    public function get_customer_id( $context = 'view' ) {
194
+        return (int) $this->get_prop( 'customer_id', $context );
195
+    }
196
+
197
+    /**
198
+     * Get customer information.
199
+     *
200
+     * @since 1.0.19
201
+     * @param  string $context View or edit context.
202
+     * @return WP_User|false WP_User object on success, false on failure.
203
+     */
204
+    public function get_customer( $context = 'view' ) {
205
+        return get_userdata( $this->get_customer_id( $context ) );
206
+    }
207
+
208
+    /**
209
+     * Get parent invoice id.
210
+     *
211
+     * @since 1.0.19
212
+     * @param  string $context View or edit context.
213
+     * @return int
214
+     */
215
+    public function get_parent_invoice_id( $context = 'view' ) {
216
+        return (int) $this->get_prop( 'parent_payment_id', $context );
217
+    }
218
+
219
+    /**
220
+     * Alias for self::get_parent_invoice_id().
221
+     *
222
+     * @since 1.0.19
223
+     * @param  string $context View or edit context.
224
+     * @return int
225
+     */
226
+    public function get_parent_payment_id( $context = 'view' ) {
227
+        return $this->get_parent_invoice_id( $context );
228
+    }
229
+
230
+    /**
231
+     * Alias for self::get_parent_invoice_id().
232
+     *
233
+     * @since  1.0.0
234
+     * @return int
235
+     */
236
+    public function get_original_payment_id( $context = 'view' ) {
237
+        return $this->get_parent_invoice_id( $context );
238
+    }
239
+
240
+    /**
241
+     * Get parent invoice.
242
+     *
243
+     * @since 1.0.19
244
+     * @param  string $context View or edit context.
245
+     * @return WPInv_Invoice
246
+     */
247
+    public function get_parent_invoice( $context = 'view' ) {
248
+        return new WPInv_Invoice( $this->get_parent_invoice_id( $context ) );
249
+    }
250
+
251
+    /**
252
+     * Alias for self::get_parent_invoice().
253
+     *
254
+     * @since 1.0.19
255
+     * @param  string $context View or edit context.
256
+     * @return WPInv_Invoice
257
+     */
258
+    public function get_parent_payment( $context = 'view' ) {
259
+        return $this->get_parent_invoice( $context );
260
+    }
261
+
262
+    /**
263
+     * Get subscription's product id.
264
+     *
265
+     * @since 1.0.19
266
+     * @param  string $context View or edit context.
267
+     * @return int
268
+     */
269
+    public function get_product_id( $context = 'view' ) {
270
+        return (int) $this->get_prop( 'product_id', $context );
271
+    }
272
+
273
+    /**
274
+     * Get the subscription product.
275
+     *
276
+     * @since 1.0.19
277
+     * @param  string $context View or edit context.
278
+     * @return WPInv_Item
279
+     */
280
+    public function get_product( $context = 'view' ) {
281
+        return new WPInv_Item( $this->get_product_id( $context ) );
282
+    }
283
+
284
+    /**
285
+     * Get parent invoice's gateway.
286
+     *
287
+     * Here for backwards compatibility.
288
+     *
289
+     * @since 1.0.19
290
+     * @param  string $context View or edit context.
291
+     * @return string
292
+     */
293
+    public function get_gateway( $context = 'view' ) {
294
+        return $this->get_parent_invoice( $context )->get_gateway();
295
+    }
296
+
297
+    /**
298
+     * Get the period of a renewal.
299
+     *
300
+     * @since 1.0.19
301
+     * @param  string $context View or edit context.
302
+     * @return string
303
+     */
304
+    public function get_period( $context = 'view' ) {
305
+        return $this->get_prop( 'period', $context );
306
+    }
307
+
308
+    /**
309
+     * Get number of periods each renewal is valid for.
310
+     *
311
+     * @since 1.0.19
312
+     * @param  string $context View or edit context.
313
+     * @return int
314
+     */
315
+    public function get_frequency( $context = 'view' ) {
316
+        return (int) $this->get_prop( 'frequency', $context );
317
+    }
318
+
319
+    /**
320
+     * Get the initial amount for the subscription.
321
+     *
322
+     * @since 1.0.19
323
+     * @param  string $context View or edit context.
324
+     * @return float
325
+     */
326
+    public function get_initial_amount( $context = 'view' ) {
327
+        return (float) wpinv_sanitize_amount( $this->get_prop( 'initial_amount', $context ) );
328
+    }
329
+
330
+    /**
331
+     * Get the recurring amount for the subscription.
332
+     *
333
+     * @since 1.0.19
334
+     * @param  string $context View or edit context.
335
+     * @return float
336
+     */
337
+    public function get_recurring_amount( $context = 'view' ) {
338
+        return (float) wpinv_sanitize_amount( $this->get_prop( 'recurring_amount', $context ) );
339
+    }
340
+
341
+    /**
342
+     * Get number of times that this subscription can be renewed.
343
+     *
344
+     * @since 1.0.19
345
+     * @param  string $context View or edit context.
346
+     * @return int
347
+     */
348
+    public function get_bill_times( $context = 'view' ) {
349
+        return (int) $this->get_prop( 'bill_times', $context );
350
+    }
351
+
352
+    /**
353
+     * Get transaction id of this subscription's parent invoice.
354
+     *
355
+     * @since 1.0.19
356
+     * @param  string $context View or edit context.
357
+     * @return string
358
+     */
359
+    public function get_transaction_id( $context = 'view' ) {
360
+        return $this->get_prop( 'transaction_id', $context );
361
+    }
362
+
363
+    /**
364
+     * Get the date that the subscription was created.
365
+     *
366
+     * @since 1.0.19
367
+     * @param  string $context View or edit context.
368
+     * @return string
369
+     */
370
+    public function get_created( $context = 'view' ) {
371
+        return $this->get_prop( 'created', $context );
372
+    }
373
+
374
+    /**
375
+     * Alias for self::get_created().
376
+     *
377
+     * @since 1.0.19
378
+     * @param  string $context View or edit context.
379
+     * @return string
380
+     */
381
+    public function get_date_created( $context = 'view' ) {
382
+        return $this->get_created( $context );
383
+    }
384
+
385
+    /**
386
+     * Retrieves the creation date in a timestamp
387
+     *
388
+     * @since  1.0.0
389
+     * @return int
390
+     */
391
+    public function get_time_created() {
392
+        $created = $this->get_date_created();
393
+        return empty( $created ) ? current_time( 'timestamp' ) : strtotime( $created, current_time( 'timestamp' ) );
394
+    }
395
+
396
+    /**
397
+     * Get GMT date when the subscription was created.
398
+     *
399
+     * @since 1.0.19
400
+     * @param  string $context View or edit context.
401
+     * @return string
402
+     */
403
+    public function get_date_created_gmt( $context = 'view' ) {
404
+        $date = $this->get_date_created( $context );
405
+
406
+        if ( $date ) {
407
+            $date = get_gmt_from_date( $date );
408
+        }
409
+        return $date;
410
+    }
411
+
412
+    /**
413
+     * Get the date that the subscription will renew.
414
+     *
415
+     * @since 1.0.19
416
+     * @param  string $context View or edit context.
417
+     * @return string
418
+     */
419
+    public function get_next_renewal_date( $context = 'view' ) {
420
+        return $this->get_prop( 'expiration', $context );
421
+    }
422
+
423
+    /**
424
+     * Alias for self::get_next_renewal_date().
425
+     *
426
+     * @since 1.0.19
427
+     * @param  string $context View or edit context.
428
+     * @return string
429
+     */
430
+    public function get_expiration( $context = 'view' ) {
431
+        return $this->get_next_renewal_date( $context );
432
+    }
433
+
434
+    /**
435
+     * Retrieves the expiration date in a timestamp
436
+     *
437
+     * @since  1.0.0
438
+     * @return int
439
+     */
440
+    public function get_expiration_time() {
441
+        $expiration = $this->get_expiration();
442
+
443
+        if ( empty( $expiration ) || '0000-00-00 00:00:00' == $expiration ) {
444
+            return current_time( 'timestamp' );
445
+        }
446
+
447
+        $expiration = strtotime( $expiration, current_time( 'timestamp' ) );
448
+        return $expiration < current_time( 'timestamp' ) ? current_time( 'timestamp' ) : $expiration;
449
+    }
450
+
451
+    /**
452
+     * Get GMT date when the subscription will renew.
453
+     *
454
+     * @since 1.0.19
455
+     * @param  string $context View or edit context.
456
+     * @return string
457
+     */
458
+    public function get_next_renewal_date_gmt( $context = 'view' ) {
459
+        $date = $this->get_next_renewal_date( $context );
460
+
461
+        if ( $date ) {
462
+            $date = get_gmt_from_date( $date );
463
+        }
464
+        return $date;
465
+    }
466
+
467
+    /**
468
+     * Get the subscription's trial period.
469
+     *
470
+     * @since 1.0.19
471
+     * @param  string $context View or edit context.
472
+     * @return string
473
+     */
474
+    public function get_trial_period( $context = 'view' ) {
475
+        return $this->get_prop( 'trial_period', $context );
476
+    }
477
+
478
+    /**
479
+     * Get the subscription's status.
480
+     *
481
+     * @since 1.0.19
482
+     * @param  string $context View or edit context.
483
+     * @return string
484
+     */
485
+    public function get_status( $context = 'view' ) {
486
+        return $this->get_prop( 'status', $context );
487
+    }
488
+
489
+    /**
490
+     * Get the subscription's profile id.
491
+     *
492
+     * @since 1.0.19
493
+     * @param  string $context View or edit context.
494
+     * @return string
495
+     */
496
+    public function get_profile_id( $context = 'view' ) {
497
+        return $this->get_prop( 'profile_id', $context );
498
+    }
499
+
500
+    /*
501
+	|--------------------------------------------------------------------------
502
+	| Setters
503
+	|--------------------------------------------------------------------------
504
+	*/
505
+
506
+    /**
507
+     * Set customer id.
508
+     *
509
+     * @since 1.0.19
510
+     * @param  int $value The customer's id.
511
+     */
512
+    public function set_customer_id( $value ) {
513
+        $this->set_prop( 'customer_id', (int) $value );
514
+    }
515
+
516
+    /**
517
+     * Set parent invoice id.
518
+     *
519
+     * @since 1.0.19
520
+     * @param  int $value The parent invoice id.
521
+     */
522
+    public function set_parent_invoice_id( $value ) {
523
+        $this->set_prop( 'parent_payment_id', (int) $value );
524
+    }
525
+
526
+    /**
527
+     * Alias for self::set_parent_invoice_id().
528
+     *
529
+     * @since 1.0.19
530
+     * @param  int $value The parent invoice id.
531
+     */
532
+    public function set_parent_payment_id( $value ) {
533
+        $this->set_parent_invoice_id( $value );
534
+    }
535
+
536
+    /**
537
+     * Alias for self::set_parent_invoice_id().
538
+     *
539
+     * @since 1.0.19
540
+     * @param  int $value The parent invoice id.
541
+     */
542
+    public function set_original_payment_id( $value ) {
543
+        $this->set_parent_invoice_id( $value );
544
+    }
545
+
546
+    /**
547
+     * Set subscription's product id.
548
+     *
549
+     * @since 1.0.19
550
+     * @param  int $value The subscription product id.
551
+     */
552
+    public function set_product_id( $value ) {
553
+        $this->set_prop( 'product_id', (int) $value );
554
+    }
555
+
556
+    /**
557
+     * Set the period of a renewal.
558
+     *
559
+     * @since 1.0.19
560
+     * @param  string $value The renewal period.
561
+     */
562
+    public function set_period( $value ) {
563
+        $this->set_prop( 'period', $value );
564
+    }
565
+
566
+    /**
567
+     * Set number of periods each renewal is valid for.
568
+     *
569
+     * @since 1.0.19
570
+     * @param  int $value The subscription frequency.
571
+     */
572
+    public function set_frequency( $value ) {
573
+        $value = empty( $value ) ? 1 : (int) $value;
574
+        $this->set_prop( 'frequency', absint( $value ) );
575
+    }
576
+
577
+    /**
578
+     * Set the initial amount for the subscription.
579
+     *
580
+     * @since 1.0.19
581
+     * @param  float $value The initial subcription amount.
582
+     */
583
+    public function set_initial_amount( $value ) {
584
+        $this->set_prop( 'initial_amount', wpinv_sanitize_amount( $value ) );
585
+    }
586
+
587
+    /**
588
+     * Set the recurring amount for the subscription.
589
+     *
590
+     * @since 1.0.19
591
+     * @param  float $value The recurring subcription amount.
592
+     */
593
+    public function set_recurring_amount( $value ) {
594
+        $this->set_prop( 'recurring_amount', wpinv_sanitize_amount( $value ) );
595
+    }
596
+
597
+    /**
598
+     * Set number of times that this subscription can be renewed.
599
+     *
600
+     * @since 1.0.19
601
+     * @param  int $value Bill times.
602
+     */
603
+    public function set_bill_times( $value ) {
604
+        $this->set_prop( 'bill_times', (int) $value );
605
+    }
606
+
607
+    /**
608
+     * Get transaction id of this subscription's parent invoice.
609
+     *
610
+     * @since 1.0.19
611
+     * @param string $value Bill times.
612
+     */
613
+    public function set_transaction_id( $value ) {
614
+        $this->set_prop( 'transaction_id', sanitize_text_field( $value ) );
615
+    }
616
+
617
+    /**
618
+     * Set date when this subscription started.
619
+     *
620
+     * @since 1.0.19
621
+     * @param string $value strtotime compliant date.
622
+     */
623
+    public function set_created( $value ) {
624
+        $date = strtotime( $value );
625
+
626
+        if ( $date && $value !== '0000-00-00 00:00:00' ) {
627
+            $this->set_prop( 'created', date( 'Y-m-d H:i:s', $date ) );
628
+            return;
629
+        }
630
+
631
+        $this->set_prop( 'created', '' );
185 632
 
186
-	/**
187
-	 * Get customer id.
188
-	 *
189
-	 * @since 1.0.19
190
-	 * @param  string $context View or edit context.
191
-	 * @return int
192
-	 */
193
-	public function get_customer_id( $context = 'view' ) {
194
-		return (int) $this->get_prop( 'customer_id', $context );
195
-	}
196
-
197
-	/**
198
-	 * Get customer information.
199
-	 *
200
-	 * @since 1.0.19
201
-	 * @param  string $context View or edit context.
202
-	 * @return WP_User|false WP_User object on success, false on failure.
203
-	 */
204
-	public function get_customer( $context = 'view' ) {
205
-		return get_userdata( $this->get_customer_id( $context ) );
206
-	}
207
-
208
-	/**
209
-	 * Get parent invoice id.
210
-	 *
211
-	 * @since 1.0.19
212
-	 * @param  string $context View or edit context.
213
-	 * @return int
214
-	 */
215
-	public function get_parent_invoice_id( $context = 'view' ) {
216
-		return (int) $this->get_prop( 'parent_payment_id', $context );
217
-	}
218
-
219
-	/**
220
-	 * Alias for self::get_parent_invoice_id().
221
-	 *
222
-	 * @since 1.0.19
223
-	 * @param  string $context View or edit context.
224
-	 * @return int
225
-	 */
226
-    public function get_parent_payment_id( $context = 'view' ) {
227
-        return $this->get_parent_invoice_id( $context );
228
-	}
633
+    }
229 634
 
230
-	/**
231
-     * Alias for self::get_parent_invoice_id().
635
+    /**
636
+     * Alias for self::set_created().
232 637
      *
233
-     * @since  1.0.0
234
-     * @return int
638
+     * @since 1.0.19
639
+     * @param string $value strtotime compliant date.
235 640
      */
236
-    public function get_original_payment_id( $context = 'view' ) {
237
-        return $this->get_parent_invoice_id( $context );
641
+    public function set_date_created( $value ) {
642
+        $this->set_created( $value );
238 643
     }
239 644
 
240
-	/**
241
-	 * Get parent invoice.
242
-	 *
243
-	 * @since 1.0.19
244
-	 * @param  string $context View or edit context.
245
-	 * @return WPInv_Invoice
246
-	 */
247
-	public function get_parent_invoice( $context = 'view' ) {
248
-		return new WPInv_Invoice( $this->get_parent_invoice_id( $context ) );
249
-	}
250
-
251
-	/**
252
-	 * Alias for self::get_parent_invoice().
253
-	 *
254
-	 * @since 1.0.19
255
-	 * @param  string $context View or edit context.
256
-	 * @return WPInv_Invoice
257
-	 */
258
-    public function get_parent_payment( $context = 'view' ) {
259
-        return $this->get_parent_invoice( $context );
260
-	}
261
-
262
-	/**
263
-	 * Get subscription's product id.
264
-	 *
265
-	 * @since 1.0.19
266
-	 * @param  string $context View or edit context.
267
-	 * @return int
268
-	 */
269
-	public function get_product_id( $context = 'view' ) {
270
-		return (int) $this->get_prop( 'product_id', $context );
271
-	}
272
-
273
-	/**
274
-	 * Get the subscription product.
275
-	 *
276
-	 * @since 1.0.19
277
-	 * @param  string $context View or edit context.
278
-	 * @return WPInv_Item
279
-	 */
280
-	public function get_product( $context = 'view' ) {
281
-		return new WPInv_Item( $this->get_product_id( $context ) );
282
-	}
283
-
284
-	/**
285
-	 * Get parent invoice's gateway.
286
-	 *
287
-	 * Here for backwards compatibility.
288
-	 *
289
-	 * @since 1.0.19
290
-	 * @param  string $context View or edit context.
291
-	 * @return string
292
-	 */
293
-	public function get_gateway( $context = 'view' ) {
294
-		return $this->get_parent_invoice( $context )->get_gateway();
295
-	}
296
-
297
-	/**
298
-	 * Get the period of a renewal.
299
-	 *
300
-	 * @since 1.0.19
301
-	 * @param  string $context View or edit context.
302
-	 * @return string
303
-	 */
304
-	public function get_period( $context = 'view' ) {
305
-		return $this->get_prop( 'period', $context );
306
-	}
307
-
308
-	/**
309
-	 * Get number of periods each renewal is valid for.
310
-	 *
311
-	 * @since 1.0.19
312
-	 * @param  string $context View or edit context.
313
-	 * @return int
314
-	 */
315
-	public function get_frequency( $context = 'view' ) {
316
-		return (int) $this->get_prop( 'frequency', $context );
317
-	}
318
-
319
-	/**
320
-	 * Get the initial amount for the subscription.
321
-	 *
322
-	 * @since 1.0.19
323
-	 * @param  string $context View or edit context.
324
-	 * @return float
325
-	 */
326
-	public function get_initial_amount( $context = 'view' ) {
327
-		return (float) wpinv_sanitize_amount( $this->get_prop( 'initial_amount', $context ) );
328
-	}
329
-
330
-	/**
331
-	 * Get the recurring amount for the subscription.
332
-	 *
333
-	 * @since 1.0.19
334
-	 * @param  string $context View or edit context.
335
-	 * @return float
336
-	 */
337
-	public function get_recurring_amount( $context = 'view' ) {
338
-		return (float) wpinv_sanitize_amount( $this->get_prop( 'recurring_amount', $context ) );
339
-	}
340
-
341
-	/**
342
-	 * Get number of times that this subscription can be renewed.
343
-	 *
344
-	 * @since 1.0.19
345
-	 * @param  string $context View or edit context.
346
-	 * @return int
347
-	 */
348
-	public function get_bill_times( $context = 'view' ) {
349
-		return (int) $this->get_prop( 'bill_times', $context );
350
-	}
351
-
352
-	/**
353
-	 * Get transaction id of this subscription's parent invoice.
354
-	 *
355
-	 * @since 1.0.19
356
-	 * @param  string $context View or edit context.
357
-	 * @return string
358
-	 */
359
-	public function get_transaction_id( $context = 'view' ) {
360
-		return $this->get_prop( 'transaction_id', $context );
361
-	}
362
-
363
-	/**
364
-	 * Get the date that the subscription was created.
365
-	 *
366
-	 * @since 1.0.19
367
-	 * @param  string $context View or edit context.
368
-	 * @return string
369
-	 */
370
-	public function get_created( $context = 'view' ) {
371
-		return $this->get_prop( 'created', $context );
372
-	}
373
-
374
-	/**
375
-	 * Alias for self::get_created().
376
-	 *
377
-	 * @since 1.0.19
378
-	 * @param  string $context View or edit context.
379
-	 * @return string
380
-	 */
381
-	public function get_date_created( $context = 'view' ) {
382
-		return $this->get_created( $context );
383
-	}
384
-
385
-	/**
386
-	 * Retrieves the creation date in a timestamp
387
-	 *
388
-	 * @since  1.0.0
389
-	 * @return int
390
-	 */
391
-	public function get_time_created() {
392
-		$created = $this->get_date_created();
393
-		return empty( $created ) ? current_time( 'timestamp' ) : strtotime( $created, current_time( 'timestamp' ) );
394
-	}
395
-
396
-	/**
397
-	 * Get GMT date when the subscription was created.
398
-	 *
399
-	 * @since 1.0.19
400
-	 * @param  string $context View or edit context.
401
-	 * @return string
402
-	 */
403
-	public function get_date_created_gmt( $context = 'view' ) {
404
-        $date = $this->get_date_created( $context );
645
+    /**
646
+     * Set the date that the subscription will renew.
647
+     *
648
+     * @since 1.0.19
649
+     * @param string $value strtotime compliant date.
650
+     */
651
+    public function set_next_renewal_date( $value ) {
652
+        $date = strtotime( $value );
405 653
 
406
-        if ( $date ) {
407
-            $date = get_gmt_from_date( $date );
654
+        if ( $date && $value !== '0000-00-00 00:00:00' ) {
655
+            $this->set_prop( 'expiration', date( 'Y-m-d H:i:s', $date ) );
656
+            return;
408 657
         }
409
-		return $date;
410
-	}
411
-
412
-	/**
413
-	 * Get the date that the subscription will renew.
414
-	 *
415
-	 * @since 1.0.19
416
-	 * @param  string $context View or edit context.
417
-	 * @return string
418
-	 */
419
-	public function get_next_renewal_date( $context = 'view' ) {
420
-		return $this->get_prop( 'expiration', $context );
421
-	}
422
-
423
-	/**
424
-	 * Alias for self::get_next_renewal_date().
425
-	 *
426
-	 * @since 1.0.19
427
-	 * @param  string $context View or edit context.
428
-	 * @return string
429
-	 */
430
-	public function get_expiration( $context = 'view' ) {
431
-		return $this->get_next_renewal_date( $context );
432
-	}
433
-
434
-	/**
435
-	 * Retrieves the expiration date in a timestamp
436
-	 *
437
-	 * @since  1.0.0
438
-	 * @return int
439
-	 */
440
-	public function get_expiration_time() {
441
-		$expiration = $this->get_expiration();
442
-
443
-		if ( empty( $expiration ) || '0000-00-00 00:00:00' == $expiration ) {
444
-			return current_time( 'timestamp' );
445
-		}
446
-
447
-		$expiration = strtotime( $expiration, current_time( 'timestamp' ) );
448
-		return $expiration < current_time( 'timestamp' ) ? current_time( 'timestamp' ) : $expiration;
449
-	}
450
-
451
-	/**
452
-	 * Get GMT date when the subscription will renew.
453
-	 *
454
-	 * @since 1.0.19
455
-	 * @param  string $context View or edit context.
456
-	 * @return string
457
-	 */
458
-	public function get_next_renewal_date_gmt( $context = 'view' ) {
459
-        $date = $this->get_next_renewal_date( $context );
460 658
 
461
-        if ( $date ) {
462
-            $date = get_gmt_from_date( $date );
463
-        }
464
-		return $date;
465
-	}
466
-
467
-	/**
468
-	 * Get the subscription's trial period.
469
-	 *
470
-	 * @since 1.0.19
471
-	 * @param  string $context View or edit context.
472
-	 * @return string
473
-	 */
474
-	public function get_trial_period( $context = 'view' ) {
475
-		return $this->get_prop( 'trial_period', $context );
476
-	}
477
-
478
-	/**
479
-	 * Get the subscription's status.
480
-	 *
481
-	 * @since 1.0.19
482
-	 * @param  string $context View or edit context.
483
-	 * @return string
484
-	 */
485
-	public function get_status( $context = 'view' ) {
486
-		return $this->get_prop( 'status', $context );
487
-	}
488
-
489
-	/**
490
-	 * Get the subscription's profile id.
491
-	 *
492
-	 * @since 1.0.19
493
-	 * @param  string $context View or edit context.
494
-	 * @return string
495
-	 */
496
-	public function get_profile_id( $context = 'view' ) {
497
-		return $this->get_prop( 'profile_id', $context );
498
-	}
499
-
500
-	/*
501
-	|--------------------------------------------------------------------------
502
-	| Setters
503
-	|--------------------------------------------------------------------------
504
-	*/
659
+        $this->set_prop( 'expiration', '' );
505 660
 
506
-	/**
507
-	 * Set customer id.
508
-	 *
509
-	 * @since 1.0.19
510
-	 * @param  int $value The customer's id.
511
-	 */
512
-	public function set_customer_id( $value ) {
513
-		$this->set_prop( 'customer_id', (int) $value );
514
-	}
515
-
516
-	/**
517
-	 * Set parent invoice id.
518
-	 *
519
-	 * @since 1.0.19
520
-	 * @param  int $value The parent invoice id.
521
-	 */
522
-	public function set_parent_invoice_id( $value ) {
523
-		$this->set_prop( 'parent_payment_id', (int) $value );
524
-	}
525
-
526
-	/**
527
-	 * Alias for self::set_parent_invoice_id().
528
-	 *
529
-	 * @since 1.0.19
530
-	 * @param  int $value The parent invoice id.
531
-	 */
532
-    public function set_parent_payment_id( $value ) {
533
-        $this->set_parent_invoice_id( $value );
534
-	}
661
+    }
535 662
 
536
-	/**
537
-     * Alias for self::set_parent_invoice_id().
663
+    /**
664
+     * Alias for self::set_next_renewal_date().
538 665
      *
539 666
      * @since 1.0.19
540
-	 * @param  int $value The parent invoice id.
667
+     * @param string $value strtotime compliant date.
541 668
      */
542
-    public function set_original_payment_id( $value ) {
543
-        $this->set_parent_invoice_id( $value );
544
-	}
545
-
546
-	/**
547
-	 * Set subscription's product id.
548
-	 *
549
-	 * @since 1.0.19
550
-	 * @param  int $value The subscription product id.
551
-	 */
552
-	public function set_product_id( $value ) {
553
-		$this->set_prop( 'product_id', (int) $value );
554
-	}
555
-
556
-	/**
557
-	 * Set the period of a renewal.
558
-	 *
559
-	 * @since 1.0.19
560
-	 * @param  string $value The renewal period.
561
-	 */
562
-	public function set_period( $value ) {
563
-		$this->set_prop( 'period', $value );
564
-	}
565
-
566
-	/**
567
-	 * Set number of periods each renewal is valid for.
568
-	 *
569
-	 * @since 1.0.19
570
-	 * @param  int $value The subscription frequency.
571
-	 */
572
-	public function set_frequency( $value ) {
573
-		$value = empty( $value ) ? 1 : (int) $value;
574
-		$this->set_prop( 'frequency', absint( $value ) );
575
-	}
576
-
577
-	/**
578
-	 * Set the initial amount for the subscription.
579
-	 *
580
-	 * @since 1.0.19
581
-	 * @param  float $value The initial subcription amount.
582
-	 */
583
-	public function set_initial_amount( $value ) {
584
-		$this->set_prop( 'initial_amount', wpinv_sanitize_amount( $value ) );
585
-	}
586
-
587
-	/**
588
-	 * Set the recurring amount for the subscription.
589
-	 *
590
-	 * @since 1.0.19
591
-	 * @param  float $value The recurring subcription amount.
592
-	 */
593
-	public function set_recurring_amount( $value ) {
594
-		$this->set_prop( 'recurring_amount', wpinv_sanitize_amount( $value ) );
595
-	}
596
-
597
-	/**
598
-	 * Set number of times that this subscription can be renewed.
599
-	 *
600
-	 * @since 1.0.19
601
-	 * @param  int $value Bill times.
602
-	 */
603
-	public function set_bill_times( $value ) {
604
-		$this->set_prop( 'bill_times', (int) $value );
605
-	}
606
-
607
-	/**
608
-	 * Get transaction id of this subscription's parent invoice.
609
-	 *
610
-	 * @since 1.0.19
611
-	 * @param string $value Bill times.
612
-	 */
613
-	public function set_transaction_id( $value ) {
614
-		$this->set_prop( 'transaction_id', sanitize_text_field( $value ) );
615
-	}
616
-
617
-	/**
618
-	 * Set date when this subscription started.
619
-	 *
620
-	 * @since 1.0.19
621
-	 * @param string $value strtotime compliant date.
622
-	 */
623
-	public function set_created( $value ) {
624
-        $date = strtotime( $value );
669
+    public function set_expiration( $value ) {
670
+        $this->set_next_renewal_date( $value );
671
+    }
625 672
 
626
-        if ( $date && $value !== '0000-00-00 00:00:00' ) {
627
-            $this->set_prop( 'created', date( 'Y-m-d H:i:s', $date ) );
673
+    /**
674
+     * Set the subscription's trial period.
675
+     *
676
+     * @since 1.0.19
677
+     * @param string $value trial period e.g 1 year.
678
+     */
679
+    public function set_trial_period( $value ) {
680
+        $this->set_prop( 'trial_period', $value );
681
+    }
682
+
683
+    /**
684
+     * Set the subscription's status.
685
+     *
686
+     * @since 1.0.19
687
+     * @param string $new_status    New subscription status.
688
+     */
689
+    public function set_status( $new_status ) {
690
+
691
+        // Abort if this is not a valid status;
692
+        if ( ! array_key_exists( $new_status, getpaid_get_subscription_statuses() ) ) {
628 693
             return;
629 694
         }
630 695
 
631
-		$this->set_prop( 'created', '' );
696
+        $this->set_prop( 'status', $new_status );
632 697
 
633
-	}
698
+        $old_status = ! empty( $this->status_transition['from'] ) ? $this->status_transition['from'] : $this->get_status();
699
+        if ( true === $this->object_read && $old_status !== $new_status ) {
700
+            $this->status_transition = array(
701
+                'from'   => $old_status,
702
+                'to'     => $new_status,
703
+            );
704
+        }
634 705
 
635
-	/**
636
-	 * Alias for self::set_created().
637
-	 *
638
-	 * @since 1.0.19
639
-	 * @param string $value strtotime compliant date.
640
-	 */
641
-	public function set_date_created( $value ) {
642
-		$this->set_created( $value );
643 706
     }
644 707
 
645
-	/**
646
-	 * Set the date that the subscription will renew.
647
-	 *
648
-	 * @since 1.0.19
649
-	 * @param string $value strtotime compliant date.
650
-	 */
651
-	public function set_next_renewal_date( $value ) {
652
-		$date = strtotime( $value );
708
+    /**
709
+     * Set the subscription's (remote) profile id.
710
+     *
711
+     * @since 1.0.19
712
+     * @param  string $value the remote profile id.
713
+     */
714
+    public function set_profile_id( $value ) {
715
+        $this->set_prop( 'profile_id', sanitize_text_field( $value ) );
716
+    }
653 717
 
654
-        if ( $date && $value !== '0000-00-00 00:00:00' ) {
655
-            $this->set_prop( 'expiration', date( 'Y-m-d H:i:s', $date ) );
656
-            return;
657
-		}
658
-
659
-		$this->set_prop( 'expiration', '' );
660
-
661
-	}
662
-
663
-	/**
664
-	 * Alias for self::set_next_renewal_date().
665
-	 *
666
-	 * @since 1.0.19
667
-	 * @param string $value strtotime compliant date.
668
-	 */
669
-	public function set_expiration( $value ) {
670
-		$this->set_next_renewal_date( $value );
671
-    }
672
-
673
-	/**
674
-	 * Set the subscription's trial period.
675
-	 *
676
-	 * @since 1.0.19
677
-	 * @param string $value trial period e.g 1 year.
678
-	 */
679
-	public function set_trial_period( $value ) {
680
-		$this->set_prop( 'trial_period', $value );
681
-	}
682
-
683
-	/**
684
-	 * Set the subscription's status.
685
-	 *
686
-	 * @since 1.0.19
687
-	 * @param string $new_status    New subscription status.
688
-	 */
689
-	public function set_status( $new_status ) {
690
-
691
-		// Abort if this is not a valid status;
692
-		if ( ! array_key_exists( $new_status, getpaid_get_subscription_statuses() ) ) {
693
-			return;
694
-		}
695
-
696
-		$this->set_prop( 'status', $new_status );
697
-
698
-		$old_status = ! empty( $this->status_transition['from'] ) ? $this->status_transition['from'] : $this->get_status();
699
-		if ( true === $this->object_read && $old_status !== $new_status ) {
700
-			$this->status_transition = array(
701
-				'from'   => $old_status,
702
-				'to'     => $new_status,
703
-			);
704
-		}
705
-
706
-	}
707
-
708
-	/**
709
-	 * Set the subscription's (remote) profile id.
710
-	 *
711
-	 * @since 1.0.19
712
-	 * @param  string $value the remote profile id.
713
-	 */
714
-	public function set_profile_id( $value ) {
715
-		$this->set_prop( 'profile_id', sanitize_text_field( $value ) );
716
-	}
717
-
718
-	/*
718
+    /*
719 719
 	|--------------------------------------------------------------------------
720 720
 	| Boolean methods
721 721
 	|--------------------------------------------------------------------------
@@ -724,55 +724,55 @@  discard block
 block discarded – undo
724 724
 	|
725 725
 	*/
726 726
 
727
-	/**
727
+    /**
728 728
      * Checks if the subscription has a given status.
729
-	 *
730
-	 * @param string|array String or array of strings to check for.
731
-	 * @return bool
729
+     *
730
+     * @param string|array String or array of strings to check for.
731
+     * @return bool
732 732
      */
733 733
     public function has_status( $status ) {
734 734
         return in_array( $this->get_status(), wpinv_clean( wpinv_parse_list( $status ) ) );
735
-	}
735
+    }
736 736
 
737
-	/**
737
+    /**
738 738
      * Checks if the subscription has a trial period.
739
-	 *
740
-	 * @return bool
739
+     *
740
+     * @return bool
741 741
      */
742 742
     public function has_trial_period() {
743
-		$period = $this->get_trial_period();
743
+        $period = $this->get_trial_period();
744 744
         return ! empty( $period );
745
-	}
746
-
747
-	/**
748
-	 * Is the subscription active?
749
-	 *
750
-	 * @return bool
751
-	 */
752
-	public function is_active() {
753
-		return $this->has_status( 'active trialling' ) && ! $this->is_expired();
754
-	}
755
-
756
-	/**
757
-	 * Is the subscription expired?
758
-	 *
759
-	 * @return bool
760
-	 */
761
-	public function is_expired() {
762
-		return $this->has_status( 'expired' ) || ( $this->has_status( 'active cancelled trialling' ) && $this->get_expiration_time() < current_time( 'mysql' ) );
763
-	}
764
-
765
-	/**
766
-	 * Is this the last renewals?
767
-	 *
768
-	 * @return bool
769
-	 */
770
-	public function is_last_renewal() {
771
-		$max_bills = $this->get_bill_times();
772
-		return ! empty( $max_bills ) && $max_bills <= $this->get_times_billed();
773
-	}
774
-
775
-	/*
745
+    }
746
+
747
+    /**
748
+     * Is the subscription active?
749
+     *
750
+     * @return bool
751
+     */
752
+    public function is_active() {
753
+        return $this->has_status( 'active trialling' ) && ! $this->is_expired();
754
+    }
755
+
756
+    /**
757
+     * Is the subscription expired?
758
+     *
759
+     * @return bool
760
+     */
761
+    public function is_expired() {
762
+        return $this->has_status( 'expired' ) || ( $this->has_status( 'active cancelled trialling' ) && $this->get_expiration_time() < current_time( 'mysql' ) );
763
+    }
764
+
765
+    /**
766
+     * Is this the last renewals?
767
+     *
768
+     * @return bool
769
+     */
770
+    public function is_last_renewal() {
771
+        $max_bills = $this->get_bill_times();
772
+        return ! empty( $max_bills ) && $max_bills <= $this->get_times_billed();
773
+    }
774
+
775
+    /*
776 776
 	|--------------------------------------------------------------------------
777 777
 	| Additional methods
778 778
 	|--------------------------------------------------------------------------
@@ -781,27 +781,27 @@  discard block
 block discarded – undo
781 781
 	|
782 782
 	*/
783 783
 
784
-	/**
785
-	 * Backwards compatibilty.
786
-	 */
787
-	public function create( $data = array() ) {
784
+    /**
785
+     * Backwards compatibilty.
786
+     */
787
+    public function create( $data = array() ) {
788 788
 
789
-		// Set the properties.
790
-		if ( is_array( $data ) ) {
791
-			$this->set_props( $data );
792
-		}
789
+        // Set the properties.
790
+        if ( is_array( $data ) ) {
791
+            $this->set_props( $data );
792
+        }
793 793
 
794
-		// Save the item.
795
-		return $this->save();
794
+        // Save the item.
795
+        return $this->save();
796 796
 
797
-	}
797
+    }
798 798
 
799
-	/**
800
-	 * Backwards compatibilty.
801
-	 */
802
-	public function update( $args = array() ) {
803
-		return $this->create( $args );
804
-	}
799
+    /**
800
+     * Backwards compatibilty.
801
+     */
802
+    public function update( $args = array() ) {
803
+        return $this->create( $args );
804
+    }
805 805
 
806 806
     /**
807 807
      * Retrieve renewal payments for a subscription
@@ -811,22 +811,22 @@  discard block
 block discarded – undo
811 811
      */
812 812
     public function get_child_payments( $hide_pending = true ) {
813 813
 
814
-		$statuses = array( 'publish', 'wpi-processing', 'wpi-renewal' );
814
+        $statuses = array( 'publish', 'wpi-processing', 'wpi-renewal' );
815 815
 
816
-		if ( ! $hide_pending ) {
817
-			$statuses = array_keys( wpinv_get_invoice_statuses() );
818
-		}
816
+        if ( ! $hide_pending ) {
817
+            $statuses = array_keys( wpinv_get_invoice_statuses() );
818
+        }
819 819
 
820 820
         return get_posts(
821
-			array(
822
-            	'post_parent'    => $this->get_parent_payment_id(),
823
-            	'numberposts'    => -1,
824
-            	'post_status'    => $statuses,
825
-            	'orderby'        => 'ID',
826
-            	'order'          => 'ASC',
827
-            	'post_type'      => 'wpi_invoice'
828
-			)
829
-		);
821
+            array(
822
+                'post_parent'    => $this->get_parent_payment_id(),
823
+                'numberposts'    => -1,
824
+                'post_status'    => $statuses,
825
+                'orderby'        => 'ID',
826
+                'order'          => 'ASC',
827
+                'post_type'      => 'wpi_invoice'
828
+            )
829
+        );
830 830
     }
831 831
 
832 832
     /**
@@ -836,7 +836,7 @@  discard block
 block discarded – undo
836 836
      * @return int
837 837
      */
838 838
     public function get_total_payments() {
839
-		return getpaid_count_subscription_invoices( $this->get_parent_invoice_id(), $this->get_id() );
839
+        return getpaid_count_subscription_invoices( $this->get_parent_invoice_id(), $this->get_id() );
840 840
     }
841 841
 
842 842
     /**
@@ -860,57 +860,57 @@  discard block
 block discarded – undo
860 860
      *
861 861
      * @since  2.4
862 862
      * @param  array $args Array of values for the payment, including amount and transaction ID
863
-	 * @param  WPInv_Invoice $invoice If adding an existing invoice.
863
+     * @param  WPInv_Invoice $invoice If adding an existing invoice.
864 864
      * @return bool
865 865
      */
866 866
     public function add_payment( $args = array(), $invoice = false ) {
867 867
 
868
-		// Process each payment once.
868
+        // Process each payment once.
869 869
         if ( ! empty( $args['transaction_id'] ) && $this->payment_exists( $args['transaction_id'] ) ) {
870 870
             return false;
871 871
         }
872 872
 
873
-		// Are we creating a new invoice?
874
-		if ( empty( $invoice ) ) {
875
-			$invoice = $this->create_payment();
873
+        // Are we creating a new invoice?
874
+        if ( empty( $invoice ) ) {
875
+            $invoice = $this->create_payment();
876 876
 
877
-			if ( empty( $invoice ) ) {
878
-				return false;
879
-			}
877
+            if ( empty( $invoice ) ) {
878
+                return false;
879
+            }
880 880
 
881
-		}
881
+        }
882 882
 
883
-		$invoice->set_status( 'wpi-renewal' );
883
+        $invoice->set_status( 'wpi-renewal' );
884 884
 
885
-		// Maybe set a transaction id.
886
-		if ( ! empty( $args['transaction_id'] ) ) {
887
-			$invoice->set_transaction_id( $args['transaction_id'] );
888
-		}
885
+        // Maybe set a transaction id.
886
+        if ( ! empty( $args['transaction_id'] ) ) {
887
+            $invoice->set_transaction_id( $args['transaction_id'] );
888
+        }
889 889
 
890
-		// Set the completed date.
891
-		$invoice->set_completed_date( current_time( 'mysql' ) );
890
+        // Set the completed date.
891
+        $invoice->set_completed_date( current_time( 'mysql' ) );
892 892
 
893
-		// And the gateway.
894
-		if ( ! empty( $args['gateway'] ) ) {
895
-			$invoice->set_gateway( $args['gateway'] );
896
-		}
893
+        // And the gateway.
894
+        if ( ! empty( $args['gateway'] ) ) {
895
+            $invoice->set_gateway( $args['gateway'] );
896
+        }
897 897
 
898
-		$invoice->save();
898
+        $invoice->save();
899 899
 
900
-		if ( ! $invoice->exists() ) {
901
-			return false;
902
-		}
900
+        if ( ! $invoice->exists() ) {
901
+            return false;
902
+        }
903 903
 
904
-		do_action( 'getpaid_after_create_subscription_renewal_invoice', $invoice, $this );
905
-		do_action( 'wpinv_recurring_add_subscription_payment', $invoice, $this );
904
+        do_action( 'getpaid_after_create_subscription_renewal_invoice', $invoice, $this );
905
+        do_action( 'wpinv_recurring_add_subscription_payment', $invoice, $this );
906 906
         do_action( 'wpinv_recurring_record_payment', $invoice->get_id(), $this->get_parent_invoice_id(), $invoice->get_recurring_total(), $invoice->get_transaction_id() );
907 907
 
908 908
         update_post_meta( $invoice->get_id(), '_wpinv_subscription_id', $this->id );
909 909
 
910 910
         return $invoice->get_id();
911
-	}
911
+    }
912 912
 
913
-	/**
913
+    /**
914 914
      * Creates a new invoice and returns it.
915 915
      *
916 916
      * @since  1.0.19
@@ -918,124 +918,124 @@  discard block
 block discarded – undo
918 918
      */
919 919
     public function create_payment() {
920 920
 
921
-		$parent_invoice = $this->get_parent_payment();
922
-
923
-		if ( ! $parent_invoice->exists() ) {
924
-			return false;
925
-		}
926
-
927
-		// Duplicate the parent invoice.
928
-		$invoice = getpaid_duplicate_invoice( $parent_invoice );
929
-		$invoice->set_parent_id( $parent_invoice->get_id() );
930
-		$invoice->set_subscription_id( $this->get_id() );
931
-		$invoice->set_remote_subscription_id( $this->get_profile_id() );
932
-
933
-		// Set invoice items.
934
-		$subscription_group = getpaid_get_invoice_subscription_group( $parent_invoice->get_id(), $this->get_id() );
935
-		$allowed_items      = empty( $subscription_group ) ? array( $this->get_product_id() ) : array_keys( $subscription_group['items'] );
936
-		$invoice_items      = array();
937
-
938
-		foreach ( $invoice->get_items() as $item ) {
939
-			if ( in_array( $item->get_id(), $allowed_items ) ) {
940
-				$invoice_items[] = $item;
941
-			}
942
-		}
943
-
944
-		$invoice->set_items( $invoice_items );
945
-
946
-		if ( ! empty( $subscription_group['fees'] ) ) {
947
-			$invoice->set_fees( $subscription_group['fees'] );
948
-		}
949
-
950
-		// Maybe recalculate discount (Pre-GetPaid Fix).
951
-		$discount = new WPInv_Discount( $invoice->get_discount_code() );
952
-		if ( $discount->exists() && $discount->is_recurring() && 0 == $invoice->get_total_discount() ) {
953
-			$invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
954
-		}
955
-
956
-		$invoice->recalculate_total();
957
-		$invoice->set_status( 'wpi-pending' );
958
-		$invoice->save();
959
-
960
-		return $invoice->exists() ? $invoice : false;
961
-    }
962
-
963
-	/**
964
-	 * Renews or completes a subscription
965
-	 *
966
-	 * @since  1.0.0
967
-	 * @return int The subscription's id
968
-	 */
969
-	public function renew() {
970
-
971
-		// Complete subscription if applicable
972
-		if ( $this->is_last_renewal() ) {
973
-			return $this->complete();
974
-		}
975
-
976
-		// Calculate new expiration
977
-		$frequency      = $this->get_frequency();
978
-		$period         = $this->get_period();
979
-		$new_expiration = strtotime( "+ $frequency $period", $this->get_expiration_time() );
980
-
981
-		$this->set_expiration( date( 'Y-m-d H:i:s',$new_expiration ) );
982
-		$this->set_status( 'active' );
983
-		$this->save();
984
-
985
-		do_action( 'getpaid_subscription_renewed', $this );
986
-
987
-		return $this->get_id();
988
-	}
989
-
990
-	/**
991
-	 * Marks a subscription as completed
992
-	 *
993
-	 * Subscription is completed when the number of payments matches the billing_times field
994
-	 *
995
-	 * @since  1.0.0
996
-	 * @return int|bool Subscription id or false if the subscription is cancelled.
997
-	 */
998
-	public function complete() {
999
-
1000
-		// Only mark a subscription as complete if it's not already cancelled.
1001
-		if ( $this->has_status( 'cancelled' ) ) {
1002
-			return false;
1003
-		}
1004
-
1005
-		$this->set_status( 'completed' );
1006
-		return $this->save();
1007
-
1008
-	}
1009
-
1010
-	/**
1011
-	 * Marks a subscription as expired
1012
-	 *
1013
-	 * @since  1.0.0
1014
-	 * @param  bool $check_expiration
1015
-	 * @return int|bool Subscription id or false if $check_expiration is true and expiration date is in the future.
1016
-	 */
1017
-	public function expire( $check_expiration = false ) {
1018
-
1019
-		if ( $check_expiration && $this->get_expiration_time() > current_time( 'timestamp' ) ) {
1020
-			// Do not mark as expired since real expiration date is in the future
1021
-			return false;
1022
-		}
1023
-
1024
-		$this->set_status( 'expired' );
1025
-		return $this->save();
1026
-
1027
-	}
1028
-
1029
-	/**
1030
-	 * Marks a subscription as failing
1031
-	 *
1032
-	 * @since  2.4.2
1033
-	 * @return int Subscription id.
1034
-	 */
1035
-	public function failing() {
1036
-		$this->set_status( 'failing' );
1037
-		return $this->save();
1038
-	}
921
+        $parent_invoice = $this->get_parent_payment();
922
+
923
+        if ( ! $parent_invoice->exists() ) {
924
+            return false;
925
+        }
926
+
927
+        // Duplicate the parent invoice.
928
+        $invoice = getpaid_duplicate_invoice( $parent_invoice );
929
+        $invoice->set_parent_id( $parent_invoice->get_id() );
930
+        $invoice->set_subscription_id( $this->get_id() );
931
+        $invoice->set_remote_subscription_id( $this->get_profile_id() );
932
+
933
+        // Set invoice items.
934
+        $subscription_group = getpaid_get_invoice_subscription_group( $parent_invoice->get_id(), $this->get_id() );
935
+        $allowed_items      = empty( $subscription_group ) ? array( $this->get_product_id() ) : array_keys( $subscription_group['items'] );
936
+        $invoice_items      = array();
937
+
938
+        foreach ( $invoice->get_items() as $item ) {
939
+            if ( in_array( $item->get_id(), $allowed_items ) ) {
940
+                $invoice_items[] = $item;
941
+            }
942
+        }
943
+
944
+        $invoice->set_items( $invoice_items );
945
+
946
+        if ( ! empty( $subscription_group['fees'] ) ) {
947
+            $invoice->set_fees( $subscription_group['fees'] );
948
+        }
949
+
950
+        // Maybe recalculate discount (Pre-GetPaid Fix).
951
+        $discount = new WPInv_Discount( $invoice->get_discount_code() );
952
+        if ( $discount->exists() && $discount->is_recurring() && 0 == $invoice->get_total_discount() ) {
953
+            $invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
954
+        }
955
+
956
+        $invoice->recalculate_total();
957
+        $invoice->set_status( 'wpi-pending' );
958
+        $invoice->save();
959
+
960
+        return $invoice->exists() ? $invoice : false;
961
+    }
962
+
963
+    /**
964
+     * Renews or completes a subscription
965
+     *
966
+     * @since  1.0.0
967
+     * @return int The subscription's id
968
+     */
969
+    public function renew() {
970
+
971
+        // Complete subscription if applicable
972
+        if ( $this->is_last_renewal() ) {
973
+            return $this->complete();
974
+        }
975
+
976
+        // Calculate new expiration
977
+        $frequency      = $this->get_frequency();
978
+        $period         = $this->get_period();
979
+        $new_expiration = strtotime( "+ $frequency $period", $this->get_expiration_time() );
980
+
981
+        $this->set_expiration( date( 'Y-m-d H:i:s',$new_expiration ) );
982
+        $this->set_status( 'active' );
983
+        $this->save();
984
+
985
+        do_action( 'getpaid_subscription_renewed', $this );
986
+
987
+        return $this->get_id();
988
+    }
989
+
990
+    /**
991
+     * Marks a subscription as completed
992
+     *
993
+     * Subscription is completed when the number of payments matches the billing_times field
994
+     *
995
+     * @since  1.0.0
996
+     * @return int|bool Subscription id or false if the subscription is cancelled.
997
+     */
998
+    public function complete() {
999
+
1000
+        // Only mark a subscription as complete if it's not already cancelled.
1001
+        if ( $this->has_status( 'cancelled' ) ) {
1002
+            return false;
1003
+        }
1004
+
1005
+        $this->set_status( 'completed' );
1006
+        return $this->save();
1007
+
1008
+    }
1009
+
1010
+    /**
1011
+     * Marks a subscription as expired
1012
+     *
1013
+     * @since  1.0.0
1014
+     * @param  bool $check_expiration
1015
+     * @return int|bool Subscription id or false if $check_expiration is true and expiration date is in the future.
1016
+     */
1017
+    public function expire( $check_expiration = false ) {
1018
+
1019
+        if ( $check_expiration && $this->get_expiration_time() > current_time( 'timestamp' ) ) {
1020
+            // Do not mark as expired since real expiration date is in the future
1021
+            return false;
1022
+        }
1023
+
1024
+        $this->set_status( 'expired' );
1025
+        return $this->save();
1026
+
1027
+    }
1028
+
1029
+    /**
1030
+     * Marks a subscription as failing
1031
+     *
1032
+     * @since  2.4.2
1033
+     * @return int Subscription id.
1034
+     */
1035
+    public function failing() {
1036
+        $this->set_status( 'failing' );
1037
+        return $this->save();
1038
+    }
1039 1039
 
1040 1040
     /**
1041 1041
      * Marks a subscription as cancelled
@@ -1044,19 +1044,19 @@  discard block
 block discarded – undo
1044 1044
      * @return int Subscription id.
1045 1045
      */
1046 1046
     public function cancel() {
1047
-		$this->set_status( 'cancelled' );
1048
-		return $this->save();
1047
+        $this->set_status( 'cancelled' );
1048
+        return $this->save();
1049 1049
     }
1050 1050
 
1051
-	/**
1052
-	 * Determines if a subscription can be cancelled both locally and with a payment processor.
1053
-	 *
1054
-	 * @since  1.0.0
1055
-	 * @return bool
1056
-	 */
1057
-	public function can_cancel() {
1058
-		return apply_filters( 'wpinv_subscription_can_cancel', $this->has_status( $this->get_cancellable_statuses() ), $this );
1059
-	}
1051
+    /**
1052
+     * Determines if a subscription can be cancelled both locally and with a payment processor.
1053
+     *
1054
+     * @since  1.0.0
1055
+     * @return bool
1056
+     */
1057
+    public function can_cancel() {
1058
+        return apply_filters( 'wpinv_subscription_can_cancel', $this->has_status( $this->get_cancellable_statuses() ), $this );
1059
+    }
1060 1060
 
1061 1061
     /**
1062 1062
      * Returns an array of subscription statuses that can be cancelled
@@ -1069,96 +1069,96 @@  discard block
 block discarded – undo
1069 1069
         return apply_filters( 'wpinv_recurring_cancellable_statuses', array( 'active', 'trialling', 'failing' ) );
1070 1070
     }
1071 1071
 
1072
-	/**
1073
-	 * Retrieves the URL to cancel subscription
1074
-	 *
1075
-	 * @since  1.0.0
1076
-	 * @return string
1077
-	 */
1078
-	public function get_cancel_url() {
1079
-		$url = getpaid_get_authenticated_action_url( 'subscription_cancel', $this->get_view_url() );
1080
-		return apply_filters( 'wpinv_subscription_cancel_url', $url, $this );
1081
-	}
1082
-
1083
-	/**
1084
-	 * Retrieves the URL to view a subscription
1085
-	 *
1086
-	 * @since  1.0.19
1087
-	 * @return string
1088
-	 */
1089
-	public function get_view_url() {
1090
-
1091
-		$url = getpaid_get_tab_url( 'gp-subscriptions', get_permalink( (int) wpinv_get_option( 'invoice_subscription_page' ) ) );
1092
-		$url = add_query_arg( 'subscription', $this->get_id(), $url );
1093
-
1094
-		return apply_filters( 'getpaid_get_subscription_view_url', $url, $this );
1095
-	}
1096
-
1097
-	/**
1098
-	 * Determines if subscription can be manually renewed
1099
-	 *
1100
-	 * This method is filtered by payment gateways in order to return true on subscriptions
1101
-	 * that can be renewed manually
1102
-	 *
1103
-	 * @since  2.5
1104
-	 * @return bool
1105
-	 */
1106
-	public function can_renew() {
1107
-		return apply_filters( 'wpinv_subscription_can_renew', true, $this );
1108
-	}
1109
-
1110
-	/**
1111
-	 * Retrieves the URL to renew a subscription
1112
-	 *
1113
-	 * @since  2.5
1114
-	 * @return string
1115
-	 */
1116
-	public function get_renew_url() {
1117
-		$url = wp_nonce_url( add_query_arg( array( 'getpaid-action' => 'renew_subscription', 'sub_id' => $this->get_id ) ), 'getpaid-nonce' );
1118
-		return apply_filters( 'wpinv_subscription_renew_url', $url, $this );
1119
-	}
1120
-
1121
-	/**
1122
-	 * Determines if subscription can have their payment method updated
1123
-	 *
1124
-	 * @since  1.0.0
1125
-	 * @return bool
1126
-	 */
1127
-	public function can_update() {
1128
-		return apply_filters( 'wpinv_subscription_can_update', false, $this );
1129
-	}
1130
-
1131
-	/**
1132
-	 * Retrieves the URL to update subscription
1133
-	 *
1134
-	 * @since  1.0.0
1135
-	 * @return string
1136
-	 */
1137
-	public function get_update_url() {
1138
-		$url = add_query_arg( array( 'action' => 'update', 'subscription_id' => $this->get_id() ) );
1139
-		return apply_filters( 'wpinv_subscription_update_url', $url, $this );
1140
-	}
1141
-
1142
-	/**
1143
-	 * Retrieves the subscription status label
1144
-	 *
1145
-	 * @since  1.0.0
1146
-	 * @return string
1147
-	 */
1148
-	public function get_status_label() {
1149
-		return getpaid_get_subscription_status_label( $this->get_status() );
1150
-	}
1151
-
1152
-	/**
1153
-	 * Retrieves the subscription status class
1154
-	 *
1155
-	 * @since  1.0.19
1156
-	 * @return string
1157
-	 */
1158
-	public function get_status_class() {
1159
-		$statuses = getpaid_get_subscription_status_classes();
1160
-		return isset( $statuses[ $this->get_status() ] ) ? $statuses[ $this->get_status() ] : 'badge-dark';
1161
-	}
1072
+    /**
1073
+     * Retrieves the URL to cancel subscription
1074
+     *
1075
+     * @since  1.0.0
1076
+     * @return string
1077
+     */
1078
+    public function get_cancel_url() {
1079
+        $url = getpaid_get_authenticated_action_url( 'subscription_cancel', $this->get_view_url() );
1080
+        return apply_filters( 'wpinv_subscription_cancel_url', $url, $this );
1081
+    }
1082
+
1083
+    /**
1084
+     * Retrieves the URL to view a subscription
1085
+     *
1086
+     * @since  1.0.19
1087
+     * @return string
1088
+     */
1089
+    public function get_view_url() {
1090
+
1091
+        $url = getpaid_get_tab_url( 'gp-subscriptions', get_permalink( (int) wpinv_get_option( 'invoice_subscription_page' ) ) );
1092
+        $url = add_query_arg( 'subscription', $this->get_id(), $url );
1093
+
1094
+        return apply_filters( 'getpaid_get_subscription_view_url', $url, $this );
1095
+    }
1096
+
1097
+    /**
1098
+     * Determines if subscription can be manually renewed
1099
+     *
1100
+     * This method is filtered by payment gateways in order to return true on subscriptions
1101
+     * that can be renewed manually
1102
+     *
1103
+     * @since  2.5
1104
+     * @return bool
1105
+     */
1106
+    public function can_renew() {
1107
+        return apply_filters( 'wpinv_subscription_can_renew', true, $this );
1108
+    }
1109
+
1110
+    /**
1111
+     * Retrieves the URL to renew a subscription
1112
+     *
1113
+     * @since  2.5
1114
+     * @return string
1115
+     */
1116
+    public function get_renew_url() {
1117
+        $url = wp_nonce_url( add_query_arg( array( 'getpaid-action' => 'renew_subscription', 'sub_id' => $this->get_id ) ), 'getpaid-nonce' );
1118
+        return apply_filters( 'wpinv_subscription_renew_url', $url, $this );
1119
+    }
1120
+
1121
+    /**
1122
+     * Determines if subscription can have their payment method updated
1123
+     *
1124
+     * @since  1.0.0
1125
+     * @return bool
1126
+     */
1127
+    public function can_update() {
1128
+        return apply_filters( 'wpinv_subscription_can_update', false, $this );
1129
+    }
1130
+
1131
+    /**
1132
+     * Retrieves the URL to update subscription
1133
+     *
1134
+     * @since  1.0.0
1135
+     * @return string
1136
+     */
1137
+    public function get_update_url() {
1138
+        $url = add_query_arg( array( 'action' => 'update', 'subscription_id' => $this->get_id() ) );
1139
+        return apply_filters( 'wpinv_subscription_update_url', $url, $this );
1140
+    }
1141
+
1142
+    /**
1143
+     * Retrieves the subscription status label
1144
+     *
1145
+     * @since  1.0.0
1146
+     * @return string
1147
+     */
1148
+    public function get_status_label() {
1149
+        return getpaid_get_subscription_status_label( $this->get_status() );
1150
+    }
1151
+
1152
+    /**
1153
+     * Retrieves the subscription status class
1154
+     *
1155
+     * @since  1.0.19
1156
+     * @return string
1157
+     */
1158
+    public function get_status_class() {
1159
+        $statuses = getpaid_get_subscription_status_classes();
1160
+        return isset( $statuses[ $this->get_status() ] ) ? $statuses[ $this->get_status() ] : 'badge-dark';
1161
+    }
1162 1162
 
1163 1163
     /**
1164 1164
      * Retrieves the subscription status label
@@ -1168,11 +1168,11 @@  discard block
 block discarded – undo
1168 1168
      */
1169 1169
     public function get_status_label_html() {
1170 1170
 
1171
-		$status_label = sanitize_text_field( $this->get_status_label() );
1172
-		$class        = esc_attr( $this->get_status_class() );
1173
-		$status       = sanitize_html_class( $this->get_status() );
1171
+        $status_label = sanitize_text_field( $this->get_status_label() );
1172
+        $class        = esc_attr( $this->get_status_class() );
1173
+        $status       = sanitize_html_class( $this->get_status() );
1174 1174
 
1175
-		return "<span class='bsui'><span class='badge $class $status'>$status_label</span></span>";
1175
+        return "<span class='bsui'><span class='badge $class $status'>$status_label</span></span>";
1176 1176
     }
1177 1177
 
1178 1178
     /**
@@ -1183,75 +1183,75 @@  discard block
 block discarded – undo
1183 1183
      * @return bool
1184 1184
      */
1185 1185
     public function payment_exists( $txn_id = '' ) {
1186
-		$invoice_id = WPInv_Invoice::get_invoice_id_by_field( $txn_id, 'transaction_id' );
1186
+        $invoice_id = WPInv_Invoice::get_invoice_id_by_field( $txn_id, 'transaction_id' );
1187 1187
         return ! empty( $invoice_id );
1188
-	}
1189
-
1190
-	/**
1191
-	 * Handle the status transition.
1192
-	 */
1193
-	protected function status_transition() {
1194
-		$status_transition = $this->status_transition;
1195
-
1196
-		// Reset status transition variable.
1197
-		$this->status_transition = false;
1198
-
1199
-		if ( $status_transition ) {
1200
-			try {
1201
-
1202
-				// Fire a hook for the status change.
1203
-				do_action( 'wpinv_subscription_' . $status_transition['to'], $this->get_id(), $this, $status_transition );
1204
-				do_action( 'getpaid_subscription_' . $status_transition['to'], $this, $status_transition );
1205
-
1206
-				if ( ! empty( $status_transition['from'] ) ) {
1207
-
1208
-					/* translators: 1: old subscription status 2: new subscription status */
1209
-					$transition_note = sprintf( __( 'Subscription status changed from %1$s to %2$s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['from'] ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1210
-
1211
-					// Note the transition occurred.
1212
-					$this->get_parent_payment()->add_note( $transition_note, false, false, true );
1213
-
1214
-					// Fire another hook.
1215
-					do_action( 'getpaid_subscription_status_' . $status_transition['from'] . '_to_' . $status_transition['to'], $this->get_id(), $this );
1216
-					do_action( 'getpaid_subscription_status_changed', $this, $status_transition['from'], $status_transition['to'] );
1217
-
1218
-				} else {
1219
-					/* translators: %s: new invoice status */
1220
-					$transition_note = sprintf( __( 'Subscription status set to %s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1221
-
1222
-					// Note the transition occurred.
1223
-					$this->get_parent_payment()->add_note( $transition_note, false, false, true );
1224
-
1225
-				}
1226
-			} catch ( Exception $e ) {
1227
-				$this->get_parent_payment()->add_note( __( 'Error during subscription status transition.', 'invoicing' ) . ' ' . $e->getMessage() );
1228
-			}
1229
-		}
1230
-
1231
-	}
1232
-
1233
-	/**
1234
-	 * Save data to the database.
1235
-	 *
1236
-	 * @since 1.0.19
1237
-	 * @return int subscription ID
1238
-	 */
1239
-	public function save() {
1240
-		parent::save();
1241
-		$this->status_transition();
1242
-		return $this->get_id();
1243
-	}
1244
-
1245
-	/**
1246
-	 * Activates a subscription.
1247
-	 *
1248
-	 * @since 1.0.19
1249
-	 * @return int subscription ID
1250
-	 */
1251
-	public function activate() {
1252
-		$status = 'trialling' == $this->get_status() ? 'trialling' : 'active';
1253
-		$this->set_status( $status );
1254
-		return $this->save();
1255
-	}
1188
+    }
1189
+
1190
+    /**
1191
+     * Handle the status transition.
1192
+     */
1193
+    protected function status_transition() {
1194
+        $status_transition = $this->status_transition;
1195
+
1196
+        // Reset status transition variable.
1197
+        $this->status_transition = false;
1198
+
1199
+        if ( $status_transition ) {
1200
+            try {
1201
+
1202
+                // Fire a hook for the status change.
1203
+                do_action( 'wpinv_subscription_' . $status_transition['to'], $this->get_id(), $this, $status_transition );
1204
+                do_action( 'getpaid_subscription_' . $status_transition['to'], $this, $status_transition );
1205
+
1206
+                if ( ! empty( $status_transition['from'] ) ) {
1207
+
1208
+                    /* translators: 1: old subscription status 2: new subscription status */
1209
+                    $transition_note = sprintf( __( 'Subscription status changed from %1$s to %2$s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['from'] ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1210
+
1211
+                    // Note the transition occurred.
1212
+                    $this->get_parent_payment()->add_note( $transition_note, false, false, true );
1213
+
1214
+                    // Fire another hook.
1215
+                    do_action( 'getpaid_subscription_status_' . $status_transition['from'] . '_to_' . $status_transition['to'], $this->get_id(), $this );
1216
+                    do_action( 'getpaid_subscription_status_changed', $this, $status_transition['from'], $status_transition['to'] );
1217
+
1218
+                } else {
1219
+                    /* translators: %s: new invoice status */
1220
+                    $transition_note = sprintf( __( 'Subscription status set to %s.', 'invoicing' ), getpaid_get_subscription_status_label( $status_transition['to'] ) );
1221
+
1222
+                    // Note the transition occurred.
1223
+                    $this->get_parent_payment()->add_note( $transition_note, false, false, true );
1224
+
1225
+                }
1226
+            } catch ( Exception $e ) {
1227
+                $this->get_parent_payment()->add_note( __( 'Error during subscription status transition.', 'invoicing' ) . ' ' . $e->getMessage() );
1228
+            }
1229
+        }
1230
+
1231
+    }
1232
+
1233
+    /**
1234
+     * Save data to the database.
1235
+     *
1236
+     * @since 1.0.19
1237
+     * @return int subscription ID
1238
+     */
1239
+    public function save() {
1240
+        parent::save();
1241
+        $this->status_transition();
1242
+        return $this->get_id();
1243
+    }
1244
+
1245
+    /**
1246
+     * Activates a subscription.
1247
+     *
1248
+     * @since 1.0.19
1249
+     * @return int subscription ID
1250
+     */
1251
+    public function activate() {
1252
+        $status = 'trialling' == $this->get_status() ? 'trialling' : 'active';
1253
+        $this->set_status( $status );
1254
+        return $this->save();
1255
+    }
1256 1256
 
1257 1257
 }
Please login to merge, or discard this patch.
includes/admin/class-getpaid-admin.php 1 patch
Indentation   +473 added lines, -473 removed lines patch added patch discarded remove patch
@@ -14,78 +14,78 @@  discard block
 block discarded – undo
14 14
 class GetPaid_Admin {
15 15
 
16 16
     /**
17
-	 * Local path to this plugins admin directory
18
-	 *
19
-	 * @var         string
20
-	 */
21
-	public $admin_path;
22
-
23
-	/**
24
-	 * Web path to this plugins admin directory
25
-	 *
26
-	 * @var         string
27
-	 */
28
-	public $admin_url;
17
+     * Local path to this plugins admin directory
18
+     *
19
+     * @var         string
20
+     */
21
+    public $admin_path;
22
+
23
+    /**
24
+     * Web path to this plugins admin directory
25
+     *
26
+     * @var         string
27
+     */
28
+    public $admin_url;
29 29
 	
30
-	/**
31
-	 * Reports components.
32
-	 *
33
-	 * @var GetPaid_Reports
34
-	 */
30
+    /**
31
+     * Reports components.
32
+     *
33
+     * @var GetPaid_Reports
34
+     */
35 35
     public $reports;
36 36
 
37 37
     /**
38
-	 * Class constructor.
39
-	 */
40
-	public function __construct(){
38
+     * Class constructor.
39
+     */
40
+    public function __construct(){
41 41
 
42 42
         $this->admin_path  = plugin_dir_path( __FILE__ );
43
-		$this->admin_url   = plugins_url( '/', __FILE__ );
44
-		$this->reports     = new GetPaid_Reports();
43
+        $this->admin_url   = plugins_url( '/', __FILE__ );
44
+        $this->reports     = new GetPaid_Reports();
45 45
 
46 46
         if ( is_admin() ) {
47
-			$this->init_admin_hooks();
47
+            $this->init_admin_hooks();
48 48
         }
49 49
 
50 50
     }
51 51
 
52 52
     /**
53
-	 * Init action and filter hooks
54
-	 *
55
-	 */
56
-	private function init_admin_hooks() {
53
+     * Init action and filter hooks
54
+     *
55
+     */
56
+    private function init_admin_hooks() {
57 57
         add_action( 'admin_enqueue_scripts', array( $this, 'enqeue_scripts' ) );
58 58
         add_filter( 'admin_body_class', array( $this, 'admin_body_class' ) );
59 59
         add_action( 'admin_init', array( $this, 'init_ayecode_connect_helper' ) );
60 60
         add_action( 'admin_init', array( $this, 'activation_redirect') );
61 61
         add_action( 'admin_init', array( $this, 'maybe_do_admin_action') );
62
-		add_action( 'admin_notices', array( $this, 'show_notices' ) );
63
-		add_action( 'getpaid_authenticated_admin_action_rate_plugin', array( $this, 'redirect_to_wordpress_rating_page' ) );
64
-		add_action( 'getpaid_authenticated_admin_action_send_invoice', array( $this, 'send_customer_invoice' ) );
65
-		add_action( 'getpaid_authenticated_admin_action_send_invoice_reminder', array( $this, 'send_customer_payment_reminder' ) );
62
+        add_action( 'admin_notices', array( $this, 'show_notices' ) );
63
+        add_action( 'getpaid_authenticated_admin_action_rate_plugin', array( $this, 'redirect_to_wordpress_rating_page' ) );
64
+        add_action( 'getpaid_authenticated_admin_action_send_invoice', array( $this, 'send_customer_invoice' ) );
65
+        add_action( 'getpaid_authenticated_admin_action_send_invoice_reminder', array( $this, 'send_customer_payment_reminder' ) );
66 66
         add_action( 'getpaid_authenticated_admin_action_reset_tax_rates', array( $this, 'admin_reset_tax_rates' ) );
67
-		add_action( 'getpaid_authenticated_admin_action_create_missing_pages', array( $this, 'admin_create_missing_pages' ) );
68
-		add_action( 'getpaid_authenticated_admin_action_create_missing_tables', array( $this, 'admin_create_missing_tables' ) );
69
-		add_action( 'getpaid_authenticated_admin_action_migrate_old_invoices', array( $this, 'admin_migrate_old_invoices' ) );
70
-		add_action( 'getpaid_authenticated_admin_action_download_customers', array( $this, 'admin_download_customers' ) );
71
-		add_action( 'getpaid_authenticated_admin_action_recalculate_discounts', array( $this, 'admin_recalculate_discounts' ) );
72
-		add_filter( 'admin_footer_text', array( $this, 'admin_footer_text' ) );
73
-		do_action( 'getpaid_init_admin_hooks', $this );
67
+        add_action( 'getpaid_authenticated_admin_action_create_missing_pages', array( $this, 'admin_create_missing_pages' ) );
68
+        add_action( 'getpaid_authenticated_admin_action_create_missing_tables', array( $this, 'admin_create_missing_tables' ) );
69
+        add_action( 'getpaid_authenticated_admin_action_migrate_old_invoices', array( $this, 'admin_migrate_old_invoices' ) );
70
+        add_action( 'getpaid_authenticated_admin_action_download_customers', array( $this, 'admin_download_customers' ) );
71
+        add_action( 'getpaid_authenticated_admin_action_recalculate_discounts', array( $this, 'admin_recalculate_discounts' ) );
72
+        add_filter( 'admin_footer_text', array( $this, 'admin_footer_text' ) );
73
+        do_action( 'getpaid_init_admin_hooks', $this );
74 74
 
75 75
     }
76 76
 
77 77
     /**
78
-	 * Register admin scripts
79
-	 *
80
-	 */
81
-	public function enqeue_scripts() {
78
+     * Register admin scripts
79
+     *
80
+     */
81
+    public function enqeue_scripts() {
82 82
         global $current_screen, $pagenow;
83 83
 
84
-		$page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
85
-		$editing = $pagenow == 'post.php' || $pagenow == 'post-new.php';
84
+        $page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
85
+        $editing = $pagenow == 'post.php' || $pagenow == 'post-new.php';
86 86
 
87 87
         if ( ! empty( $current_screen->post_type ) ) {
88
-			$page = $current_screen->post_type;
88
+            $page = $current_screen->post_type;
89 89
         }
90 90
 
91 91
         // General styles.
@@ -106,54 +106,54 @@  discard block
 block discarded – undo
106 106
         }
107 107
 
108 108
         // Payment form scripts.
109
-		if ( 'wpi_payment_form' == $page && $editing ) {
109
+        if ( 'wpi_payment_form' == $page && $editing ) {
110 110
             $this->load_payment_form_scripts();
111 111
         }
112 112
 
113
-		if ( $page == 'wpinv-subscriptions' ) {
114
-			wp_enqueue_script( 'postbox' );
115
-		}
113
+        if ( $page == 'wpinv-subscriptions' ) {
114
+            wp_enqueue_script( 'postbox' );
115
+        }
116 116
 
117 117
     }
118 118
 
119 119
     /**
120
-	 * Returns admin js translations.
121
-	 *
122
-	 */
123
-	protected function get_admin_i18() {
120
+     * Returns admin js translations.
121
+     *
122
+     */
123
+    protected function get_admin_i18() {
124 124
         global $post;
125 125
 
126
-		$date_range = array(
127
-			'period' => isset( $_GET['date_range'] ) ? sanitize_text_field( $_GET['date_range'] ) : '7_days'
128
-		);
126
+        $date_range = array(
127
+            'period' => isset( $_GET['date_range'] ) ? sanitize_text_field( $_GET['date_range'] ) : '7_days'
128
+        );
129 129
 
130
-		if ( $date_range['period'] == 'custom' ) {
130
+        if ( $date_range['period'] == 'custom' ) {
131 131
 			
132
-			if ( isset( $_GET['from'] ) ) {
133
-				$date_range[ 'after' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['from'] ), current_time( 'timestamp' ) ) - DAY_IN_SECONDS );
134
-			}
132
+            if ( isset( $_GET['from'] ) ) {
133
+                $date_range[ 'after' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['from'] ), current_time( 'timestamp' ) ) - DAY_IN_SECONDS );
134
+            }
135 135
 
136
-			if ( isset( $_GET['to'] ) ) {
137
-				$date_range[ 'before' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['to'] ), current_time( 'timestamp' ) ) + DAY_IN_SECONDS );
138
-			}
136
+            if ( isset( $_GET['to'] ) ) {
137
+                $date_range[ 'before' ] = date( 'Y-m-d', strtotime( sanitize_text_field( $_GET['to'] ), current_time( 'timestamp' ) ) + DAY_IN_SECONDS );
138
+            }
139 139
 
140
-		}
140
+        }
141 141
 
142 142
         $i18n = array(
143 143
             'ajax_url'                  => admin_url( 'admin-ajax.php' ),
144 144
             'post_ID'                   => isset( $post->ID ) ? $post->ID : '',
145
-			'wpinv_nonce'               => wp_create_nonce( 'wpinv-nonce' ),
146
-			'rest_nonce'                => wp_create_nonce( 'wp_rest' ),
147
-			'rest_root'                 => esc_url_raw( rest_url() ),
148
-			'date_range'                => $date_range,
145
+            'wpinv_nonce'               => wp_create_nonce( 'wpinv-nonce' ),
146
+            'rest_nonce'                => wp_create_nonce( 'wp_rest' ),
147
+            'rest_root'                 => esc_url_raw( rest_url() ),
148
+            'date_range'                => $date_range,
149 149
             'add_invoice_note_nonce'    => wp_create_nonce( 'add-invoice-note' ),
150 150
             'delete_invoice_note_nonce' => wp_create_nonce( 'delete-invoice-note' ),
151 151
             'invoice_item_nonce'        => wp_create_nonce( 'invoice-item' ),
152 152
             'billing_details_nonce'     => wp_create_nonce( 'get-billing-details' ),
153 153
             'tax'                       => wpinv_tax_amount(),
154 154
             'discount'                  => 0,
155
-			'currency_symbol'           => wpinv_currency_symbol(),
156
-			'currency'                  => wpinv_get_currency(),
155
+            'currency_symbol'           => wpinv_currency_symbol(),
156
+            'currency'                  => wpinv_get_currency(),
157 157
             'currency_pos'              => wpinv_currency_position(),
158 158
             'thousand_sep'              => wpinv_thousands_separator(),
159 159
             'decimal_sep'               => wpinv_decimal_separator(),
@@ -173,118 +173,118 @@  discard block
 block discarded – undo
173 173
             'item_description'          => __( 'Item Description', 'invoicing' ),
174 174
             'invoice_description'       => __( 'Invoice Description', 'invoicing' ),
175 175
             'discount_description'      => __( 'Discount Description', 'invoicing' ),
176
-			'searching'                 => __( 'Searching', 'invoicing' ),
177
-			'loading'                   => __( 'Loading...', 'invoicing' ),
178
-			'search_customers'          => __( 'Enter customer name or email', 'invoicing' ),
179
-			'search_items'              => __( 'Enter item name', 'invoicing' ),
176
+            'searching'                 => __( 'Searching', 'invoicing' ),
177
+            'loading'                   => __( 'Loading...', 'invoicing' ),
178
+            'search_customers'          => __( 'Enter customer name or email', 'invoicing' ),
179
+            'search_items'              => __( 'Enter item name', 'invoicing' ),
180 180
         );
181 181
 
182
-		if ( ! empty( $post ) && getpaid_is_invoice_post_type( $post->post_type ) ) {
182
+        if ( ! empty( $post ) && getpaid_is_invoice_post_type( $post->post_type ) ) {
183 183
 
184
-			$invoice              = new WPInv_Invoice( $post );
185
-			$i18n['save_invoice'] = sprintf(
186
-				__( 'Save %s', 'invoicing' ),
187
-				ucfirst( $invoice->get_invoice_quote_type() )
188
-			);
184
+            $invoice              = new WPInv_Invoice( $post );
185
+            $i18n['save_invoice'] = sprintf(
186
+                __( 'Save %s', 'invoicing' ),
187
+                ucfirst( $invoice->get_invoice_quote_type() )
188
+            );
189 189
 
190
-			$i18n['invoice_description'] = sprintf(
191
-				__( '%s Description', 'invoicing' ),
192
-				ucfirst( $invoice->get_invoice_quote_type() )
193
-			);
190
+            $i18n['invoice_description'] = sprintf(
191
+                __( '%s Description', 'invoicing' ),
192
+                ucfirst( $invoice->get_invoice_quote_type() )
193
+            );
194 194
 
195
-		}
196
-		return $i18n;
197
-	}
195
+        }
196
+        return $i18n;
197
+    }
198 198
 
199
-	/**
200
-	 * Change the admin footer text on GetPaid admin pages.
201
-	 *
202
-	 * @since  2.0.0
203
-	 * @param  string $footer_text
204
-	 * @return string
205
-	 */
206
-	public function admin_footer_text( $footer_text ) {
207
-		global $current_screen;
199
+    /**
200
+     * Change the admin footer text on GetPaid admin pages.
201
+     *
202
+     * @since  2.0.0
203
+     * @param  string $footer_text
204
+     * @return string
205
+     */
206
+    public function admin_footer_text( $footer_text ) {
207
+        global $current_screen;
208 208
 
209
-		$page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
209
+        $page    = isset( $_GET['page'] ) ? $_GET['page'] : '';
210 210
 
211 211
         if ( ! empty( $current_screen->post_type ) ) {
212
-			$page = $current_screen->post_type;
212
+            $page = $current_screen->post_type;
213 213
         }
214 214
 
215 215
         // General styles.
216 216
         if ( apply_filters( 'getpaid_display_admin_footer_text', wpinv_current_user_can_manage_invoicing() ) && false !== stripos( $page, 'wpi' ) ) {
217 217
 
218
-			// Change the footer text
219
-			if ( ! get_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', true ) ) {
220
-
221
-				$rating_url  = esc_url(
222
-					wp_nonce_url(
223
-						admin_url( 'admin.php?page=wpinv-reports&getpaid-admin-action=rate_plugin' ),
224
-						'getpaid-nonce',
225
-						'getpaid-nonce'
226
-						)
227
-				);
228
-
229
-				$footer_text = sprintf(
230
-					/* translators: %s: five stars */
231
-					__( 'If you like <strong>GetPaid</strong>, please leave us a %s rating. A huge thanks in advance!', 'invoicing' ),
232
-					"<a href='$rating_url'>&#9733;&#9733;&#9733;&#9733;&#9733;</a>"
233
-				);
234
-
235
-			} else {
236
-
237
-				$footer_text = sprintf(
238
-					/* translators: %s: GetPaid */
239
-					__( 'Thank you for using %s!', 'invoicing' ),
240
-					"<a href='https://wpgetpaid.com/' target='_blank'><strong>GetPaid</strong></a>"
241
-				);
242
-
243
-			}
244
-
245
-		}
246
-
247
-		return $footer_text;
248
-	}
249
-
250
-	/**
251
-	 * Redirects to wp.org to rate the plugin.
252
-	 *
253
-	 * @since  2.0.0
254
-	 */
255
-	public function redirect_to_wordpress_rating_page() {
256
-		update_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', 1 );
257
-		wp_redirect( 'https://wordpress.org/support/plugin/invoicing/reviews?rate=5#new-post' );
258
-		exit;
259
-	}
218
+            // Change the footer text
219
+            if ( ! get_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', true ) ) {
220
+
221
+                $rating_url  = esc_url(
222
+                    wp_nonce_url(
223
+                        admin_url( 'admin.php?page=wpinv-reports&getpaid-admin-action=rate_plugin' ),
224
+                        'getpaid-nonce',
225
+                        'getpaid-nonce'
226
+                        )
227
+                );
228
+
229
+                $footer_text = sprintf(
230
+                    /* translators: %s: five stars */
231
+                    __( 'If you like <strong>GetPaid</strong>, please leave us a %s rating. A huge thanks in advance!', 'invoicing' ),
232
+                    "<a href='$rating_url'>&#9733;&#9733;&#9733;&#9733;&#9733;</a>"
233
+                );
234
+
235
+            } else {
236
+
237
+                $footer_text = sprintf(
238
+                    /* translators: %s: GetPaid */
239
+                    __( 'Thank you for using %s!', 'invoicing' ),
240
+                    "<a href='https://wpgetpaid.com/' target='_blank'><strong>GetPaid</strong></a>"
241
+                );
242
+
243
+            }
244
+
245
+        }
246
+
247
+        return $footer_text;
248
+    }
249
+
250
+    /**
251
+     * Redirects to wp.org to rate the plugin.
252
+     *
253
+     * @since  2.0.0
254
+     */
255
+    public function redirect_to_wordpress_rating_page() {
256
+        update_user_meta( get_current_user_id(), 'getpaid_admin_footer_text_rated', 1 );
257
+        wp_redirect( 'https://wordpress.org/support/plugin/invoicing/reviews?rate=5#new-post' );
258
+        exit;
259
+    }
260 260
 
261 261
     /**
262
-	 * Loads payment form js.
263
-	 *
264
-	 */
265
-	protected function load_payment_form_scripts() {
262
+     * Loads payment form js.
263
+     *
264
+     */
265
+    protected function load_payment_form_scripts() {
266 266
         global $post;
267 267
 
268 268
         wp_enqueue_script( 'vue', WPINV_PLUGIN_URL . 'assets/js/vue/vue.js', array(), WPINV_VERSION );
269
-		wp_enqueue_script( 'sortable', WPINV_PLUGIN_URL . 'assets/js/sortable.min.js', array(), WPINV_VERSION );
270
-		wp_enqueue_script( 'vue_draggable', WPINV_PLUGIN_URL . 'assets/js/vue/vuedraggable.min.js', array( 'sortable', 'vue' ), WPINV_VERSION );
269
+        wp_enqueue_script( 'sortable', WPINV_PLUGIN_URL . 'assets/js/sortable.min.js', array(), WPINV_VERSION );
270
+        wp_enqueue_script( 'vue_draggable', WPINV_PLUGIN_URL . 'assets/js/vue/vuedraggable.min.js', array( 'sortable', 'vue' ), WPINV_VERSION );
271 271
 
272
-		$version = filemtime( WPINV_PLUGIN_DIR . 'assets/js/admin-payment-forms.js' );
273
-		wp_register_script( 'wpinv-admin-payment-form-script', WPINV_PLUGIN_URL . 'assets/js/admin-payment-forms.js', array( 'wpinv-admin-script', 'vue_draggable' ),  $version );
272
+        $version = filemtime( WPINV_PLUGIN_DIR . 'assets/js/admin-payment-forms.js' );
273
+        wp_register_script( 'wpinv-admin-payment-form-script', WPINV_PLUGIN_URL . 'assets/js/admin-payment-forms.js', array( 'wpinv-admin-script', 'vue_draggable' ),  $version );
274 274
 
275
-		wp_localize_script(
275
+        wp_localize_script(
276 276
             'wpinv-admin-payment-form-script',
277 277
             'wpinvPaymentFormAdmin',
278 278
             array(
279
-				'elements'      => wpinv_get_data( 'payment-form-elements' ),
280
-				'form_elements' => getpaid_get_payment_form_elements( $post->ID ),
281
-				'currency'      => wpinv_currency_symbol(),
282
-				'position'      => wpinv_currency_position(),
283
-				'decimals'      => (int) wpinv_decimals(),
284
-				'thousands_sep' => wpinv_thousands_separator(),
285
-				'decimals_sep'  => wpinv_decimal_separator(),
286
-				'form_items'    => gepaid_get_form_items( $post->ID ),
287
-				'is_default'    => $post->ID == wpinv_get_default_payment_form(),
279
+                'elements'      => wpinv_get_data( 'payment-form-elements' ),
280
+                'form_elements' => getpaid_get_payment_form_elements( $post->ID ),
281
+                'currency'      => wpinv_currency_symbol(),
282
+                'position'      => wpinv_currency_position(),
283
+                'decimals'      => (int) wpinv_decimals(),
284
+                'thousands_sep' => wpinv_thousands_separator(),
285
+                'decimals_sep'  => wpinv_decimal_separator(),
286
+                'form_items'    => gepaid_get_form_items( $post->ID ),
287
+                'is_default'    => $post->ID == wpinv_get_default_payment_form(),
288 288
             )
289 289
         );
290 290
 
@@ -293,20 +293,20 @@  discard block
 block discarded – undo
293 293
     }
294 294
 
295 295
     /**
296
-	 * Add our classes to admin pages.
296
+     * Add our classes to admin pages.
297 297
      *
298 298
      * @param string $classes
299 299
      * @return string
300
-	 *
301
-	 */
300
+     *
301
+     */
302 302
     public function admin_body_class( $classes ) {
303
-		global $pagenow, $post, $current_screen;
303
+        global $pagenow, $post, $current_screen;
304 304
 
305 305
 
306 306
         $page = isset( $_GET['page'] ) ? $_GET['page'] : '';
307 307
 
308 308
         if ( ! empty( $current_screen->post_type ) ) {
309
-			$page = $current_screen->post_type;
309
+            $page = $current_screen->post_type;
310 310
         }
311 311
 
312 312
         if ( false !== stripos( $page, 'wpi' ) ) {
@@ -315,59 +315,59 @@  discard block
 block discarded – undo
315 315
 
316 316
         if ( in_array( $page, wpinv_parse_list( 'wpi_invoice wpi_payment_form wpi_quote' ) ) ) {
317 317
             $classes .= ' wpinv-cpt wpinv';
318
-		}
318
+        }
319 319
 		
320
-		if ( getpaid_is_invoice_post_type( $page ) ) {
320
+        if ( getpaid_is_invoice_post_type( $page ) ) {
321 321
             $classes .= ' getpaid-is-invoice-cpt';
322 322
         }
323 323
 
324
-		return $classes;
324
+        return $classes;
325 325
     }
326 326
 
327 327
     /**
328
-	 * Maybe show the AyeCode Connect Notice.
329
-	 */
330
-	public function init_ayecode_connect_helper(){
328
+     * Maybe show the AyeCode Connect Notice.
329
+     */
330
+    public function init_ayecode_connect_helper(){
331 331
 
332 332
         new AyeCode_Connect_Helper(
333 333
             array(
334
-				'connect_title' => __("WP Invoicing - an AyeCode product!","invoicing"),
335
-				'connect_external'  => __( "Please confirm you wish to connect your site?","invoicing" ),
336
-				'connect'           => sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s","invoicing" ),"<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>","</a>" ),
337
-				'connect_button'    => __("Connect Site","invoicing"),
338
-				'connecting_button'    => __("Connecting...","invoicing"),
339
-				'error_localhost'   => __( "This service will only work with a live domain, not a localhost.","invoicing" ),
340
-				'error'             => __( "Something went wrong, please refresh and try again.","invoicing" ),
334
+                'connect_title' => __("WP Invoicing - an AyeCode product!","invoicing"),
335
+                'connect_external'  => __( "Please confirm you wish to connect your site?","invoicing" ),
336
+                'connect'           => sprintf( __( "<strong>Have a license?</strong> Forget about entering license keys or downloading zip files, connect your site for instant access. %slearn more%s","invoicing" ),"<a href='https://ayecode.io/introducing-ayecode-connect/' target='_blank'>","</a>" ),
337
+                'connect_button'    => __("Connect Site","invoicing"),
338
+                'connecting_button'    => __("Connecting...","invoicing"),
339
+                'error_localhost'   => __( "This service will only work with a live domain, not a localhost.","invoicing" ),
340
+                'error'             => __( "Something went wrong, please refresh and try again.","invoicing" ),
341 341
             ),
342 342
             array( 'wpi-addons' )
343 343
         );
344 344
 
345 345
     }
346 346
 
347
-	/**
348
-	 * Redirect users to settings on activation.
349
-	 *
350
-	 * @return void
351
-	 */
352
-	public function activation_redirect() {
347
+    /**
348
+     * Redirect users to settings on activation.
349
+     *
350
+     * @return void
351
+     */
352
+    public function activation_redirect() {
353 353
 
354
-		$redirected = get_option( 'wpinv_redirected_to_settings' );
354
+        $redirected = get_option( 'wpinv_redirected_to_settings' );
355 355
 
356
-		if ( ! empty( $redirected ) || wp_doing_ajax() || ! current_user_can( 'manage_options' ) ) {
357
-			return;
358
-		}
356
+        if ( ! empty( $redirected ) || wp_doing_ajax() || ! current_user_can( 'manage_options' ) ) {
357
+            return;
358
+        }
359 359
 
360
-		// Bail if activating from network, or bulk
361
-		if ( is_network_admin() || isset( $_GET['activate-multi'] ) ) {
362
-			return;
363
-		}
360
+        // Bail if activating from network, or bulk
361
+        if ( is_network_admin() || isset( $_GET['activate-multi'] ) ) {
362
+            return;
363
+        }
364 364
 
365
-	    update_option( 'wpinv_redirected_to_settings', 1 );
365
+        update_option( 'wpinv_redirected_to_settings', 1 );
366 366
 
367 367
         wp_safe_redirect( admin_url( 'admin.php?page=wpinv-settings&tab=general' ) );
368 368
         exit;
369 369
 
370
-	}
370
+    }
371 371
 
372 372
     /**
373 373
      * Fires an admin action after verifying that a user can fire them.
@@ -381,384 +381,384 @@  discard block
 block discarded – undo
381 381
 
382 382
     }
383 383
 
384
-	/**
384
+    /**
385 385
      * Sends a payment reminder to a customer.
386
-	 * 
387
-	 * @param array $args
386
+     * 
387
+     * @param array $args
388 388
      */
389 389
     public function send_customer_invoice( $args ) {
390
-		$sent = getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $args['invoice_id'] ), true );
390
+        $sent = getpaid()->get( 'invoice_emails' )->user_invoice( new WPInv_Invoice( $args['invoice_id'] ), true );
391 391
 
392
-		if ( $sent ) {
393
-			$this->show_success( __( 'Invoice was successfully sent to the customer', 'invoicing' ) );
394
-		} else {
395
-			$this->show_error( __( 'Could not send the invoice to the customer', 'invoicing' ) );
396
-		}
392
+        if ( $sent ) {
393
+            $this->show_success( __( 'Invoice was successfully sent to the customer', 'invoicing' ) );
394
+        } else {
395
+            $this->show_error( __( 'Could not send the invoice to the customer', 'invoicing' ) );
396
+        }
397 397
 
398
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
399
-		exit;
400
-	}
398
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
399
+        exit;
400
+    }
401 401
 
402
-	/**
402
+    /**
403 403
      * Sends a payment reminder to a customer.
404
-	 * 
405
-	 * @param array $args
404
+     * 
405
+     * @param array $args
406 406
      */
407 407
     public function send_customer_payment_reminder( $args ) {
408
-		$sent = getpaid()->get( 'invoice_emails' )->force_send_overdue_notice( new WPInv_Invoice( $args['invoice_id'] ) );
408
+        $sent = getpaid()->get( 'invoice_emails' )->force_send_overdue_notice( new WPInv_Invoice( $args['invoice_id'] ) );
409 409
 
410
-		if ( $sent ) {
411
-			$this->show_success( __( 'Payment reminder was successfully sent to the customer', 'invoicing' ) );
412
-		} else {
413
-			$this->show_error( __( 'Could not sent payment reminder to the customer', 'invoicing' ) );
414
-		}
410
+        if ( $sent ) {
411
+            $this->show_success( __( 'Payment reminder was successfully sent to the customer', 'invoicing' ) );
412
+        } else {
413
+            $this->show_error( __( 'Could not sent payment reminder to the customer', 'invoicing' ) );
414
+        }
415 415
 
416
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
417
-		exit;
418
-	}
416
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce', 'invoice_id' ) ) );
417
+        exit;
418
+    }
419 419
 
420
-	/**
420
+    /**
421 421
      * Resets tax rates.
422
-	 * 
422
+     * 
423 423
      */
424 424
     public function admin_reset_tax_rates() {
425 425
 
426
-		update_option( 'wpinv_tax_rates', wpinv_get_data( 'tax-rates' ) );
427
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
428
-		exit;
426
+        update_option( 'wpinv_tax_rates', wpinv_get_data( 'tax-rates' ) );
427
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
428
+        exit;
429 429
 
430
-	}
430
+    }
431 431
 
432
-	/**
432
+    /**
433 433
      * Resets admin pages.
434
-	 * 
434
+     * 
435 435
      */
436 436
     public function admin_create_missing_pages() {
437
-		$installer = new GetPaid_Installer();
438
-		$installer->create_pages();
439
-		$this->show_success( __( 'GetPaid pages updated.', 'invoicing' ) );
440
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
441
-		exit;
442
-	}
443
-
444
-	/**
437
+        $installer = new GetPaid_Installer();
438
+        $installer->create_pages();
439
+        $this->show_success( __( 'GetPaid pages updated.', 'invoicing' ) );
440
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
441
+        exit;
442
+    }
443
+
444
+    /**
445 445
      * Creates an missing admin tables.
446
-	 * 
446
+     * 
447 447
      */
448 448
     public function admin_create_missing_tables() {
449
-		global $wpdb;
450
-		$installer = new GetPaid_Installer();
449
+        global $wpdb;
450
+        $installer = new GetPaid_Installer();
451 451
 
452
-		if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}wpinv_subscriptions'" ) != $wpdb->prefix . 'wpinv_subscriptions' ) {
453
-			$installer->create_subscriptions_table();
452
+        if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}wpinv_subscriptions'" ) != $wpdb->prefix . 'wpinv_subscriptions' ) {
453
+            $installer->create_subscriptions_table();
454 454
 
455
-			if ( $wpdb->last_error !== '' ) {
456
-				$this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
457
-			}
458
-		}
455
+            if ( $wpdb->last_error !== '' ) {
456
+                $this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
457
+            }
458
+        }
459 459
 
460
-		if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoices'" ) != $wpdb->prefix . 'getpaid_invoices' ) {
461
-			$installer->create_invoices_table();
460
+        if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoices'" ) != $wpdb->prefix . 'getpaid_invoices' ) {
461
+            $installer->create_invoices_table();
462 462
 
463
-			if ( $wpdb->last_error !== '' ) {
464
-				$this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
465
-			}
466
-		}
463
+            if ( $wpdb->last_error !== '' ) {
464
+                $this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
465
+            }
466
+        }
467 467
 
468
-		if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoice_items'" ) != $wpdb->prefix . 'getpaid_invoice_items' ) {
469
-			$installer->create_invoice_items_table();
468
+        if ( $wpdb->get_var( "SHOW TABLES LIKE '{$wpdb->prefix}getpaid_invoice_items'" ) != $wpdb->prefix . 'getpaid_invoice_items' ) {
469
+            $installer->create_invoice_items_table();
470 470
 
471
-			if ( $wpdb->last_error !== '' ) {
472
-				$this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
473
-			}
474
-		}
471
+            if ( $wpdb->last_error !== '' ) {
472
+                $this->show_error( __( 'Your GetPaid tables have been updated:', 'invoicing' ) . ' ' . $wpdb->last_error );
473
+            }
474
+        }
475 475
 
476
-		if ( ! $this->has_notices() ) {
477
-			$this->show_success( __( 'Your GetPaid tables have been updated.', 'invoicing' ) );
478
-		}
476
+        if ( ! $this->has_notices() ) {
477
+            $this->show_success( __( 'Your GetPaid tables have been updated.', 'invoicing' ) );
478
+        }
479 479
 
480
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
481
-		exit;
482
-	}
480
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
481
+        exit;
482
+    }
483 483
 
484
-	/**
484
+    /**
485 485
      * Migrates old invoices to the new database tables.
486
-	 * 
486
+     * 
487 487
      */
488 488
     public function admin_migrate_old_invoices() {
489 489
 
490
-		// Migrate the invoices.
491
-		$installer = new GetPaid_Installer();
492
-		$installer->migrate_old_invoices();
490
+        // Migrate the invoices.
491
+        $installer = new GetPaid_Installer();
492
+        $installer->migrate_old_invoices();
493 493
 
494
-		// Show an admin message.
495
-		$this->show_success( __( 'Your invoices have been migrated.', 'invoicing' ) );
494
+        // Show an admin message.
495
+        $this->show_success( __( 'Your invoices have been migrated.', 'invoicing' ) );
496 496
 
497
-		// Redirect the admin.
498
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
499
-		exit;
497
+        // Redirect the admin.
498
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
499
+        exit;
500 500
 
501
-	}
501
+    }
502 502
 
503
-	/**
503
+    /**
504 504
      * Download customers.
505
-	 * 
505
+     * 
506 506
      */
507 507
     public function admin_download_customers() {
508
-		global $wpdb;
508
+        global $wpdb;
509 509
 
510
-		$output = fopen( 'php://output', 'w' ) or die( __( 'Unsupported server', 'invoicing' ) );
510
+        $output = fopen( 'php://output', 'w' ) or die( __( 'Unsupported server', 'invoicing' ) );
511 511
 
512
-		header( "Content-Type:text/csv" );
513
-		header( "Content-Disposition:attachment;filename=customers.csv" );
512
+        header( "Content-Type:text/csv" );
513
+        header( "Content-Disposition:attachment;filename=customers.csv" );
514 514
 
515
-		$post_types = '';
515
+        $post_types = '';
516 516
 
517
-		foreach ( array_keys( getpaid_get_invoice_post_types() ) as $post_type ) {
518
-			$post_types .= $wpdb->prepare( "post_type=%s OR ", $post_type );
519
-		}
517
+        foreach ( array_keys( getpaid_get_invoice_post_types() ) as $post_type ) {
518
+            $post_types .= $wpdb->prepare( "post_type=%s OR ", $post_type );
519
+        }
520 520
 
521
-		$post_types = rtrim( $post_types, ' OR' );
521
+        $post_types = rtrim( $post_types, ' OR' );
522 522
 
523
-		$customers = $wpdb->get_col(
524
-			$wpdb->prepare(
525
-				"SELECT DISTINCT( post_author ) FROM $wpdb->posts WHERE $post_types"
526
-			)
527
-		);
523
+        $customers = $wpdb->get_col(
524
+            $wpdb->prepare(
525
+                "SELECT DISTINCT( post_author ) FROM $wpdb->posts WHERE $post_types"
526
+            )
527
+        );
528 528
 
529
-		$columns = array(
530
-			'name'     => __( 'Name', 'invoicing' ),
531
-			'email'    => __( 'Email', 'invoicing' ),
532
-			'country'  => __( 'Country', 'invoicing' ),
533
-			'state'    => __( 'State', 'invoicing' ),
534
-			'city'     => __( 'City', 'invoicing' ),
535
-			'zip'      => __( 'ZIP', 'invoicing' ),
536
-			'address'  => __( 'Address', 'invoicing' ),
537
-			'phone'    => __( 'Phone', 'invoicing' ),
538
-			'company'  => __( 'Company', 'invoicing' ),
539
-			'invoices' => __( 'Invoices', 'invoicing' ),
540
-			'total'    => __( 'Total Spend', 'invoicing' ),
541
-			'signup'   => __( 'Date created', 'invoicing' ),
542
-		);
529
+        $columns = array(
530
+            'name'     => __( 'Name', 'invoicing' ),
531
+            'email'    => __( 'Email', 'invoicing' ),
532
+            'country'  => __( 'Country', 'invoicing' ),
533
+            'state'    => __( 'State', 'invoicing' ),
534
+            'city'     => __( 'City', 'invoicing' ),
535
+            'zip'      => __( 'ZIP', 'invoicing' ),
536
+            'address'  => __( 'Address', 'invoicing' ),
537
+            'phone'    => __( 'Phone', 'invoicing' ),
538
+            'company'  => __( 'Company', 'invoicing' ),
539
+            'invoices' => __( 'Invoices', 'invoicing' ),
540
+            'total'    => __( 'Total Spend', 'invoicing' ),
541
+            'signup'   => __( 'Date created', 'invoicing' ),
542
+        );
543 543
 
544
-		// Output the csv column headers.
545
-		fputcsv( $output, array_values( $columns ) );
544
+        // Output the csv column headers.
545
+        fputcsv( $output, array_values( $columns ) );
546 546
 
547
-		// Loop through
548
-		$table = new WPInv_Customers_Table();
549
-		foreach ( $customers as $customer_id ) {
547
+        // Loop through
548
+        $table = new WPInv_Customers_Table();
549
+        foreach ( $customers as $customer_id ) {
550 550
 
551
-			$user = get_user_by( 'id', $customer_id );
552
-			$row  = array();
553
-			if ( empty( $user ) ) {
554
-				continue;
555
-			}
551
+            $user = get_user_by( 'id', $customer_id );
552
+            $row  = array();
553
+            if ( empty( $user ) ) {
554
+                continue;
555
+            }
556 556
 
557
-			foreach ( array_keys( $columns ) as $column ) {
557
+            foreach ( array_keys( $columns ) as $column ) {
558 558
 
559
-				$method = 'column_' . $column;
559
+                $method = 'column_' . $column;
560 560
 
561
-				if ( 'name' == $column ) {
562
-					$value = sanitize_text_field( $user->display_name );
563
-				} else if( 'email' == $column ) {
564
-					$value = sanitize_email( $user->user_email );
565
-				} else if ( is_callable( array( $table, $method ) ) ) {
566
-					$value = strip_tags( $table->$method( $user ) );
567
-				}
561
+                if ( 'name' == $column ) {
562
+                    $value = sanitize_text_field( $user->display_name );
563
+                } else if( 'email' == $column ) {
564
+                    $value = sanitize_email( $user->user_email );
565
+                } else if ( is_callable( array( $table, $method ) ) ) {
566
+                    $value = strip_tags( $table->$method( $user ) );
567
+                }
568 568
 
569
-				if ( empty( $value ) ) {
570
-					$value = sanitize_text_field( get_user_meta( $user->ID, '_wpinv_' . $column, true ) );
571
-				}
569
+                if ( empty( $value ) ) {
570
+                    $value = sanitize_text_field( get_user_meta( $user->ID, '_wpinv_' . $column, true ) );
571
+                }
572 572
 
573
-				$row[] = $value;
573
+                $row[] = $value;
574 574
 
575
-			}
575
+            }
576 576
 
577
-			fputcsv( $output, $row );
578
-		}
577
+            fputcsv( $output, $row );
578
+        }
579 579
 
580
-		fclose( $output );
581
-		exit;
580
+        fclose( $output );
581
+        exit;
582 582
 
583
-	}
583
+    }
584 584
 
585
-	/**
585
+    /**
586 586
      * Recalculates discounts.
587
-	 * 
587
+     * 
588 588
      */
589 589
     public function admin_recalculate_discounts() {
590
-		global $wpdb;
590
+        global $wpdb;
591 591
 
592
-		// Fetch all invoices that have discount codes.
593
-		$table    = $wpdb->prefix . 'getpaid_invoices';
594
-		$invoices = $wpdb->get_col( "SELECT `post_id` FROM `$table` WHERE `discount` = 0 && `discount_code` <> ''" );
592
+        // Fetch all invoices that have discount codes.
593
+        $table    = $wpdb->prefix . 'getpaid_invoices';
594
+        $invoices = $wpdb->get_col( "SELECT `post_id` FROM `$table` WHERE `discount` = 0 && `discount_code` <> ''" );
595 595
 
596
-		foreach ( $invoices as $invoice ) {
596
+        foreach ( $invoices as $invoice ) {
597 597
 
598
-			$invoice = new WPInv_Invoice( $invoice );
598
+            $invoice = new WPInv_Invoice( $invoice );
599 599
 
600
-			if ( ! $invoice->exists() ) {
601
-				continue;
602
-			}
600
+            if ( ! $invoice->exists() ) {
601
+                continue;
602
+            }
603 603
 
604
-			// Abort if the discount does not exist or does not apply here.
605
-			$discount = new WPInv_Discount( $invoice->get_discount_code() );
606
-			if ( ! $discount->exists() ) {
607
-				continue;
608
-			}
604
+            // Abort if the discount does not exist or does not apply here.
605
+            $discount = new WPInv_Discount( $invoice->get_discount_code() );
606
+            if ( ! $discount->exists() ) {
607
+                continue;
608
+            }
609 609
 
610
-			$invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
611
-			$invoice->recalculate_total();
610
+            $invoice->add_discount( getpaid_calculate_invoice_discount( $invoice, $discount ) );
611
+            $invoice->recalculate_total();
612 612
 
613
-			if ( $invoice->get_total_discount() > 0 ) {
614
-				$invoice->save();
615
-			}
613
+            if ( $invoice->get_total_discount() > 0 ) {
614
+                $invoice->save();
615
+            }
616 616
 
617
-		}
617
+        }
618 618
 
619
-		// Show an admin message.
620
-		$this->show_success( __( 'Discounts have been recalculated.', 'invoicing' ) );
619
+        // Show an admin message.
620
+        $this->show_success( __( 'Discounts have been recalculated.', 'invoicing' ) );
621 621
 
622
-		// Redirect the admin.
623
-		wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
624
-		exit;
622
+        // Redirect the admin.
623
+        wp_safe_redirect( remove_query_arg( array( 'getpaid-admin-action', 'getpaid-nonce' ) ) );
624
+        exit;
625 625
 
626
-	}
626
+    }
627 627
 
628 628
     /**
629
-	 * Returns an array of admin notices.
630
-	 *
631
-	 * @since       1.0.19
629
+     * Returns an array of admin notices.
630
+     *
631
+     * @since       1.0.19
632 632
      * @return array
633
-	 */
634
-	public function get_notices() {
635
-		$notices = get_option( 'wpinv_admin_notices' );
633
+     */
634
+    public function get_notices() {
635
+        $notices = get_option( 'wpinv_admin_notices' );
636 636
         return is_array( $notices ) ? $notices : array();
637
-	}
637
+    }
638 638
 
639
-	/**
640
-	 * Checks if we have any admin notices.
641
-	 *
642
-	 * @since       2.0.4
639
+    /**
640
+     * Checks if we have any admin notices.
641
+     *
642
+     * @since       2.0.4
643 643
      * @return array
644
-	 */
645
-	public function has_notices() {
646
-		return count( $this->get_notices() ) > 0;
647
-	}
648
-
649
-	/**
650
-	 * Clears all admin notices
651
-	 *
652
-	 * @access      public
653
-	 * @since       1.0.19
654
-	 */
655
-	public function clear_notices() {
656
-		delete_option( 'wpinv_admin_notices' );
657
-	}
658
-
659
-	/**
660
-	 * Saves a new admin notice
661
-	 *
662
-	 * @access      public
663
-	 * @since       1.0.19
664
-	 */
665
-	public function save_notice( $type, $message ) {
666
-		$notices = $this->get_notices();
667
-
668
-		if ( empty( $notices[ $type ] ) || ! is_array( $notices[ $type ]) ) {
669
-			$notices[ $type ] = array();
670
-		}
671
-
672
-		$notices[ $type ][] = $message;
673
-
674
-		update_option( 'wpinv_admin_notices', $notices );
675
-	}
676
-
677
-	/**
678
-	 * Displays a success notice
679
-	 *
680
-	 * @param       string $msg The message to qeue.
681
-	 * @access      public
682
-	 * @since       1.0.19
683
-	 */
684
-	public function show_success( $msg ) {
685
-		$this->save_notice( 'success', $msg );
686
-	}
687
-
688
-	/**
689
-	 * Displays a error notice
690
-	 *
691
-	 * @access      public
692
-	 * @param       string $msg The message to qeue.
693
-	 * @since       1.0.19
694
-	 */
695
-	public function show_error( $msg ) {
696
-		$this->save_notice( 'error', $msg );
697
-	}
698
-
699
-	/**
700
-	 * Displays a warning notice
701
-	 *
702
-	 * @access      public
703
-	 * @param       string $msg The message to qeue.
704
-	 * @since       1.0.19
705
-	 */
706
-	public function show_warning( $msg ) {
707
-		$this->save_notice( 'warning', $msg );
708
-	}
709
-
710
-	/**
711
-	 * Displays a info notice
712
-	 *
713
-	 * @access      public
714
-	 * @param       string $msg The message to qeue.
715
-	 * @since       1.0.19
716
-	 */
717
-	public function show_info( $msg ) {
718
-		$this->save_notice( 'info', $msg );
719
-	}
720
-
721
-	/**
722
-	 * Show notices
723
-	 *
724
-	 * @access      public
725
-	 * @since       1.0.19
726
-	 */
727
-	public function show_notices() {
644
+     */
645
+    public function has_notices() {
646
+        return count( $this->get_notices() ) > 0;
647
+    }
648
+
649
+    /**
650
+     * Clears all admin notices
651
+     *
652
+     * @access      public
653
+     * @since       1.0.19
654
+     */
655
+    public function clear_notices() {
656
+        delete_option( 'wpinv_admin_notices' );
657
+    }
658
+
659
+    /**
660
+     * Saves a new admin notice
661
+     *
662
+     * @access      public
663
+     * @since       1.0.19
664
+     */
665
+    public function save_notice( $type, $message ) {
666
+        $notices = $this->get_notices();
667
+
668
+        if ( empty( $notices[ $type ] ) || ! is_array( $notices[ $type ]) ) {
669
+            $notices[ $type ] = array();
670
+        }
671
+
672
+        $notices[ $type ][] = $message;
673
+
674
+        update_option( 'wpinv_admin_notices', $notices );
675
+    }
676
+
677
+    /**
678
+     * Displays a success notice
679
+     *
680
+     * @param       string $msg The message to qeue.
681
+     * @access      public
682
+     * @since       1.0.19
683
+     */
684
+    public function show_success( $msg ) {
685
+        $this->save_notice( 'success', $msg );
686
+    }
687
+
688
+    /**
689
+     * Displays a error notice
690
+     *
691
+     * @access      public
692
+     * @param       string $msg The message to qeue.
693
+     * @since       1.0.19
694
+     */
695
+    public function show_error( $msg ) {
696
+        $this->save_notice( 'error', $msg );
697
+    }
698
+
699
+    /**
700
+     * Displays a warning notice
701
+     *
702
+     * @access      public
703
+     * @param       string $msg The message to qeue.
704
+     * @since       1.0.19
705
+     */
706
+    public function show_warning( $msg ) {
707
+        $this->save_notice( 'warning', $msg );
708
+    }
709
+
710
+    /**
711
+     * Displays a info notice
712
+     *
713
+     * @access      public
714
+     * @param       string $msg The message to qeue.
715
+     * @since       1.0.19
716
+     */
717
+    public function show_info( $msg ) {
718
+        $this->save_notice( 'info', $msg );
719
+    }
720
+
721
+    /**
722
+     * Show notices
723
+     *
724
+     * @access      public
725
+     * @since       1.0.19
726
+     */
727
+    public function show_notices() {
728 728
 
729 729
         $notices = $this->get_notices();
730 730
         $this->clear_notices();
731 731
 
732
-		foreach ( $notices as $type => $messages ) {
732
+        foreach ( $notices as $type => $messages ) {
733 733
 
734
-			if ( ! is_array( $messages ) ) {
735
-				continue;
736
-			}
734
+            if ( ! is_array( $messages ) ) {
735
+                continue;
736
+            }
737 737
 
738 738
             $type  = sanitize_key( $type );
739
-			foreach ( $messages as $message ) {
739
+            foreach ( $messages as $message ) {
740 740
                 $message = wp_kses_post( $message );
741
-				echo "<div class='notice notice-$type is-dismissible'><p>$message</p></div>";
741
+                echo "<div class='notice notice-$type is-dismissible'><p>$message</p></div>";
742 742
             }
743 743
 
744 744
         }
745 745
 
746
-		foreach ( array( 'checkout_page', 'invoice_history_page', 'success_page', 'failure_page', 'invoice_subscription_page' ) as $page ) {
747
-
748
-			if ( ! is_numeric( wpinv_get_option( $page, false ) ) ) {
749
-				$url     = wp_nonce_url(
750
-					add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
751
-					'getpaid-nonce',
752
-					'getpaid-nonce'
753
-				);
754
-				$message  = __( 'Some GetPaid pages are missing. To use GetPaid without any issues, click the button below to generate the missing pages.', 'invoicing' );
755
-				$message2 = __( 'Generate Pages', 'invoicing' );
756
-				echo "<div class='notice notice-warning is-dismissible'><p>$message<br><br><a href='$url' class='button button-primary'>$message2</a></p></div>";
757
-				break;
758
-			}
746
+        foreach ( array( 'checkout_page', 'invoice_history_page', 'success_page', 'failure_page', 'invoice_subscription_page' ) as $page ) {
747
+
748
+            if ( ! is_numeric( wpinv_get_option( $page, false ) ) ) {
749
+                $url     = wp_nonce_url(
750
+                    add_query_arg( 'getpaid-admin-action', 'create_missing_pages' ),
751
+                    'getpaid-nonce',
752
+                    'getpaid-nonce'
753
+                );
754
+                $message  = __( 'Some GetPaid pages are missing. To use GetPaid without any issues, click the button below to generate the missing pages.', 'invoicing' );
755
+                $message2 = __( 'Generate Pages', 'invoicing' );
756
+                echo "<div class='notice notice-warning is-dismissible'><p>$message<br><br><a href='$url' class='button button-primary'>$message2</a></p></div>";
757
+                break;
758
+            }
759 759
 
760
-		}
760
+        }
761 761
 
762
-	}
762
+    }
763 763
 
764 764
 }
Please login to merge, or discard this patch.