diff --git a/src/components/notification/notification.vue b/src/components/notification/notification.vue
index fa931fb6..7d88c90b 100644
--- a/src/components/notification/notification.vue
+++ b/src/components/notification/notification.vue
@@ -6,15 +6,15 @@
>
-
-
+
+
-
+
-
- {{ notification.action.user.name }}
+
+ {{ notification.action.account.name }}
{{$t('notifications.favorited_you')}}
@@ -30,18 +30,18 @@
-
+
-
+
- @{{notification.action.user.screen_name}}
+ @{{notification.action.account.screen_name}}
diff --git a/src/modules/statuses.js b/src/modules/statuses.js
index e18b0d1f..f14b8703 100644
--- a/src/modules/statuses.js
+++ b/src/modules/statuses.js
@@ -271,7 +271,12 @@ const addNewStatuses = (state, { statuses, showImmediately = false, timeline, us
}
const addNewNotifications = (state, { dispatch, notifications, older, visibleNotificationTypes }) => {
+ const allStatuses = state.allStatuses
+ const allStatusesObject = state.allStatusesObject
each(notifications, (notification) => {
+ notification.action = mergeOrAdd(allStatuses, allStatusesObject, notification.action).item
+ notification.status = notification.status && mergeOrAdd(allStatuses, allStatusesObject, notification.status).item
+
// Only add a new notification if we don't have one for the same action
if (!state.notifications.idStore.hasOwnProperty(notification.id)) {
state.notifications.maxId = notification.id > state.notifications.maxId
diff --git a/src/services/entity_normalizer/entity_normalizer.service.js b/src/services/entity_normalizer/entity_normalizer.service.js
index 36a9508a..3bd42b94 100644
--- a/src/services/entity_normalizer/entity_normalizer.service.js
+++ b/src/services/entity_normalizer/entity_normalizer.service.js
@@ -180,8 +180,8 @@ export const parseStatus = (data) => {
// Missing!! fix in UI?
// output.in_reply_to_screen_name = ???
- // Not exactly the same but works
- output.statusnet_conversation_id = data.id
+ // It breaks the conversation when combined with notification
+ // output.statusnet_conversation_id = data.id
if (output.type === 'retweet') {
output.retweeted_status = parseStatus(data.reblog)
@@ -218,7 +218,6 @@ export const parseStatus = (data) => {
output.in_reply_to_status_id = data.in_reply_to_status_id
output.in_reply_to_user_id = data.in_reply_to_user_id
output.in_reply_to_screen_name = data.in_reply_to_screen_name
-
output.statusnet_conversation_id = data.statusnet_conversation_id
if (output.type === 'retweet') {
@@ -266,6 +265,8 @@ export const parseFollow = (data) => {
output.visibility = true
output.created_at = new Date(data.created_at)
output.user = parseUser(data.account)
+ output.notified_at = output.created_at
+ output.account = output.user
return output
}
@@ -286,7 +287,8 @@ export const parseNotification = (data) => {
: parseStatus(data.status)
if (data.type === 'reblog' || data.type === 'favourite') {
output.status.user = parseUser(data.account)
- output.status.created_at = new Date(data.created_at)
+ output.status.account = parseUser(data.account)
+ output.status.notified_at = new Date(data.created_at)
}
output.action = output.status // not sure
output.from_profile = parseUser(data.account)