summaryrefslogtreecommitdiffstats
path: root/apps/comments/js
diff options
context:
space:
mode:
authorVincent Petry <pvince81@owncloud.com>2016-02-04 18:20:16 +0100
committerVincent Petry <pvince81@owncloud.com>2016-02-08 10:05:03 +0100
commit78864dc6fa13c5454ba5d91a97389b3260b9ebf6 (patch)
tree84cf2903894983cca703f6b5cd3ae2253064b6a5 /apps/comments/js
parent62b5948ff5745e29d4c8739f416a6a599cb6e3b4 (diff)
downloadnextcloud-server-78864dc6fa13c5454ba5d91a97389b3260b9ebf6.tar.gz
nextcloud-server-78864dc6fa13c5454ba5d91a97389b3260b9ebf6.zip
Collapse long comments
Very crude a naive implementation that relies on length and number of newlines. Should be good enough for most cases. Clicking on such comments will expand them.
Diffstat (limited to 'apps/comments/js')
-rw-r--r--apps/comments/js/commentstabview.js29
1 files changed, 25 insertions, 4 deletions
diff --git a/apps/comments/js/commentstabview.js b/apps/comments/js/commentstabview.js
index d75cf39538c..1326d544b1a 100644
--- a/apps/comments/js/commentstabview.js
+++ b/apps/comments/js/commentstabview.js
@@ -41,7 +41,7 @@
'</div>';
var COMMENT_TEMPLATE =
- '<li class="comment{{#if isUnread}} unread{{/if}}" data-id="{{id}}">' +
+ '<li class="comment{{#if isUnread}} unread{{/if}}{{#if isLong}} collapsed{{/if}}" data-id="{{id}}">' +
' <div class="authorRow">' +
' {{#if avatarEnabled}}' +
' <div class="avatar" {{#if actorId}}data-username="{{actorId}}"{{/if}}> </div>' +
@@ -53,6 +53,9 @@
' <div class="date has-tooltip" title="{{altDate}}">{{date}}</div>' +
' </div>' +
' <div class="message">{{{formattedMessage}}}</div>' +
+ '{{#if isLong}}' +
+ ' <div class="message-overlay"></div>' +
+ '{{/if}}' +
'</li>';
/**
@@ -68,7 +71,8 @@
'click .showMore': '_onClickShowMore',
'click .action.edit': '_onClickEditComment',
'click .action.delete': '_onClickDeleteComment',
- 'click .cancel': '_onClickCloseComment'
+ 'click .cancel': '_onClickCloseComment',
+ 'click .comment': '_onClickComment'
},
_commentMaxLength: 1000,
@@ -124,7 +128,8 @@
params = _.extend({
avatarEnabled: this._avatarsEnabled,
editTooltip: t('comments', 'Edit comment'),
- isUserAuthor: OC.getCurrentUser().uid === params.actorId
+ isUserAuthor: OC.getCurrentUser().uid === params.actorId,
+ isLong: this._isLong(params.message)
}, params);
if (params.actorType === 'deleted_users') {
@@ -264,7 +269,7 @@
submitText: t('comments', 'Save')
}, commentToEdit.attributes)));
- $comment.addClass('hidden');
+ $comment.addClass('hidden').removeClass('collapsed');
// spawn form
$comment.after($formRow);
$formRow.data('commentEl', $comment);
@@ -298,6 +303,14 @@
$submitButton.prop('disabled', limitExceeded);
},
+ _onClickComment: function(ev) {
+ var $row = $(ev.target);
+ if (!$row.is('.comment')) {
+ $row = $row.closest('.comment');
+ }
+ $row.removeClass('collapsed');
+ },
+
_onClickCloseComment: function(ev) {
ev.preventDefault();
var $row = $(ev.target).closest('.comment');
@@ -406,6 +419,14 @@
}
return false;
+ },
+
+ /**
+ * Returns whether the given message is long and needs
+ * collapsing
+ */
+ _isLong: function(message) {
+ return message.length > 250 || (message.match(/\n/g) || []).length > 1;
}
});