2016-11-26 09:57:08 -08:00
|
|
|
import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
|
2016-12-08 00:08:59 -08:00
|
|
|
import { compact, map, each, find, merge } from 'lodash'
|
2017-02-13 14:22:32 -08:00
|
|
|
import { set } from 'vue'
|
2016-10-27 09:03:14 -07:00
|
|
|
|
2016-11-30 09:29:44 -08:00
|
|
|
// TODO: Unify with mergeOrAdd in statuses.js
|
|
|
|
export const mergeOrAdd = (arr, item) => {
|
2016-11-30 14:32:22 -08:00
|
|
|
if (!item) { return false }
|
2016-11-30 09:29:44 -08:00
|
|
|
const oldItem = find(arr, {id: item.id})
|
|
|
|
if (oldItem) {
|
|
|
|
// We already have this, so only merge the new info.
|
|
|
|
merge(oldItem, item)
|
|
|
|
return {item: oldItem, new: false}
|
|
|
|
} else {
|
|
|
|
// This is a new item, prepare it
|
|
|
|
arr.push(item)
|
|
|
|
return {item, new: true}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const mutations = {
|
2017-02-13 14:22:32 -08:00
|
|
|
setMuted (state, { user: {id}, muted }) {
|
|
|
|
const user = find(state.users, {id})
|
|
|
|
set(user, 'muted', muted)
|
|
|
|
},
|
2016-11-30 09:29:44 -08:00
|
|
|
setCurrentUser (state, user) {
|
|
|
|
state.currentUser = user
|
2016-10-27 09:03:14 -07:00
|
|
|
},
|
2016-11-30 09:29:44 -08:00
|
|
|
beginLogin (state) {
|
|
|
|
state.loggingIn = true
|
|
|
|
},
|
|
|
|
endLogin (state) {
|
|
|
|
state.loggingIn = false
|
2016-10-27 09:03:14 -07:00
|
|
|
},
|
2016-11-30 09:29:44 -08:00
|
|
|
addNewUsers (state, users) {
|
|
|
|
each(users, (user) => mergeOrAdd(state.users, user))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export const defaultState = {
|
|
|
|
currentUser: false,
|
|
|
|
loggingIn: false,
|
|
|
|
users: []
|
|
|
|
}
|
|
|
|
|
|
|
|
const users = {
|
|
|
|
state: defaultState,
|
|
|
|
mutations,
|
2016-10-27 09:03:14 -07:00
|
|
|
actions: {
|
2016-11-30 09:29:44 -08:00
|
|
|
addNewStatuses (store, { statuses }) {
|
|
|
|
const users = map(statuses, 'user')
|
2016-12-08 00:08:59 -08:00
|
|
|
const retweetedUsers = compact(map(statuses, 'retweeted_status.user'))
|
2016-11-30 09:29:44 -08:00
|
|
|
store.commit('addNewUsers', users)
|
2016-12-08 00:08:59 -08:00
|
|
|
store.commit('addNewUsers', retweetedUsers)
|
2017-02-13 15:01:50 -08:00
|
|
|
|
|
|
|
// Reconnect users to statuses
|
|
|
|
each(statuses, (status) => {
|
|
|
|
status.user = find(store.state.users, status.user)
|
|
|
|
})
|
|
|
|
// Reconnect users to retweets
|
|
|
|
each(compact(map(statuses, 'retweeted_status')), (status) => {
|
|
|
|
status.user = find(store.state.users, status.user)
|
|
|
|
})
|
2016-11-30 09:29:44 -08:00
|
|
|
},
|
2016-10-28 05:26:51 -07:00
|
|
|
loginUser (store, userCredentials) {
|
|
|
|
const commit = store.commit
|
2016-10-27 09:03:14 -07:00
|
|
|
commit('beginLogin')
|
2016-11-30 12:27:25 -08:00
|
|
|
store.rootState.api.backendInteractor.verifyCredentials(userCredentials)
|
2016-10-27 09:03:14 -07:00
|
|
|
.then((response) => {
|
|
|
|
if (response.ok) {
|
|
|
|
response.json()
|
2016-10-30 08:12:35 -07:00
|
|
|
.then((user) => {
|
|
|
|
user.credentials = userCredentials
|
|
|
|
commit('setCurrentUser', user)
|
2016-11-30 12:27:25 -08:00
|
|
|
commit('addNewUsers', [user])
|
|
|
|
|
|
|
|
// Set our new backend interactor
|
|
|
|
commit('setBackendInteractor', backendInteractorService(userCredentials))
|
|
|
|
|
2017-02-16 02:17:47 -08:00
|
|
|
// Start getting fresh tweets.
|
|
|
|
store.dispatch('startFetching', 'friends')
|
|
|
|
|
2016-11-30 12:27:25 -08:00
|
|
|
// Fetch our friends
|
|
|
|
store.rootState.api.backendInteractor.fetchFriends()
|
|
|
|
.then((friends) => commit('addNewUsers', friends))
|
2016-10-30 08:12:35 -07:00
|
|
|
})
|
2016-10-27 09:03:14 -07:00
|
|
|
}
|
|
|
|
commit('endLogin')
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
console.log(error)
|
|
|
|
commit('endLogin')
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default users
|