2021-10-17 10:36:14 +02:00
|
|
|
import Lbry from 'lbry';
|
|
|
|
import { doWalletReconnect } from 'redux/actions/wallet';
|
|
|
|
import * as SETTINGS from 'constants/settings';
|
|
|
|
import * as DAEMON_SETTINGS from 'constants/daemon_settings';
|
|
|
|
import * as ACTIONS from 'constants/action_types';
|
|
|
|
import * as SHARED_PREFERENCES from 'constants/shared_preferences';
|
2020-06-12 22:44:25 +02:00
|
|
|
import { doToast } from 'redux/actions/notifications';
|
2018-02-16 10:16:50 +01:00
|
|
|
import analytics from 'analytics';
|
2019-11-05 19:54:58 +01:00
|
|
|
import SUPPORTED_LANGUAGES from 'constants/supported_languages';
|
2019-11-18 19:30:15 +01:00
|
|
|
import { launcher } from 'util/autoLaunch';
|
2021-11-23 05:29:04 +01:00
|
|
|
import { selectClientSetting } from 'redux/selectors/settings';
|
2021-01-21 20:50:51 +01:00
|
|
|
import { doSyncLoop, doSyncUnsubscribe, doSetSyncLock } from 'redux/actions/sync';
|
2020-10-05 20:31:51 +02:00
|
|
|
import { doAlertWaitingForSync, doGetAndPopulatePreferences } from 'redux/actions/app';
|
|
|
|
import { selectPrefsReady } from 'redux/selectors/sync';
|
2020-11-11 21:56:31 +01:00
|
|
|
import { Lbryio } from 'lbryinc';
|
2021-01-06 19:13:56 +01:00
|
|
|
import { getDefaultLanguage } from 'util/default-languages';
|
2020-09-04 17:02:30 +02:00
|
|
|
|
2021-12-31 11:24:18 +01:00
|
|
|
const { DEFAULT_LANGUAGE, URL_DEV } = require('config');
|
2020-07-10 23:04:36 +02:00
|
|
|
const { SDK_SYNC_KEYS } = SHARED_PREFERENCES;
|
2018-01-14 10:14:15 +01:00
|
|
|
|
2019-11-18 19:30:15 +01:00
|
|
|
export const IS_MAC = process.platform === 'darwin';
|
2019-08-18 18:54:55 +02:00
|
|
|
const UPDATE_IS_NIGHT_INTERVAL = 5 * 60 * 1000;
|
2017-12-26 21:13:05 +01:00
|
|
|
|
2017-05-17 23:52:45 +02:00
|
|
|
export function doFetchDaemonSettings() {
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
|
|
|
Lbry.settings_get().then((settings) => {
|
2020-02-19 07:31:40 +01:00
|
|
|
analytics.toggleInternal(settings.share_usage_data);
|
2017-05-17 23:52:45 +02:00
|
|
|
dispatch({
|
2017-12-21 18:32:51 +01:00
|
|
|
type: ACTIONS.DAEMON_SETTINGS_RECEIVED,
|
2017-05-17 23:52:45 +02:00
|
|
|
data: {
|
2017-06-06 23:19:12 +02:00
|
|
|
settings,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
2017-05-17 23:52:45 +02:00
|
|
|
}
|
|
|
|
|
2020-03-24 18:57:17 +01:00
|
|
|
export function doFindFFmpeg() {
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
2020-03-24 18:57:17 +01:00
|
|
|
dispatch({
|
2021-10-17 10:36:14 +02:00
|
|
|
type: ACTIONS.FINDING_FFMPEG_STARTED,
|
2020-03-24 18:57:17 +01:00
|
|
|
});
|
2021-09-02 22:05:32 +02:00
|
|
|
return Lbry.ffmpeg_find().then((done) => {
|
2020-03-26 17:28:48 +01:00
|
|
|
dispatch(doGetDaemonStatus());
|
2020-03-24 18:57:17 +01:00
|
|
|
dispatch({
|
2021-10-17 10:36:14 +02:00
|
|
|
type: ACTIONS.FINDING_FFMPEG_COMPLETED,
|
2020-03-24 18:57:17 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export function doGetDaemonStatus() {
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
|
|
|
return Lbry.status().then((status) => {
|
2019-12-12 21:18:13 +01:00
|
|
|
dispatch({
|
|
|
|
type: ACTIONS.DAEMON_STATUS_RECEIVED,
|
|
|
|
data: {
|
|
|
|
status,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
return status;
|
2020-02-19 07:31:40 +01:00
|
|
|
});
|
2019-12-12 21:18:13 +01:00
|
|
|
};
|
2020-02-19 07:31:40 +01:00
|
|
|
}
|
2019-12-12 21:18:13 +01:00
|
|
|
|
2019-12-11 21:09:27 +01:00
|
|
|
export function doClearDaemonSetting(key) {
|
2020-10-05 20:31:51 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
|
|
|
const ready = selectPrefsReady(state);
|
|
|
|
|
|
|
|
if (!ready) {
|
|
|
|
return dispatch(doAlertWaitingForSync());
|
|
|
|
}
|
|
|
|
|
2019-12-11 21:09:27 +01:00
|
|
|
const clearKey = {
|
|
|
|
key,
|
|
|
|
};
|
2020-10-05 20:31:51 +02:00
|
|
|
// not if syncLocked
|
2021-09-02 22:05:32 +02:00
|
|
|
Lbry.settings_clear(clearKey).then((defaultSettings) => {
|
2020-07-10 23:04:36 +02:00
|
|
|
if (SDK_SYNC_KEYS.includes(key)) {
|
2019-12-11 21:09:27 +01:00
|
|
|
dispatch({
|
|
|
|
type: ACTIONS.SHARED_PREFERENCE_SET,
|
2019-12-13 17:13:49 +01:00
|
|
|
data: { key: key, value: null },
|
2019-12-11 21:09:27 +01:00
|
|
|
});
|
|
|
|
}
|
2020-07-10 23:04:36 +02:00
|
|
|
if (key === DAEMON_SETTINGS.LBRYUM_SERVERS) {
|
2019-12-11 21:09:27 +01:00
|
|
|
dispatch(doWalletReconnect());
|
|
|
|
}
|
|
|
|
});
|
2021-09-02 22:05:32 +02:00
|
|
|
Lbry.settings_get().then((settings) => {
|
2020-02-19 07:31:40 +01:00
|
|
|
analytics.toggleInternal(settings.share_usage_data);
|
2019-12-11 21:09:27 +01:00
|
|
|
dispatch({
|
|
|
|
type: ACTIONS.DAEMON_SETTINGS_RECEIVED,
|
|
|
|
data: {
|
|
|
|
settings,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
2020-02-19 07:31:40 +01:00
|
|
|
// if doPopulate is applying settings, we don't want to cause a loop; doNotDispatch = true.
|
|
|
|
export function doSetDaemonSetting(key, value, doNotDispatch = false) {
|
2020-10-05 20:31:51 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
|
|
|
const ready = selectPrefsReady(state);
|
|
|
|
|
|
|
|
if (!ready) {
|
|
|
|
return dispatch(doAlertWaitingForSync());
|
|
|
|
}
|
|
|
|
|
2019-02-12 18:26:50 +01:00
|
|
|
const newSettings = {
|
|
|
|
key,
|
|
|
|
value: !value && value !== false ? null : value,
|
|
|
|
};
|
2021-09-02 22:05:32 +02:00
|
|
|
Lbry.settings_set(newSettings).then((newSetting) => {
|
2020-07-10 23:04:36 +02:00
|
|
|
if (SDK_SYNC_KEYS.includes(key) && !doNotDispatch) {
|
2019-12-11 21:09:27 +01:00
|
|
|
dispatch({
|
|
|
|
type: ACTIONS.SHARED_PREFERENCE_SET,
|
2020-02-19 07:31:40 +01:00
|
|
|
data: { key: key, value: newSetting[key] },
|
2019-12-11 21:09:27 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
// hardcoding this in lieu of a better solution
|
2020-07-10 23:04:36 +02:00
|
|
|
if (key === DAEMON_SETTINGS.LBRYUM_SERVERS) {
|
2019-12-11 21:09:27 +01:00
|
|
|
dispatch(doWalletReconnect());
|
2020-02-19 07:31:40 +01:00
|
|
|
// todo: add sdk reloadsettings() (or it happens automagically?)
|
2019-12-11 21:09:27 +01:00
|
|
|
}
|
|
|
|
});
|
2021-09-02 22:05:32 +02:00
|
|
|
Lbry.settings_get().then((settings) => {
|
2020-02-19 07:31:40 +01:00
|
|
|
analytics.toggleInternal(settings.share_usage_data);
|
2017-05-17 23:52:45 +02:00
|
|
|
dispatch({
|
2017-12-21 18:32:51 +01:00
|
|
|
type: ACTIONS.DAEMON_SETTINGS_RECEIVED,
|
2017-05-17 23:52:45 +02:00
|
|
|
data: {
|
2017-12-26 21:13:05 +01:00
|
|
|
settings,
|
2017-06-06 23:19:12 +02:00
|
|
|
},
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
2017-06-06 06:21:55 +02:00
|
|
|
}
|
2017-06-28 09:12:01 +02:00
|
|
|
|
2019-12-12 21:18:13 +01:00
|
|
|
export function doSaveCustomWalletServers(servers) {
|
2019-12-11 21:09:27 +01:00
|
|
|
return {
|
2019-12-12 21:18:13 +01:00
|
|
|
type: ACTIONS.SAVE_CUSTOM_WALLET_SERVERS,
|
2019-12-11 21:09:27 +01:00
|
|
|
data: servers,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-09-04 17:02:30 +02:00
|
|
|
export function doSetClientSetting(key, value, pushPrefs) {
|
2020-10-05 20:31:51 +02:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
|
|
|
const ready = selectPrefsReady(state);
|
|
|
|
|
2020-11-10 21:26:00 +01:00
|
|
|
if (!ready && pushPrefs) {
|
2020-10-05 20:31:51 +02:00
|
|
|
return dispatch(doAlertWaitingForSync());
|
|
|
|
}
|
|
|
|
|
2020-02-19 07:31:40 +01:00
|
|
|
dispatch({
|
|
|
|
type: ACTIONS.CLIENT_SETTING_CHANGED,
|
|
|
|
data: {
|
|
|
|
key,
|
|
|
|
value,
|
|
|
|
},
|
|
|
|
});
|
2020-11-10 21:26:00 +01:00
|
|
|
|
2020-09-04 17:02:30 +02:00
|
|
|
if (pushPrefs) {
|
|
|
|
dispatch(doPushSettingsToPrefs());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2018-01-14 10:14:15 +01:00
|
|
|
export function doUpdateIsNight() {
|
|
|
|
return {
|
|
|
|
type: ACTIONS.UPDATE_IS_NIGHT,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2018-03-08 00:03:45 +01:00
|
|
|
export function doUpdateIsNightAsync() {
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
2018-03-08 00:03:45 +01:00
|
|
|
dispatch(doUpdateIsNight());
|
2019-02-12 18:26:50 +01:00
|
|
|
|
2019-03-05 05:46:57 +01:00
|
|
|
setInterval(() => dispatch(doUpdateIsNight()), UPDATE_IS_NIGHT_INTERVAL);
|
2018-03-08 00:03:45 +01:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-08-18 18:54:55 +02:00
|
|
|
export function doSetDarkTime(value, options) {
|
|
|
|
const { fromTo, time } = options;
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
2019-09-17 20:49:03 +02:00
|
|
|
const darkModeTimes = state.settings.clientSettings[SETTINGS.DARK_MODE_TIMES];
|
2019-08-18 18:54:55 +02:00
|
|
|
const { hour, min } = darkModeTimes[fromTo];
|
|
|
|
const newHour = time === 'hour' ? value : hour;
|
|
|
|
const newMin = time === 'min' ? value : min;
|
|
|
|
const modifiedTimes = {
|
|
|
|
[fromTo]: {
|
|
|
|
hour: newHour,
|
|
|
|
min: newMin,
|
|
|
|
formattedTime: newHour + ':' + newMin,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
const mergedTimes = { ...darkModeTimes, ...modifiedTimes };
|
|
|
|
|
2019-09-24 01:47:58 +02:00
|
|
|
dispatch(doSetClientSetting(SETTINGS.DARK_MODE_TIMES, mergedTimes));
|
2019-08-18 18:54:55 +02:00
|
|
|
dispatch(doUpdateIsNight());
|
|
|
|
};
|
|
|
|
}
|
2019-11-05 19:54:58 +01:00
|
|
|
|
2020-09-11 20:35:50 +02:00
|
|
|
export function doGetWalletSyncPreference() {
|
|
|
|
const SYNC_KEY = 'enable-sync';
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
|
|
|
return Lbry.preference_get({ key: SYNC_KEY }).then((result) => {
|
2020-09-11 20:35:50 +02:00
|
|
|
const enabled = result && result[SYNC_KEY];
|
|
|
|
if (enabled !== null) {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.ENABLE_SYNC, enabled));
|
|
|
|
}
|
|
|
|
return enabled;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function doSetWalletSyncPreference(pref) {
|
|
|
|
const SYNC_KEY = 'enable-sync';
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
|
|
|
return Lbry.preference_set({ key: SYNC_KEY, value: pref }).then((result) => {
|
2020-09-11 20:35:50 +02:00
|
|
|
const enabled = result && result[SYNC_KEY];
|
|
|
|
if (enabled !== null) {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.ENABLE_SYNC, enabled));
|
|
|
|
}
|
|
|
|
return enabled;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-09-04 17:02:30 +02:00
|
|
|
export function doPushSettingsToPrefs() {
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
2020-09-04 17:02:30 +02:00
|
|
|
return new Promise((resolve, reject) => {
|
2020-07-29 04:52:44 +02:00
|
|
|
dispatch({
|
2021-10-17 10:36:14 +02:00
|
|
|
type: ACTIONS.SYNC_CLIENT_SETTINGS,
|
2020-07-29 04:52:44 +02:00
|
|
|
});
|
2020-09-04 17:02:30 +02:00
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function doEnterSettingsPage() {
|
|
|
|
return async (dispatch, getState) => {
|
|
|
|
const state = getState();
|
2021-11-23 05:29:04 +01:00
|
|
|
const syncEnabled = selectClientSetting(state, SETTINGS.ENABLE_SYNC);
|
2020-09-04 17:02:30 +02:00
|
|
|
const hasVerifiedEmail = state.user && state.user.user && state.user.user.has_verified_email;
|
2020-09-11 20:35:50 +02:00
|
|
|
if (IS_WEB && !hasVerifiedEmail) {
|
|
|
|
return;
|
|
|
|
}
|
2020-09-04 17:02:30 +02:00
|
|
|
dispatch(doSyncUnsubscribe());
|
|
|
|
if (syncEnabled && hasVerifiedEmail) {
|
2021-01-21 20:50:51 +01:00
|
|
|
await dispatch(doSyncLoop(true));
|
2020-09-04 17:02:30 +02:00
|
|
|
} else {
|
|
|
|
await dispatch(doGetAndPopulatePreferences());
|
2020-07-29 04:52:44 +02:00
|
|
|
}
|
2020-09-04 17:02:30 +02:00
|
|
|
dispatch(doSetSyncLock(true));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function doExitSettingsPage() {
|
|
|
|
return (dispatch, getState) => {
|
2020-09-11 20:35:50 +02:00
|
|
|
const state = getState();
|
|
|
|
const hasVerifiedEmail = state.user && state.user.user && state.user.user.has_verified_email;
|
|
|
|
if (IS_WEB && !hasVerifiedEmail) {
|
|
|
|
return;
|
|
|
|
}
|
2020-09-04 17:02:30 +02:00
|
|
|
dispatch(doSetSyncLock(false));
|
|
|
|
dispatch(doPushSettingsToPrefs());
|
2021-01-21 20:50:51 +01:00
|
|
|
// syncLoop is restarted in store.js sharedStateCB if necessary
|
2020-07-10 23:04:36 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-05-07 20:44:11 +02:00
|
|
|
export function doFetchLanguage(language) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const { settings } = getState();
|
|
|
|
|
|
|
|
if (settings.language !== language || (settings.loadedLanguages && !settings.loadedLanguages.includes(language))) {
|
|
|
|
// this should match the behavior/logic in index-web.html
|
|
|
|
fetch('https://lbry.com/i18n/get/lbry-desktop/app-strings/' + language + '.json')
|
2021-09-02 22:05:32 +02:00
|
|
|
.then((r) => r.json())
|
|
|
|
.then((j) => {
|
2020-05-07 20:44:11 +02:00
|
|
|
window.i18n_messages[language] = j;
|
|
|
|
dispatch({
|
2021-10-17 10:36:14 +02:00
|
|
|
type: ACTIONS.DOWNLOAD_LANGUAGE_SUCCESS,
|
2020-05-07 20:44:11 +02:00
|
|
|
data: {
|
|
|
|
language,
|
|
|
|
},
|
|
|
|
});
|
2020-06-18 17:41:37 +02:00
|
|
|
})
|
2021-09-02 22:05:32 +02:00
|
|
|
.catch((e) => {
|
2020-06-18 17:41:37 +02:00
|
|
|
dispatch({
|
2021-10-17 10:36:14 +02:00
|
|
|
type: ACTIONS.DOWNLOAD_LANGUAGE_FAILURE,
|
2020-06-18 17:41:37 +02:00
|
|
|
});
|
2020-05-07 20:44:11 +02:00
|
|
|
});
|
|
|
|
}
|
2021-12-31 11:24:18 +01:00
|
|
|
|
|
|
|
// @if process.env.NODE_ENV!='production'
|
|
|
|
if (!window.app_strings) {
|
|
|
|
fetch(`${URL_DEV}/app-strings.json`)
|
|
|
|
.then((r) => r.json())
|
|
|
|
.then((j) => {
|
|
|
|
window.app_strings = j;
|
2022-04-13 16:21:09 +02:00
|
|
|
})
|
|
|
|
.catch(() => {});
|
2021-12-31 11:24:18 +01:00
|
|
|
}
|
|
|
|
// @endif
|
2020-05-07 20:44:11 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-04-29 09:57:23 +02:00
|
|
|
function populateCategoryTitles(categories) {
|
|
|
|
if (categories) {
|
|
|
|
window.CATEGORY_PAGE_TITLE = {};
|
|
|
|
Object.values(categories).forEach((x) => {
|
|
|
|
window.CATEGORY_PAGE_TITLE[x.name] = x.label;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-03 15:22:59 +01:00
|
|
|
export function doFetchHomepages() {
|
|
|
|
return (dispatch) => {
|
2022-04-15 14:50:15 +02:00
|
|
|
// -- Use this env flag to use local homepage data. Otherwise, it will grab from `/$/api/content/v*/get`.
|
2022-03-03 15:22:59 +01:00
|
|
|
// @if USE_LOCAL_HOMEPAGE_DATA='true'
|
|
|
|
const homepages = require('homepages');
|
|
|
|
if (homepages) {
|
2022-04-15 14:50:15 +02:00
|
|
|
const v2 = {};
|
|
|
|
const homepageKeys = Object.keys(homepages);
|
|
|
|
homepageKeys.forEach((hp) => {
|
2022-05-09 09:28:39 +02:00
|
|
|
v2[hp] = homepages[hp];
|
2022-04-15 14:50:15 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
window.homepages = v2;
|
2022-04-29 09:57:23 +02:00
|
|
|
populateCategoryTitles(window.homepages?.en?.categories);
|
2022-04-13 16:53:58 +02:00
|
|
|
dispatch({ type: ACTIONS.FETCH_HOMEPAGES_DONE });
|
2022-03-03 15:22:59 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
// @endif
|
|
|
|
|
2022-04-15 14:50:15 +02:00
|
|
|
fetch('https://odysee.com/$/api/content/v2/get')
|
2022-03-03 15:22:59 +01:00
|
|
|
.then((response) => response.json())
|
|
|
|
.then((json) => {
|
|
|
|
if (json?.status === 'success' && json?.data) {
|
|
|
|
window.homepages = json.data;
|
2022-04-29 09:57:23 +02:00
|
|
|
populateCategoryTitles(window.homepages?.en?.categories);
|
2022-03-03 15:22:59 +01:00
|
|
|
dispatch({ type: ACTIONS.FETCH_HOMEPAGES_DONE });
|
|
|
|
} else {
|
|
|
|
dispatch({ type: ACTIONS.FETCH_HOMEPAGES_FAILED });
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(() => {
|
|
|
|
dispatch({ type: ACTIONS.FETCH_HOMEPAGES_FAILED });
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2020-11-20 14:21:31 +01:00
|
|
|
export function doSetHomepage(code) {
|
2021-10-27 19:25:08 +02:00
|
|
|
return (dispatch, getState) => {
|
2022-03-21 14:25:14 +01:00
|
|
|
const languageCode = code === getDefaultLanguage() ? null : code;
|
|
|
|
|
2020-11-20 14:21:31 +01:00
|
|
|
dispatch(doSetClientSetting(SETTINGS.HOMEPAGE, languageCode));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2019-11-05 19:54:58 +01:00
|
|
|
export function doSetLanguage(language) {
|
2019-11-12 23:25:44 +01:00
|
|
|
return (dispatch, getState) => {
|
|
|
|
const { settings } = getState();
|
2020-11-11 21:56:31 +01:00
|
|
|
const { daemonSettings } = settings;
|
|
|
|
const { share_usage_data: shareSetting } = daemonSettings;
|
|
|
|
const isSharingData = shareSetting || IS_WEB;
|
2020-11-20 14:21:31 +01:00
|
|
|
let languageSetting;
|
2021-01-06 19:13:56 +01:00
|
|
|
if (language === getDefaultLanguage()) {
|
2020-11-20 14:21:31 +01:00
|
|
|
languageSetting = null;
|
|
|
|
} else {
|
|
|
|
languageSetting = language;
|
|
|
|
}
|
2020-11-11 21:56:31 +01:00
|
|
|
|
2020-11-20 14:21:31 +01:00
|
|
|
if (
|
|
|
|
settings.language !== languageSetting ||
|
|
|
|
(settings.loadedLanguages && !settings.loadedLanguages.includes(language))
|
|
|
|
) {
|
2019-11-12 23:25:44 +01:00
|
|
|
// this should match the behavior/logic in index-web.html
|
|
|
|
fetch('https://lbry.com/i18n/get/lbry-desktop/app-strings/' + language + '.json')
|
2021-09-02 22:05:32 +02:00
|
|
|
.then((r) => r.json())
|
|
|
|
.then((j) => {
|
2019-11-12 23:25:44 +01:00
|
|
|
window.i18n_messages[language] = j;
|
|
|
|
dispatch({
|
2021-10-17 10:36:14 +02:00
|
|
|
type: ACTIONS.DOWNLOAD_LANGUAGE_SUCCESS,
|
2019-11-12 23:25:44 +01:00
|
|
|
data: {
|
|
|
|
language,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
})
|
|
|
|
.then(() => {
|
|
|
|
// set on localStorage so it can be read outside of redux
|
|
|
|
window.localStorage.setItem(SETTINGS.LANGUAGE, language);
|
2020-11-20 14:21:31 +01:00
|
|
|
dispatch(doSetClientSetting(SETTINGS.LANGUAGE, languageSetting));
|
2020-11-11 21:56:31 +01:00
|
|
|
if (isSharingData) {
|
|
|
|
Lbryio.call('user', 'language', {
|
|
|
|
language: language,
|
|
|
|
});
|
|
|
|
}
|
2019-11-12 23:25:44 +01:00
|
|
|
})
|
2021-09-02 22:05:32 +02:00
|
|
|
.catch((e) => {
|
2020-05-07 20:44:11 +02:00
|
|
|
window.localStorage.setItem(SETTINGS.LANGUAGE, DEFAULT_LANGUAGE);
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.LANGUAGE, DEFAULT_LANGUAGE));
|
2019-11-12 23:25:44 +01:00
|
|
|
const languageName = SUPPORTED_LANGUAGES[language] ? SUPPORTED_LANGUAGES[language] : language;
|
|
|
|
dispatch(
|
|
|
|
doToast({
|
|
|
|
message: __('Failed to load %language% translations.', { language: languageName }),
|
2019-11-14 00:54:41 +01:00
|
|
|
isError: true,
|
2019-11-12 23:25:44 +01:00
|
|
|
})
|
|
|
|
);
|
2019-11-08 21:51:42 +01:00
|
|
|
});
|
2019-11-12 23:25:44 +01:00
|
|
|
}
|
2019-11-05 19:54:58 +01:00
|
|
|
};
|
|
|
|
}
|
2019-11-18 19:30:15 +01:00
|
|
|
|
|
|
|
export function doSetAutoLaunch(value) {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
2021-11-23 05:29:04 +01:00
|
|
|
const autoLaunch = selectClientSetting(state, SETTINGS.AUTO_LAUNCH);
|
2019-11-18 19:30:15 +01:00
|
|
|
|
2019-11-28 02:55:29 +01:00
|
|
|
if (IS_MAC || process.env.NODE_ENV !== 'production') {
|
2019-11-18 19:30:15 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (value === undefined) {
|
2021-09-02 22:05:32 +02:00
|
|
|
launcher.isEnabled().then((isEnabled) => {
|
2019-11-18 19:30:15 +01:00
|
|
|
if (isEnabled) {
|
|
|
|
if (!autoLaunch) {
|
|
|
|
launcher.disable().then(() => {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTO_LAUNCH, false));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (autoLaunch || autoLaunch === null || autoLaunch === undefined) {
|
|
|
|
launcher.enable().then(() => {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTO_LAUNCH, true));
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else if (value === true) {
|
2021-09-02 22:05:32 +02:00
|
|
|
launcher.isEnabled().then(function (isEnabled) {
|
2019-11-18 19:30:15 +01:00
|
|
|
if (!isEnabled) {
|
|
|
|
launcher.enable().then(() => {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTO_LAUNCH, true));
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTO_LAUNCH, true));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
// value = false
|
2021-09-02 22:05:32 +02:00
|
|
|
launcher.isEnabled().then(function (isEnabled) {
|
2019-11-18 19:30:15 +01:00
|
|
|
if (isEnabled) {
|
|
|
|
launcher.disable().then(() => {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTO_LAUNCH, false));
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTO_LAUNCH, false));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
2020-08-13 18:57:00 +02:00
|
|
|
|
|
|
|
export function doSetAppToTrayWhenClosed(value) {
|
2021-09-02 22:05:32 +02:00
|
|
|
return (dispatch) => {
|
2020-08-13 18:57:00 +02:00
|
|
|
window.localStorage.setItem(SETTINGS.TO_TRAY_WHEN_CLOSED, value);
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.TO_TRAY_WHEN_CLOSED, value));
|
|
|
|
};
|
|
|
|
}
|
2021-01-08 16:21:27 +01:00
|
|
|
|
|
|
|
export function toggleVideoTheaterMode() {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
2021-11-23 05:29:04 +01:00
|
|
|
const videoTheaterMode = selectClientSetting(state, SETTINGS.VIDEO_THEATER_MODE);
|
2021-01-08 16:21:27 +01:00
|
|
|
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.VIDEO_THEATER_MODE, !videoTheaterMode));
|
|
|
|
};
|
|
|
|
}
|
2021-09-02 22:05:32 +02:00
|
|
|
|
|
|
|
export function toggleAutoplayNext() {
|
|
|
|
return (dispatch, getState) => {
|
|
|
|
const state = getState();
|
2021-09-09 18:53:27 +02:00
|
|
|
const ready = selectPrefsReady(state);
|
2021-11-23 05:29:04 +01:00
|
|
|
const autoplayNext = selectClientSetting(state, SETTINGS.AUTOPLAY_NEXT);
|
2021-09-02 22:05:32 +02:00
|
|
|
|
2021-09-09 18:53:27 +02:00
|
|
|
dispatch(doSetClientSetting(SETTINGS.AUTOPLAY_NEXT, !autoplayNext, ready));
|
2021-09-10 19:27:21 +02:00
|
|
|
|
|
|
|
dispatch(
|
|
|
|
doToast({
|
|
|
|
message: autoplayNext ? __('Autoplay Next is off.') : __('Autoplay Next is on.'),
|
|
|
|
})
|
|
|
|
);
|
2021-09-02 22:05:32 +02:00
|
|
|
};
|
|
|
|
}
|
2022-04-19 18:55:32 +02:00
|
|
|
|
|
|
|
export const doSetDefaultVideoQuality = (value) => (dispatch) =>
|
|
|
|
dispatch(doSetClientSetting(SETTINGS.DEFAULT_VIDEO_QUALITY, value, true));
|