mirror of
https://github.com/silverstripe/silverstripe-comments
synced 2024-10-22 09:05:49 +00:00
FIX Resolve linting issues
This commit is contained in:
parent
81902f6293
commit
0048a7abb9
@ -1,133 +1,130 @@
|
|||||||
|
/* global ss, jQuery */
|
||||||
/**
|
/**
|
||||||
* @package comments
|
* @package comments
|
||||||
*/
|
*/
|
||||||
(function($) {
|
(function ($) {
|
||||||
// The above closure encapsulates the $ variable away from the global scope
|
// The above closure encapsulates the $ variable away from the global scope
|
||||||
// and the one below is the `$(document).ready(...)` shorthand.
|
// and the one below is the `$(document).ready(...)` shorthand.
|
||||||
$(function() {
|
$(() => {
|
||||||
// Override the default URL validator in order to extend it to allow protocol-less URLs
|
// Override the default URL validator in order to extend it to allow protocol-less URLs
|
||||||
$.validator.methods.url = function( value, element ) {
|
$.validator.methods.url = function (value, element) {
|
||||||
// This line is copied directly from the jQuery.validation source (version 1.19.0)
|
// This line is copied directly from the jQuery.validation source (version 1.19.0)
|
||||||
// the only change is a single question mark added here ---------v
|
// the only change is a single question mark added here -------v
|
||||||
return this.optional( element ) || /^(?:(?:(?:https?|ftp):)?\/\/)?(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})).?)(?::\d{2,5})?(?:[/?#]\S*)?$/i.test( value );
|
// eslint-disable-next-line max-len
|
||||||
}
|
return this.optional(element) || /^(?:(?:(?:https?|ftp):)?\/\/)?(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})).?)(?::\d{2,5})?(?:[/?#]\S*)?$/i.test(value);
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enable form validation
|
* Enable form validation
|
||||||
*/
|
*/
|
||||||
$('.comments-holder-container form').each(function() {
|
$('.comments-holder-container form').each(function () {
|
||||||
$(this).validate({
|
$(this).validate({
|
||||||
|
// Ignore hidden elements in this form
|
||||||
|
ignore: ':hidden',
|
||||||
|
|
||||||
// Ignore hidden elements in this form
|
// Use default 'required' for error labels
|
||||||
ignore: ':hidden',
|
errorClass: 'required',
|
||||||
|
|
||||||
// Use default 'required' for error labels
|
// Use span instead of labels
|
||||||
errorClass: "required",
|
errorElement: 'span',
|
||||||
|
|
||||||
// Use span instead of labels
|
// On error, scroll to the invalid element
|
||||||
errorElement: "span",
|
invalidHandler(form, validator) {
|
||||||
|
$('html, body').animate({
|
||||||
|
scrollTop: $(validator.errorList[0].element).offset().top - 30
|
||||||
|
}, 200);
|
||||||
|
},
|
||||||
|
|
||||||
// On error, scroll to the invalid element
|
// Ensure any new error message has the correct class and placement
|
||||||
invalidHandler : function(form, validator){
|
errorPlacement(error, element) {
|
||||||
$('html, body').animate({
|
error
|
||||||
scrollTop: $(validator.errorList[0].element).offset().top - 30
|
.addClass('message')
|
||||||
}, 200);
|
.insertAfter(element);
|
||||||
},
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
// Ensure any new error message has the correct class and placement
|
/**
|
||||||
errorPlacement: function(error, element) {
|
* Hide comment reply forms by default (unless visiting via permalink)
|
||||||
error
|
*/
|
||||||
.addClass('message')
|
$('.comment')
|
||||||
.insertAfter(element);
|
.children('.info')
|
||||||
}
|
.not(window.document.location.hash)
|
||||||
|
.nextAll('.comment-replies-container')
|
||||||
|
.children('.comment-reply-form-holder')
|
||||||
|
.hide();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Toggle on/off reply form
|
||||||
|
*/
|
||||||
|
$('.comments-holder').on('click', '.comment-reply-link', function (e) {
|
||||||
|
const allForms = $('.comment-reply-form-holder');
|
||||||
|
const formID = `#${$(this).attr('aria-controls')}`;
|
||||||
|
const form = $(formID).closest('.comment-reply-form-holder');
|
||||||
|
|
||||||
|
$(this).attr('aria-expanded', (i, attr) => (attr === 'true' ? 'false' : 'true'));
|
||||||
|
|
||||||
|
// Prevent focus
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
if (form.is(':visible')) {
|
||||||
|
allForms.slideUp();
|
||||||
|
} else {
|
||||||
|
allForms.not(form).slideUp();
|
||||||
|
form.slideDown();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clicking one of the metalinks performs the operation via ajax
|
||||||
|
* this inclues the spam and approve links
|
||||||
|
*/
|
||||||
|
$('.comments-holder .comments-list').on('click', 'div.comment-moderation-options a', function (e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
|
||||||
|
const link = $(this);
|
||||||
|
if (link.hasClass('delete')) {
|
||||||
|
const confirmationMsg = ss.i18n._t('CommentsInterface_singlecomment_ss.DELETE_CONFIRMATION');
|
||||||
|
const confirmation = window.confirm(confirmationMsg);
|
||||||
|
if (!confirmation) {
|
||||||
|
e.preventDefault();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const comment = link.parents('.comment:first');
|
||||||
|
|
||||||
|
$.ajax({
|
||||||
|
url: $(this).attr('href'),
|
||||||
|
cache: false,
|
||||||
|
success(html) {
|
||||||
|
if (link.hasClass('ham')) {
|
||||||
|
// comment has been marked as not spam
|
||||||
|
comment.html(html);
|
||||||
|
comment.removeClass('spam');
|
||||||
|
} else if (link.hasClass('approve')) {
|
||||||
|
// comment has been approved
|
||||||
|
comment.html(html);
|
||||||
|
comment.removeClass('unmoderated');
|
||||||
|
} else if (link.hasClass('delete')) {
|
||||||
|
comment.fadeOut(1000, () => {
|
||||||
|
comment.remove();
|
||||||
|
|
||||||
|
if ($('.comments-holder .comments-list').children().length === 0) {
|
||||||
|
$('.no-comments-yet').show();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
});
|
} else if (link.hasClass('spam')) {
|
||||||
|
comment.html(html).addClass('spam');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
failure(html) {
|
||||||
|
const errorMsg = ss.i18n._t('CommentsInterface_singlecomment_ss.AJAX_ERROR');
|
||||||
|
alert(errorMsg);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
/**
|
e.preventDefault();
|
||||||
* Hide comment reply forms by default (unless visiting via permalink)
|
return false;
|
||||||
*/
|
});
|
||||||
$(".comment")
|
});
|
||||||
.children('.info')
|
}(jQuery));
|
||||||
.not(window.document.location.hash)
|
|
||||||
.nextAll(".comment-replies-container")
|
|
||||||
.children(".comment-reply-form-holder")
|
|
||||||
.hide();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Toggle on/off reply form
|
|
||||||
*/
|
|
||||||
$('.comments-holder').on('click', '.comment-reply-link', function(e) {
|
|
||||||
var allForms = $('.comment-reply-form-holder');
|
|
||||||
var formID = '#' + $(this).attr('aria-controls');
|
|
||||||
var form = $(formID).closest('.comment-reply-form-holder');
|
|
||||||
|
|
||||||
$(this).attr('aria-expanded', function (i, attr) {
|
|
||||||
return attr == 'true' ? 'false' : 'true'
|
|
||||||
});
|
|
||||||
|
|
||||||
// Prevent focus
|
|
||||||
e.preventDefault();
|
|
||||||
|
|
||||||
if(form.is(':visible')) {
|
|
||||||
allForms.slideUp();
|
|
||||||
} else {
|
|
||||||
allForms.not(form).slideUp();
|
|
||||||
form.slideDown();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Clicking one of the metalinks performs the operation via ajax
|
|
||||||
* this inclues the spam and approve links
|
|
||||||
*/
|
|
||||||
$('.comments-holder .comments-list').on('click', 'div.comment-moderation-options a', function(e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
|
|
||||||
var link = $(this);
|
|
||||||
if (link.hasClass('delete')) {
|
|
||||||
var confirmationMsg = ss.i18n._t('CommentsInterface_singlecomment_ss.DELETE_CONFIRMATION');
|
|
||||||
var confirmation = window.confirm(confirmationMsg);
|
|
||||||
if (!confirmation) {
|
|
||||||
e.preventDefault();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var comment = link.parents('.comment:first');
|
|
||||||
|
|
||||||
$.ajax({
|
|
||||||
url: $(this).attr('href'),
|
|
||||||
cache: false,
|
|
||||||
success: function(html){
|
|
||||||
if(link.hasClass('ham')) {
|
|
||||||
// comment has been marked as not spam
|
|
||||||
comment.html(html);
|
|
||||||
comment.removeClass('spam');
|
|
||||||
}
|
|
||||||
else if(link.hasClass('approve')) {
|
|
||||||
// comment has been approved
|
|
||||||
comment.html(html);
|
|
||||||
comment.removeClass('unmoderated');
|
|
||||||
}
|
|
||||||
else if(link.hasClass('delete')) {
|
|
||||||
comment.fadeOut(1000, function() {
|
|
||||||
comment.remove();
|
|
||||||
|
|
||||||
if($('.comments-holder .comments-list').children().length === 0) {
|
|
||||||
$('.no-comments-yet').show();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else if(link.hasClass('spam')) {
|
|
||||||
comment.html(html).addClass('spam');
|
|
||||||
}
|
|
||||||
},
|
|
||||||
failure: function(html) {
|
|
||||||
var errorMsg = ss.i18n._t('CommentsInterface_singlecomment_ss.AJAX_ERROR');
|
|
||||||
alert(errorMsg);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
e.preventDefault();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
})(jQuery);
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user