FIX: Actions summary expanding was broken
This commit is contained in:
parent
2bec7253e9
commit
9cb928e893
|
@ -10,20 +10,20 @@ export default Em.Component.extend(StringBuffer, {
|
||||||
rerenderTriggers: ['actionsHistory.@each', 'actionsHistory.users.length', 'post.deleted'],
|
rerenderTriggers: ['actionsHistory.@each', 'actionsHistory.users.length', 'post.deleted'],
|
||||||
|
|
||||||
// This was creating way too many bound ifs and subviews in the handlebars version.
|
// This was creating way too many bound ifs and subviews in the handlebars version.
|
||||||
renderString: function(buffer) {
|
renderString(buffer) {
|
||||||
if (!this.get('emptyHistory')) {
|
if (!this.get('emptyHistory')) {
|
||||||
this.get('actionsHistory').forEach(function(c) {
|
this.get('actionsHistory').forEach(function(c) {
|
||||||
buffer.push("<div class='post-action'>");
|
buffer.push("<div class='post-action'>");
|
||||||
|
|
||||||
var renderActionIf = function(property, dataAttribute, text) {
|
const renderActionIf = function(property, dataAttribute, text) {
|
||||||
if (!c.get(property)) { return; }
|
if (!c.get(property)) { return; }
|
||||||
buffer.push(" <span class='action-link " + dataAttribute +"-action'><a href='#' data-" + dataAttribute + "='" + c.get('id') + "'>" + text + "</a>.</span>");
|
buffer.push(" <span class='action-link " + dataAttribute +"-action'><a href='#' data-" + dataAttribute + "='" + c.get('id') + "'>" + text + "</a>.</span>");
|
||||||
};
|
};
|
||||||
|
|
||||||
// TODO multi line expansion for flags
|
// TODO multi line expansion for flags
|
||||||
var iconsHtml = "";
|
let iconsHtml = "";
|
||||||
if (c.get('usersExpanded')) {
|
if (c.get('usersExpanded')) {
|
||||||
var postUrl;
|
let postUrl;
|
||||||
c.get('users').forEach(function(u) {
|
c.get('users').forEach(function(u) {
|
||||||
iconsHtml += "<a href=\"" + Discourse.getURL("/users/") + u.get('username_lower') + "\" data-user-card=\"" + u.get('username_lower') + "\">";
|
iconsHtml += "<a href=\"" + Discourse.getURL("/users/") + u.get('username_lower') + "\" data-user-card=\"" + u.get('username_lower') + "\">";
|
||||||
if (u.post_url) {
|
if (u.post_url) {
|
||||||
|
@ -37,7 +37,7 @@ export default Em.Component.extend(StringBuffer, {
|
||||||
iconsHtml += "</a>";
|
iconsHtml += "</a>";
|
||||||
});
|
});
|
||||||
|
|
||||||
var key = 'post.actions.people.' + c.get('actionType.name_key');
|
let key = 'post.actions.people.' + c.get('actionType.name_key');
|
||||||
if (postUrl) { key = key + "_with_url"; }
|
if (postUrl) { key = key + "_with_url"; }
|
||||||
|
|
||||||
// TODO postUrl might be uninitialized? pick a good default
|
// TODO postUrl might be uninitialized? pick a good default
|
||||||
|
@ -52,7 +52,7 @@ export default Em.Component.extend(StringBuffer, {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var post = this.get('post');
|
const post = this.get('post');
|
||||||
if (post.get('deleted')) {
|
if (post.get('deleted')) {
|
||||||
buffer.push("<div class='post-action'>" +
|
buffer.push("<div class='post-action'>" +
|
||||||
"<i class='fa fa-trash-o'></i> " +
|
"<i class='fa fa-trash-o'></i> " +
|
||||||
|
@ -62,32 +62,34 @@ export default Em.Component.extend(StringBuffer, {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
actionTypeById: function(actionTypeId) {
|
actionTypeById(actionTypeId) {
|
||||||
return this.get('actionsHistory').findProperty('id', actionTypeId);
|
return this.get('actionsHistory').findProperty('id', actionTypeId);
|
||||||
},
|
},
|
||||||
|
|
||||||
click: function(e) {
|
click(e) {
|
||||||
var $target = $(e.target),
|
const $target = $(e.target);
|
||||||
actionTypeId;
|
let actionTypeId;
|
||||||
|
|
||||||
|
const post = this.get('post');
|
||||||
|
|
||||||
if (actionTypeId = $target.data('defer-flags')) {
|
if (actionTypeId = $target.data('defer-flags')) {
|
||||||
this.actionTypeById(actionTypeId).deferFlags();
|
this.actionTypeById(actionTypeId).deferFlags(post);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// User wants to know who actioned it
|
// User wants to know who actioned it
|
||||||
if (actionTypeId = $target.data('who-acted')) {
|
if (actionTypeId = $target.data('who-acted')) {
|
||||||
this.actionTypeById(actionTypeId).loadUsers();
|
this.actionTypeById(actionTypeId).loadUsers(post);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (actionTypeId = $target.data('act')) {
|
if (actionTypeId = $target.data('act')) {
|
||||||
this.get('actionsHistory').findProperty('id', actionTypeId).act();
|
this.get('actionsHistory').findProperty('id', actionTypeId).act(post);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (actionTypeId = $target.data('undo')) {
|
if (actionTypeId = $target.data('undo')) {
|
||||||
this.get('actionsHistory').findProperty('id', actionTypeId).undo();
|
this.get('actionsHistory').findProperty('id', actionTypeId).undo(post);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -81,7 +81,8 @@ export default ObjectController.extend(ModalFunctionality, {
|
||||||
if (opts) params = $.extend(params, opts);
|
if (opts) params = $.extend(params, opts);
|
||||||
|
|
||||||
this.send('hideModal');
|
this.send('hideModal');
|
||||||
postAction.act(params).then(function() {
|
|
||||||
|
postAction.act(this.get('model'), params).then(function() {
|
||||||
self.send('closeModal');
|
self.send('closeModal');
|
||||||
}, function(errors) {
|
}, function(errors) {
|
||||||
self.send('closeModal');
|
self.send('closeModal');
|
||||||
|
|
|
@ -150,7 +150,7 @@ export default ObjectController.extend(Discourse.SelectedPostsCount, BufferedCon
|
||||||
toggleLike(post) {
|
toggleLike(post) {
|
||||||
const likeAction = post.get('actionByName.like');
|
const likeAction = post.get('actionByName.like');
|
||||||
if (likeAction && likeAction.get('canToggle')) {
|
if (likeAction && likeAction.get('canToggle')) {
|
||||||
likeAction.toggle();
|
likeAction.toggle(post);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,3 @@
|
||||||
/**
|
|
||||||
A data model for summarizing actions a user has taken, for example liking a post.
|
|
||||||
|
|
||||||
@class ActionSummary
|
|
||||||
@extends Discourse.Model
|
|
||||||
@namespace Discourse
|
|
||||||
@module Discourse
|
|
||||||
**/
|
|
||||||
Discourse.ActionSummary = Discourse.Model.extend({
|
Discourse.ActionSummary = Discourse.Model.extend({
|
||||||
|
|
||||||
// Description for the action
|
// Description for the action
|
||||||
|
@ -44,16 +36,16 @@ Discourse.ActionSummary = Discourse.Model.extend({
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
toggle: function() {
|
toggle: function(post) {
|
||||||
if (!this.get('acted')) {
|
if (!this.get('acted')) {
|
||||||
this.act();
|
this.act(post);
|
||||||
} else {
|
} else {
|
||||||
this.undo();
|
this.undo(post);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// Perform this action
|
// Perform this action
|
||||||
act: function(opts) {
|
act: function(post, opts) {
|
||||||
if (!opts) opts = {};
|
if (!opts) opts = {};
|
||||||
|
|
||||||
var action = this.get('actionType.name_key');
|
var action = this.get('actionType.name_key');
|
||||||
|
@ -82,18 +74,14 @@ Discourse.ActionSummary = Discourse.Model.extend({
|
||||||
return Discourse.ajax("/post_actions", {
|
return Discourse.ajax("/post_actions", {
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: {
|
||||||
id: this.get('flagTopic') ? this.get('flagTopic.id') : this.get('post.id'),
|
id: this.get('flagTopic') ? this.get('flagTopic.id') : post.get('id'),
|
||||||
post_action_type_id: this.get('id'),
|
post_action_type_id: this.get('id'),
|
||||||
message: opts.message,
|
message: opts.message,
|
||||||
take_action: opts.takeAction,
|
take_action: opts.takeAction,
|
||||||
flag_topic: this.get('flagTopic') ? true : false
|
flag_topic: this.get('flagTopic') ? true : false
|
||||||
}
|
}
|
||||||
}).then(function(result) {
|
}).then(function(result) {
|
||||||
var post = self.get('post');
|
return post.updateActionsSummary(result);
|
||||||
if (post && result && result.id === post.get('id')) {
|
|
||||||
post.updateFromJson(result);
|
|
||||||
}
|
|
||||||
return post;
|
|
||||||
}).catch(function (error) {
|
}).catch(function (error) {
|
||||||
self.removeAction();
|
self.removeAction();
|
||||||
var message = $.parseJSON(error.responseText).errors;
|
var message = $.parseJSON(error.responseText).errors;
|
||||||
|
@ -102,43 +90,38 @@ Discourse.ActionSummary = Discourse.Model.extend({
|
||||||
},
|
},
|
||||||
|
|
||||||
// Undo this action
|
// Undo this action
|
||||||
undo: function() {
|
undo: function(post) {
|
||||||
this.removeAction();
|
this.removeAction();
|
||||||
|
|
||||||
// Remove our post action
|
// Remove our post action
|
||||||
var self = this;
|
return Discourse.ajax("/post_actions/" + post.get('id'), {
|
||||||
return Discourse.ajax("/post_actions/" + (this.get('post.id')), {
|
|
||||||
type: 'DELETE',
|
type: 'DELETE',
|
||||||
data: {
|
data: {
|
||||||
post_action_type_id: this.get('id')
|
post_action_type_id: this.get('id')
|
||||||
}
|
}
|
||||||
}).then(function(result) {
|
}).then(function(result) {
|
||||||
var post = self.get('post');
|
return post.updateActionsSummary(result);
|
||||||
if (post && result && result.id === post.get('id')) {
|
|
||||||
post.updateFromJson(result);
|
|
||||||
}
|
|
||||||
return post;
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
deferFlags: function() {
|
deferFlags: function(post) {
|
||||||
var self = this;
|
var self = this;
|
||||||
return Discourse.ajax("/post_actions/defer_flags", {
|
return Discourse.ajax("/post_actions/defer_flags", {
|
||||||
type: "POST",
|
type: "POST",
|
||||||
data: {
|
data: {
|
||||||
post_action_type_id: this.get("id"),
|
post_action_type_id: this.get("id"),
|
||||||
id: this.get("post.id")
|
id: post.get('id')
|
||||||
}
|
}
|
||||||
}).then(function () {
|
}).then(function () {
|
||||||
self.set("count", 0);
|
self.set("count", 0);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
loadUsers: function() {
|
loadUsers: function(post) {
|
||||||
var self = this;
|
var self = this;
|
||||||
Discourse.ajax("/post_actions/users", {
|
Discourse.ajax("/post_actions/users", {
|
||||||
data: {
|
data: {
|
||||||
id: this.get('post.id'),
|
id: post.get('id'),
|
||||||
post_action_type_id: this.get('id')
|
post_action_type_id: this.get('id')
|
||||||
}
|
}
|
||||||
}).then(function (result) {
|
}).then(function (result) {
|
||||||
|
|
|
@ -332,6 +332,13 @@ const Post = RestModel.extend({
|
||||||
if (bookmarkedTopic) {self.set("topic.bookmarked", false); }
|
if (bookmarkedTopic) {self.set("topic.bookmarked", false); }
|
||||||
throw e;
|
throw e;
|
||||||
});
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
updateActionsSummary(json) {
|
||||||
|
if (json && json.id === this.get('id')) {
|
||||||
|
json = Post.munge(json);
|
||||||
|
this.set('actions_summary', json.actions_summary);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -343,7 +350,6 @@ Post.reopenClass({
|
||||||
const lookup = Em.Object.create();
|
const lookup = Em.Object.create();
|
||||||
// this area should be optimized, it is creating way too many objects per post
|
// this area should be optimized, it is creating way too many objects per post
|
||||||
json.actions_summary = json.actions_summary.map(function(a) {
|
json.actions_summary = json.actions_summary.map(function(a) {
|
||||||
a.post = json;
|
|
||||||
a.actionType = Discourse.Site.current().postActionTypeById(a.id);
|
a.actionType = Discourse.Site.current().postActionTypeById(a.id);
|
||||||
const actionSummary = Discourse.ActionSummary.create(a);
|
const actionSummary = Discourse.ActionSummary.create(a);
|
||||||
lookup[a.actionType.name_key] = actionSummary;
|
lookup[a.actionType.name_key] = actionSummary;
|
||||||
|
|
Loading…
Reference in New Issue