Completed
Pull Request — master (#664)
by Devin
19:01
created

misc-functions.php ➔ give_currency_symbol()   D

Complexity

Conditions 30
Paths 58

Size

Total Lines 86
Code Lines 81

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 16
CRAP Score 458.4122

Importance

Changes 3
Bugs 2 Features 3
Metric Value
cc 30
eloc 81
c 3
b 2
f 3
nc 58
nop 1
dl 0
loc 86
rs 4.6946
ccs 16
cts 73
cp 0.2192
crap 458.4122

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

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