From addbd0ee43fad3a2fdfd42653a50bcd7d614c252 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Renaudeau?= Date: Wed, 9 May 2018 12:50:24 +0200 Subject: [PATCH] fix middleware to save countervalues --- src/middlewares/db.js | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/src/middlewares/db.js b/src/middlewares/db.js index b41b4113..3ac08297 100644 --- a/src/middlewares/db.js +++ b/src/middlewares/db.js @@ -7,17 +7,19 @@ import { settingsExportSelector } from 'reducers/settings' import CounterValues from 'helpers/countervalues' export default store => next => action => { - if (!action.type.startsWith('DB:')) { - return next(action) + if (action.type.startsWith('DB:')) { + const [, type] = action.type.split(':') + store.dispatch({ type, payload: action.payload }) + const state = store.getState() + db.set('settings', settingsExportSelector(state)) + db.set('accounts', getAccounts(state)) + } else { + const oldState = store.getState() + const res = next(action) + const newState = store.getState() + if (oldState.countervalues !== newState.countervalues) { + db.set('countervalues', CounterValues.exportSelector(newState)) + } + return res } - - const { dispatch, getState } = store - const [, type] = action.type.split(':') - - dispatch({ type, payload: action.payload }) - - const state = getState() - db.set('settings', settingsExportSelector(state)) - db.set('accounts', getAccounts(state)) - db.set('countervalues', CounterValues.exportSelector(state)) }