Completed
Push — master ( 5796ad...446f8c )
by Devin
20:22
created

misc-functions.php ➔ cal_days_in_month()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 1
eloc 2
c 1
b 0
f 1
nc 1
nop 3
dl 0
loc 3
ccs 0
cts 0
cp 0
crap 2
rs 10
1
<?php
0 ignored issues
show
Coding Style Compatibility introduced by
For compatibility and reusability of your code, PSR1 recommends that a file should introduce either new symbols (like classes, functions, etc.) or have side-effects (like outputting something, or including other files), but not both at the same time. The first symbol is defined on line 24 and the first side effect is on line 14.

The PSR-1: Basic Coding Standard recommends that a file should either introduce new symbols, that is classes, functions, constants or similar, or have side effects. Side effects are anything that executes logic, like for example printing output, changing ini settings or writing to a file.

The idea behind this recommendation is that merely auto-loading a class should not change the state of an application. It also promotes a cleaner style of programming and makes your code less prone to errors, because the logic is not spread out all over the place.

To learn more about the PSR-1, please see the PHP-FIG site on the PSR-1.

Loading history...
2
/**
3
 * Misc Functions
4
 *
5
 * @package     Give
6
 * @subpackage  Functions
7
 * @copyright   Copyright (c) 2016, WordImpress
8
 * @license     http://opensource.org/licenses/gpl-2.0.php GNU Public License
9
 * @since       1.0
10
 */
11
12
// Exit if accessed directly
13
if ( ! defined( 'ABSPATH' ) ) {
14
	exit;
15
}
16
17
/**
18
 * Is Test Mode
19
 *
20
 * @since 1.0
21
 * @global $give_options
22
 * @return bool $ret True if return mode is enabled, false otherwise
23
 */
24
function give_is_test_mode() {
25 34
	global $give_options;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
26
27 34
	$ret = ! empty( $give_options['test_mode'] );
28
29 34
	return (bool) apply_filters( 'give_is_test_mode', $ret );
30
}
31
32
/**
33
 * Get the set currency
34
 *
35
 * @since 1.0
36
 * @return string The currency code
37
 */
38
function give_get_currency() {
39 40
	global $give_options;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
40 40
	$currency = isset( $give_options['currency'] ) ? $give_options['currency'] : 'USD';
41
42 40
	return apply_filters( 'give_currency', $currency );
43
}
44
45
/**
46
 * Get the set currency position
47
 *
48
 * @since 1.3.6
49
 *
50
 * @return string The currency code
51
 */
52
function give_get_currency_position() {
53 1
	global $give_options;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
54 1
	$currency_pos = isset( $give_options['currency_position'] ) ? $give_options['currency_position'] : 'before';
55
56 1
	return apply_filters( 'give_currency_position', $currency_pos );
57
}
58
59
60
/**
61
 * Get Currencies
62
 *
63
 * @since 1.0
64
 * @return array $currencies A list of the available currencies
65
 */
66
function give_get_currencies() {
67
	$currencies = array(
68
		'USD'  => __( 'US Dollars ($)', 'give' ),
69
		'EUR'  => __( 'Euros (€)', 'give' ),
70
		'GBP'  => __( 'Pounds Sterling (£)', 'give' ),
71
		'AUD'  => __( 'Australian Dollars ($)', 'give' ),
72
		'BRL'  => __( 'Brazilian Real (R$)', 'give' ),
73
		'CAD'  => __( 'Canadian Dollars ($)', 'give' ),
74
		'CZK'  => __( 'Czech Koruna (Kč)', 'give' ),
75
		'DKK'  => __( 'Danish Krone (kr)', 'give' ),
76
		'HKD'  => __( 'Hong Kong Dollar ($)', 'give' ),
77
		'HUF'  => __( 'Hungarian Forint (Ft)', 'give' ),
78
		'ILS'  => __( 'Israeli Shekel (₪)', 'give' ),
79
		'JPY'  => __( 'Japanese Yen (¥)', 'give' ),
80
		'MYR'  => __( 'Malaysian Ringgits (RM)', 'give' ),
81
		'MXN'  => __( 'Mexican Peso ($)', 'give' ),
82
		'NZD'  => __( 'New Zealand Dollar ($)', 'give' ),
83
		'NOK'  => __( 'Norwegian Krone (Kr.)', 'give' ),
84
		'PHP'  => __( 'Philippine Pesos (₱)', 'give' ),
85
		'PLN'  => __( 'Polish Zloty (zł)', 'give' ),
86
		'SGD'  => __( 'Singapore Dollar ($)', 'give' ),
87
		'SEK'  => __( 'Swedish Krona (kr)', 'give' ),
88
		'CHF'  => __( 'Swiss Franc (CHF)', 'give' ),
89
		'TWD'  => __( 'Taiwan New Dollars (NT$)', 'give' ),
90
		'THB'  => __( 'Thai Baht (฿)', 'give' ),
91
		'INR'  => __( 'Indian Rupee (₹)', 'give' ),
92
		'TRY'  => __( 'Turkish Lira (₺)', 'give' ),
93
		'RIAL' => __( 'Iranian Rial (﷼)', 'give' ),
94
		'RUB'  => __( 'Russian Rubles (руб)', 'give' )
95
	);
96
97
	return apply_filters( 'give_currencies', $currencies );
98
}
99
100
101
/**
102
 * Give Currency Symbol
103
 *
104
 * @description: Given a currency determine the symbol to use. If no currency given, site default is used. If no symbol is determine, the currency string is returned.
105
 *
106
 * @since      1.0
107
 *
108
 * @param  string $currency The currency string
109
 *
110
 * @return string           The symbol to use for the currency
111
 */
112
function give_currency_symbol( $currency = '' ) {
113
114 37
	if ( empty( $currency ) ) {
115
		$currency = give_get_currency();
116
	}
117
	switch ( $currency ) :
118 37
		case 'GBP' :
119
			$symbol = '£';
120
			break;
121 37
		case 'BRL' :
122
			$symbol = 'R$';
123
			break;
124 37
		case 'EUR' :
125
			$symbol = '€';
126
			break;
127 37
		case 'NOK' :
128
			$symbol = 'Kr.';
129
			break;
130 37
		case 'INR' :
131
			$symbol = '₹';
132
			break;
133 37
		case 'USD' :
134 37
		case 'AUD' :
135 37
		case 'CAD' :
136 37
		case 'HKD' :
137 37
		case 'MXN' :
138 37
		case 'SGD' :
139 37
			$symbol = '$';
140 37
			break;
141
		case 'JPY' :
142
			$symbol = '¥';
143
			break;
144
		case 'THB' :
145
			$symbol = '฿';
146
			break;
147
		case 'TRY' :
148
			$symbol = '₺';
149
			break;
150
		case 'TWD' :
151
			$symbol = 'NT$';
152
			break;
153
		case 'ILS' :
154
			$symbol = '₪';
155
			break;
156
		case 'RIAL' :
157
			$symbol = '﷼';
158
			break;
159
		case 'RUB' :
160
			$symbol = 'руб';
161
			break;
162
		case 'DKK' :
163
		case 'SEK' :
164
			$symbol = 'kr';
165
			break;
166
		case 'PLN' :
167
			$symbol = 'zł';
168
			break;
169
		case 'PHP' :
170
			$symbol = '₱';
171
			break;
172
		case 'MYR' :
173
			$symbol = 'RM';
174
			break;
175
		case 'HUF' :
176
			$symbol = 'Ft';
177
			break;
178
		case 'CZK' :
179
			$symbol = 'Kč';
180
			break;
181
		default :
182
			$symbol = $currency;
183
			break;
184
	endswitch;
185
186 37
	return apply_filters( 'give_currency_symbol', $symbol, $currency );
187
}
188
189
190
/**
191
 * Get the current page URL
192
 *
193
 * @since 1.0
194
 * @return string $current_url Current page URL
195
 */
196
function give_get_current_page_url() {
197
198 6
	if ( is_front_page() ) {
199
		$current_url = home_url( '/' );
200
	} else {
201 6
		$current_url = set_url_scheme( 'http://' . $_SERVER['HTTP_HOST'] . untrailingslashit( $_SERVER['REQUEST_URI'] ) );
202
	}
203
204 6
	return apply_filters( 'give_get_current_page_url', esc_url( $current_url ) );
205
}
206
207
208
/**
209
 * Verify credit card numbers live?
210
 *
211
 * @since 1.0
212
 * @global $give_options
213
 * @return bool $ret True is verify credit cards is live
214
 */
215
function give_is_cc_verify_enabled() {
216
217
	$ret = true;
218
219
	/*
220
	 * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards
221
	 * Enable if using more than one gateway if they aren't both PayPal and manual, again assuming credit card usage
222
	 */
223
	$gateways = give_get_enabled_payment_gateways();
224
225
	if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) {
226
		$ret = true;
227
	} else if ( count( $gateways ) == 1 ) {
228
		$ret = false;
229
	} else if ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) {
230
		$ret = false;
231
	}
232
233
	return (bool) apply_filters( 'give_verify_credit_cards', $ret );
234
}
235
236
/**
237
 * Retrieve timezone
238
 *
239
 * @since 1.0
240
 * @return string $timezone The timezone ID
241
 */
242
function give_get_timezone_id() {
243
244
	// if site timezone string exists, return it
245 34
	if ( $timezone = get_option( 'timezone_string' ) ) {
246
		return $timezone;
247
	}
248
249
	// get UTC offset, if it isn't set return UTC
250 34
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
251 34
		return 'UTC';
252
	}
253
254
	// attempt to guess the timezone string from the UTC offset
255
	$timezone = timezone_name_from_abbr( '', $utc_offset );
256
257
	// last try, guess timezone string manually
258
	if ( $timezone === false ) {
259
260
		$is_dst = date( 'I' );
261
262
		foreach ( timezone_abbreviations_list() as $abbr ) {
263
			foreach ( $abbr as $city ) {
264
				if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) {
265
					return $city['timezone_id'];
266
				}
267
			}
268
		}
269
	}
270
271
	// fallback
272
	return 'UTC';
273
}
274
275
276
/**
277
 * Get User IP
278
 *
279
 * Returns the IP address of the current visitor
280
 *
281
 * @since 1.0
282
 * @return string $ip User's IP address
283
 */
284
function give_get_ip() {
285
286 34
	$ip = '127.0.0.1';
287
288 34
	if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
289
		//check ip from share internet
290
		$ip = $_SERVER['HTTP_CLIENT_IP'];
291 34
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
292
		//to check ip is pass from proxy
293
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
294 34
	} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) {
295 34
		$ip = $_SERVER['REMOTE_ADDR'];
296 34
	}
297
298 34
	return apply_filters( 'give_get_ip', $ip );
299
}
300
301
302
/**
303
 * Store Purchase Data in Sessions
304
 *
305
 * Used for storing info about purchase
306
 *
307
 * @since 1.0
308
 *
309
 * @param $purchase_data
310
 *
311
 * @uses  Give()->session->set()
312
 */
313
function give_set_purchase_session( $purchase_data = array() ) {
314
	Give()->session->set( 'give_purchase', $purchase_data );
315
	Give()->session->set( 'give_email', $purchase_data['user_email'] );
316
}
317
318
/**
319
 * Retrieve Purchase Data from Session
320
 *
321
 * Used for retrieving info about purchase
322
 * after completing a purchase
323
 *
324
 * @since 1.0
325
 * @uses  Give()->session->get()
326
 * @return mixed array | false
327
 */
328
function give_get_purchase_session() {
329
	return Give()->session->get( 'give_purchase' );
330
}
331
332
/**
333
 * Get Purchase Summary
334
 *
335
 * Retrieves the purchase summary.
336
 *
337
 * @since       1.0
338
 *
339
 * @param      $purchase_data
340
 * @param bool $email
341
 *
342
 * @return string
343
 */
344
function give_get_purchase_summary( $purchase_data, $email = true ) {
345
	$summary = '';
346
347
	if ( $email ) {
348
		$summary .= $purchase_data['user_email'] . ' - ';
349
	}
350
351
	$summary .= get_the_title( $purchase_data['post_data']['give-form-id'] );
352
353
	return $summary;
354
}
355
356
357
/**
358
 * Get user host
359
 *
360
 * Returns the webhost this site is using if possible
361
 *
362
 * @since 1.0
363
 * @return mixed string $host if detected, false otherwise
364
 */
365
function give_get_host() {
366
	$host = false;
367
368
	if ( defined( 'WPE_APIKEY' ) ) {
369
		$host = 'WP Engine';
370
	} elseif ( defined( 'PAGELYBIN' ) ) {
371
		$host = 'Pagely';
372
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
373
		$host = 'ICDSoft';
374
	} elseif ( DB_HOST == 'mysqlv5' ) {
375
		$host = 'NetworkSolutions';
376
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
377
		$host = 'iPage';
378
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
379
		$host = 'IPower';
380
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
381
		$host = 'MediaTemple Grid';
382
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
383
		$host = 'pair Networks';
384
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
385
		$host = 'Rackspace Cloud';
386
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
387
		$host = 'SysFix.eu Power Hosting';
388
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
389
		$host = 'Flywheel';
390
	} else {
391
		// Adding a general fallback for data gathering
392
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
393
	}
394
395
	return $host;
396
}
397
398
399
/**
400
 * Check site host
401
 *
402
 * @since 1.0
403
 *
404
 * @param $host The host to check
405
 *
406
 * @return bool true if host matches, false if not
407
 */
408
function give_is_host( $host = false ) {
409
410
	$return = false;
411
412
	if ( $host ) {
413
		$host = str_replace( ' ', '', strtolower( $host ) );
414
415
		switch ( $host ) {
416
			case 'wpengine':
417
				if ( defined( 'WPE_APIKEY' ) ) {
418
					$return = true;
419
				}
420
				break;
421
			case 'pagely':
422
				if ( defined( 'PAGELYBIN' ) ) {
423
					$return = true;
424
				}
425
				break;
426
			case 'icdsoft':
427
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
428
					$return = true;
429
				}
430
				break;
431
			case 'networksolutions':
432
				if ( DB_HOST == 'mysqlv5' ) {
433
					$return = true;
434
				}
435
				break;
436
			case 'ipage':
437
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
438
					$return = true;
439
				}
440
				break;
441
			case 'ipower':
442
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
443
					$return = true;
444
				}
445
				break;
446
			case 'mediatemplegrid':
447
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
448
					$return = true;
449
				}
450
				break;
451
			case 'pairnetworks':
452
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
453
					$return = true;
454
				}
455
				break;
456
			case 'rackspacecloud':
457
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
458
					$return = true;
459
				}
460
				break;
461
			case 'sysfix.eu':
462
			case 'sysfix.eupowerhosting':
463
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
464
					$return = true;
465
				}
466
				break;
467
			case 'flywheel':
468
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
469
					$return = true;
470
				}
471
				break;
472
			default:
473
				$return = false;
474
		}
475
	}
476
477
	return $return;
478
}
479
480
/**
481
 * Marks a function as deprecated and informs when it has been used.
482
 *
483
 * There is a hook edd_deprecated_function_run that will be called that can be used
484
 * to get the backtrace up to what file and function called the deprecated
485
 * function.
486
 *
487
 * The current behavior is to trigger a user error if WP_DEBUG is true.
488
 *
489
 * This function is to be used in every function that is deprecated.
490
 *
491
 * @uses do_action() Calls 'edd_deprecated_function_run' and passes the function name, what to use instead,
492
 *   and the version the function was deprecated in.
493
 * @uses apply_filters() Calls 'edd_deprecated_function_trigger_error' and expects boolean value of true to do
494
 *   trigger or false to not trigger error.
495
 *
496
 * @param string $function The function that was called
497
 * @param string $version The version of EDD that deprecated the function
498
 * @param string $replacement Optional. The function that should have been called
499
 * @param array $backtrace Optional. Contains stack backtrace of deprecated function
500
 */
501
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
502
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
503
504
	$show_errors = current_user_can( 'manage_options' );
505
506
	// Allow plugin to filter the output error trigger
507
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
508
		if ( ! is_null( $replacement ) ) {
509
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
510
			trigger_error( print_r( $backtrace, 1 ) ); // Limited to previous 1028 characters, but since we only need to move back 1 in stack that should be fine.
511
			// Alternatively we could dump this to a file.
512
		} else {
513
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
514
			trigger_error( print_r( $backtrace, 1 ) );// Limited to previous 1028 characters, but since we only need to move back 1 in stack that should be fine.
515
			// Alternatively we could dump this to a file.
516
		}
517
	}
518
}
519
520
/**
521
 * Give Get Admin ID
522
 *
523
 * Helper function to return the ID of the post for admin usage
524
 *
525
 * @return string $post_id
526
 */
527
function give_get_admin_post_id() {
528
	$post_id = isset( $_GET['post'] ) ? $_GET['post'] : null;
529
	if ( ! $post_id && isset( $_POST['post_id'] ) ) {
530
		$post_id = $_POST['post_id'];
531
	}
532
533
	return $post_id;
534
}
535
536
/**
537
 * Get PHP Arg Separator Output
538
 *
539
 * @since 1.0
540
 * @return string Arg separator output
541
 */
542
function give_get_php_arg_separator_output() {
543
	return ini_get( 'arg_separator.output' );
544
}
545
546
547
/**
548
 * Month Num To Name
549
 *
550
 * Takes a month number and returns the name three letter name of it.
551
 *
552
 * @since 1.0
553
 *
554
 * @param unknown $n
555
 *
556
 * @return string Short month name
557
 */
558
function give_month_num_to_name( $n ) {
559
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
560
561
	return date_i18n( "M", $timestamp );
562
}
563
564
565
/**
566
 * Checks whether function is disabled.
567
 *
568
 * @since 1.0
569
 *
570
 * @param string $function Name of the function.
571
 *
572
 * @return bool Whether or not function is disabled.
573
 */
574
function give_is_func_disabled( $function ) {
575
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
576
577
	return in_array( $function, $disabled );
578
}
579
580
581
/**
582
 * Give Newsletter
583
 *
584
 * @description: Returns the main Give newsletter form
585
 */
586
function give_get_newsletter() { ?>
587
588
	<div class="give-newsletter-form-wrap">
589
590
		<form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13" method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate" target="_blank" novalidate>
591
			<div class="give-newsletter-confirmation">
592
				<p><?php _e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
593
			</div>
594
595
			<table class="form-table give-newsletter-form">
596
				<tr valign="middle">
597
					<td>
598
						<input type="email" value="" name="EMAIL" class="required email" id="mce-EMAIL" placeholder="Email Address (required)">
599
					</td>
600
601
					<td scope="row">
602
						<input type="text" value="" placeholder="First Name" name="FNAME" class="" id="mce-FNAME"></td>
603
604
					<td scope="row">
605
						<input type="text" value="" placeholder="Last Name" name="LNAME" class="" id="mce-LNAME"></td>
606
607
					<td scope="row">
608
						<input type="submit" value="Subscribe" name="subscribe" id="mc-embedded-subscribe" class="button">
609
					</td>
610
				</tr>
611
			</table>
612
		</form>
613
614
		<div style="position: absolute; left: -5000px;">
615
			<input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value=""></div>
616
617
	</div>
618
619
	<script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>
620
	<script type='text/javascript'>(function ($) {
621
			window.fnames = new Array();
622
			window.ftypes = new Array();
623
			fnames[0] = 'EMAIL';
624
			ftypes[0] = 'email';
625
			fnames[1] = 'FNAME';
626
			ftypes[1] = 'text';
627
			fnames[2] = 'LNAME';
628
			ftypes[2] = 'text';
629
630
			//Successful submission
631
			$('form[name="mc-embedded-subscribe-form"]').on('submit', function () {
632
633
				var email_field = $(this).find('#mce-EMAIL').val();
634
				if (!email_field) {
635
					return false;
636
				}
637
				$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp();
638
				$(this).find('.give-newsletter-form').hide();
639
640
			});
641
642
643
		}(jQuery));
644
		var $mcj = jQuery.noConflict(true);
645
646
647
	</script>
648
	<!--End mc_embed_signup-->
649
650
<?php }
651
652
653
/**
654
 * Social Media Like Buttons
655
 *
656
 * @description: Various social media elements to Give
657
 */
658
function give_social_media_elements() { ?>
659
660
	<div class="social-items-wrap">
661
662
		<iframe src="//www.facebook.com/plugins/like.php?href=https%3A%2F%2Fwww.facebook.com%2Fwpgive&amp;send=false&amp;layout=button_count&amp;width=100&amp;show_faces=false&amp;font&amp;colorscheme=light&amp;action=like&amp;height=21&amp;appId=220596284639969" scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:100px; height:21px;" allowTransparency="true"></iframe>
663
664
		<a href="https://twitter.com/givewp" class="twitter-follow-button" data-show-count="false">Follow @givewp</a>
665
		<script>!function (d, s, id) {
666
				var js, fjs = d.getElementsByTagName(s)[0], p = /^http:/.test(d.location) ? 'http' : 'https';
667
				if (!d.getElementById(id)) {
668
					js = d.createElement(s);
669
					js.id = id;
670
					js.src = p + '://platform.twitter.com/widgets.js';
671
					fjs.parentNode.insertBefore(js, fjs);
672
				}
673
			}(document, 'script', 'twitter-wjs');</script>
674
	</div>
675
	<!--/.social-items-wrap -->
676
677
678
<?php }
679
680
681
/**
682
 * Create SVG library function
683
 *
684
 * @param $icon
685
 *
686
 * @return mixed
687
 */
688
function give_svg_icons( $icon ) {
689
690
	// Store your SVGs in an associative array
691
	$svgs = array(
692
		'microphone'    => '',
693
		'alert'         => "",
694
		'placemark'     => '',
695
		'give_grey'     => '',
696
		'give_cpt_icon' => '',
697
	);
698
699
	// Return the chosen icon's SVG string
700
	return $svgs[ $icon ];
701
}
702
703
/**
704
 * Modify Admin Nav Menu Label
705
 *
706
 * @since 1.3
707
 *
708
 * @param $post_type
709
 *
710
 * @return mixed
711
 */
712
function modify_nav_menu_meta_box_object( $post_type ) {
713
	if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) {
714
		$post_type->labels->name = 'Donation Forms';
715
	}
716
717
	return $post_type;
718
}
719
720
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
721
722
723
/**
724
 * Array_column backup usage
725
 *
726
 * @desctipiont: This file is part of the array_column library
727
 * @since      : 1.3.0.1
728
 *
729
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
730
 * @license    http://opensource.org/licenses/MIT MIT
731
 */
732
733
if ( ! function_exists( 'array_column' ) ) {
734
	/**
735
	 * Returns the values from a single column of the input array, identified by
736
	 * the $columnKey.
737
	 *
738
	 * Optionally, you may provide an $indexKey to index the values in the returned
739
	 * array by the values from the $indexKey column in the input array.
740
	 *
741
	 * @param array $input A multi-dimensional array (record set) from which to pull
742
	 *                         a column of values.
743
	 * @param mixed $columnKey The column of values to return. This value may be the
744
	 *                         integer key of the column you wish to retrieve, or it
745
	 *                         may be the string key name for an associative array.
746
	 * @param mixed $indexKey (Optional.) The column to use as the index/keys for
747
	 *                         the returned array. This value may be the integer key
748
	 *                         of the column, or it may be the string key name.
749
	 *
750
	 * @return array
751
	 */
752
	function array_column( $input = null, $columnKey = null, $indexKey = null ) {
0 ignored issues
show
Unused Code introduced by
The parameter $input is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
Unused Code introduced by
The parameter $columnKey is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
Unused Code introduced by
The parameter $indexKey is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
753
		// Using func_get_args() in order to check for proper number of
754
		// parameters and trigger errors exactly as the built-in array_column()
755
		// does in PHP 5.5.
756
		$argc   = func_num_args();
757
		$params = func_get_args();
758
759
		if ( $argc < 2 ) {
760
			trigger_error( "array_column() expects at least 2 parameters, {$argc} given", E_USER_WARNING );
761
762
			return null;
763
		}
764
765
		if ( ! is_array( $params[0] ) ) {
766
			trigger_error(
767
				'array_column() expects parameter 1 to be array, ' . gettype( $params[0] ) . ' given',
768
				E_USER_WARNING
769
			);
770
771
			return null;
772
		}
773
774
		if ( ! is_int( $params[1] )
775
		     && ! is_float( $params[1] )
776
		     && ! is_string( $params[1] )
777
		     && $params[1] !== null
778
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
779
		) {
780
			trigger_error( 'array_column(): The column key should be either a string or an integer', E_USER_WARNING );
781
782
			return false;
783
		}
784
785
		if ( isset( $params[2] )
786
		     && ! is_int( $params[2] )
787
		     && ! is_float( $params[2] )
788
		     && ! is_string( $params[2] )
789
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
790
		) {
791
			trigger_error( 'array_column(): The index key should be either a string or an integer', E_USER_WARNING );
792
793
			return false;
794
		}
795
796
		$paramsInput     = $params[0];
797
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
798
799
		$paramsIndexKey = null;
800
		if ( isset( $params[2] ) ) {
801
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
802
				$paramsIndexKey = (int) $params[2];
803
			} else {
804
				$paramsIndexKey = (string) $params[2];
805
			}
806
		}
807
808
		$resultArray = array();
809
810
		foreach ( $paramsInput as $row ) {
811
			$key    = $value = null;
812
			$keySet = $valueSet = false;
813
814
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
815
				$keySet = true;
816
				$key    = (string) $row[ $paramsIndexKey ];
817
			}
818
819
			if ( $paramsColumnKey === null ) {
820
				$valueSet = true;
821
				$value    = $row;
822
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
823
				$valueSet = true;
824
				$value    = $row[ $paramsColumnKey ];
825
			}
826
827
			if ( $valueSet ) {
828
				if ( $keySet ) {
829
					$resultArray[ $key ] = $value;
830
				} else {
831
					$resultArray[] = $value;
832
				}
833
			}
834
835
		}
836
837
		return $resultArray;
838
	}
839
840
}
841
842
/**
843
 * Determines the receipt visibility status
844
 *
845
 * @since 1.3.2
846
 *
847
 * @param string $payment_key
848
 *
849
 * @return bool Whether the receipt is visible or not.
850
 */
851
function give_can_view_receipt( $payment_key = '' ) {
852
853
	$return = false;
854
855
	if ( empty( $payment_key ) ) {
856
		return $return;
857
	}
858
859
	global $give_receipt_args;
0 ignored issues
show
Compatibility Best Practice introduced by
Use of global functionality is not recommended; it makes your code harder to test, and less reusable.

Instead of relying on global state, we recommend one of these alternatives:

1. Pass all data via parameters

function myFunction($a, $b) {
    // Do something
}

2. Create a class that maintains your state

class MyClass {
    private $a;
    private $b;

    public function __construct($a, $b) {
        $this->a = $a;
        $this->b = $b;
    }

    public function myFunction() {
        // Do something
    }
}
Loading history...
860
861
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
862
863
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
864
865
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
866
867
	if ( is_user_logged_in() ) {
868
		if ( $user_id === (int) get_current_user_id() ) {
869
			$return = true;
870
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
871
			$return = true;
872
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
873
			$return = true;
874
		}
875
	}
876
877
	$session = give_get_purchase_session();
878
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
879
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
880
			$return = true;
881
		}
882
	}
883
884
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
885
886
}
887
888
/**
889
 * Fallback for cal_days_in_month
890
 *
891
 * @description: Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
892
 */
893
if ( ! function_exists( 'cal_days_in_month' ) ) {
894
	/**
895
	 * cal_days_in_month
896
	 *
897
	 * @param $calendar
898
	 * @param $month
899
	 * @param $year
900
	 *
901
	 * @return bool|string
902
	 */
903
	function cal_days_in_month( $calendar, $month, $year ) {
0 ignored issues
show
Unused Code introduced by
The parameter $calendar is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
904
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
905
	}
906
}
907