From f88b8ce757f62486d5843e1ea0191db1e5c61194 Mon Sep 17 00:00:00 2001 From: Eugen Rochko Date: Tue, 18 Oct 2016 17:09:45 +0200 Subject: Improve how errors are displayed in the UI --- .../components/reducers/notifications.jsx | 72 ++++------------------ 1 file changed, 12 insertions(+), 60 deletions(-) (limited to 'app/assets/javascripts/components/reducers') diff --git a/app/assets/javascripts/components/reducers/notifications.jsx b/app/assets/javascripts/components/reducers/notifications.jsx index 63a814bef..886587bdb 100644 --- a/app/assets/javascripts/components/reducers/notifications.jsx +++ b/app/assets/javascripts/components/reducers/notifications.jsx @@ -1,68 +1,20 @@ -import { COMPOSE_SUBMIT_FAIL, COMPOSE_UPLOAD_FAIL } from '../actions/compose'; -import { FOLLOW_SUBMIT_FAIL } from '../actions/follow'; import { - REBLOG_FAIL, - UNREBLOG_FAIL, - FAVOURITE_FAIL, - UNFAVOURITE_FAIL -} from '../actions/interactions'; -import { - TIMELINE_REFRESH_FAIL, - TIMELINE_EXPAND_FAIL -} from '../actions/timelines'; -import { NOTIFICATION_DISMISS, NOTIFICATION_CLEAR } from '../actions/notifications'; -import { - ACCOUNT_FETCH_FAIL, - ACCOUNT_FOLLOW_FAIL, - ACCOUNT_UNFOLLOW_FAIL, - ACCOUNT_TIMELINE_FETCH_FAIL, - ACCOUNT_TIMELINE_EXPAND_FAIL -} from '../actions/accounts'; -import { - STATUS_FETCH_FAIL, - STATUS_DELETE_FAIL -} from '../actions/statuses'; -import Immutable from 'immutable'; - -const initialState = Immutable.List(); + NOTIFICATION_SHOW, + NOTIFICATION_DISMISS, + NOTIFICATION_CLEAR +} from '../actions/notifications'; +import Immutable from 'immutable'; -function notificationFromError(state, error) { - let n = Immutable.Map({ - key: state.size > 0 ? state.last().get('key') + 1 : 0, - message: '' - }); - - if (error.response) { - n = n.withMutations(map => { - map.set('message', error.response.statusText); - map.set('title', `${error.response.status}`); - }); - } else { - n = n.set('message', `${error}`); - } - - return state.push(n); -}; +const initialState = Immutable.List([]); export default function notifications(state = initialState, action) { switch(action.type) { - case COMPOSE_SUBMIT_FAIL: - case COMPOSE_UPLOAD_FAIL: - case FOLLOW_SUBMIT_FAIL: - case REBLOG_FAIL: - case FAVOURITE_FAIL: - case TIMELINE_REFRESH_FAIL: - case TIMELINE_EXPAND_FAIL: - case ACCOUNT_FETCH_FAIL: - case ACCOUNT_FOLLOW_FAIL: - case ACCOUNT_UNFOLLOW_FAIL: - case ACCOUNT_TIMELINE_FETCH_FAIL: - case ACCOUNT_TIMELINE_EXPAND_FAIL: - case STATUS_FETCH_FAIL: - case STATUS_DELETE_FAIL: - case UNREBLOG_FAIL: - case UNFAVOURITE_FAIL: - return notificationFromError(state, action.error); + case NOTIFICATION_SHOW: + return state.push(Immutable.Map({ + key: state.size > 0 ? state.last().get('key') + 1 : 0, + title: action.title, + message: action.message + })); case NOTIFICATION_DISMISS: return state.filterNot(item => item.get('key') === action.notification.key); case NOTIFICATION_CLEAR: -- cgit