Completed
Push — issues/611 ( e8b3e4...d18391 )
by Ravinder
37:18 queued 17:16
created

misc-functions.php ➔ give_is_add_new_form_page()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 9
Code Lines 5

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 5
nc 2
nop 0
dl 0
loc 9
rs 9.6666
c 0
b 0
f 0
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     https://opensource.org/licenses/gpl-license 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 Enabled.
19
 *
20
 * @since 1.0
21
 *
22
 * @return bool $ret True if return mode is enabled, false otherwise
23
 */
24
function give_is_test_mode() {
25
26
	$ret = give_is_setting_enabled( give_get_option( 'test_mode' ) );
27
28
	return (bool) apply_filters( 'give_is_test_mode', $ret );
29
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
	$currency = give_get_option( 'currency', 'USD' );
41
42
	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
54
	$currency_pos = give_get_option( 'currency_position', 'before' );
55
56
	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
 * Given a currency determine the symbol to use. If no currency given, site default is used. If no symbol is determine,
109
 * the currency string is returned.
110
 *
111
 * @since      1.0
112
 *
113
 * @param  string $currency The currency string
114
 *
115
 * @return string           The symbol to use for the currency
116
 */
117
function give_currency_symbol( $currency = '' ) {
118
119
	if ( empty( $currency ) ) {
120
		$currency = give_get_currency();
121
	}
122
	switch ( $currency ) :
123
		case 'GBP' :
124
			$symbol = '£';
125
			break;
126
		case 'BRL' :
127
			$symbol = 'R$';
128
			break;
129
		case 'EUR' :
130
			$symbol = '€';
131
			break;
132
		case 'NOK' :
133
			$symbol = 'Kr.';
134
			break;
135
		case 'INR' :
136
			$symbol = '₹';
137
			break;
138
		case 'USD' :
139
		case 'AUD' :
140
		case 'CAD' :
141
		case 'HKD' :
142
		case 'MXN' :
143
		case 'SGD' :
144
			$symbol = '$';
145
			break;
146
		case 'JPY' :
147
			$symbol = '¥';
148
			break;
149
		case 'THB' :
150
			$symbol = '฿';
151
			break;
152
		case 'TRY' :
153
			$symbol = '₺';
154
			break;
155
		case 'TWD' :
156
			$symbol = 'NT$';
157
			break;
158
		case 'ILS' :
159
			$symbol = '₪';
160
			break;
161
		case 'RIAL' :
162
			$symbol = '﷼';
163
			break;
164
		case 'RUB' :
165
			$symbol = 'руб';
166
			break;
167
		case 'DKK' :
168
		case 'SEK' :
169
			$symbol = '&nbsp;kr.&nbsp;';
170
			break;
171
		case 'PLN' :
172
			$symbol = 'zł';
173
			break;
174
		case 'PHP' :
175
			$symbol = '₱';
176
			break;
177
		case 'MYR' :
178
			$symbol = 'RM';
179
			break;
180
		case 'HUF' :
181
			$symbol = 'Ft';
182
			break;
183
		case 'CZK' :
184
			$symbol = 'Kč';
185
			break;
186
		case 'KRW' :
187
			$symbol = '₩';
188
			break;
189
		case 'ZAR' :
190
			$symbol = 'R';
191
			break;
192
		case 'MAD' :
193
			$symbol = '&#x2e;&#x62f;&#x2e;&#x645;';
194
			break;
195
		default :
196
			$symbol = $currency;
197
			break;
198
	endswitch;
199
200
201
	return apply_filters( 'give_currency_symbol', $symbol, $currency );
202
}
203
204
205
/**
206
 * Get the current page URL
207
 *
208
 * @since 1.0
209
 * @return string $current_url Current page URL
210
 */
211
function give_get_current_page_url() {
212
213
	global $wp;
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...
214
215
	if ( get_option( 'permalink_structure' ) ) {
216
		$base = trailingslashit( home_url( $wp->request ) );
217
	} else {
218
		$base = add_query_arg( $wp->query_string, '', trailingslashit( home_url( $wp->request ) ) );
219
		$base = remove_query_arg( array( 'post_type', 'name' ), $base );
220
	}
221
222
	$scheme      = is_ssl() ? 'https' : 'http';
223
	$current_uri = set_url_scheme( $base, $scheme );
224
225
	if ( is_front_page() ) {
226
		$current_uri = home_url( '/' );
227
	}
228
229
	return apply_filters( 'give_get_current_page_url', $current_uri );
230
231
}
232
233
234
/**
235
 * Verify credit card numbers live?
236
 *
237
 * @since 1.0
238
 *
239
 * @return bool $ret True is verify credit cards is live
240
 */
241
function give_is_cc_verify_enabled() {
242
243
	$ret = true;
244
245
	/*
246
	 * Enable if use a single gateway other than PayPal or Manual. We have to assume it accepts credit cards
247
	 * Enable if using more than one gateway if they aren't both PayPal and manual, again assuming credit card usage
248
	 */
249
	$gateways = give_get_enabled_payment_gateways();
250
251
	if ( count( $gateways ) == 1 && ! isset( $gateways['paypal'] ) && ! isset( $gateways['manual'] ) ) {
252
		$ret = true;
253
	} else if ( count( $gateways ) == 1 ) {
254
		$ret = false;
255
	} else if ( count( $gateways ) == 2 && isset( $gateways['paypal'] ) && isset( $gateways['manual'] ) ) {
256
		$ret = false;
257
	}
258
259
	return (bool) apply_filters( 'give_verify_credit_cards', $ret );
260
}
261
262
/**
263
 * Retrieve timezone
264
 *
265
 * @since 1.0
266
 * @return string $timezone The timezone ID
267
 */
268
function give_get_timezone_id() {
269
270
	// if site timezone string exists, return it
271
	if ( $timezone = get_option( 'timezone_string' ) ) {
272
		return $timezone;
273
	}
274
275
	// get UTC offset, if it isn't set return UTC
276
	if ( ! ( $utc_offset = 3600 * get_option( 'gmt_offset', 0 ) ) ) {
277
		return 'UTC';
278
	}
279
280
	// attempt to guess the timezone string from the UTC offset
281
	$timezone = timezone_name_from_abbr( '', $utc_offset );
282
283
	// last try, guess timezone string manually
284
	if ( $timezone === false ) {
285
286
		$is_dst = date( 'I' );
287
288
		foreach ( timezone_abbreviations_list() as $abbr ) {
289
			foreach ( $abbr as $city ) {
290
				if ( $city['dst'] == $is_dst && $city['offset'] == $utc_offset ) {
291
					return $city['timezone_id'];
292
				}
293
			}
294
		}
295
	}
296
297
	// fallback
298
	return 'UTC';
299
}
300
301
302
/**
303
 * Get User IP
304
 *
305
 * Returns the IP address of the current visitor
306
 *
307
 * @since 1.0
308
 * @return string $ip User's IP address
309
 */
310
function give_get_ip() {
311
312
	$ip = '127.0.0.1';
313
314
	if ( ! empty( $_SERVER['HTTP_CLIENT_IP'] ) ) {
315
		//check ip from share internet
316
		$ip = $_SERVER['HTTP_CLIENT_IP'];
317
	} elseif ( ! empty( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
318
		//to check ip is pass from proxy
319
		$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
320
	} elseif ( ! empty( $_SERVER['REMOTE_ADDR'] ) ) {
321
		$ip = $_SERVER['REMOTE_ADDR'];
322
	}
323
324
	return apply_filters( 'give_get_ip', $ip );
325
}
326
327
328
/**
329
 * Store Donation Data in Sessions
330
 *
331
 * Used for storing info about donation
332
 *
333
 * @since 1.0
334
 *
335
 * @param $purchase_data
336
 *
337
 * @uses  Give()->session->set()
338
 */
339
function give_set_purchase_session( $purchase_data = array() ) {
340
	Give()->session->set( 'give_purchase', $purchase_data );
341
	Give()->session->set( 'give_email', $purchase_data['user_email'] );
342
}
343
344
/**
345
 * Retrieve Donation Data from Session
346
 *
347
 * Used for retrieving info about donation
348
 * after completing a donation
349
 *
350
 * @since 1.0
351
 * @uses  Give()->session->get()
352
 * @return mixed array | false
353
 */
354
function give_get_purchase_session() {
355
	return Give()->session->get( 'give_purchase' );
356
}
357
358
/**
359
 * Get Donation Summary
360
 *
361
 * Retrieves the donation summary.
362
 *
363
 * @since       1.0
364
 *
365
 * @param array $purchase_data
366
 * @param bool  $email
367
 *
368
 * @return string
369
 */
370
function give_get_purchase_summary( $purchase_data, $email = true ) {
371
	$summary = '';
372
373
	if ( $email ) {
374
		$summary .= $purchase_data['user_email'] . ' - ';
375
	}
376
377
	$summary .= get_the_title( $purchase_data['post_data']['give-form-id'] );
378
379
	return $summary;
380
}
381
382
383
/**
384
 * Get user host
385
 *
386
 * Returns the webhost this site is using if possible
387
 *
388
 * @since 1.0
389
 * @return string $host if detected, false otherwise
390
 */
391
function give_get_host() {
392
	$host = false;
393
394
	if ( defined( 'WPE_APIKEY' ) ) {
395
		$host = 'WP Engine';
396
	} elseif ( defined( 'PAGELYBIN' ) ) {
397
		$host = 'Pagely';
398
	} elseif ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
399
		$host = 'ICDSoft';
400
	} elseif ( DB_HOST == 'mysqlv5' ) {
401
		$host = 'NetworkSolutions';
402
	} elseif ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
403
		$host = 'iPage';
404
	} elseif ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
405
		$host = 'IPower';
406
	} elseif ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
407
		$host = 'MediaTemple Grid';
408
	} elseif ( strpos( DB_HOST, '.pair.com' ) !== false ) {
409
		$host = 'pair Networks';
410
	} elseif ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
411
		$host = 'Rackspace Cloud';
412
	} elseif ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
413
		$host = 'SysFix.eu Power Hosting';
414
	} elseif ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
415
		$host = 'Flywheel';
416
	} else {
417
		// Adding a general fallback for data gathering
418
		$host = 'DBH: ' . DB_HOST . ', SRV: ' . $_SERVER['SERVER_NAME'];
419
	}
420
421
	return $host;
422
}
423
424
425
/**
426
 * Check site host
427
 *
428
 * @since 1.0
429
 *
430
 * @param bool /string $host The host to check
431
 *
432
 * @return bool true if host matches, false if not
433
 */
434
function give_is_host( $host = false ) {
435
436
	$return = false;
437
438
	if ( $host ) {
439
		$host = str_replace( ' ', '', strtolower( $host ) );
440
441
		switch ( $host ) {
442
			case 'wpengine':
443
				if ( defined( 'WPE_APIKEY' ) ) {
444
					$return = true;
445
				}
446
				break;
447
			case 'pagely':
448
				if ( defined( 'PAGELYBIN' ) ) {
449
					$return = true;
450
				}
451
				break;
452
			case 'icdsoft':
453
				if ( DB_HOST == 'localhost:/tmp/mysql5.sock' ) {
454
					$return = true;
455
				}
456
				break;
457
			case 'networksolutions':
458
				if ( DB_HOST == 'mysqlv5' ) {
459
					$return = true;
460
				}
461
				break;
462
			case 'ipage':
463
				if ( strpos( DB_HOST, 'ipagemysql.com' ) !== false ) {
464
					$return = true;
465
				}
466
				break;
467
			case 'ipower':
468
				if ( strpos( DB_HOST, 'ipowermysql.com' ) !== false ) {
469
					$return = true;
470
				}
471
				break;
472
			case 'mediatemplegrid':
473
				if ( strpos( DB_HOST, '.gridserver.com' ) !== false ) {
474
					$return = true;
475
				}
476
				break;
477
			case 'pairnetworks':
478
				if ( strpos( DB_HOST, '.pair.com' ) !== false ) {
479
					$return = true;
480
				}
481
				break;
482
			case 'rackspacecloud':
483
				if ( strpos( DB_HOST, '.stabletransit.com' ) !== false ) {
484
					$return = true;
485
				}
486
				break;
487
			case 'sysfix.eu':
488
			case 'sysfix.eupowerhosting':
489
				if ( strpos( DB_HOST, '.sysfix.eu' ) !== false ) {
490
					$return = true;
491
				}
492
				break;
493
			case 'flywheel':
494
				if ( strpos( $_SERVER['SERVER_NAME'], 'Flywheel' ) !== false ) {
495
					$return = true;
496
				}
497
				break;
498
			default:
499
				$return = false;
500
		}
501
	}
502
503
	return $return;
504
}
505
506
/**
507
 * Marks a function as deprecated and informs when it has been used.
508
 *
509
 * There is a hook give_deprecated_function_run that will be called that can be used
510
 * to get the backtrace up to what file and function called the deprecated
511
 * function.
512
 *
513
 * The current behavior is to trigger a user error if WP_DEBUG is true.
514
 *
515
 * This function is to be used in every function that is deprecated.
516
 *
517
 * @uses do_action() Calls 'give_deprecated_function_run' and passes the function name, what to use instead,
518
 *   and the version the function was deprecated in.
519
 * @uses apply_filters() Calls 'give_deprecated_function_trigger_error' and expects boolean value of true to do
520
 *   trigger or false to not trigger error.
521
 *
522
 * @param string $function    The function that was called.
523
 * @param string $version     The plugin version that deprecated the function.
524
 * @param string $replacement Optional. The function that should have been called.
525
 * @param array  $backtrace   Optional. Contains stack backtrace of deprecated function.
526
 */
527
function _give_deprecated_function( $function, $version, $replacement = null, $backtrace = null ) {
528
529
	/**
530
	 * Fires while give deprecated function call occurs.
531
	 *
532
	 * Allow you to hook to deprecated function call.
533
	 *
534
	 * @since 1.0
535
	 *
536
	 * @param string $function    The function that was called.
537
	 * @param string $replacement Optional. The function that should have been called.
538
	 * @param string $version     The plugin version that deprecated the function.
539
	 */
540
	do_action( 'give_deprecated_function_run', $function, $replacement, $version );
541
542
	$show_errors = current_user_can( 'manage_options' );
543
544
	// Allow plugin to filter the output error trigger
545
	if ( WP_DEBUG && apply_filters( 'give_deprecated_function_trigger_error', $show_errors ) ) {
546
		if ( ! is_null( $replacement ) ) {
547
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s! Use %3$s instead.', 'give' ), $function, $version, $replacement ) );
548
			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.
549
			// Alternatively we could dump this to a file.
550
		} else {
551
			trigger_error( sprintf( __( '%1$s is <strong>deprecated</strong> since Give version %2$s with no alternative available.', 'give' ), $function, $version ) );
552
			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.
553
			// Alternatively we could dump this to a file.
554
		}
555
	}
556
}
557
558
/**
559
 * Give Get Admin ID
560
 *
561
 * Helper function to return the ID of the post for admin usage
562
 *
563
 * @return string $post_id
564
 */
565
function give_get_admin_post_id() {
566
	$post_id = isset( $_REQUEST['post'] )
567
		? absint( $_REQUEST['post'] )
568
		: null;
569
570
	$post_id = ! empty( $post_id )
571
		? $post_id
572
		: ( isset( $_REQUEST['post_id'] ) ? absint( $_REQUEST['post_id'] ) : null );
573
574
	$post_id = ! empty( $post_id )
575
		? $post_id
576
		: ( isset( $_REQUEST['post_ID'] ) ? absint( $_REQUEST['post_ID'] ) : null );
577
578
	return $post_id;
579
}
580
581
/**
582
 * Get PHP Arg Separator Output
583
 *
584
 * @since 1.0
585
 * @return string Arg separator output
586
 */
587
function give_get_php_arg_separator_output() {
588
	return ini_get( 'arg_separator.output' );
589
}
590
591
592
/**
593
 * Month Num To Name
594
 *
595
 * Takes a month number and returns the name three letter name of it.
596
 *
597
 * @since 1.0
598
 *
599
 * @param int $n
600
 *
601
 * @return string Short month name
602
 */
603
function give_month_num_to_name( $n ) {
604
	$timestamp = mktime( 0, 0, 0, $n, 1, 2005 );
605
606
	return date_i18n( "M", $timestamp );
607
}
608
609
610
/**
611
 * Checks whether function is disabled.
612
 *
613
 * @since 1.0
614
 *
615
 * @param string $function Name of the function.
616
 *
617
 * @return bool Whether or not function is disabled.
618
 */
619
function give_is_func_disabled( $function ) {
620
	$disabled = explode( ',', ini_get( 'disable_functions' ) );
621
622
	return in_array( $function, $disabled );
623
}
624
625
626
/**
627
 * Give Newsletter
628
 *
629
 * Returns the main Give newsletter form
630
 */
631
function give_get_newsletter() { ?>
632
633
    <p class="newsletter-intro"><?php esc_html_e( 'Be sure to sign up for the Give newsletter below to stay informed of important updates and news.', 'give' ); ?></p>
634
635
    <div class="give-newsletter-form-wrap">
636
637
        <form action="//givewp.us3.list-manage.com/subscribe/post?u=3ccb75d68bda4381e2f45794c&amp;id=12a081aa13"
638
              method="post" id="mc-embedded-subscribe-form" name="mc-embedded-subscribe-form" class="validate"
639
              target="_blank" novalidate>
640
            <div class="give-newsletter-confirmation">
641
                <p><?php esc_html_e( 'Thanks for Subscribing!', 'give' ); ?> :)</p>
642
            </div>
643
644
            <table class="form-table give-newsletter-form">
645
                <tr valign="middle">
646
                    <td>
647
                        <label for="mce-EMAIL"
648
                               class="screen-reader-text"><?php esc_html_e( 'Email Address (required)', 'give' ); ?></label>
649
                        <input type="email" name="EMAIL" id="mce-EMAIL"
650
                               placeholder="<?php esc_attr_e( 'Email Address (required)', 'give' ); ?>"
651
                               class="required email" value="">
652
                    </td>
653
                    <td>
654
                        <label for="mce-FNAME"
655
                               class="screen-reader-text"><?php esc_html_e( 'First Name', 'give' ); ?></label>
656
                        <input type="text" name="FNAME" id="mce-FNAME"
657
                               placeholder="<?php esc_attr_e( 'First Name', 'give' ); ?>" class="" value="">
658
                    </td>
659
                    <td>
660
                        <label for="mce-LNAME"
661
                               class="screen-reader-text"><?php esc_html_e( 'Last Name', 'give' ); ?></label>
662
                        <input type="text" name="LNAME" id="mce-LNAME"
663
                               placeholder="<?php esc_attr_e( 'Last Name', 'give' ); ?>" class="" value="">
664
                    </td>
665
                    <td>
666
                        <input type="submit" name="subscribe" id="mc-embedded-subscribe" class="button"
667
                               value="<?php esc_attr_e( 'Subscribe', 'give' ); ?>">
668
                    </td>
669
                </tr>
670
            </table>
671
        </form>
672
673
        <div style="position: absolute; left: -5000px;">
674
            <input type="text" name="b_3ccb75d68bda4381e2f45794c_12a081aa13" tabindex="-1" value="">
675
        </div>
676
677
    </div>
678
679
    <script type='text/javascript' src='//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>
680
    <script type='text/javascript'>(function ($) {
681
			window.fnames = new Array();
682
			window.ftypes = new Array();
683
			fnames[0] = 'EMAIL';
684
			ftypes[0] = 'email';
685
			fnames[1] = 'FNAME';
686
			ftypes[1] = 'text';
687
			fnames[2] = 'LNAME';
688
			ftypes[2] = 'text';
689
690
			//Successful submission
691
			$('form[name="mc-embedded-subscribe-form"]').on('submit', function () {
692
693
				var email_field = $(this).find('#mce-EMAIL').val();
694
				if (!email_field) {
695
					return false;
696
				}
697
				$(this).find('.give-newsletter-confirmation').show().delay(5000).slideUp();
698
				$(this).find('.give-newsletter-form').hide();
699
700
			});
701
702
703
		}(jQuery));
704
		var $mcj = jQuery.noConflict(true);
705
706
707
    </script>
708
    <!--End mc_embed_signup-->
709
710
<?php }
711
712
713
/**
714
 * Social Media Like Buttons
715
 *
716
 * Various social media elements to Give
717
 */
718
function give_social_media_elements() {
719
	?>
720
721
    <div class="social-items-wrap">
722
723
        <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"
724
                scrolling="no" frameborder="0" style="border:none; overflow:hidden; width:100px; height:21px;"
725
                allowTransparency="true"></iframe>
726
727
        <a href="https://twitter.com/givewp" class="twitter-follow-button" data-show-count="false"><?php
728
			printf(
729
			/* translators: %s: Give twitter user @givewp */
730
				esc_html_e( 'Follow %s', 'give' ),
731
				'@givewp'
732
			);
733
			?></a>
734
        <script>!function (d, s, id) {
735
				var js, fjs = d.getElementsByTagName(s)[0], p = /^http:/.test(d.location) ? 'http' : 'https';
736
				if (!d.getElementById(id)) {
737
					js = d.createElement(s);
738
					js.id = id;
739
					js.src = p + '://platform.twitter.com/widgets.js';
740
					fjs.parentNode.insertBefore(js, fjs);
741
				}
742
			}(document, 'script', 'twitter-wjs');
743
        </script>
744
745
    </div>
746
    <!--/.social-items-wrap -->
747
748
	<?php
749
}
750
751
752
/**
753
 * Create SVG library function
754
 *
755
 * @param string $icon
756
 *
757
 * @return string
758
 */
759
function give_svg_icons( $icon ) {
760
761
	// Store your SVGs in an associative array
762
	$svgs = array(
763
		'microphone'    => '',
764
		'alert'         => "",
765
		'placemark'     => '',
766
		'give_grey'     => '',
767
		'give_cpt_icon' => '',
768
	);
769
770
	// Return the chosen icon's SVG string
771
	return $svgs[ $icon ];
772
}
773
774
/**
775
 * Modify Admin Nav Menu Label
776
 *
777
 * @since 1.3
778
 *
779
 * @param object $post_type The current object to add a menu items meta box for.
780
 *
781
 * @return mixed
782
 */
783
function modify_nav_menu_meta_box_object( $post_type ) {
784
	if ( isset( $post_type->name ) && $post_type->name == 'give_forms' ) {
785
		$post_type->labels->name = esc_html__( 'Donation Forms', 'give' );
786
	}
787
788
	return $post_type;
789
}
790
791
add_filter( 'nav_menu_meta_box_object', 'modify_nav_menu_meta_box_object' );
792
793
794
/**
795
 * Array_column backup usage
796
 *
797
 * This file is part of the array_column library.
798
 *
799
 * @since      : 1.3.0.1
800
 *
801
 * @copyright  Copyright (c) Ben Ramsey (http://benramsey.com)
802
 * @license    https://opensource.org/licenses/MIT MIT
803
 */
804
805
if ( ! function_exists( 'array_column' ) ) {
806
	/**
807
	 * Returns the values from a single column of the input array, identified by
808
	 * the $columnKey.
809
	 *
810
	 * Optionally, you may provide an $indexKey to index the values in the returned
811
	 * array by the values from the $indexKey column in the input array.
812
	 *
813
	 * @param array      $input     A multi-dimensional array (record set) from which to pull
814
	 *                              a column of values.
815
	 * @param int|string $columnKey The column of values to return. This value may be the
816
	 *                              integer key of the column you wish to retrieve, or it
817
	 *                              may be the string key name for an associative array.
818
	 * @param mixed      $indexKey  (Optional.) The column to use as the index/keys for
819
	 *                              the returned array. This value may be the integer key
820
	 *                              of the column, or it may be the string key name.
821
	 *
822
	 * @return array
0 ignored issues
show
Documentation introduced by
Should the return type not be null|false|array?

This check compares the return type specified in the @return annotation of a function or method doc comment with the types returned by the function and raises an issue if they mismatch.

Loading history...
823
	 */
824
	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...
825
		// Using func_get_args() in order to check for proper number of
826
		// parameters and trigger errors exactly as the built-in array_column()
827
		// does in PHP 5.5.
828
		$argc   = func_num_args();
829
		$params = func_get_args();
830
831
		if ( $argc < 2 ) {
832
			trigger_error( sprintf( esc_html__( 'array_column() expects at least 2 parameters, %s given.', 'give' ), $argc ), E_USER_WARNING );
833
834
			return null;
835
		}
836
837
		if ( ! is_array( $params[0] ) ) {
838
			trigger_error( sprintf( esc_html__( 'array_column() expects parameter 1 to be array, %s given.', 'give' ), gettype( $params[0] ) ), E_USER_WARNING );
839
840
			return null;
841
		}
842
843
		if ( ! is_int( $params[1] )
844
		     && ! is_float( $params[1] )
845
		     && ! is_string( $params[1] )
846
		     && $params[1] !== null
847
		     && ! ( is_object( $params[1] ) && method_exists( $params[1], '__toString' ) )
848
		) {
849
			trigger_error( esc_html__( 'array_column(): The column key should be either a string or an integer.', 'give' ), E_USER_WARNING );
850
851
			return false;
852
		}
853
854
		if ( isset( $params[2] )
855
		     && ! is_int( $params[2] )
856
		     && ! is_float( $params[2] )
857
		     && ! is_string( $params[2] )
858
		     && ! ( is_object( $params[2] ) && method_exists( $params[2], '__toString' ) )
859
		) {
860
			trigger_error( esc_html__( 'array_column(): The index key should be either a string or an integer.', 'give' ), E_USER_WARNING );
861
862
			return false;
863
		}
864
865
		$paramsInput     = $params[0];
866
		$paramsColumnKey = ( $params[1] !== null ) ? (string) $params[1] : null;
867
868
		$paramsIndexKey = null;
869
		if ( isset( $params[2] ) ) {
870
			if ( is_float( $params[2] ) || is_int( $params[2] ) ) {
871
				$paramsIndexKey = (int) $params[2];
872
			} else {
873
				$paramsIndexKey = (string) $params[2];
874
			}
875
		}
876
877
		$resultArray = array();
878
879
		foreach ( $paramsInput as $row ) {
880
			$key    = $value = null;
881
			$keySet = $valueSet = false;
882
883
			if ( $paramsIndexKey !== null && array_key_exists( $paramsIndexKey, $row ) ) {
884
				$keySet = true;
885
				$key    = (string) $row[ $paramsIndexKey ];
886
			}
887
888
			if ( $paramsColumnKey === null ) {
889
				$valueSet = true;
890
				$value    = $row;
891
			} elseif ( is_array( $row ) && array_key_exists( $paramsColumnKey, $row ) ) {
892
				$valueSet = true;
893
				$value    = $row[ $paramsColumnKey ];
894
			}
895
896
			if ( $valueSet ) {
897
				if ( $keySet ) {
898
					$resultArray[ $key ] = $value;
899
				} else {
900
					$resultArray[] = $value;
901
				}
902
			}
903
904
		}
905
906
		return $resultArray;
907
	}
908
909
}
910
911
/**
912
 * Determines the receipt visibility status.
913
 *
914
 * @since 1.3.2
915
 *
916
 * @param string $payment_key
917
 *
918
 * @return bool Whether the receipt is visible or not.
919
 */
920
function give_can_view_receipt( $payment_key = '' ) {
921
922
	$return = false;
923
924
	if ( empty( $payment_key ) ) {
925
		return $return;
926
	}
927
928
	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...
929
930
	$give_receipt_args['id'] = give_get_purchase_id_by_key( $payment_key );
931
932
	$user_id = (int) give_get_payment_user_id( $give_receipt_args['id'] );
933
934
	$payment_meta = give_get_payment_meta( $give_receipt_args['id'] );
935
936
	if ( is_user_logged_in() ) {
937
		if ( $user_id === (int) get_current_user_id() ) {
938
			$return = true;
939
		} elseif ( wp_get_current_user()->user_email === give_get_payment_user_email( $give_receipt_args['id'] ) ) {
940
			$return = true;
941
		} elseif ( current_user_can( 'view_give_sensitive_data' ) ) {
942
			$return = true;
943
		}
944
	}
945
946
	$session = give_get_purchase_session();
947
	if ( ! empty( $session ) && ! is_user_logged_in() ) {
948
		if ( $session['purchase_key'] === $payment_meta['key'] ) {
949
			$return = true;
950
		}
951
	}
952
953
	return (bool) apply_filters( 'give_can_view_receipt', $return, $payment_key );
954
955
}
956
957
/**
958
 * Fallback for cal_days_in_month
959
 *
960
 * Fallback in case the calendar extension is not loaded in PHP; Only supports Gregorian calendar
961
 */
962
if ( ! function_exists( 'cal_days_in_month' ) ) {
963
	/**
964
	 * cal_days_in_month
965
	 *
966
	 * @param int $calendar
967
	 * @param int $month
968
	 * @param int $year
969
	 *
970
	 * @return bool|string
971
	 */
972
	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...
973
		return date( 't', mktime( 0, 0, 0, $month, 1, $year ) );
974
	}
975
}
976
977
/**
978
 * Get plugin info including status, type, and license validation.
979
 *
980
 * This is an enhanced version of get_plugins() that returns the status
981
 * (`active` or `inactive`) of all plugins, type of plugin (`add-on` or `other`
982
 * and license validation for Give add-ons (`true` or `false`). Does not include
983
 * MU plugins.
984
 *
985
 * @since 1.8.0
986
 *
987
 * @return array Plugin info plus status, type, and license validation if
988
 *               available.
989
 */
990
function give_get_plugins() {
991
	$plugins             = get_plugins();
992
	$active_plugin_paths = (array) get_option( 'active_plugins', array() );
993
994
	if ( is_multisite() ) {
995
		$network_activated_plugin_paths = array_keys( get_site_option( 'active_sitewide_plugins', array() ) );
996
		$active_plugin_paths            = array_merge( $active_plugin_paths, $network_activated_plugin_paths );
997
	}
998
999
	foreach ( $plugins as $plugin_path => $plugin_data ) {
1000
		// Is plugin active?
1001
		if ( in_array( $plugin_path, $active_plugin_paths ) ) {
1002
			$plugins[ $plugin_path ]['Status'] = 'active';
1003
		} else {
1004
			$plugins[ $plugin_path ]['Status'] = 'inactive';
1005
		}
1006
1007
		$dirname = strtolower( dirname( $plugin_path ) );
1008
1009
		// Is plugin a Give add-on by WordImpress?
1010
		if ( strstr( $dirname, 'give-' ) && strstr( $plugin_data['AuthorURI'], 'wordimpress.com' ) ) {
1011
			// Plugin is a Give-addon.
1012
			$plugins[ $plugin_path ]['Type'] = 'add-on';
1013
1014
			// Get license info from database.
1015
			$plugin_name    = str_replace( 'Give - ', '', $plugin_data['Name'] );
1016
			$db_option      = 'give_' . preg_replace( '/[^a-zA-Z0-9_\s]/', '', str_replace( ' ', '_', strtolower( $plugin_name ) ) ) . '_license_active';
1017
			$license_active = get_option( $db_option );
1018
1019
			// Does a valid license exist?
1020
			if ( ! empty( $license_active ) && 'valid' === $license_active->license ) {
1021
				$plugins[ $plugin_path ]['License'] = true;
1022
			} else {
1023
				$plugins[ $plugin_path ]['License'] = false;
1024
			}
1025
		} else {
1026
			// Plugin is not a Give add-on.
1027
			$plugins[ $plugin_path ]['Type'] = 'other';
1028
		}
1029
	}
1030
1031
	return $plugins;
1032
}
1033
1034
1035
/**
1036
 * Check if terms enabled or not for form.
1037
 *
1038
 * @since 1.8
1039
 *
1040
 * @param $form_id
1041
 *
1042
 * @return bool
1043
 */
1044
function give_is_terms_enabled( $form_id ) {
1045
	$form_option = get_post_meta( $form_id, '_give_terms_option', true );
1046
1047
	if (
1048
		give_is_setting_enabled( $form_option, 'global' )
1049
		&& give_is_setting_enabled( give_get_option( 'terms' ) )
1050
	) {
1051
		return true;
1052
1053
	} elseif ( give_is_setting_enabled( $form_option ) ) {
1054
		return true;
1055
1056
	} else {
1057
		return false;
1058
	}
1059
}
1060
1061
1062
/**
1063
 * Delete donation stats cache.
1064
 * @todo Resolve stats cache key naming issue. Currently it is difficult to regenerate cache key.
1065
 *
1066
 * @since 1.8.7
1067
 *
1068
 * @param string|array $date_range Date for stats.
1069
 *                           Date value should be in today, yesterday, this_week, last_week, this_month, last_month, this_quarter, last_quarter, this_year, last_year.
1070
 *                           For date value other, all cache will be removed.
1071
 *
1072
 * @param array  $args
1073
 *
1074
 * @return WP_Error|bool
1075
 */
1076
function give_delete_donation_stats( $date_range = '', $args = array() ) {
1077
	// Delete all cache.
1078
	$status = Give_Cache::delete( Give_Cache::get_options_like( 'give_stats' ) );
1079
1080
	/**
1081
	 * Fire the action when donation stats delete.
1082
	 *
1083
	 * @since 1.8.7
1084
	 *
1085
	 * @param string|array $date_range
1086
	 * @param array  $args
1087
	 */
1088
	do_action( 'give_delete_donation_stats', $status, $date_range, $args );
1089
1090
	return $status;
1091
}
1092
1093
/**
1094
 * Check if admin creating new donation form or not.
1095
 *
1096
 * @since 2.0
1097
 * @return bool
1098
 */
1099
function give_is_add_new_form_page() {
1100
	$status = false;
1101
1102
	if ( false !== strpos( $_SERVER['REQUEST_URI'], '/wp-admin/post-new.php?post_type=give_forms' ) ) {
1103
		$status = true;
1104
	}
1105
1106
	return $status;
1107
}