1
|
|
|
<?php |
|
|
|
|
2
|
|
|
/** |
3
|
|
|
* Offline Donations Gateway |
4
|
|
|
* |
5
|
|
|
* @package Give |
6
|
|
|
* @subpackage Gateways |
7
|
|
|
* @copyright Copyright (c) 2016, WordImpress |
8
|
|
|
* @license https://opensource.org/licenses/gpl-license GNU Public License |
9
|
|
|
* @since 1.0 |
10
|
|
|
*/ |
11
|
|
|
|
12
|
|
|
/** |
13
|
|
|
* Register the payment gateway |
14
|
|
|
* |
15
|
|
|
* @since 1.0 |
16
|
|
|
* |
17
|
|
|
* @param array $gateways |
18
|
|
|
* |
19
|
|
|
* @return array |
20
|
|
|
*/ |
21
|
|
|
function give_offline_register_gateway( $gateways ) { |
22
|
|
|
// Format: ID => Name |
23
|
44 |
|
$gateways['offline'] = array( |
24
|
44 |
|
'admin_label' => esc_attr__( 'Offline Donation', 'give' ), |
25
|
44 |
|
'checkout_label' => esc_attr__( 'Offline Donation', 'give' ) |
26
|
44 |
|
); |
27
|
|
|
|
28
|
44 |
|
return $gateways; |
29
|
|
|
} |
30
|
|
|
|
31
|
|
|
add_filter( 'give_payment_gateways', 'give_offline_register_gateway', 1 ); |
32
|
|
|
|
33
|
|
|
|
34
|
|
|
/** |
35
|
|
|
* Add our payment instructions to the checkout |
36
|
|
|
* |
37
|
|
|
* @since 1.0 |
38
|
|
|
* |
39
|
|
|
* @param int $form_id Give form id. |
40
|
|
|
* |
41
|
|
|
* @return void |
42
|
|
|
*/ |
43
|
|
|
function give_offline_payment_cc_form( $form_id ) { |
44
|
|
|
// Get offline payment instruction. |
45
|
|
|
$offline_instructions = give_get_offline_payment_instruction( $form_id, true ); |
46
|
|
|
|
47
|
|
|
ob_start(); |
48
|
|
|
|
49
|
|
|
/** |
50
|
|
|
* Fires before the offline info fields. |
51
|
|
|
* |
52
|
|
|
* @since 1.0 |
53
|
|
|
* |
54
|
|
|
* @param int $form_id Give form id. |
55
|
|
|
*/ |
56
|
|
|
do_action( 'give_before_offline_info_fields', $form_id ); |
57
|
|
|
?> |
58
|
|
|
<fieldset id="give_offline_payment_info"> |
59
|
|
|
<?php echo stripslashes( $offline_instructions ); ?> |
60
|
|
|
</fieldset> |
61
|
|
|
<?php |
62
|
|
|
/** |
63
|
|
|
* Fires after the offline info fields. |
64
|
|
|
* |
65
|
|
|
* @since 1.0 |
66
|
|
|
* |
67
|
|
|
* @param int $form_id Give form id. |
68
|
|
|
*/ |
69
|
|
|
do_action( 'give_after_offline_info_fields', $form_id ); |
70
|
|
|
|
71
|
|
|
echo ob_get_clean(); |
72
|
|
|
} |
73
|
|
|
|
74
|
|
|
add_action( 'give_offline_cc_form', 'give_offline_payment_cc_form' ); |
75
|
|
|
|
76
|
|
|
/** |
77
|
|
|
* Give Offline Billing Field |
78
|
|
|
* |
79
|
|
|
* @param $form_id |
80
|
|
|
*/ |
81
|
|
|
function give_offline_billing_fields( $form_id ) { |
82
|
|
|
//Enable Default CC fields (billing info) |
83
|
|
|
$post_offline_cc_fields = get_post_meta( $form_id, '_give_offline_donation_enable_billing_fields_single', true ); |
84
|
|
|
$post_offline_customize_option = get_post_meta( $form_id, '_give_customize_offline_donations', true ); |
85
|
|
|
|
86
|
|
|
$global_offline_cc_fields = give_get_option( 'give_offline_donation_enable_billing_fields' ); |
87
|
|
|
|
88
|
|
|
//Output CC Address fields if global option is on and user hasn't elected to customize this form's offline donation options |
89
|
|
|
if ( |
90
|
|
|
( give_is_setting_enabled( $post_offline_customize_option, 'global' ) && give_is_setting_enabled( $global_offline_cc_fields ) ) |
91
|
|
|
|| ( give_is_setting_enabled( $post_offline_customize_option, 'enabled' ) && give_is_setting_enabled( $post_offline_cc_fields ) ) |
92
|
|
|
) { |
93
|
|
|
give_default_cc_address_fields( $form_id ); |
94
|
|
|
} |
95
|
|
|
} |
96
|
|
|
|
97
|
|
|
add_action( 'give_before_offline_info_fields', 'give_offline_billing_fields', 10, 1 ); |
98
|
|
|
|
99
|
|
|
/** |
100
|
|
|
* Process the payment |
101
|
|
|
* |
102
|
|
|
* @since 1.0 |
103
|
|
|
* |
104
|
|
|
* @param $purchase_data |
105
|
|
|
* |
106
|
|
|
* @return void |
107
|
|
|
*/ |
108
|
|
|
function give_offline_process_payment( $purchase_data ) { |
109
|
|
|
|
110
|
|
|
$purchase_summary = give_get_purchase_summary( $purchase_data ); |
111
|
|
|
|
112
|
|
|
// setup the payment details |
113
|
|
|
$payment_data = array( |
114
|
|
|
'price' => $purchase_data['price'], |
115
|
|
|
'give_form_title' => $purchase_data['post_data']['give-form-title'], |
116
|
|
|
'give_form_id' => intval( $purchase_data['post_data']['give-form-id'] ), |
117
|
|
|
'give_price_id' => isset( $purchase_data['post_data']['give-price-id'] ) ? $purchase_data['post_data']['give-price-id'] : '', |
118
|
|
|
'date' => $purchase_data['date'], |
119
|
|
|
'user_email' => $purchase_data['user_email'], |
120
|
|
|
'purchase_key' => $purchase_data['purchase_key'], |
121
|
|
|
'currency' => give_get_currency(), |
122
|
|
|
'user_info' => $purchase_data['user_info'], |
123
|
|
|
'status' => 'pending', |
124
|
|
|
'gateway' => 'offline' |
125
|
|
|
); |
126
|
|
|
|
127
|
|
|
|
128
|
|
|
// record the pending payment |
129
|
|
|
$payment = give_insert_payment( $payment_data ); |
130
|
|
|
|
131
|
|
|
if ( $payment ) { |
|
|
|
|
132
|
|
|
give_offline_send_admin_notice( $payment ); |
133
|
|
|
give_offline_send_donor_instructions( $payment ); |
134
|
|
|
give_send_to_success_page(); |
135
|
|
|
} else { |
136
|
|
|
// if errors are present, send the user back to the donation form so they can be corrected |
137
|
|
|
give_send_back_to_checkout( '?payment-mode=' . $purchase_data['post_data']['give-gateway'] ); |
138
|
|
|
} |
139
|
|
|
|
140
|
|
|
} |
141
|
|
|
|
142
|
|
|
add_action( 'give_gateway_offline', 'give_offline_process_payment' ); |
143
|
|
|
|
144
|
|
|
|
145
|
|
|
/** |
146
|
|
|
* Send Offline Donation Instructions |
147
|
|
|
* |
148
|
|
|
* Sends a notice to the donor with offline instructions; can be customized per form |
149
|
|
|
* |
150
|
|
|
* @param int $payment_id |
151
|
|
|
* |
152
|
|
|
* @since 1.0 |
153
|
|
|
* @return void |
154
|
|
|
*/ |
155
|
|
|
function give_offline_send_donor_instructions( $payment_id = 0 ) { |
156
|
|
|
|
157
|
|
|
$payment_data = give_get_payment_meta( $payment_id ); |
158
|
|
|
$post_offline_customization_option = get_post_meta( $payment_data['form_id'], '_give_customize_offline_donations', true ); |
159
|
|
|
|
160
|
|
|
//Customize email content depending on whether the single form has been customized |
161
|
|
|
$email_content = give_get_option( 'global_offline_donation_email' ); |
162
|
|
|
|
163
|
|
|
if ( give_is_setting_enabled( $post_offline_customization_option, 'enabled' ) ) { |
164
|
|
|
$email_content = get_post_meta( $payment_data['form_id'], '_give_offline_donation_email', true ); |
165
|
|
|
} |
166
|
|
|
|
167
|
|
|
$from_name = give_get_option( 'from_name', wp_specialchars_decode( get_bloginfo( 'name' ), ENT_QUOTES ) ); |
168
|
|
|
|
169
|
|
|
/** |
170
|
|
|
* Filters the from name. |
171
|
|
|
* |
172
|
|
|
* @since 1.7 |
173
|
|
|
*/ |
174
|
|
|
$from_name = apply_filters( 'give_donation_from_name', $from_name, $payment_id, $payment_data ); |
175
|
|
|
|
176
|
|
|
$from_email = give_get_option( 'from_email', get_bloginfo( 'admin_email' ) ); |
177
|
|
|
|
178
|
|
|
/** |
179
|
|
|
* Filters the from email. |
180
|
|
|
* |
181
|
|
|
* @since 1.7 |
182
|
|
|
*/ |
183
|
|
|
$from_email = apply_filters( 'give_donation_from_address', $from_email, $payment_id, $payment_data ); |
184
|
|
|
|
185
|
|
|
$to_email = give_get_payment_user_email( $payment_id ); |
186
|
|
|
|
187
|
|
|
$subject = give_get_option( 'offline_donation_subject', __( 'Offline Donation Instructions', 'give' ) ); |
188
|
|
|
if ( give_is_setting_enabled( $post_offline_customization_option, 'enabled' ) ) { |
189
|
|
|
$subject = get_post_meta( $payment_data['form_id'], '_give_offline_donation_subject', true ); |
190
|
|
|
} |
191
|
|
|
|
192
|
|
|
$subject = apply_filters( 'give_offline_donation_subject', wp_strip_all_tags( $subject ), $payment_id ); |
193
|
|
|
$subject = give_do_email_tags( $subject, $payment_id ); |
194
|
|
|
|
195
|
|
|
$attachments = apply_filters( 'give_offline_donation_attachments', array(), $payment_id, $payment_data ); |
196
|
|
|
$message = give_do_email_tags( $email_content, $payment_id ); |
197
|
|
|
|
198
|
|
|
$emails = Give()->emails; |
199
|
|
|
|
200
|
|
|
$emails->__set( 'from_name', $from_name ); |
201
|
|
|
$emails->__set( 'from_email', $from_email ); |
202
|
|
|
$emails->__set( 'heading', __( 'Offline Donation Instructions', 'give' ) ); |
203
|
|
|
|
204
|
|
|
$headers = apply_filters( 'give_receipt_headers', $emails->get_headers(), $payment_id, $payment_data ); |
205
|
|
|
$emails->__set( 'headers', $headers ); |
206
|
|
|
|
207
|
|
|
$emails->send( $to_email, $subject, $message, $attachments ); |
208
|
|
|
|
209
|
|
|
} |
210
|
|
|
|
211
|
|
|
|
212
|
|
|
/** |
213
|
|
|
* Send Offline Donation Admin Notice. |
214
|
|
|
* |
215
|
|
|
* Sends a notice to site admins about the pending donation. |
216
|
|
|
* |
217
|
|
|
* @since 1.0 |
218
|
|
|
* |
219
|
|
|
* @param int $payment_id |
220
|
|
|
* |
221
|
|
|
* @return void |
222
|
|
|
* |
223
|
|
|
*/ |
224
|
|
|
function give_offline_send_admin_notice( $payment_id = 0 ) { |
225
|
|
|
|
226
|
|
|
/* Send an email notification to the admin */ |
227
|
|
|
$admin_email = give_get_admin_notice_emails(); |
228
|
|
|
$user_info = give_get_payment_meta_user_info( $payment_id ); |
229
|
|
|
|
230
|
|
|
if ( isset( $user_info['id'] ) && $user_info['id'] > 0 ) { |
231
|
|
|
$user_data = get_userdata( $user_info['id'] ); |
232
|
|
|
$name = $user_data->display_name; |
233
|
|
|
} elseif ( isset( $user_info['first_name'] ) && isset( $user_info['last_name'] ) ) { |
234
|
|
|
$name = $user_info['first_name'] . ' ' . $user_info['last_name']; |
235
|
|
|
} else { |
236
|
|
|
$name = $user_info['email']; |
237
|
|
|
} |
238
|
|
|
|
239
|
|
|
$amount = give_currency_filter( give_format_amount( give_get_payment_amount( $payment_id ) ) ); |
240
|
|
|
|
241
|
|
|
$admin_subject = apply_filters( 'give_offline_admin_donation_notification_subject', __( 'New Pending Donation', 'give' ), $payment_id ); |
242
|
|
|
|
243
|
|
|
$admin_message = __( 'Dear Admin,', 'give' ) . "\n\n"; |
244
|
|
|
$admin_message .= __( 'An offline donation has been made on your website:', 'give' ) . ' ' . get_bloginfo( 'name' ) . ' '; |
245
|
|
|
$admin_message .= __( 'Hooray! The donation is in a pending status and is awaiting payment. Donation instructions have been emailed to the donor. Once you receive payment, be sure to mark the donation as complete using the link below.', 'give' ) . "\n\n"; |
246
|
|
|
|
247
|
|
|
|
248
|
|
|
$admin_message .= '<strong>' . __( 'Donor:', 'give' ) . '</strong> {fullname}' . "\n"; |
249
|
|
|
$admin_message .= '<strong>' . __( 'Amount:', 'give' ) . '</strong> {amount}' . "\n\n"; |
250
|
|
|
|
251
|
|
|
$admin_message .= sprintf( |
252
|
|
|
'<a href="%1$s">%2$s</a>', |
253
|
|
|
admin_url( 'edit.php?post_type=give_forms&page=give-payment-history&view=view-order-details&id=' . $payment_id ), |
254
|
|
|
__( 'Click Here to View and/or Update Donation Details', 'give' ) |
255
|
|
|
) . "\n\n"; |
256
|
|
|
|
257
|
|
|
$admin_message = apply_filters( 'give_offline_admin_donation_notification', $admin_message, $payment_id ); |
258
|
|
|
$admin_message = give_do_email_tags( $admin_message, $payment_id ); |
259
|
|
|
|
260
|
|
|
$attachments = apply_filters( 'give_offline_admin_donation_notification_attachments', array(), $payment_id ); |
261
|
|
|
$admin_headers = apply_filters( 'give_offline_admin_donation_notification_headers', array(), $payment_id ); |
262
|
|
|
|
263
|
|
|
//Send Email |
264
|
|
|
$emails = Give()->emails; |
265
|
|
|
if ( ! empty( $admin_headers ) ) { |
266
|
|
|
$emails->__set( 'headers', $admin_headers ); |
267
|
|
|
} |
268
|
|
|
|
269
|
|
|
$emails->send( $admin_email, $admin_subject, $admin_message, $attachments ); |
270
|
|
|
|
271
|
|
|
} |
272
|
|
|
|
273
|
|
|
|
274
|
|
|
/** |
275
|
|
|
* Register gateway settings. |
276
|
|
|
* |
277
|
|
|
* @param $settings |
278
|
|
|
* |
279
|
|
|
* @return array |
280
|
|
|
*/ |
281
|
|
|
function give_offline_add_settings( $settings ) { |
282
|
|
|
|
283
|
|
|
// Bailout: Do not show offline gateways setting in to metabox if its disabled globally. |
284
|
|
|
if ( in_array( 'offline', give_get_option( 'gateways' ) ) ) { |
285
|
|
|
return $settings; |
286
|
|
|
} |
287
|
|
|
|
288
|
|
|
//Vars |
289
|
|
|
$prefix = '_give_'; |
290
|
|
|
|
291
|
|
|
$is_gateway_active = give_is_gateway_active( 'offline' ); |
292
|
|
|
|
293
|
|
|
//this gateway isn't active |
294
|
|
|
if ( ! $is_gateway_active ) { |
295
|
|
|
//return settings and bounce |
296
|
|
|
return $settings; |
297
|
|
|
} |
298
|
|
|
|
299
|
|
|
//Fields |
300
|
|
|
$check_settings = array( |
301
|
|
|
|
302
|
|
|
array( |
303
|
|
|
'name' => __( 'Offline Donations', 'give' ), |
304
|
|
|
'desc' => __( 'Do you want to customize the donation instructions for this form?', 'give' ), |
305
|
|
|
'id' => $prefix . 'customize_offline_donations', |
306
|
|
|
'type' => 'radio_inline', |
307
|
|
|
'default' => 'global', |
308
|
|
|
'options' => apply_filters( 'give_forms_content_options_select', array( |
309
|
|
|
'global' => __( 'Global Options', 'give' ), |
310
|
|
|
'enabled' => __( 'Customize', 'give' ), |
311
|
|
|
'disabled' => __( 'Disable', 'give' ), |
312
|
|
|
) |
313
|
|
|
), |
314
|
|
|
), |
315
|
|
|
array( |
316
|
|
|
'name' => __( 'Billing Fields', 'give' ), |
317
|
|
|
'desc' => __( 'This option will enable the billing details section for this form\'s offline donation payment gateway. The fieldset will appear above the offline donation instructions.', 'give' ), |
318
|
|
|
'id' => $prefix . 'offline_donation_enable_billing_fields_single', |
319
|
|
|
'row_classes' => 'give-subfield', |
320
|
|
|
'type' => 'radio_inline', |
321
|
|
|
'default' => 'disabled', |
322
|
|
|
'options' => array( |
323
|
|
|
'enabled' => __( 'Enabled', 'give' ), |
324
|
|
|
'disabled' => __( 'Disabled', 'give' ), |
325
|
|
|
), |
326
|
|
|
), |
327
|
|
|
array( |
328
|
|
|
'id' => $prefix . 'offline_checkout_notes', |
329
|
|
|
'name' => __( 'Donation Instructions', 'give' ), |
330
|
|
|
'desc' => __( 'Enter the instructions you want to display to the donor during the donation process. Most likely this would include important information like mailing address and who to make the check out to.', 'give' ), |
331
|
|
|
'default' => give_get_default_offline_donation_content(), |
332
|
|
|
'type' => 'wysiwyg', |
333
|
|
|
'row_classes' => 'give-subfield', |
334
|
|
|
'options' => array( |
335
|
|
|
'textarea_rows' => 6, |
336
|
|
|
) |
337
|
|
|
), |
338
|
|
|
array( |
339
|
|
|
'id' => $prefix . 'offline_donation_subject', |
340
|
|
|
'name' => __( 'Email Subject', 'give' ), |
341
|
|
|
'desc' => __( 'Enter the subject line for the donation receipt email.', 'give' ), |
342
|
|
|
'default' => __( '{form_title} - Offline Donation Instructions', 'give' ), |
343
|
|
|
'row_classes' => 'give-subfield', |
344
|
|
|
'type' => 'text' |
345
|
|
|
), |
346
|
|
|
array( |
347
|
|
|
'id' => $prefix . 'offline_donation_email', |
348
|
|
|
'name' => __( 'Email Instructions', 'give' ), |
349
|
|
|
'desc' => __( 'Enter the instructions you want emailed to the donor after they have submitted the donation form. Most likely this would include important information like mailing address and who to make the check out to.', 'give' ), |
350
|
|
|
'default' => give_get_default_offline_donation_email_content(), |
351
|
|
|
'type' => 'wysiwyg', |
352
|
|
|
'row_classes' => 'give-subfield', |
353
|
|
|
'options' => array( |
354
|
|
|
'textarea_rows' => 6, |
355
|
|
|
) |
356
|
|
|
), |
357
|
|
|
array( |
358
|
|
|
'name' => 'offline_docs', |
359
|
|
|
'type' => 'docs_link', |
360
|
|
|
'url' => 'http://docs.givewp.com/offlinegateway', |
361
|
|
|
'title' => __('Offline Donations', 'give'), |
362
|
|
|
), |
363
|
|
|
); |
364
|
|
|
|
365
|
|
|
return array_merge( $settings, $check_settings ); |
366
|
|
|
} |
367
|
|
|
|
368
|
|
|
add_filter( 'give_forms_offline_donations_metabox_fields', 'give_offline_add_settings' ); |
369
|
|
|
|
370
|
|
|
|
371
|
|
|
/** |
372
|
|
|
* Offline Donation Content |
373
|
|
|
* |
374
|
|
|
* Get default offline donation text |
375
|
|
|
* |
376
|
|
|
* @return string |
377
|
|
|
*/ |
378
|
|
|
function give_get_default_offline_donation_content() { |
379
|
|
|
|
380
|
|
|
$sitename = get_bloginfo( 'sitename' ); |
381
|
|
|
|
382
|
|
|
$default_text = '<p>' . __( 'In order to make an offline donation we ask that you please follow these instructions', 'give' ) . ': </p>'; |
383
|
|
|
$default_text .= '<ol>'; |
384
|
|
|
$default_text .= '<li>'; |
385
|
|
|
$default_text .= sprintf( |
386
|
|
|
/* translators: %s: site name */ |
387
|
|
|
__( 'Make a check payable to "%s"', 'give' ), |
388
|
|
|
$sitename |
389
|
|
|
); |
390
|
|
|
$default_text .= '</li>'; |
391
|
|
|
$default_text .= '<li>'; |
392
|
|
|
$default_text .= sprintf( |
393
|
|
|
/* translators: %s: site name */ |
394
|
|
|
__( 'On the memo line of the check, please indicate that the donation is for "%s"', 'give' ), |
395
|
|
|
$sitename |
396
|
|
|
); |
397
|
|
|
$default_text .= '</li>'; |
398
|
|
|
$default_text .= '<li>' . __( 'Please mail your check to:', 'give' ) . '</li>'; |
399
|
|
|
$default_text .= '</ol>'; |
400
|
|
|
$default_text .= ' <em>' . $sitename . '</em><br>'; |
401
|
|
|
$default_text .= ' <em>123 G Street </em><br>'; |
402
|
|
|
$default_text .= ' <em>San Diego, CA 92101 </em><br>'; |
403
|
|
|
$default_text .= '<p>' . __( 'All contributions will be gratefully acknowledged and are tax deductible.', 'give' ) . '</p>'; |
404
|
|
|
|
405
|
|
|
return apply_filters( 'give_default_offline_donation_content', $default_text ); |
406
|
|
|
|
407
|
|
|
} |
408
|
|
|
|
409
|
|
|
/** |
410
|
|
|
* Offline Donation Email Content |
411
|
|
|
* |
412
|
|
|
* Gets the default offline donation email content |
413
|
|
|
* |
414
|
|
|
* @return string |
415
|
|
|
*/ |
416
|
|
|
function give_get_default_offline_donation_email_content() { |
417
|
|
|
|
418
|
|
|
$sitename = get_bloginfo( 'sitename' ); |
419
|
|
|
$default_text = '<p>' . __( 'Dear {name},', 'give' ) . '</p>'; |
420
|
|
|
$default_text .= '<p>' . __( 'Thank you for your offline donation request! Your generosity is greatly appreciated. In order to make an offline donation we ask that you please follow these instructions:', 'give' ) . '</p>'; |
421
|
|
|
$default_text .= '<ol>'; |
422
|
|
|
$default_text .= '<li>'; |
423
|
|
|
$default_text .= sprintf( |
424
|
|
|
/* translators: %s: site name */ |
425
|
|
|
__( 'Make a check payable to "%s"', 'give' ), |
426
|
|
|
$sitename |
427
|
|
|
); |
428
|
|
|
$default_text .= '</li>'; |
429
|
|
|
$default_text .= '<li>'; |
430
|
|
|
$default_text .= sprintf( |
431
|
|
|
/* translators: %s: site name */ |
432
|
|
|
__( 'On the memo line of the check, please indicate that the donation is for "%s"', 'give' ), |
433
|
|
|
$sitename |
434
|
|
|
); |
435
|
|
|
$default_text .= '</li>'; |
436
|
|
|
$default_text .= '<li>' . __( 'Please mail your check to:', 'give' ) . '</li>'; |
437
|
|
|
$default_text .= '</ol>'; |
438
|
|
|
$default_text .= ' <em>' . $sitename . '</em><br>'; |
439
|
|
|
$default_text .= ' <em>123 G Street </em><br>'; |
440
|
|
|
$default_text .= ' <em>San Diego, CA 92101 </em><br>'; |
441
|
|
|
$default_text .= '<p>' . __( 'Once your donation has been received we will mark it as complete and you will receive an email receipt for your records. Please contact us with any questions you may have!', 'give' ) . '</p>'; |
442
|
|
|
$default_text .= '<p>' . __( 'Sincerely,', 'give' ) . '</p>'; |
443
|
|
|
$default_text .= '<p>' . $sitename . '</p>'; |
444
|
|
|
|
445
|
|
|
return apply_filters( 'give_default_offline_donation_content', $default_text ); |
446
|
|
|
|
447
|
|
|
} |
448
|
|
|
|
449
|
|
|
/** |
450
|
|
|
* Set notice for offline donation. |
451
|
|
|
* |
452
|
|
|
* @since 1.7 |
453
|
|
|
* |
454
|
|
|
* @param string $notice |
455
|
|
|
* @param int $id |
456
|
|
|
* |
457
|
|
|
* @return string |
|
|
|
|
458
|
|
|
*/ |
459
|
|
|
function give_offline_donation_receipt_status_notice( $notice, $id ) { |
460
|
|
|
$payment = new Give_Payment( $id ); |
461
|
|
|
|
462
|
|
|
if ( 'offline' !== $payment->gateway ) { |
463
|
|
|
return $notice; |
464
|
|
|
} |
465
|
|
|
|
466
|
|
|
return give_output_error( __('Payment Pending: Please follow the instructions below to complete your donation.', 'give'), false, 'warning' ); |
467
|
|
|
} |
468
|
|
|
|
469
|
|
|
add_filter( 'give_receipt_status_notice', 'give_offline_donation_receipt_status_notice', 10, 2 ); |
470
|
|
|
|
471
|
|
|
/** |
472
|
|
|
* Add offline payment instruction on payment receipt. |
473
|
|
|
* |
474
|
|
|
* @since 1.7 |
475
|
|
|
* |
476
|
|
|
* @param WP_Post $payment |
477
|
|
|
* |
478
|
|
|
* @return mixed |
479
|
|
|
*/ |
480
|
|
|
function give_offline_payment_receipt_after( $payment ) { |
481
|
|
|
// Get payment object. |
482
|
|
|
$payment = new Give_Payment( $payment->ID ); |
483
|
|
|
|
484
|
|
|
// Bailout. |
485
|
|
|
if ( 'offline' !== $payment->gateway ) { |
486
|
|
|
return false; |
487
|
|
|
} |
488
|
|
|
|
489
|
|
|
?> |
490
|
|
|
<tr> |
491
|
|
|
<td scope="row"><strong><?php esc_html_e( 'Offline Payment Instruction:', 'give' ); ?></strong></td> |
492
|
|
|
<td> |
493
|
|
|
<?php echo give_get_offline_payment_instruction( $payment->form_id, true ); ?> |
494
|
|
|
</td> |
495
|
|
|
</tr> |
496
|
|
|
<?php |
497
|
|
|
} |
498
|
|
|
|
499
|
|
|
add_filter( 'give_payment_receipt_after', 'give_offline_payment_receipt_after' ); |
500
|
|
|
|
501
|
|
|
/** |
502
|
|
|
* Get offline payment instructions. |
503
|
|
|
* |
504
|
|
|
* @since 1.7 |
505
|
|
|
* |
506
|
|
|
* @param int $form_id |
507
|
|
|
* @param bool $wpautop |
508
|
|
|
* |
509
|
|
|
* @return string |
510
|
|
|
*/ |
511
|
|
|
function give_get_offline_payment_instruction( $form_id, $wpautop = false ) { |
512
|
|
|
// Bailout. |
513
|
|
|
if ( ! $form_id ) { |
514
|
|
|
return ''; |
515
|
|
|
} |
516
|
|
|
|
517
|
|
|
$post_offline_customization_option = get_post_meta( $form_id, '_give_customize_offline_donations', true ); |
518
|
|
|
$post_offline_instructions = get_post_meta( $form_id, '_give_offline_checkout_notes', true ); |
519
|
|
|
$global_offline_instruction = give_get_option( 'global_offline_donation_content' ); |
520
|
|
|
$offline_instructions = $global_offline_instruction; |
521
|
|
|
|
522
|
|
|
if ( $post_offline_customization_option == 'yes' ) { |
523
|
|
|
$offline_instructions = $post_offline_instructions; |
524
|
|
|
} |
525
|
|
|
|
526
|
|
|
$settings_url = admin_url( 'post.php?post=' . $form_id . '&action=edit&message=1' ); |
527
|
|
|
|
528
|
|
|
/* translators: %s: form settings url */ |
529
|
|
|
$offline_instructions = ! empty( $offline_instructions ) ? $offline_instructions : sprintf( __( 'Please enter offline donation instructions in <a href="%s">this form\'s settings</a>.', 'give' ), $settings_url ); |
530
|
|
|
|
531
|
|
|
return ( $wpautop ? wpautop( $offline_instructions ) : $offline_instructions ); |
532
|
|
|
} |
533
|
|
|
|
534
|
|
|
|
535
|
|
|
/** |
536
|
|
|
* Remove offline gateway from gateway list of offline disable for form. |
537
|
|
|
* |
538
|
|
|
* @since 1.8 |
539
|
|
|
* |
540
|
|
|
* @param array $gateway_list |
541
|
|
|
* @param $form_id |
542
|
|
|
* |
543
|
|
|
* @return array |
544
|
|
|
*/ |
545
|
|
|
function give_filter_offline_gateway( $gateway_list, $form_id ) { |
546
|
|
|
if ( $form_id && ! give_is_setting_enabled( get_post_meta( $form_id, '_give_customize_offline_donations', true ), array( 'enabled', 'global' ) ) ) { |
547
|
|
|
unset( $gateway_list['offline'] ); |
548
|
|
|
} |
549
|
|
|
|
550
|
|
|
// Output. |
551
|
|
|
return $gateway_list; |
552
|
|
|
} |
553
|
|
|
|
554
|
|
|
add_filter( 'give_enabled_payment_gateways', 'give_filter_offline_gateway', 10, 2 ); |
555
|
|
|
|
556
|
|
|
/** |
557
|
|
|
* Set default gateway to global default payment gateway |
558
|
|
|
* if current default gateways selected offline and offline payment gateway is disabled. |
559
|
|
|
* |
560
|
|
|
* @since 1.8 |
561
|
|
|
* |
562
|
|
|
* @param string $meta_key Meta key. |
563
|
|
|
* @param string $meta_value Meta value. |
564
|
|
|
* @param int $postid Form ID. |
565
|
|
|
* |
566
|
|
|
* @return void |
567
|
|
|
*/ |
568
|
|
|
function _give_customize_offline_donations_on_save_callback( $meta_key, $meta_value, $postid ) { |
|
|
|
|
569
|
|
|
if ( ( 'no' === $meta_value ) && ( 'offline' === get_post_meta( $postid, '_give_default_gateway', true ) ) ) { |
570
|
|
|
update_post_meta( $postid, '_give_default_gateway', 'global' ); |
571
|
|
|
} |
572
|
|
|
} |
573
|
|
|
|
574
|
|
|
add_filter( 'give_save__give_customize_offline_donations', '_give_customize_offline_donations_on_save_callback', 10, 3 ); |
575
|
|
|
|
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.