lbry-desktop/ui/redux/selectors/settings.js

48 lines
1.4 KiB
JavaScript
Raw Normal View History

import * as SETTINGS from 'constants/settings';
import { createSelector } from 'reselect';
const selectState = state => state.settings || {};
2019-03-04 23:46:57 -05:00
export const selectDaemonSettings = createSelector(
selectState,
state => state.daemonSettings
);
export const selectClientSettings = createSelector(
selectState,
2017-06-28 14:12:01 +07:00
state => state.clientSettings || {}
2017-06-05 21:21:55 -07:00
);
2019-11-08 15:51:42 -05:00
export const selectLoadedLanguages = createSelector(
selectState,
2019-11-08 15:51:42 -05:00
state => state.loadedLanguages || {}
);
2017-12-13 18:36:30 -03:00
export const makeSelectClientSetting = setting =>
2019-03-04 23:46:57 -05:00
createSelector(
selectClientSettings,
settings => (settings ? settings[setting] : undefined)
);
2017-08-20 23:06:26 -04:00
2017-12-13 18:36:30 -03:00
// refactor me
2019-09-17 14:49:03 -04:00
export const selectShowMatureContent = makeSelectClientSetting(SETTINGS.SHOW_MATURE);
2017-08-08 10:36:14 +01:00
2018-01-14 20:14:15 +11:00
export const selectTheme = makeSelectClientSetting(SETTINGS.THEME);
2019-05-07 17:38:29 -04:00
export const selectAutomaticDarkModeEnabled = makeSelectClientSetting(SETTINGS.AUTOMATIC_DARK_MODE_ENABLED);
2019-03-04 23:46:57 -05:00
export const selectIsNight = createSelector(
selectState,
state => state.isNight
);
2018-01-14 20:14:15 +11:00
2017-09-06 20:52:34 -04:00
export const selectThemePath = createSelector(
2018-01-14 20:14:15 +11:00
selectTheme,
selectAutomaticDarkModeEnabled,
selectIsNight,
(theme, automaticDarkModeEnabled, isNight) => {
const dynamicTheme = automaticDarkModeEnabled && isNight ? 'dark' : theme;
2018-10-18 11:45:24 -05:00
return dynamicTheme || 'light';
2018-01-14 20:14:15 +11:00
}
2017-09-06 20:52:34 -04:00
);
2019-05-07 17:38:29 -04:00
export const selectosNotificationsEnabled = makeSelectClientSetting(SETTINGS.OS_NOTIFICATIONS_ENABLED);