Vulcan/client/views/users/user_profile.js
Charlie DeTar ea7efc3550 Replace "throwError" with "flashMessage" and type
Currently, ``throwError`` is used for all manner of messages, including
errors, "success" messages, and "info" messages.  This makes appropriate
styling of the error message difficult.  In addition, the name
``throwError`` seems to create confusion, implying that an error will
actually be thrown (e.g. stopping execution when a user isn't logged in
[0][1]), when in fact it just displays a message.

Replace ``throwError`` with ``flashMessage``, and reliably include a
message "type" (e.g. "error", "success", "info") every time.  rename
``lib/errors.js`` to ``lib/messages.js`` to more accurately reflect its
function.

This commit doesn't rename the message collection (``Errors``), nor the
template responsible for rendering the messages (``error_item.html``) --
that should probably still be done, but has higher likelihood of
trouble for existing alternate themes and installations.

[0] 6ccf7d7d47/client/views/users/user_edit.js (L43)
[1] 083a4c4dc4/client/views/users/user_email.js (L13)
2014-11-05 13:12:09 -07:00

104 lines
3.7 KiB
JavaScript

Template[getTemplate('user_profile')].created = function () {
Session.set('postsShown', 5);
Session.set('upvotedPostsShown', 5);
Session.set('downvotedPostsShown', 5);
Session.set('commentsShown', 5);
};
Template[getTemplate('user_profile')].helpers({
canEditProfile: function() {
var currentUser = Meteor.user();
return currentUser && (this._id == currentUser._id || isAdmin(currentUser));
},
createdAtFormatted: function() {
return this.createdAt;
},
canInvite: function() {
// if the user is logged in, the target user hasn't been invited yet, invites are enabled, and user is not viewing their own profile
return Meteor.user() && Meteor.user()._id != this._id && !isInvited(this) && invitesEnabled() && canInvite(Meteor.user());
},
inviteCount: function() {
return Meteor.user().inviteCount;
},
getTwitterName: function () {
return getTwitterName(this);
},
getGitHubName: function () {
return getGitHubName(this);
},
posts: function () {
return Posts.find({userId: this._id}, {limit: Session.get('postsShown')});
},
hasMorePosts: function () {
return Posts.find({userId: this._id}).count() > Session.get('postsShown');
},
upvotedPosts: function () {
// extend upvotes with each upvoted post
if(!!this.votes.upvotedPosts){
var extendedVotes = this.votes.upvotedPosts.map(function (item) {
var post = Posts.findOne(item.itemId);
return _.extend(item, post);
});
return _.first(extendedVotes, Session.get('upvotedPostsShown'));
}
},
hasMoreUpvotedPosts: function () {
return !!this.votes.upvotedPosts && this.votes.upvotedPosts.length > Session.get('upvotedPostsShown');
},
downvotedPosts: function () {
// extend upvotes with each upvoted post
if(!!this.votes.downvotedPosts){
var extendedVotes = this.votes.downvotedPosts.map(function (item) {
var post = Posts.findOne(item.itemId);
return _.extend(item, post);
});
return _.first(extendedVotes, Session.get('downvotedPostsShown'));
}
},
hasMoreDownvotedPosts: function () {
return !!this.votes.downvotedPosts && this.votes.downvotedPosts.length > Session.get('downvotedPostsShown');
},
comments: function () {
var comments = Comments.find({userId: this._id}, {limit: Session.get('commentsShown')});
if(!!comments){
// extend comments with each commented post
var extendedComments = comments.map(function (comment) {
var post = Posts.findOne(comment.postId);
if(post) // post might not be available anymore
comment.postTitle = post.title;
return comment;
});
return extendedComments;
}
},
hasMoreComments: function () {
return Comments.find({userId: this._id}).count() > Session.get('commentsShown');
}
});
Template[getTemplate('user_profile')].events({
'click .invite-link': function(e, instance){
Meteor.call('inviteUser', instance.data.user._id);
flashMessage('Thanks, user has been invited.', "success");
},
'click .posts-more': function (e) {
e.preventDefault();
var postsShown = Session.get('postsShown');
Session.set('postsShown', postsShown + 10);
},
'click .upvotedposts-more': function (e) {
e.preventDefault();
var upvotedPostsShown = Session.get('upvotedPostsShown');
Session.set('upvotedPostsShown', upvotedPostsShown + 10);
},
'click .downvotedposts-more': function (e) {
e.preventDefault();
var downvotedPostsShown = Session.get('downvotedPostsShown');
Session.set('downvotedPostsShown', downvotedPostsShown + 10);
},
'click .comments-more': function (e) {
e.preventDefault();
var commentsShown = Session.get('commentsShown');
Session.set('commentsShown', commentsShown + 10);
}
});