diff options
author | Kirill Rogovoy <[email protected]> | 2021-07-20 21:24:52 +0300 |
---|---|---|
committer | Kirill Rogovoy <[email protected]> | 2021-07-20 21:24:52 +0300 |
commit | 5f4611d65e40eae3ca6191a15f68d69ea5a1c4cb (patch) | |
tree | 273dfc086444533d86d580961c92ba8d14781a67 /app/models/root-store/setup-root-store.ts | |
parent | f0bf4e7afdcd8b02a62be45ab3e7d047ed865a79 (diff) |
WIP
Diffstat (limited to 'app/models/root-store/setup-root-store.ts')
-rw-r--r-- | app/models/root-store/setup-root-store.ts | 57 |
1 files changed, 0 insertions, 57 deletions
diff --git a/app/models/root-store/setup-root-store.ts b/app/models/root-store/setup-root-store.ts deleted file mode 100644 index b1a741b..0000000 --- a/app/models/root-store/setup-root-store.ts +++ /dev/null @@ -1,57 +0,0 @@ -import { onSnapshot } from 'mobx-state-tree' -import { RootStoreModel, RootStore } from './root-store' -import { Environment } from '../environment' -import * as storage from '../../utils/storage' - -/** - * The key we'll be saving our state as within async storage. - */ -const ROOT_STATE_STORAGE_KEY = 'root' - -/** - * Setup the environment that all the models will be sharing. - * - * The environment includes other functions that will be picked from some - * of the models that get created later. This is how we loosly couple things - * like events between models. - */ -export async function createEnvironment() { - const env = new Environment() - await env.setup() - return env -} - -/** - * Setup the root state. - */ -export async function setupRootStore() { - let rootStore: RootStore - let data: any - - // prepare the environment that will be associated with the RootStore. - const env = await createEnvironment() - try { - // load data from storage - data = (await storage.load(ROOT_STATE_STORAGE_KEY)) || {} - rootStore = RootStoreModel.create(data, env) - } catch (e) { - // if there's any problems loading, then let's at least fallback to an empty state - // instead of crashing. - rootStore = RootStoreModel.create({}, env) - - // but please inform us what happened - __DEV__ && console.tron.error(e.message, null) - } - - // reactotron logging - if (__DEV__) { - env.reactotron.setRootStore(rootStore, data) - } - - // track changes & save to storage - onSnapshot(rootStore, (snapshot) => - storage.save(ROOT_STATE_STORAGE_KEY, snapshot), - ) - - return rootStore -} |