-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathwordpress-oauth.js
502 lines (454 loc) · 20.7 KB
/
wordpress-oauth.js
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
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
// after the document has loaded, we hook up our events and initialize any other js functionality:
jQuery(document).ready(function() {
wpoa.init();
});
// namespace the wpoa functions to prevent global conflicts, using the 'immediately invoked function expression' pattern:
;(function ( wpoa, undefined ) {
// <private properties>
var wp_media_dialog_field; // field to populate after the admin selects an image using the wordpress media dialog
var timeout_interval;
var timeout_idle_time = 0;
var timeout_warning_reached = false;
// <public methods and properties>
// init the client-side wpoa functionality:
wpoa.init = function() {
// store the client's GMT offset (timezone) for converting server time into local time on a per-client basis (this makes the time at which a provider was linked more accurate to the specific user):
d = new Date;
gmtoffset = d.getTimezoneOffset() / 60;
document.cookie = 'gmtoffset=' + gmtoffset;
// START of Settings Page functionality
// handle accordion sections:
jQuery(".wpoa-settings h3").click(function(e) {
jQuery(this).parent().find(".form-padding").slideToggle();
});
// handle help tip buttons:
jQuery(".tip-button").click(function(e) {
e.preventDefault();
jQuery(this).parents(".has-tip").find(".tip-message").fadeToggle();
});
// automatically show warning tips when the user enters a sensitive form field:
jQuery(".wpoa-settings input, .wpoa-settings select").focus(function(e) {
e.preventDefault();
var tip_warning = jQuery(this).parents(".has-tip").find(".tip-warning, .tip-info");
//var tip_info = jQuery(this).parents("tr").find(".tip-info");
if (tip_warning.length > 0) {
tip_warning.fadeIn();
jQuery(this).parents(".has-tip").find(".tip-message").fadeIn();
}
});
// handle global togglers:
jQuery("#wpoa-settings-sections-on").click(function(e) {
e.preventDefault();
jQuery(".wpoa-settings h3").parent().find(".form-padding").slideDown();
});
jQuery("#wpoa-settings-sections-off").click(function(e) {
e.preventDefault();
jQuery(".wpoa-settings h3").parent().find(".form-padding").slideUp();
});
jQuery("#wpoa-settings-tips-on").click(function(e) {
e.preventDefault();
jQuery(".tip-message").fadeIn();
});
jQuery("#wpoa-settings-tips-off").click(function(e) {
e.preventDefault();
jQuery(".tip-message").fadeOut();
});
// START of login form designer features
// handle login form design select box:
/*
jQuery("[name=wpoa_login_form_design]").change(function() {
var design_name = jQuery("#wpoa-login-form-design :selected").text();
var designs = jQuery("[name=wpoa_login_form_designs]").val();
var designs = JSON.parse(designs);
var design = designs[design_name];
if (design) {
jQuery("[name=wpoa_login_form_design_name]").val(design_name);
jQuery("[name=wpoa_login_form_icon_set]").val(design.icon_set);
jQuery("[name=wpoa_login_form_button_prefix]").val(design.button_prefix);
jQuery("[name=wpoa_login_form_logged_out_title]").val(design.logged_out_title);
jQuery("[name=wpoa_login_form_logged_in_title]").val(design.logged_in_title);
jQuery("[name=wpoa_login_form_logging_in_title]").val(design.logging_in_title);
jQuery("[name=wpoa_login_form_logging_out_title]").val(design.logging_out_title);
}
});
jQuery("[name=wpoa_login_form_design]").change(); // fire this once to populate the sub-form
*/
// new design button:
jQuery("#wpoa-login-form-new").click(function(e) {
// show the edit design sub-section and hide the design selector:
jQuery("#wpoa-login-form-design").parents("tr").hide();
jQuery("#wpoa-login-form-design-form").addClass('new-design');
jQuery("#wpoa-login-form-design-form input").not(":button").val(''); // clears the form field values
jQuery("#wpoa-login-form-design-form h4").text('New Design');
jQuery("#wpoa-login-form-design-form").show();
});
// edit design button:
jQuery("#wpoa-login-form-edit").click(function(e) {
var design_name = jQuery("#wpoa-login-form-design :selected").text();
var designs = jQuery("[name=wpoa_login_form_designs]").val();
var designs = JSON.parse(designs);
var design = designs[design_name];
if (design) {
// pull the design into the form fields for editing
// TODO: don't hard code these, we want to add new fields in the future without having to update this function...
jQuery("[name=wpoa_login_form_design_name]").val(design_name);
jQuery("[name=wpoa_login_form_icon_set]").val(design.icon_set);
jQuery("[name=wpoa_login_form_show_login]").val(design.show_login);
jQuery("[name=wpoa_login_form_show_logout]").val(design.show_logout);
jQuery("[name=wpoa_login_form_layout]").val(design.layout);
jQuery("[name=wpoa_login_form_button_prefix]").val(design.button_prefix);
jQuery("[name=wpoa_login_form_logged_out_title]").val(design.logged_out_title);
jQuery("[name=wpoa_login_form_logged_in_title]").val(design.logged_in_title);
jQuery("[name=wpoa_login_form_logging_in_title]").val(design.logging_in_title);
jQuery("[name=wpoa_login_form_logging_out_title]").val(design.logging_out_title);
// show the edit design sub-section and hide the design selector:
jQuery("#wpoa-login-form-design").parents("tr").hide();
jQuery("#wpoa-login-form-design-form").removeClass('new-design');
jQuery("#wpoa-login-form-design-form h4").text('Edit Design');
jQuery("#wpoa-login-form-design-form").show();
}
});
// delete design button:
jQuery("#wpoa-login-form-delete").click(function(e) {
// get the designs:
var designs = jQuery("[name=wpoa_login_form_designs]").val();
var designs = JSON.parse(designs);
// get the old design name (the design we'll be deleting)
var old_design_name = jQuery("#wpoa-login-form-design :selected").text();
jQuery("#wpoa-login-form-design option:contains('" + old_design_name + "')").remove();
delete designs[old_design_name];
// update the designs array for POST:
jQuery("[name=wpoa_login_form_designs]").val(JSON.stringify(designs));
});
// edit design ok button:
jQuery("#wpoa-login-form-ok").click(function(e) {
// applies changes to the current design by updating the designs array stored as JSON in a hidden form field...
// get the design name being proposed
var new_design_name = jQuery("[name=wpoa_login_form_design_name]").val();
// remove any validation error from a previous failed attempt:
jQuery("#wpoa-login-form-design-form .validation-warning").remove();
// make sure the design name is not empty:
if (!jQuery("#wpoa-login-form-design-name").val()) {
var validation_warning = "<p id='validation-warning' class='validation-warning'>Design name cannot be empty.</span>";
jQuery("#wpoa-login-form-design-name").parent().append(validation_warning);
return;
}
// this is either a NEW design or MODIFIED design, handle accordingly:
if (jQuery("#wpoa-login-form-design-form").hasClass('new-design')) {
// NEW DESIGN, add it...
// make sure the design name doesn't already exist:
if (jQuery("#wpoa-login-form-design option").text().indexOf(new_design_name) != -1) {
// design name already exists, notify the user and abort:
var validation_warning = "<p id='validation-warning' class='validation-warning'>Design name already exists! Please choose a different name.</span>";
jQuery("#wpoa-login-form-design-name").parent().append(validation_warning);
return;
}
else {
// get the designs array which contains all of our designs:
var designs = jQuery("[name=wpoa_login_form_designs]").val();
var designs = JSON.parse(designs);
// add a design to the designs array:
// TODO: don't hard code these, we want to add new fields in the future without having to update this function...
designs[new_design_name] = {};
designs[new_design_name].icon_set = jQuery("[name=wpoa_login_form_icon_set]").val();
designs[new_design_name].show_login = jQuery("[name=wpoa_login_form_show_login]").val();
designs[new_design_name].show_logout = jQuery("[name=wpoa_login_form_show_logout]").val();
designs[new_design_name].layout = jQuery("[name=wpoa_login_form_layout]").val();
designs[new_design_name].button_prefix = jQuery("[name=wpoa_login_form_button_prefix]").val();
designs[new_design_name].logged_out_title = jQuery("[name=wpoa_login_form_logged_out_title]").val();
designs[new_design_name].logged_in_title = jQuery("[name=wpoa_login_form_logged_in_title]").val();
designs[new_design_name].logging_in_title = jQuery("[name=wpoa_login_form_logging_in_title]").val();
designs[new_design_name].logging_out_title = jQuery("[name=wpoa_login_form_logging_out_title]").val();
// update the select box to include this new design:
jQuery("#wpoa-login-form-design").append(jQuery("<option></option>").text(new_design_name).attr("selected", "selected"));
// select the design in the selector:
//jQuery("#wpoa-login-form-design :selected").text(new_design_name);
// update the designs array for POST:
jQuery("[name=wpoa_login_form_designs]").val(JSON.stringify(designs));
// hide the design editor and show the select box:
jQuery("#wpoa-login-form-design").parents("tr").show();
jQuery("#wpoa-login-form-design-form").hide();
}
}
else {
// MODIFIED DESIGN, add it and remove the old one...
// get the designs array which contains all of our designs:
var designs = jQuery("[name=wpoa_login_form_designs]").val();
var designs = JSON.parse(designs);
// remove the old design:
var old_design_name = jQuery("#wpoa-login-form-design :selected").text();
jQuery("#wpoa-login-form-design option:contains('" + old_design_name + "')").remove();
delete designs[old_design_name];
// add the modified design:
// TODO: don't hard code these, we want to add new fields in the future without having to update this function...
designs[new_design_name] = {};
designs[new_design_name].icon_set = jQuery("[name=wpoa_login_form_icon_set]").val();
designs[new_design_name].show_login = jQuery("[name=wpoa_login_form_show_login]").val();
designs[new_design_name].show_logout = jQuery("[name=wpoa_login_form_show_logout]").val();
designs[new_design_name].layout = jQuery("[name=wpoa_login_form_layout]").val();
designs[new_design_name].button_prefix = jQuery("[name=wpoa_login_form_button_prefix]").val();
designs[new_design_name].logged_out_title = jQuery("[name=wpoa_login_form_logged_out_title]").val();
designs[new_design_name].logged_in_title = jQuery("[name=wpoa_login_form_logged_in_title]").val();
designs[new_design_name].logging_in_title = jQuery("[name=wpoa_login_form_logging_in_title]").val();
designs[new_design_name].logging_out_title = jQuery("[name=wpoa_login_form_logging_out_title]").val();
// update the select box to include this new design:
jQuery("#wpoa-login-form-design").append(jQuery("<option></option>").text(new_design_name).attr("selected", "selected"));
// select the design in the selector:
//jQuery("#wpoa-login-form-design :selected").text(new_design_name);
//jQuery("#wpoa-login-form-design option:contains('" + new_design_name + "')").attr("selected", "selected");
// update the designs array for POST:
jQuery("[name=wpoa_login_form_designs]").val(JSON.stringify(designs));
// hide the design editor and show the design selector:
jQuery("#wpoa-login-form-design").parents("tr").show();
jQuery("#wpoa-login-form-design-form").hide();
}
});
// cancels the changes to the current design
jQuery("#wpoa-login-form-cancel").click(function(e) {
jQuery("#wpoa-login-form-design").parents("tr").show();
jQuery("#wpoa-login-form-design-form").hide();
});
// END of login form designer features
// login redirect sub-settings:
jQuery("[name=wpoa_login_redirect]").change(function() {
jQuery("[name=wpoa_login_redirect_url]").hide();
jQuery("[name=wpoa_login_redirect_page]").hide();
var val = jQuery(this).val();
if (val == "specific_page") {
jQuery("[name=wpoa_login_redirect_page]").show();
}
else if (val == "custom_url") {
jQuery("[name=wpoa_login_redirect_url]").show();
}
});
// logout redirect sub-settings:
jQuery("[name=wpoa_login_redirect]").change();
jQuery("[name=wpoa_logout_redirect]").change(function() {
jQuery("[name=wpoa_logout_redirect_url]").hide();
jQuery("[name=wpoa_logout_redirect_page]").hide();
var val = jQuery(this).val();
if (val == "specific_page") {
jQuery("[name=wpoa_logout_redirect_page]").show();
}
else if (val == "custom_url") {
jQuery("[name=wpoa_logout_redirect_url]").show();
}
});
jQuery("[name=wpoa_logout_redirect]").change();
// show the wordpress media dialog for selecting a logo image:
jQuery('#wpoa_logo_image_button').click(function(e) {
e.preventDefault();
wp_media_dialog_field = jQuery('#wpoa_logo_image');
wpoa.selectMedia();
});
// show the wordpress media dialog for selecting a bg image:
jQuery('#wpoa_bg_image_button').click(function(e) {
e.preventDefault();
wp_media_dialog_field = jQuery('#wpoa_bg_image');
wpoa.selectMedia();
});
jQuery("#wpoa-paypal-button").hover(
function() {
jQuery("#wpoa-heart").css("opacity", "1");
},
function() {
jQuery("#wpoa-heart").css("opacity", "0");
});
// END of Settings Page functionality
// START of Profile Page functionality
// attach unlink button click events:
jQuery(".wpoa-unlink-account").click(function(event) {
event.preventDefault();
var btn = jQuery(this);
var wpoa_identity_row = btn.data("wpoa-identity-row");
//jQuery(this).replaceWith("<span>Please wait...</span>");
btn.hide();
btn.after("<span> Please wait...</span>");
var post_data = {
action: "wpoa_unlink_account",
wpoa_identity_row: wpoa_identity_row,
}
jQuery.ajax({
type: "POST",
url: wpoa_cvars.ajaxurl,
data: post_data,
success: function(json_response) {
var oresponse = JSON.parse(json_response);
if (oresponse["result"] == 1) {
btn.parent().fadeOut(1000, function() {
btn.parent().remove();
});
}
}
});
});
// END Profile Page functionality
// START Login Form functionality
// handle login button click:
jQuery(".wpoa-login-button").click(function(event) {
event.preventDefault();
window.location = jQuery(this).attr("href");
// fade out the WordPress login form:
jQuery("#login #loginform").fadeOut(); // the WordPress username/password form.
jQuery("#login #nav").fadeOut(); // the WordPress "Forgot my password" link.
jQuery("#login #backtoblog").fadeOut(); // the WordPress "<- Back to blog" link.
jQuery(".message").fadeOut(); // the WordPress messages (e.g. "You are now logged out.").
// toggle the loading style:
jQuery(".wpoa-login-form .wpoa-login-button").not(this).addClass("loading-other");
jQuery(".wpoa-login-form .wpoa-logout-button").addClass("loading-other");
jQuery(this).addClass("loading");
var logging_in_title = jQuery(this).parents(".wpoa-login-form").data("logging-in-title");
jQuery(".wpoa-login-form #wpoa-title").text(logging_in_title);
//return false;
});
//handle logout button click:
jQuery(".wpoa-logout-button").click(function(event) {
// fade out the login form:
jQuery("#login #loginform").fadeOut();
jQuery("#login #nav").fadeOut();
jQuery("#login #backtoblog").fadeOut();
// toggle the loading style:
jQuery(this).addClass("loading");
jQuery(".wpoa-login-form .wpoa-logout-button").not(this).addClass("loading-other");
jQuery(".wpoa-login-form .wpoa-login-button").addClass("loading-other");
var logging_out_title = jQuery(this).parents(".wpoa-login-form").data("logging-out-title");
jQuery(".wpoa-login-form #wpoa-title").text(logging_out_title);
//return false;
});
// show or log the client's login result which includes success or error messages:
var msg = jQuery("#wpoa-result").html();
//var msg = wpoa_cvars.login_message; // TODO: this method doesn't work that well since we don't clear the session variable at the server...
if (msg) {
if (wpoa_cvars.show_login_messages) {
// notify the client of the login result with a visible, short-lived message at the top of the screen:
wpoa.notify(msg);
}
else {
// log the message to the dev console; useful for client support, troubleshooting and debugging if the admin has turned off the visible messages:
console.log(msg);
}
}
// create the login session timeout if the admin enabled this setting:
if (wpoa_cvars.logged_in === '1' && wpoa_cvars.logout_inactive_users !== '0') {
// bind mousemove, keypress events to reset the timeout:
jQuery(document).mousemove(function(e) {
timeout_idle_time = 0;
});
jQuery(document).keypress(function(e) {
timeout_idle_time = 0;
});
// start a timer to keep track of each minute that passes:
timeout_interval = setInterval(wpoa.timeoutIncrement, 60000);
}
// END of Login Form functionality
// START of Login Screen customizations
// hide the login form if the admin enabled this setting:
// TODO: consider .remove() as well...maybe too intrusive though...and remember that bots don't use javascript so this won't remove it for bots and those bots can still spam the login form...
if (wpoa_cvars.hide_login_form == 1) {
jQuery("#login #loginform").hide();
jQuery("#login #nav").hide();
jQuery("#login #backtoblog").hide();
}
// show custom logo and bg if the admin enabled this setting:
if (document.URL.indexOf("wp-login") >= 0) {
if (wpoa_cvars.logo_image) {
jQuery(".login h1 a").css("background-image", "url(" + wpoa_cvars.logo_image + ")");
}
if (wpoa_cvars.bg_image) {
jQuery("body").css("background-image", "url(" + wpoa_cvars.bg_image + ")");
jQuery("body").css("background-size", "cover");
}
}
// END of Login Screen customizations
} // END of wpoa.init()
// handle idle timeout:
wpoa.timeoutIncrement = function() {
var duration = wpoa_cvars.logout_inactive_users;
if (timeout_idle_time == duration - 1) {
// warning reached, next time we logout:
timeout_idle_time += 1;
wpoa.notify('Your session will expire in 1 minute due to inactivity.');
}
else if (timeout_idle_time == duration) {
// idle duration reached, logout the user:
wpoa.notify('Logging out due to inactivity...');
wpoa.processLogout();
}
/*
else {
// increment the idle time:
timeout_idle_time += 1;
console.log('Timeout incremented to ' + timeout_idle_time);
}
*/
}
// shows the associated tip message for a setting:
wpoa.showTip = function(id) {
jQuery(id).parents("tr").find(".tip-message").fadeIn();
}
// shows the default wordpress media dialog for selecting or uploading an image:
wpoa.selectMedia = function() {
var custom_uploader;
if (custom_uploader) {
custom_uploader.open();
return;
}
custom_uploader = wp.media.frames.file_frame = wp.media({
title: 'Choose Image',
button: {
text: 'Choose Image'
},
multiple: false
});
custom_uploader.on('select', function() {
attachment = custom_uploader.state().get('selection').first().toJSON();
wp_media_dialog_field.val(attachment.url);
});
custom_uploader.open();
}
// displays a short-lived notification message at the top of the screen:
wpoa.notify = function(msg) {
jQuery(".wpoa-login-message").remove();
var h = "";
h += "<div class='wpoa-login-message'><span>" + msg + "</span></div>";
jQuery("body").prepend(h);
jQuery(".wpoa-login-message").fadeOut(5000);
}
// this was going to be introduced for the login form design editor, but it was determined that having multiple lightboxes (e.g. edit design -> lightbox -> choose media -> another lightbox) is counter-productive to UX, but this could be used later for other things...
wpoa.dialog = function(msg) {
/*
// create a lightbox
jQuery("body").prepend("<div id='wpoa-lightbox' class='wpoa-settings wpoa-settings-section'></div>");
jQuery("#wpoa-lightbox").click(function(e) {
jQuery("#wpoa-lightbox").fadeOut();
jQuery("body").removeClass("wpoa-lightbox-visible");
});
// embed designer form into the lightbox
jQuery("#wpoa-login-form-design-form").appendTo("#wpoa-lightbox");
jQuery("#wpoa-login-form-design-form").show();
// show the lightbox
jQuery("#wpoa-lightbox").fadeIn();
jQuery("body").addClass("wpoa-lightbox-visible");
*/
}
// logout:
wpoa.processLogout = function(callback) {
var data = {
'action': 'wpoa_logout',
};
jQuery.ajax({
url: wpoa_cvars.ajaxurl,
data: data,
success: function(json) {
window.location = wpoa_cvars.url + "/";
}
});
}
// <private methods>
/* e.g.
function say(msg) {
console.log(msg);
};
*/
// check to evaluate whether 'wpoa' exists in the global namespace - if not, assign window.wpoa an object literal:
})(window.wpoa = window.wpoa || {});