2017-12-21 18:32:51 +01:00
|
|
|
import * as SETTINGS from 'constants/settings';
|
2019-12-12 21:18:13 +01:00
|
|
|
import { SHARED_PREFERENCES } from 'lbry-redux';
|
2017-12-21 18:32:51 +01:00
|
|
|
import { createSelector } from 'reselect';
|
2017-05-17 23:52:45 +02:00
|
|
|
|
2017-12-21 18:32:51 +01:00
|
|
|
const selectState = state => state.settings || {};
|
2017-05-17 23:52:45 +02:00
|
|
|
|
2019-03-05 05:46:57 +01:00
|
|
|
export const selectDaemonSettings = createSelector(
|
|
|
|
selectState,
|
|
|
|
state => state.daemonSettings
|
|
|
|
);
|
2017-05-17 23:52:45 +02:00
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export const selectDaemonStatus = createSelector(
|
|
|
|
selectState,
|
|
|
|
state => state.daemonStatus
|
|
|
|
);
|
|
|
|
|
2017-05-17 23:52:45 +02:00
|
|
|
export const selectClientSettings = createSelector(
|
2017-12-21 18:32:51 +01:00
|
|
|
selectState,
|
2017-06-28 09:12:01 +02:00
|
|
|
state => state.clientSettings || {}
|
2017-06-06 06:21:55 +02:00
|
|
|
);
|
2017-05-17 23:52:45 +02:00
|
|
|
|
2019-11-08 21:51:42 +01:00
|
|
|
export const selectLoadedLanguages = createSelector(
|
2019-09-04 23:43:37 +02:00
|
|
|
selectState,
|
2019-11-08 21:51:42 +01:00
|
|
|
state => state.loadedLanguages || {}
|
2019-09-04 23:43:37 +02:00
|
|
|
);
|
|
|
|
|
2017-12-13 22:36:30 +01:00
|
|
|
export const makeSelectClientSetting = setting =>
|
2019-03-05 05:46:57 +01:00
|
|
|
createSelector(
|
|
|
|
selectClientSettings,
|
|
|
|
settings => (settings ? settings[setting] : undefined)
|
|
|
|
);
|
2017-08-21 05:06:26 +02:00
|
|
|
|
2017-12-13 22:36:30 +01:00
|
|
|
// refactor me
|
2019-09-17 20:49:03 +02:00
|
|
|
export const selectShowMatureContent = makeSelectClientSetting(SETTINGS.SHOW_MATURE);
|
2017-08-08 11:36:14 +02:00
|
|
|
|
2018-01-14 10:14:15 +01:00
|
|
|
export const selectTheme = makeSelectClientSetting(SETTINGS.THEME);
|
2019-05-07 23:38:29 +02:00
|
|
|
export const selectAutomaticDarkModeEnabled = makeSelectClientSetting(SETTINGS.AUTOMATIC_DARK_MODE_ENABLED);
|
2019-03-05 05:46:57 +01:00
|
|
|
export const selectIsNight = createSelector(
|
|
|
|
selectState,
|
|
|
|
state => state.isNight
|
|
|
|
);
|
2018-01-14 10:14:15 +01:00
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export const selectSavedWalletServers = createSelector(
|
2019-12-11 21:09:27 +01:00
|
|
|
selectState,
|
|
|
|
state => state.customWalletServers
|
|
|
|
);
|
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export const selectSharedPreferences = createSelector(
|
2019-12-11 21:09:27 +01:00
|
|
|
selectState,
|
2019-12-12 21:18:13 +01:00
|
|
|
state => state.sharedPreferences
|
2019-12-11 21:09:27 +01:00
|
|
|
);
|
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export const makeSelectSharedPreferencesForKey = key =>
|
2019-12-11 21:09:27 +01:00
|
|
|
createSelector(
|
2019-12-12 21:18:13 +01:00
|
|
|
selectSharedPreferences,
|
2019-12-11 21:09:27 +01:00
|
|
|
prefs => (prefs ? prefs[key] : undefined)
|
|
|
|
);
|
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export const selectHasWalletServerPrefs =
|
|
|
|
createSelector(
|
|
|
|
makeSelectSharedPreferencesForKey(SHARED_PREFERENCES.WALLET_SERVERS),
|
|
|
|
servers => {
|
|
|
|
if (servers && servers.length) return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2017-09-07 02:52:34 +02:00
|
|
|
export const selectThemePath = createSelector(
|
2018-01-14 10:14:15 +01:00
|
|
|
selectTheme,
|
|
|
|
selectAutomaticDarkModeEnabled,
|
|
|
|
selectIsNight,
|
|
|
|
(theme, automaticDarkModeEnabled, isNight) => {
|
|
|
|
const dynamicTheme = automaticDarkModeEnabled && isNight ? 'dark' : theme;
|
2018-10-18 18:45:24 +02:00
|
|
|
return dynamicTheme || 'light';
|
2018-01-14 10:14:15 +01:00
|
|
|
}
|
2017-09-07 02:52:34 +02:00
|
|
|
);
|
2018-07-31 02:13:57 +02:00
|
|
|
|
2019-05-07 23:38:29 +02:00
|
|
|
export const selectosNotificationsEnabled = makeSelectClientSetting(SETTINGS.OS_NOTIFICATIONS_ENABLED);
|