forked from formbricks/wordpress
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathformbricks.php
352 lines (307 loc) · 13.9 KB
/
formbricks.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
<?php
/*
* Plugin Name: Formbricks
* Plugin URI: https://github.com/formbricks/wordpress
* Description: Official WordPress Plugin for Formbricks | An Open Source Survey Platform
* Version: 1.0.1
* Author: Formbricks
* Author Email: [email protected]
* Author URI: https://formbricks.com
* License: GPL v2
* License URI: ./LICENSE.txt
*/
// If this file is called directly, abort.
if (!defined('WPINC')) {
die;
}
// Increase the nonce lifespan to 1 day (86400 seconds)
add_filter('csrf_token_lifespan', function () {
return 86400;
});
/**
* Currently plugin version.
* Start at version 1.0.0 and use SemVer - https://semver.org
* Rename this for your plugin and update it as you release new versions.
*/
define('FORMBRICKS_VERSION', '1.0.1');
/**
* The code that runs during plugin activation.
* This action is documented in includes/class-formbricks-activator.php
*/
function formbricks_activate_plugin()
{
require_once plugin_dir_path(__FILE__) . 'includes/class-formbricks-activator.php';
Formbricks_Activator::activate();
}
/**
* The code that runs during plugin deactivation.
* This action is documented in includes/class-formbricks-deactivator.php
*/
function formbricks_deactivate_plugin()
{
require_once plugin_dir_path(__FILE__) . 'includes/class-formbricks-deactivator.php';
Formbricks_Deactivator::deactivate();
}
register_activation_hook(__FILE__, 'formbricks_activate_plugin');
register_deactivation_hook(__FILE__, 'formbricks_deactivate_plugin');
/**
* The core plugin class that is used to define internationalization,
* admin-specific hooks, and public-facing site hooks.
*/
require plugin_dir_path(__FILE__) . 'includes/class-formbricks.php';
/**
* Begins execution of the plugin.
*
* Since everything within the plugin is registered via hooks,
* then kicking off the plugin from this point in the file does
* not affect the page life cycle.
*
* @since 1.0.0
*/
function formbricks_run_plugin()
{
$plugin = new Formbricks();
$plugin->run();
}
formbricks_run_plugin();
function formbricks_admin_settings_page()
{
add_menu_page(
'Formbricks Settings',
'Formbricks',
'manage_options',
'formbricks-settings',
'formbricks_settings_page_content',
plugin_dir_url(__FILE__) . 'public/formbricks.svg',
);
}
function formbricks_settings_page_content()
{
$nonce = wp_create_nonce('formbricks_settings_nonce');
$form_submitted = isset($_POST['formbricks_settings_nonce_field']);
if ($form_submitted && wp_verify_nonce(sanitize_text_field(wp_unslash($_POST['formbricks_settings_nonce_field'])), 'formbricks_settings_nonce')) {
$environment_id = isset($_POST['formbricks_environment_id']) ? sanitize_text_field(wp_unslash($_POST['formbricks_environment_id'])) : '';
$api_host = isset($_POST['formbricks_api_host']) ? esc_url_raw(wp_unslash($_POST['formbricks_api_host'])) : '';
update_option('formbricks_environment_id', $environment_id);
update_option('formbricks_api_host', $api_host);
echo '<div id="formbricks-settings-saved" class="updated notice is-dismissible"><p>Settings saved successfully!</p></div>';
} elseif ($form_submitted) {
echo '<div id="formbricks-settings-error" class="error notice is-dismissible"><p>Error saving settings: Nonce verification failed. Please try again.</p></div>';
}
?>
<div class="wrap">
<h2>Formbricks Settings</h2>
<!-- Setup Checklist -->
<div class="container">
<h3>Setup Checklist</h3>
<p>To run targeted surveys on your website, you need to complete the following steps:</p>
<ul>
<li>1. Free Formbricks Account (No Credit Card Needed) <a href="https://app.formbricks.com/auth/signup"
target="_blank">Signup here</a></li>
<li>2. The <b>environment ID</b> of your account. You find it in your Formbricks account settings under
"Setup Checklist"</li>
<li>3. The <b>API Host</b> When you use the Formbricks Cloud it is always "https://app.formbricks.com". Only
when you self-host Formbricks, it would be different</li>
<li>4. Here is a <a href="https://formbricks.com/docs/getting-started/framework-guides#prerequisites"
target="_blank">detailed guide</a> on how to get started</li>
</ul>
</div>
<!-- Configuration -->
<div class="container">
<form method="post" action="options.php">
<?php wp_nonce_field('formbricks_settings_nonce', 'formbricks_settings_nonce_field'); ?>
<?php settings_fields('formbricks_settings_group'); ?>
<?php do_settings_sections('formbricks-settings'); ?>
<h3>Configuration</h3>
<div>
<div>
<b>Environment ID</b>
<p>You can find your environment ID in your Formbricks account under "Setup Checklist". It looks
like: clmyq4k....</p>
<input type="text" name="formbricks_environment_id" id="formbricks_environment_id"
value="<?php echo esc_attr(get_option('formbricks_environment_id')); ?>" />
</div>
<div style="margin-top: 20px;">
<b>API Host</b>
<p>When you use the Formbricks Cloud it is always "https://app.formbricks.com". Only when you
self-host Formbricks, it would be different</p>
<input type="text" name="formbricks_api_host" id="formbricks_api_host"
value="<?php echo esc_attr(get_option('formbricks_api_host')); ?>" />
</div>
<div style="margin-top: 20px;">
<div style="display: flex; align-items: center; gap: 10px;">
<button type="button" id="formbricks-test-ping" class="test-button">Check Connection</button>
<button type="submit" id="formbricks-save-changes" class="save-button" disabled>Save
Changes</button>
</div>
<p id="formbricks-ping-result"></p>
</div>
</div>
</form>
</div>
<!-- Enable Formbricks -->
<div class="container">
<form method="post" action="options.php">
<?php wp_nonce_field('formbricks_toggle_nonce', 'formbricks_toggle_nonce_field'); ?>
<?php settings_fields('formbricks_toggle_group'); ?>
<?php do_settings_sections('formbricks-toggle'); ?>
<h3>Enable Formbricks</h3>
<!-- Show Formbricks is enabled or not -->
<p>
<b>Formbricks is currently: </b>
<?php
$globalToggle = get_option('formbricks_global_toggle');
if ($globalToggle == 'on') {
echo '<span style="color: green;">Enabled ✅</span>';
} else {
echo '<span style="color: red;">Disabled ❌</span>';
}
?>
</p>
<label class="toggle-switch">
<input type="checkbox" name="formbricks_global_toggle" <?php checked(get_option('formbricks_global_toggle'), 'on'); ?> />
<span class="slider"></span>
</label>
<div style="margin-top: 20px;">
<input type="submit" class="save-button" value="Save Changes" />
</div>
<div style="margin-top: 20px;">
<b>What now?</b>
<p>
Create a survey on Formbricks to display on your website. <a
href="https://formbricks.com/docs/integrations/wordpress" target="_blank">Here is a step by step
guide</a>
</p>
<p>
Help needed? <a href="https://formbricks.com/discord" target="_blank">Join our Discord Community</a>
</p>
</div>
</form>
</div>
</div>
<script>
jQuery(document).ready(function ($) {
setTimeout(function () {
$('#formbricks-settings-saved').fadeOut('slow');
}, 5000);
});
</script>
<script>
jQuery(document).ready(function ($) {
// Function to handle ping response and update UI
function handlePingResponse(response) {
var enableSaveChanges = response && response.data && response.data.product;
$('#formbricks-ping-result').html(enableSaveChanges ?
'<span style="color: green;">Test Request Success! Click the Save Changes Button</span>' :
'<span style="color: red;">Error: Invalid response format!</span>'
);
$('#formbricks-save-changes').prop('disabled', !enableSaveChanges);
}
// Function to handle ping error and update UI
function handlePingError() {
$('#formbricks-ping-result').html('<span style="color: red;">Test Request Failed! Make sure both field values are correct!</span>');
$('#formbricks-save-changes').prop('disabled', true);
}
// Event binding for the "Test Ping" button
$('#formbricks-test-ping').on('click', function () {
var environmentId = $('#formbricks_environment_id').val();
var apiHost = $('#formbricks_api_host').val();
apiHost = apiHost.replace(/\/$/, '');
if (environmentId && apiHost) {
// Perform AJAX request
$.ajax({
url: apiHost + '/api/v1/client/' + environmentId + '/environment',
type: 'GET',
dataType: 'json',
success: function (response) {
handlePingResponse(response);
},
error: function (xhr, status, error) {
handlePingError();
}
});
} else {
handlePingError();
}
});
// Event binding for the "Save Changes" button
$('#formbricks-save-changes').on('click', function () {
// Remove trailing slash from the apiHost
var apiHost = $('#formbricks_api_host').val();
$('#formbricks_api_host').val(apiHost.replace(/\/$/, ''));
});
});
</script>
<script>
jQuery(document).ready(function ($) {
setTimeout(function () {
$('#formbricks-settings-saved').fadeOut('slow');
}, 5000);
});
</script>
<?php
}
function formbricks_register_toggle_settings()
{
register_setting('formbricks_toggle_group', 'formbricks_global_toggle', function ($option) {
if (isset($_POST['formbricks_toggle_nonce_field']) && wp_verify_nonce(sanitize_text_field(wp_unslash($_POST['formbricks_toggle_nonce_field'])), 'formbricks_toggle_nonce')) {
return $option;
} else {
add_settings_error('formbricks_global_toggle', 'formbricks_toggle_nonce_error', 'Error saving settings: Nonce verification failed. Please try again.');
return get_option('formbricks_global_toggle');
}
});
}
function formbricks_register_settings()
{
register_setting('formbricks_settings_group', 'formbricks_environment_id', 'sanitize_text_field');
register_setting('formbricks_settings_group', 'formbricks_api_host', 'esc_url_raw');
}
add_action('admin_menu', 'formbricks_admin_settings_page');
add_action('admin_init', 'formbricks_register_settings');
add_action('admin_init', 'formbricks_register_toggle_settings');
// Enqueue JavaScript on the frontend
function formbricks_enqueue_script()
{
if (!is_admin()) {
$globalToggle = get_option('formbricks_global_toggle');
if ($globalToggle == 'on') {
$environmentId = get_option('formbricks_environment_id');
$apiHost = get_option('formbricks_api_host');
if (!empty($environmentId) && !empty($apiHost)) {
wp_enqueue_script(
'formbricks',
$apiHost . '/js/formbricks.umd.cjs',
array('jquery'),
"3.0.1",
true
);
wp_enqueue_script(
'formbricks-init',
plugin_dir_url(__FILE__) . 'public/js/index.js',
array('jquery', 'formbricks'),
'1.0.1',
true
);
wp_add_inline_script(
'formbricks',
'const formbricksPluginSettings = ' . wp_json_encode(array(
'environmentId' => $environmentId,
'apiHost' => $apiHost,
)),
'before'
);
}
}
}
}
add_action('wp_enqueue_scripts', 'formbricks_enqueue_script');
// Enqueue Scripts and Styles
function formbricks_enqueue_admin_scripts($hook) {
if ('toplevel_page_formbricks-settings' !== $hook) {
return;
}
wp_enqueue_script('formbricks-admin', plugin_dir_url(__FILE__) . 'admin/js/formbricks-admin.js', array('jquery'), '1.0.1', true);
wp_add_inline_script('formbricks-admin', 'jQuery(document).ready(function ($) { setTimeout(function () { $("#formbricks-settings-saved").fadeOut("slow"); }, 5000); });');
}
add_action('admin_enqueue_scripts', 'formbricks_enqueue_admin_scripts');