diff options
author | Stefan Malzner <stefan@adlk.io> | 2018-12-02 00:52:05 +0100 |
---|---|---|
committer | Stefan Malzner <stefan@adlk.io> | 2018-12-02 00:52:05 +0100 |
commit | fce68f7433537d52e15abf1ffe140e8dcc8afe80 (patch) | |
tree | 32b2c8b0c7867434dd2cbcf5e2a1de7a3548dbec /src/features/spellchecker/index.js | |
parent | Merge branch 'develop' into release/5.0.0-beta.19 (diff) | |
parent | Check if service is enabled before trying to reload (diff) | |
download | ferdium-app-fce68f7433537d52e15abf1ffe140e8dcc8afe80.tar.gz ferdium-app-fce68f7433537d52e15abf1ffe140e8dcc8afe80.tar.zst ferdium-app-fce68f7433537d52e15abf1ffe140e8dcc8afe80.zip |
Merge branch 'develop' into release/5.0.0-beta.19
Diffstat (limited to 'src/features/spellchecker/index.js')
-rw-r--r-- | src/features/spellchecker/index.js | 35 |
1 files changed, 13 insertions, 22 deletions
diff --git a/src/features/spellchecker/index.js b/src/features/spellchecker/index.js index 454096e4e..63506103c 100644 --- a/src/features/spellchecker/index.js +++ b/src/features/spellchecker/index.js | |||
@@ -1,36 +1,27 @@ | |||
1 | import { autorun, reaction } from 'mobx'; | 1 | import { autorun, observable } from 'mobx'; |
2 | 2 | ||
3 | import { DEFAULT_FEATURES_CONFIG } from '../../config'; | 3 | import { DEFAULT_FEATURES_CONFIG } from '../../config'; |
4 | 4 | ||
5 | const debug = require('debug')('Franz:feature:spellchecker'); | 5 | const debug = require('debug')('Franz:feature:spellchecker'); |
6 | 6 | ||
7 | export const config = { | 7 | export const config = observable({ |
8 | isPremiumFeature: DEFAULT_FEATURES_CONFIG.isSpellcheckerPremiumFeature, | 8 | isPremiumFeature: DEFAULT_FEATURES_CONFIG.isSpellcheckerPremiumFeature, |
9 | }; | 9 | }); |
10 | 10 | ||
11 | export default function init(stores) { | 11 | export default function init(stores) { |
12 | reaction( | 12 | debug('Initializing `spellchecker` feature'); |
13 | () => stores.features.features.isSpellcheckerPremiumFeature, | ||
14 | (enabled, r) => { | ||
15 | debug('Initializing `spellchecker` feature'); | ||
16 | 13 | ||
17 | // Dispose the reaction to run this only once | 14 | autorun(() => { |
18 | r.dispose(); | 15 | const { isSpellcheckerPremiumFeature } = stores.features.features; |
19 | 16 | ||
20 | const { isSpellcheckerPremiumFeature } = stores.features.features; | 17 | config.isPremiumFeature = isSpellcheckerPremiumFeature !== undefined ? isSpellcheckerPremiumFeature : DEFAULT_FEATURES_CONFIG.isSpellcheckerPremiumFeature; |
21 | 18 | ||
22 | config.isPremiumFeature = isSpellcheckerPremiumFeature !== undefined ? isSpellcheckerPremiumFeature : DEFAULT_FEATURES_CONFIG.isSpellcheckerPremiumFeature; | 19 | if (!stores.user.data.isPremium && config.isPremiumFeature && stores.settings.app.enableSpellchecking) { |
20 | debug('Override settings.spellcheckerEnabled flag to false'); | ||
23 | 21 | ||
24 | autorun(() => { | 22 | Object.assign(stores.settings.app, { |
25 | if (!stores.user.data.isPremium && config.isPremiumFeature) { | 23 | enableSpellchecking: false, |
26 | debug('Override settings.spellcheckerEnabled flag to false'); | ||
27 | |||
28 | Object.assign(stores.settings.all.app, { | ||
29 | enableSpellchecking: false, | ||
30 | }); | ||
31 | } | ||
32 | }); | 24 | }); |
33 | }, | 25 | } |
34 | ); | 26 | }); |
35 | } | 27 | } |
36 | |||