PluginProbe ʕ •ᴥ•ʔ
GiveWP – Donation Plugin and Fundraising Platform / 2.13.3
GiveWP – Donation Plugin and Fundraising Platform v2.13.3
4.16.2 4.16.1 4.16.0 4.15.5 4.15.4 4.15.3 4.15.2 4.15.1 4.15.0 2.3.0 2.3.1 2.3.2 2.30.0 2.31.0 2.31.1 2.32.0 2.33.0 2.33.1 2.33.2 2.33.3 2.33.4 2.33.5 2.4.0 2.4.1 2.4.2 2.4.3 2.4.4 2.4.5 2.4.6 2.4.7 2.5.0 2.5.1 2.5.10 2.5.11 2.5.12 2.5.13 2.5.2 2.5.3 2.5.4 2.5.5 2.5.6 2.5.7 2.5.8 2.5.9 2.6.0 2.6.1 2.6.2 2.6.3 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.8.0 2.8.1 2.9.0 2.9.1 2.9.2 2.9.3 2.9.4 2.9.5 2.9.6 2.9.7 3.0.0 3.0.1 3.0.2 3.0.3 3.0.4 3.1.0 3.1.1 3.1.2 3.10.0 3.11.0 3.12.0 3.12.1 3.12.2 3.12.3 3.13.0 3.14.0 3.14.1 3.14.2 3.15.0 3.15.1 3.16.0 3.16.1 3.16.2 3.16.3 3.16.4 3.16.5 3.17.0 3.17.1 3.17.2 3.18.0 3.19.0 3.19.1 3.19.2 3.19.3 3.19.4 3.2.0 3.2.1 3.2.2 3.20.0 3.21.0 3.21.1 3.22.0 3.22.1 3.22.2 3.3.0 3.3.1 3.4.0 3.4.1 3.4.2 3.5.0 3.5.1 3.6.0 3.6.1 3.6.2 3.7.0 3.8.0 3.9.0 4.0.0 4.1.0 4.1.1 4.10.0 4.10.1 4.11.0 4.12.0 4.13.0 4.13.1 4.13.2 4.14.0 4.14.1 4.14.2 4.14.3 4.14.4 4.14.5 4.14.6 4.2.0 4.2.1 4.3.0 4.3.1 4.3.2 4.4.0 4.5.0 4.6.1 4.7.0 4.7.1 4.8.0 4.8.1 4.9.0 trunk 1.9.0 2.0.0 2.0.1 2.0.2 2.0.3 2.0.4 2.0.5 2.0.6 2.0.7 2.1.0 2.1.1 2.1.2 2.1.3 2.1.4 2.1.5 2.1.6 2.1.7 2.1.8 2.10.0 2.10.1 2.10.2 2.10.3 2.10.4 2.11.0 2.11.1 2.11.2 2.11.3 2.12.0 2.12.1 2.12.2 2.12.3 2.13.0 2.13.1 2.13.2 2.13.3 2.13.4 2.14.0 2.15.0 2.16.0 2.16.1 2.17.0 2.17.1 2.17.3 2.18.0 2.18.1 2.19.1 2.19.2 2.19.3 2.19.4 2.19.5 2.19.6 2.19.7 2.19.8 2.2.0 2.2.1 2.2.2 2.2.3 2.2.4 2.2.5 2.2.6 2.20.0 2.20.1 2.20.2 2.21.0 2.21.1 2.21.2 2.21.3 2.21.4 2.22.0 2.22.1 2.22.2 2.22.3 2.23.0 2.23.1 2.23.2 2.24.0 2.24.1 2.24.2 2.25.0 2.25.1 2.25.2 2.25.3 2.26.0 2.27.0 2.27.1 2.27.2 2.27.3 2.28.0 2.29.0 2.29.1 2.29.2
give / includes / admin / settings / class-settings-advanced.php
give / includes / admin / settings Last commit date
class-settings-addon.php 6 years ago class-settings-advanced.php 5 years ago class-settings-display.php 5 years ago class-settings-email.php 6 years ago class-settings-gateways.php 4 years ago class-settings-general.php 5 years ago class-settings-license.php 6 years ago
class-settings-advanced.php
366 lines
1 <?php
2 /**
3 * Give Settings Page/Tab
4 *
5 * @package Give
6 * @subpackage Classes/Give_Settings_Advanced
7 * @copyright Copyright (c) 2016, GiveWP
8 * @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
9 * @since 1.8
10 */
11
12 use Give\Onboarding\Setup\Page as SetupPage;
13
14 if ( ! defined( 'ABSPATH' ) ) {
15 exit; // Exit if accessed directly
16 }
17
18 if ( ! class_exists( 'Give_Settings_Advanced' ) ) :
19
20 /**
21 * Give_Settings_Advanced.
22 *
23 * @sine 1.8
24 */
25 class Give_Settings_Advanced extends Give_Settings_Page {
26
27 /**
28 * Constructor.
29 */
30 public function __construct() {
31 $this->id = 'advanced';
32 $this->label = __( 'Advanced', 'give' );
33
34 $this->default_tab = 'advanced-options';
35
36 if ( $this->id === give_get_current_setting_tab() ) {
37 add_action(
38 'give_admin_field_remove_cache_button',
39 [
40 $this,
41 'render_remove_cache_button',
42 ],
43 10,
44 1
45 );
46 add_action( 'give_save_settings_give_settings', [ $this, 'validate_settngs' ] );
47 }
48
49 parent::__construct();
50 }
51
52 /**
53 * Get settings array.
54 *
55 * @return array
56 * @since 1.8
57 */
58 public function get_settings() {
59 $settings = [];
60
61 $current_section = give_get_current_setting_section();
62
63 switch ( $current_section ) {
64 case 'advanced-options':
65 $settings = [
66 [
67 'id' => 'give_title_data_control_2',
68 'type' => 'title',
69 ],
70 [
71 'name' => __( 'Default GiveWP Styles', 'give' ),
72 'desc' => __( 'This controls GiveWP\'s default styles for legacy donation forms and other front end elements. Disabling this option means that you\'ll need to supply your own styles.', 'give' ),
73 'id' => 'css',
74 'type' => 'radio_inline',
75 'default' => 'enabled',
76 'options' => [
77 'enabled' => __( 'Enabled', 'give' ),
78 'disabled' => __( 'Disabled', 'give' ),
79 ],
80 ],
81 [
82 'name' => __( 'Remove Data on Uninstall', 'give' ),
83 'desc' => __( 'When the plugin is deleted, completely remove all GiveWP data. This includes all GiveWP settings, forms, form meta, donor, donor data, donations. Everything.', 'give' ),
84 'id' => 'uninstall_on_delete',
85 'type' => 'radio_inline',
86 'default' => 'disabled',
87 'options' => [
88 'enabled' => __( 'Yes, Remove all data', 'give' ),
89 'disabled' => __( 'No, keep my GiveWP settings and donation data', 'give' ),
90 ],
91 ],
92 [
93 'name' => __( 'Default User Role', 'give' ),
94 'desc' => __( 'Users are given this user role when they opt into creating a WordPress/site account along with their donation.', 'give' ),
95 'id' => 'donor_default_user_role',
96 'type' => 'select',
97 'default' => 'give_donor',
98 'options' => give_get_user_roles(),
99 ],
100 [
101 /* translators: %s: the_content */
102 'name' => sprintf( __( '%s filter', 'give' ), '<code>the_content</code>' ),
103 /* translators: 1: https://codex.wordpress.org/Plugin_API/Filter_Reference/the_content 2: the_content */
104 'desc' => sprintf( __( 'This controls whether or not GiveWP legacy form content is treated like WordPress content. Disabling this option means that things like social sharing and other theme- or plugin-added functionality to enhance or append things to content will not be applied to GiveWP legacy form content. <a href="%1$s" target="_blank">Learn more</a> about %2$s filter.', 'give' ), esc_url( 'https://codex.wordpress.org/Plugin_API/Filter_Reference/the_content' ), '<code>the_content</code>' ),
105 'id' => 'the_content_filter',
106 'default' => 'enabled',
107 'type' => 'radio_inline',
108 'options' => [
109 'enabled' => __( 'Enabled', 'give' ),
110 'disabled' => __( 'Disabled', 'give' ),
111 ],
112 ],
113 [
114 'name' => __( 'Script Loading Location', 'give' ),
115 'desc' => __( 'This allows you to load your GiveWP scripts either in the <code>&lt;head&gt;</code> or footer of your website.', 'give' ),
116 'id' => 'scripts_footer',
117 'type' => 'radio_inline',
118 'default' => 'disabled',
119 'options' => [
120 'disabled' => __( 'Head', 'give' ),
121 'enabled' => __( 'Footer', 'give' ),
122 ],
123 ],
124 [
125 'name' => __( 'Babel Polyfill Script', 'give' ),
126 'desc' => __( 'This controls loading the Babel polyfill, which provides backwards compatibility for older browsers such as IE 11. The polyfill may be disabled to avoid conflicts with other themes or plugins that load the same script.', 'give' ),
127 'id' => 'babel_polyfill_script',
128 'type' => 'radio_inline',
129 'default' => 'enabled',
130 'options' => [
131 'enabled' => __( 'Enabled', 'give' ),
132 'disabled' => __( 'Disabled', 'give' ),
133 ],
134 ],
135 [
136 'name' => __( 'Setup Page', 'give' ),
137 /* translators: %s: about page URL */
138 'desc' => sprintf(
139 wp_kses(
140 __( 'This option controls the display of the <a href="%s" target="_blank">GiveWP Setup page</a> when GiveWP is first installed.', 'give' ),
141 [
142 'a' => [
143 'href' => [],
144 'target' => [],
145 ],
146 ]
147 ),
148 esc_url( admin_url( 'edit.php?post_type=give_forms&page=give-setup' ) )
149 ),
150 'id' => 'setup_page_enabled',
151 'type' => 'radio_inline',
152 'default' => give_is_setting_enabled(
153 SetupPage::getSetupPageEnabledOrDisabled()
154 )
155 ? SetupPage::ENABLED
156 : SetupPage::DISABLED,
157 'options' => [
158 SetupPage::ENABLED => __( 'Enabled', 'give' ),
159 SetupPage::DISABLED => __( 'Disabled', 'give' ),
160 ],
161 'wrapper_class' => version_compare( get_bloginfo( 'version' ), '5.0', '<=' ) ? 'give-hidden' : null,
162 ],
163 [
164 'name' => __( 'Form Page URL Prefix', 'give' ),
165 'desc' => sprintf(
166 __( 'This slug is used as a base for the (invisible to users/site visitors) iframe URL that contains all form templates besides the legacy form template. The URL currently looks like this: %1$s. This option allows you to modify that URL to avoid conflicts that might exist with other pages and URLs on the site.', 'give' ),
167 '<code>' . trailingslashit( home_url() ) . Give()->routeForm->getBase() . '/{form-slug}</code>'
168 ),
169 'id' => Give()->routeForm->getOptionName(),
170 'type' => 'text',
171 'default' => Give()->routeForm->getBase(),
172 ],
173 [
174 'name' => __( 'Advanced Database Updates', 'give' ),
175 'desc' => __( 'This option is only for advanced users and/or those directed by GiveWP support. Once you enable this, you\'ll have the ability to override the run order and to force re-running for database updates at Donations > Tools > Data. If you don\'t know what you are doing, you can easily break things with this option enabled. Do not leave this option enabled after you\'re done troubleshooting.', 'give' ),
176 'id' => 'enable_database_updates',
177 'type' => 'radio_inline',
178 'default' => 'disabled',
179 'options' => [
180 'enabled' => __( 'Enabled', 'give' ),
181 'disabled' => __( 'Disabled', 'give' ),
182 ],
183 ],
184 [
185 'name' => 'GiveWP Cache',
186 'id' => 'give-clear-cache',
187 'buttonTitle' => __( 'Clear Cache', 'give' ),
188 'desc' => __( 'Click this button if you want to clear GiveWP\'s cache. The plugin stores common settings and queries in cache to optimize performance. Clearing cache will remove and begin rebuilding these saved queries.', 'give' ),
189 'type' => 'remove_cache_button',
190 ],
191 [
192 'name' => __( 'Advanced Settings Docs Link', 'give' ),
193 'id' => 'advanced_settings_docs_link',
194 'url' => esc_url( 'http://docs.givewp.com/settings-advanced' ),
195 'title' => __( 'Advanced Settings', 'give' ),
196 'type' => 'give_docs_link',
197 ],
198 [
199 'id' => 'give_title_data_control_2',
200 'type' => 'sectionend',
201 ],
202 ];
203 break;
204
205 case 'akismet-spam-protection':
206 $settings = [
207 [
208 'id' => 'give_setting_advanced_section_akismet_spam_protection',
209 'type' => 'title',
210 ],
211 [
212 'name' => __( 'Akismet SPAM Protection', 'give' ),
213 'desc' => __( 'Add a layer of SPAM protection to your donation submissions with Akismet. When enabled, donation submissions will be first sent through Akismet\'s SPAM check API if you have the plugin activated and configured.', 'give' ),
214 'id' => 'akismet_spam_protection',
215 'type' => 'radio_inline',
216 'default' => ( give_check_akismet_key() ) ? 'enabled' : 'disabled',
217 'options' => [
218 'enabled' => __( 'Enabled', 'give' ),
219 'disabled' => __( 'Disabled', 'give' ),
220 ],
221 ],
222 [
223 'name' => __( 'Whitelist by Email', 'give' ),
224 'desc' => sprintf(
225 '%1$s %2$s',
226 __( 'Add emails one at a time to ensure that donations using that email bypass GiveWP\'s Akismet SPAM filtering. Emails added to the list here are always allowed to donate, even if they\'ve been flagged by Akismet.', 'give' ),
227 sprintf(
228 __( 'To permanently prevent emails from being flagged as SPAM by Akismet <a href="%1$s" target="_blank">contact their team here</a>.', 'give' ),
229 esc_url( 'https://akismet.com/contact/' )
230 )
231 ),
232 'id' => 'akismet_whitelisted_email_addresses',
233 'type' => 'email',
234 'attributes' => [
235 'placeholder' => 'test@example.com',
236 ],
237 'repeat' => true,
238 'repeat_btn_title' => esc_html__( 'Add Email', 'give' ),
239 ],
240 [
241 'id' => 'give_setting_advanced_section_akismet_spam_protection',
242 'type' => 'sectionend',
243 ],
244 ];
245 break;
246 }
247
248 /**
249 * Hide caching setting by default.
250 *
251 * @since 2.0
252 */
253 if ( apply_filters( 'give_settings_advanced_show_cache_setting', false ) ) {
254 array_splice(
255 $settings,
256 1,
257 0,
258 [
259 [
260 'name' => __( 'Cache', 'give' ),
261 'desc' => __( 'If caching is enabled the plugin will start caching custom post type related queries and reduce the overall load time.', 'give' ),
262 'id' => 'cache',
263 'type' => 'radio_inline',
264 'default' => 'enabled',
265 'options' => [
266 'enabled' => __( 'Enabled', 'give' ),
267 'disabled' => __( 'Disabled', 'give' ),
268 ],
269 ],
270 ]
271 );
272 }
273
274 /**
275 * Filter the advanced settings.
276 * Backward compatibility: Please do not use this filter. This filter is deprecated in 1.8
277 */
278 $settings = apply_filters( 'give_settings_advanced', $settings );
279
280 /**
281 * Filter the settings.
282 *
283 * @param array $settings
284 *
285 * @since 1.8
286 */
287 $settings = apply_filters( 'give_get_settings_' . $this->id, $settings );
288
289 // Output.
290 return $settings;
291 }
292
293 /**
294 * Get sections.
295 *
296 * @return array
297 * @since 1.8
298 */
299 public function get_sections() {
300 $sections = [
301 'advanced-options' => __( 'Advanced Options', 'give' ),
302 'akismet-spam-protection' => __( 'Akismet SPAM Protection', 'give' ),
303 ];
304
305 return apply_filters( 'give_get_sections_' . $this->id, $sections );
306 }
307
308
309 /**
310 * Render remove_cache_button field type
311 *
312 * @param array $field
313 *
314 * @since 2.1
315 * @access public
316 */
317 public function render_remove_cache_button( $field ) {
318 ?>
319 <tr valign="top" <?php echo ! empty( $field['wrapper_class'] ) ? 'class="' . $field['wrapper_class'] . '"' : ''; ?>>
320 <th scope="row" class="titledesc">
321 <label
322 for="<?php echo esc_attr( $field['id'] ); ?>"><?php echo esc_html( $field['name'] ); ?></label>
323 </th>
324 <td class="give-forminp">
325 <button type="button" id="<?php echo esc_attr( $field['id'] ); ?>"
326 class="button button-secondary"><?php echo esc_html( $field['buttonTitle'] ); ?></button>
327 <?php echo Give_Admin_Settings::get_field_description( $field ); ?>
328 </td>
329 </tr>
330 <?php
331 }
332
333
334 /**
335 * Validate setting
336 *
337 * @param array $options
338 *
339 * @since 2.2.0
340 * @access public
341 */
342 public function validate_settngs( $options ) {
343 // Sanitize data.
344 $akismet_spam_protection = isset( $options['akismet_spam_protection'] )
345 ? $options['akismet_spam_protection']
346 : ( give_check_akismet_key() ? 'enabled' : 'disabled' );
347
348 // Show error message if Akismet not configured and Admin try to save 'enabled' option.
349 if (
350 give_is_setting_enabled( $akismet_spam_protection )
351 && ! give_check_akismet_key()
352 ) {
353 Give_Admin_Settings::add_error(
354 'give-akismet-protection',
355 __( 'Please properly configure Akismet to enable SPAM protection.', 'give' )
356 );
357
358 give_update_option( 'akismet_spam_protection', 'disabled' );
359 }
360 }
361 }
362
363 endif;
364
365 return new Give_Settings_Advanced();
366