From 85479bad0881d9251b7cd77f6dcd199e9b8b4f73 Mon Sep 17 00:00:00 2001 From: Anton Gilgur Date: Fri, 21 Jun 2019 22:40:25 -0400 Subject: [PATCH] (fix): handle non-existent key in storage - if key is falsey, i.e. when storage has been cleared or has yet to be set to initial state, applySnapshot will fail and throw an error - so don't apply it if falsey, just skip the applySnapshot call - was thinking of applying `{}`, an empty object, if falsey, but this will reset the initial state of the store to its defaults - one might set initial state in `create({ ... })`, so that alternative doesn't work - getting the initial snapshot and setting it to itself was another alternative considered, but that would be quite complex with unnecessary operations, and might cause some unintended behavior due to whitelists, blacklists, etc applying - still need to think about the ramifications of those since applySnapshot doesn't merge, it just sets (and defaults are applied on top) - see also #1 --- persist.js | 2 ++ 1 file changed, 2 insertions(+) diff --git a/persist.js b/persist.js index dadd0e3..cdd94a1 100644 --- a/persist.js +++ b/persist.js @@ -30,6 +30,8 @@ export const persist = (name, store, options = {}) => { return storage.getItem(name) .then((data) => { const snapshot = !jsonify ? data : JSON.parse(data) + // don't apply falsey (which will error), leave store in initial state + if (!snapshot) { return } applySnapshot(store, snapshot) }) }