mirror of
https://github.com/silverstripe/silverstripe-comments
synced 2024-10-22 11:05:49 +02:00
FIX: Added reply to link for non JS to avoid multiple forms. If using AJAX a hidden form is used. Fallback for JavaScript turned off in browsers
This commit is contained in:
parent
bb0de16f36
commit
ff31c296b4
@ -629,7 +629,7 @@ class CommentingController extends Controller
|
|||||||
} elseif (!$comment->Moderated) {
|
} elseif (!$comment->Moderated) {
|
||||||
// Display the "awaiting moderation" text
|
// Display the "awaiting moderation" text
|
||||||
$holder = $this->getOption('comments_holder_id');
|
$holder = $this->getOption('comments_holder_id');
|
||||||
$hash = "{$holder}_PostCommentForm_error";
|
$hash = "moderated";
|
||||||
} else {
|
} else {
|
||||||
// Link to the moderated, non-spam comment
|
// Link to the moderated, non-spam comment
|
||||||
$hash = $comment->Permalink();
|
$hash = $comment->Permalink();
|
||||||
|
@ -480,6 +480,22 @@ class CommentsExtension extends DataExtension
|
|||||||
->renderWith('CommentsInterface');
|
->renderWith('CommentsInterface');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
JavaScript form reply requires an empty form, when the reply button is
|
||||||
|
clicked the correct values are inserted, the form moved, and then shown
|
||||||
|
*/
|
||||||
|
public function getReplyFormForJavaScript() {
|
||||||
|
// Build reply controller
|
||||||
|
$controller = CommentingController::create();
|
||||||
|
$controller->setOwnerRecord($this->owner);
|
||||||
|
$controller->setBaseClass($this->owner->ClassName);
|
||||||
|
$controller->setOwnerController(Controller::curr());
|
||||||
|
$comment = new Comment();
|
||||||
|
$comment->ID='JSOnly';
|
||||||
|
$comment->ParentID = $this->owner->ID;
|
||||||
|
return $controller->ReplyForm($comment);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns whether this extension instance is attached to a {@link SiteTree} object
|
* Returns whether this extension instance is attached to a {@link SiteTree} object
|
||||||
*
|
*
|
||||||
|
@ -734,6 +734,17 @@ class Comment extends DataObject
|
|||||||
return $list;
|
return $list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Ascertains whether or not to show the reply form
|
||||||
|
*/
|
||||||
|
public function ShowReplyToForm() {
|
||||||
|
$controller = Controller::curr();
|
||||||
|
$request = $controller->getRequest();
|
||||||
|
$replyTo = $request->getVar('replyTo');
|
||||||
|
$result = $replyTo == $this->ID;
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the list of replies, with spam and unmoderated items excluded, for use in the frontend
|
* Returns the list of replies, with spam and unmoderated items excluded, for use in the frontend
|
||||||
*
|
*
|
||||||
|
@ -57,44 +57,81 @@
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
|
||||||
* Comment reply form
|
|
||||||
*/
|
|
||||||
$( ".comment-replies-container .comment-reply-form-holder" ).entwine({
|
|
||||||
onmatch: function() {
|
|
||||||
// If and only if this is not the currently selected form, hide it on page load
|
|
||||||
var selectedHash = window.document.location.hash.substr(1),
|
|
||||||
form = $(this).children('.reply-form');
|
|
||||||
if( !selectedHash || selectedHash !== form.prop( 'id' ) ) {
|
|
||||||
this.hide();
|
|
||||||
}
|
|
||||||
this._super();
|
|
||||||
},
|
|
||||||
onunmatch: function() {
|
|
||||||
this._super();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Toggle on/off reply form
|
* Toggle on/off reply form
|
||||||
*/
|
*/
|
||||||
$( ".comment-reply-link" ).entwine({
|
$( ".comment-reply-link" ).entwine({
|
||||||
onclick: function( e ) {
|
onclick: function( e ) {
|
||||||
|
// Prevent focus
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
var jqTarget = $(e.target);
|
||||||
|
var commentID = jqTarget.attr('data-comment-id');
|
||||||
|
container = $('#replyFormJS');
|
||||||
|
var state = jqTarget.attr('data-state');
|
||||||
|
|
||||||
|
// Show possibly hidden reply form, alter state so that it works
|
||||||
|
// in context of relevant comment
|
||||||
|
if (state != 'replying') {
|
||||||
|
cancelTheCancels();
|
||||||
|
toggleButtonText(jqTarget);
|
||||||
|
|
||||||
|
// hide the form if it's visible
|
||||||
|
if(container.is(':visible')) {
|
||||||
|
container.toggle();
|
||||||
|
}
|
||||||
|
|
||||||
|
var jqComment = $('#reply-form-container-' + commentID);
|
||||||
|
var form = container.find('form');
|
||||||
|
action = form.attr('action');
|
||||||
|
form.attr('action', '/CommentingController/reply/' + commentID);
|
||||||
|
var inputParemtCommentID = container.find("input[name='ParentCommentID']");
|
||||||
|
var inputComment = container.find("input[name='Comment']");
|
||||||
|
inputParemtCommentID.attr('value', commentID);
|
||||||
|
inputComment.attr('value', '');
|
||||||
|
container.detach().appendTo(jqComment);
|
||||||
|
|
||||||
var allForms = $( ".comment-reply-form-holder" ),
|
var allForms = $( ".comment-reply-form-holder" ),
|
||||||
formID = $( this ).prop('href').replace(/^[^#]*#/, '#'),
|
formID = $( this ).prop('href').replace(/^[^#]*#/, '#'),
|
||||||
form = $(formID).closest('.comment-reply-form-holder');
|
form = $(formID).closest('.comment-reply-form-holder');
|
||||||
|
|
||||||
// Prevent focus
|
// Show the form
|
||||||
e.preventDefault();
|
container.toggle();
|
||||||
if(form.is(':visible')) {
|
|
||||||
allForms.slideUp();
|
$('html, body').animate({
|
||||||
|
scrollTop: container.offset().top - 30
|
||||||
|
}, 200);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
allForms.not(form).slideUp();
|
// Cancel reply, hide form, change button text
|
||||||
form.slideDown();
|
toggleButtonText(jqTarget);
|
||||||
|
container.slideUp();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Revert buttons in a state of replying to that of cancelled, changing
|
||||||
|
* text back to 'Reply to <person>'
|
||||||
|
*/
|
||||||
|
function toggleButtonText(node) {
|
||||||
|
var state = node.attr('data-state');
|
||||||
|
if (state != 'replying') {
|
||||||
|
node.html(ss.i18n._t('CommentsInterface_singlecomment_ss.CANCEL_REPLY'));
|
||||||
|
node.attr('data-state', 'replying');
|
||||||
|
} else {
|
||||||
|
node.html(ss.i18n._t('CommentsInterface_singlecomment_ss.REPLY_TO'));
|
||||||
|
node.attr('data-state', 'cancelled');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function cancelTheCancels() {
|
||||||
|
var toFix = $("a[data-state='replying']");
|
||||||
|
toFix.each(function(index) {
|
||||||
|
var jqTarget = $(this);
|
||||||
|
toggleButtonText(jqTarget);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Preview comment by fetching it from the server via ajax.
|
* Preview comment by fetching it from the server via ajax.
|
||||||
@ -212,5 +249,3 @@
|
|||||||
});*/
|
});*/
|
||||||
});
|
});
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
|
||||||
|
|
||||||
|
@ -6,5 +6,7 @@ if (typeof(ss) == 'undefined' || typeof(ss.i18n) == 'undefined') {
|
|||||||
ss.i18n.addDictionary('en', {
|
ss.i18n.addDictionary('en', {
|
||||||
"CommentsInterface_singlecomment_ss.DELETE_CONFIRMATION": "Are you sure?",
|
"CommentsInterface_singlecomment_ss.DELETE_CONFIRMATION": "Are you sure?",
|
||||||
"CommentsInterface_singlecomment_ss.AJAX_ERROR": "An error occurred whilst updating the comment",
|
"CommentsInterface_singlecomment_ss.AJAX_ERROR": "An error occurred whilst updating the comment",
|
||||||
|
"CommentsInterface_singlecomment_ss.REPLY_TO" : "Reply to",
|
||||||
|
"CommentsInterface_singlecomment_ss.CANCEL_REPLY" : "Cancel Reply",
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -61,6 +61,8 @@ en:
|
|||||||
ISSPAM: 'spam it'
|
ISSPAM: 'spam it'
|
||||||
PBY: 'Posted by'
|
PBY: 'Posted by'
|
||||||
REMCOM: 'reject it'
|
REMCOM: 'reject it'
|
||||||
|
REPLY_TO: 'Reply to'
|
||||||
|
CANCEL_REPLY: 'Cancel Reply'
|
||||||
CommentsInterface_ss:
|
CommentsInterface_ss:
|
||||||
AWAITINGMODERATION: 'Your comment has been submitted and is now awaiting moderation.'
|
AWAITINGMODERATION: 'Your comment has been submitted and is now awaiting moderation.'
|
||||||
COMMENTLOGINERROR: 'You cannot post comments until you have logged in'
|
COMMENTLOGINERROR: 'You cannot post comments until you have logged in'
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
<% if $RepliesEnabled %>
|
<% if $RepliesEnabled %>
|
||||||
<div class="comment-replies-container">
|
<div class="comment-replies-container">
|
||||||
|
|
||||||
<div class="comment-reply-form-holder">
|
<div class="comment-reply-form-holder">
|
||||||
$ReplyForm
|
<%-- non ajax, only show if replyTo is set --%>
|
||||||
|
<% if $ShowReplyToForm %>$ReplyForm<% end_if %>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="comment-replies-holder">
|
<div class="comment-replies-holder">
|
||||||
|
@ -51,3 +51,5 @@
|
|||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
|
<%-- include a hidden form for JS use when replying --%>
|
||||||
|
<div id="replyFormJS" style="display:none;">$ReplyFormForJavaScript</div>
|
||||||
|
@ -33,10 +33,12 @@
|
|||||||
<% end_if %>
|
<% end_if %>
|
||||||
</div>
|
</div>
|
||||||
<% if $RepliesEnabled %>
|
<% if $RepliesEnabled %>
|
||||||
<a class="comment-reply-link" href="#{$ReplyForm.FormName}">Reply to $AuthorName.XML</a>
|
<a data-comment-id="$ID" class="comment-reply-link" href="$Parent.Link?replyTo=$ID#Form_ReplyForm_$ID"><% _t('CommentsInterface_singlecomment_ss.REPLY_TO','Reply to') %> $AuthorName.XML</a>
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
</div>
|
</div>
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
|
|
||||||
|
<div class="comment-replies-container" id="reply-form-container-$ID"></div>
|
||||||
|
|
||||||
<% include CommentReplies %>
|
<% include CommentReplies %>
|
||||||
<% end_if %>
|
<% end_if %>
|
||||||
|
Loading…
Reference in New Issue
Block a user