2021-10-17 16:36:14 +08:00
|
|
|
import * as SETTINGS from 'constants/settings';
|
|
|
|
import * as DAEMON_SETTINGS from 'constants/daemon_settings';
|
2022-02-15 14:36:33 -03:00
|
|
|
import SUPPORTED_BROWSER_LANGUAGES from 'constants/supported_browser_languages';
|
2021-10-17 16:36:14 +08:00
|
|
|
|
2017-12-21 14:32:51 -03:00
|
|
|
import { createSelector } from 'reselect';
|
2021-07-06 14:16:57 -04:00
|
|
|
import { ENABLE_MATURE } from 'config';
|
2021-04-06 15:15:08 -04:00
|
|
|
import { getDefaultHomepageKey, getDefaultLanguage } from 'util/default-languages';
|
2022-05-05 09:23:31 -03:00
|
|
|
import { selectClaimWithId } from 'redux/selectors/claims';
|
2017-05-17 17:52:45 -04:00
|
|
|
|
2021-03-25 01:12:24 -04:00
|
|
|
const selectState = (state) => state.settings || {};
|
2017-05-17 17:52:45 -04:00
|
|
|
|
2021-10-23 10:41:43 +08:00
|
|
|
export const selectDaemonSettings = (state) => selectState(state).daemonSettings;
|
|
|
|
export const selectDaemonStatus = (state) => selectState(state).daemonStatus;
|
2021-03-25 01:12:24 -04:00
|
|
|
export const selectFfmpegStatus = createSelector(selectDaemonStatus, (status) => status.ffmpeg_status);
|
2021-10-23 10:41:43 +08:00
|
|
|
export const selectFindingFFmpeg = (state) => selectState(state).findingFFmpeg || false;
|
|
|
|
export const selectClientSettings = (state) => selectState(state).clientSettings || {};
|
|
|
|
export const selectLoadedLanguages = (state) => selectState(state).loadedLanguages || {};
|
2019-09-04 17:43:37 -04:00
|
|
|
|
2021-11-16 12:04:40 +08:00
|
|
|
export const selectClientSetting = (state, setting) => {
|
|
|
|
const clientSettings = selectClientSettings(state);
|
|
|
|
return clientSettings ? clientSettings[setting] : undefined;
|
|
|
|
};
|
|
|
|
|
2017-12-13 18:36:30 -03:00
|
|
|
// refactor me
|
2021-11-16 12:04:40 +08:00
|
|
|
export const selectShowMatureContent = (state) => {
|
|
|
|
return !ENABLE_MATURE ? false : selectClientSetting(state, SETTINGS.SHOW_MATURE);
|
|
|
|
};
|
2017-08-08 10:36:14 +01:00
|
|
|
|
2021-11-23 12:29:04 +08:00
|
|
|
export const selectTheme = (state) => selectClientSetting(state, SETTINGS.THEME);
|
|
|
|
export const selectAutomaticDarkModeEnabled = (state) =>
|
|
|
|
selectClientSetting(state, SETTINGS.AUTOMATIC_DARK_MODE_ENABLED);
|
2021-10-23 10:41:43 +08:00
|
|
|
export const selectIsNight = (state) => selectState(state).isNight;
|
|
|
|
export const selectSavedWalletServers = (state) => selectState(state).customWalletServers;
|
|
|
|
export const selectSharedPreferences = (state) => selectState(state).sharedPreferences;
|
2019-12-11 15:09:27 -05:00
|
|
|
|
2021-03-25 01:12:24 -04:00
|
|
|
export const makeSelectSharedPreferencesForKey = (key) =>
|
|
|
|
createSelector(selectSharedPreferences, (prefs) => (prefs ? prefs[key] : undefined));
|
2019-12-11 15:09:27 -05:00
|
|
|
|
2020-02-20 12:30:27 +00:00
|
|
|
export const selectHasWalletServerPrefs = createSelector(
|
2020-07-10 17:04:36 -04:00
|
|
|
makeSelectSharedPreferencesForKey(DAEMON_SETTINGS.LBRYUM_SERVERS),
|
2021-03-25 01:12:24 -04:00
|
|
|
(servers) => {
|
2020-03-24 13:57:17 -04:00
|
|
|
return !!(servers && servers.length);
|
2020-02-20 12:30:27 +00:00
|
|
|
}
|
|
|
|
);
|
2019-12-12 15:18:13 -05: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
|
|
|
);
|
2018-07-30 21:13:57 -03:00
|
|
|
|
2021-11-23 12:29:04 +08:00
|
|
|
export const selectHomepageCode = (state) => {
|
|
|
|
const hp = selectClientSetting(state, SETTINGS.HOMEPAGE);
|
2022-03-03 06:22:59 -08:00
|
|
|
const homepages = window.homepages || {};
|
2021-11-23 12:29:04 +08:00
|
|
|
return homepages[hp] ? hp : getDefaultHomepageKey();
|
|
|
|
};
|
2020-11-20 08:21:31 -05:00
|
|
|
|
2021-11-23 12:29:04 +08:00
|
|
|
export const selectLanguage = (state) => {
|
|
|
|
const lang = selectClientSetting(state, SETTINGS.LANGUAGE);
|
|
|
|
return lang || getDefaultLanguage();
|
|
|
|
};
|
2020-11-10 11:07:00 -05:00
|
|
|
|
2022-03-03 06:22:59 -08:00
|
|
|
export const selectHomepageData = (state) => {
|
|
|
|
const homepageCode = selectHomepageCode(state);
|
|
|
|
const homepages = window.homepages;
|
2022-04-15 20:50:15 +08:00
|
|
|
return homepages ? homepages[homepageCode].categories || homepages['en'].categories || {} : {};
|
2022-03-03 06:22:59 -08:00
|
|
|
};
|
2020-11-10 11:07:00 -05:00
|
|
|
|
2022-05-09 15:28:39 +08:00
|
|
|
export const selectHomepageMeme = (state) => {
|
|
|
|
const homepageCode = selectHomepageCode(state);
|
|
|
|
const homepages = window.homepages;
|
|
|
|
if (homepages) {
|
|
|
|
const meme = homepages[homepageCode].meme;
|
|
|
|
if (meme && meme.text && meme.url) {
|
|
|
|
return meme;
|
|
|
|
}
|
|
|
|
}
|
2022-05-10 13:25:47 -04:00
|
|
|
return homepages ? homepages['en'].meme || {} : {};
|
2022-05-09 15:28:39 +08:00
|
|
|
};
|
|
|
|
|
2022-05-18 17:06:21 +08:00
|
|
|
export const selectHomepageAnnouncement = (state) => {
|
|
|
|
const homepageCode = selectHomepageCode(state);
|
|
|
|
const homepages = window.homepages;
|
|
|
|
if (homepages) {
|
|
|
|
const news = homepages[homepageCode].announcement;
|
|
|
|
if (news) {
|
|
|
|
return news;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return homepages ? homepages['en'].announcement || '' : '';
|
|
|
|
};
|
|
|
|
|
2022-02-15 14:36:33 -03:00
|
|
|
export const selectInRegionByCode = (state, code) => {
|
|
|
|
const hp = selectClientSetting(state, SETTINGS.HOMEPAGE);
|
|
|
|
const lang = selectLanguage(state);
|
|
|
|
|
|
|
|
return hp === code || lang === code;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const selectWildWestDisabled = (state) => {
|
2022-03-03 06:22:59 -08:00
|
|
|
return selectInRegionByCode(state, SUPPORTED_BROWSER_LANGUAGES.de);
|
2022-02-15 14:36:33 -03:00
|
|
|
};
|
|
|
|
|
2021-11-23 12:29:04 +08:00
|
|
|
export const selectosNotificationsEnabled = (state) => selectClientSetting(state, SETTINGS.OS_NOTIFICATIONS_ENABLED);
|
2022-05-05 09:23:31 -03:00
|
|
|
|
|
|
|
export const selectDefaultChannelClaim = createSelector(
|
|
|
|
(state) => selectClaimWithId(state, selectClientSetting(state, SETTINGS.ACTIVE_CHANNEL_CLAIM)),
|
|
|
|
(defaultChannelClaim) => defaultChannelClaim
|
|
|
|
);
|