mirror of
https://github.com/silverstripe/silverstripe-cms
synced 2024-10-22 06:05:56 +00:00
Improved spam protection question updating. Now refreshes immediately after posting the form, no matter if you get it right or wrong. More consistent notification if you get the question wrong (same box used as other notifications).
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/cms/trunk@39982 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
c0f872b8fe
commit
8c8d1986e0
@ -26,6 +26,12 @@ PageCommentInterface.prototype = {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
loadSpamQuestion: function(response) {
|
||||||
|
var spamQuestionDiv = $('Math');
|
||||||
|
var mathLabel = spamQuestionDiv.getElementsByTagName('label')[0];
|
||||||
|
mathLabel.innerHTML = response.responseText;
|
||||||
|
},
|
||||||
|
|
||||||
postComment: function() {
|
postComment: function() {
|
||||||
var form = $("PageCommentInterface_Form_PageCommentsPostCommentForm");
|
var form = $("PageCommentInterface_Form_PageCommentsPostCommentForm");
|
||||||
var message = $("PageCommentInterface_Form_PageCommentsPostCommentForm_error");
|
var message = $("PageCommentInterface_Form_PageCommentsPostCommentForm_error");
|
||||||
@ -44,28 +50,57 @@ PageCommentInterface.prototype = {
|
|||||||
var pageComments = $('PageComments').getElementsByTagName('li');
|
var pageComments = $('PageComments').getElementsByTagName('li');
|
||||||
var __newComment = document.createElement('li');
|
var __newComment = document.createElement('li');
|
||||||
|
|
||||||
// Add it to the list with a 'loading' message
|
|
||||||
|
// Add it to the list with a 'loading' message
|
||||||
$('PageComments').insertBefore(__newComment, pageComments[0]);
|
$('PageComments').insertBefore(__newComment, pageComments[0]);
|
||||||
__newComment.innerHTML = '<p><img src="cms/images/network-save.gif" /> Loading...</p>';
|
__newComment.innerHTML = '<p><img src="cms/images/network-save.gif" /> Loading...</p>';
|
||||||
|
__newComment.className ="even";
|
||||||
|
|
||||||
// Submit the form via ajax
|
// Submit the form via ajax
|
||||||
Ajax.SubmitForm(form, "action_postcomment", {
|
Ajax.SubmitForm(form, "action_postcomment", {
|
||||||
onSuccess : function(response) {
|
onSuccess : function(response) {
|
||||||
// Load the response into the new <li>
|
|
||||||
__newComment.innerHTML = response.responseText;
|
|
||||||
Behaviour.apply(__newComment);
|
|
||||||
|
|
||||||
// Flash it using Scriptaculous
|
// Create an Ajax request to regenerate the spam protection question
|
||||||
new Effect.Highlight(__newComment, { endcolor: '#e9e9e9' } );
|
//need to check if there is actually a spam question to change first
|
||||||
if(response.responseText.match('<b>Spam detected!!</b>')) {
|
if(form.elements.Math){
|
||||||
__newComment.className = 'spam';
|
new Ajax.Request(document.getElementsByTagName('base')[0].href+'PageCommentInterface_Controller/newspamquestion', {
|
||||||
|
onSuccess: loadSpamQuestion,
|
||||||
|
onFailure: Ajax.Evaluator
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if(response.responseText != "spamprotectionfalied"){
|
||||||
|
|
||||||
|
// Load the response into the new <li>
|
||||||
|
__newComment.innerHTML = response.responseText;
|
||||||
|
Behaviour.apply(__newComment);
|
||||||
|
|
||||||
|
// Flash it using Scriptaculous
|
||||||
|
new Effect.Highlight(__newComment, { endcolor: '#e9e9e9' } );
|
||||||
|
if(response.responseText.match('<b>Spam detected!!</b>')) {
|
||||||
|
__newComment.className = 'spam';
|
||||||
|
}
|
||||||
|
|
||||||
|
}else{
|
||||||
|
__newComment.innerHTML = "";
|
||||||
|
Behaviour.apply(__newComment);
|
||||||
|
message.style.display = '';
|
||||||
|
message.innerHTML = "You got the spam question wrong.";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
},
|
||||||
|
onFailure : function(response) {
|
||||||
|
alert(response.responseText);
|
||||||
}
|
}
|
||||||
},
|
|
||||||
onFailure : function(response) {
|
|
||||||
alert(response.responseText);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Clear the fields
|
// Clear the fields
|
||||||
|
|
||||||
// form.elements.Name.value = "";
|
// form.elements.Name.value = "";
|
||||||
@ -214,3 +249,8 @@ PageCommentInterface.prototype = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
PageCommentInterface.applyTo("#PageComments_holder");
|
PageCommentInterface.applyTo("#PageComments_holder");
|
||||||
|
function loadSpamQuestion(response) {
|
||||||
|
var spamQuestionDiv = $('Math');
|
||||||
|
var mathLabel = spamQuestionDiv.getElementsByTagName('label')[0];
|
||||||
|
mathLabel.innerHTML = response.responseText;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user