lbry-desktop/ui/js/actions/settings.js

185 lines
4.5 KiB
JavaScript
Raw Normal View History

2017-06-06 23:19:12 +02:00
import * as types from "constants/action_types";
2017-08-20 01:59:48 +02:00
import * as settings from "constants/settings";
2017-08-08 11:36:14 +02:00
import batchActions from "util/batchActions";
2017-08-24 20:28:05 +02:00
2017-06-06 23:19:12 +02:00
import lbry from "lbry";
2017-08-08 11:36:14 +02:00
import fs from "fs";
import http from "http";
2017-08-24 18:11:39 +02:00
const { remote } = require("electron");
const { extname } = require("path");
const { download } = remote.require("electron-dl");
const { readdirSync } = remote.require("fs");
export function doFetchDaemonSettings() {
return function(dispatch, getState) {
2017-06-06 23:19:12 +02:00
lbry.settings_get().then(settings => {
dispatch({
type: types.DAEMON_SETTINGS_RECEIVED,
data: {
2017-06-06 23:19:12 +02:00
settings,
},
});
});
};
}
export function doSetDaemonSetting(key, value) {
return function(dispatch, getState) {
let settings = {};
settings[key] = value;
2017-06-06 23:19:12 +02:00
lbry.settings_set(settings).then(settings);
lbry.settings_get().then(settings => {
dispatch({
type: types.DAEMON_SETTINGS_RECEIVED,
data: {
2017-06-06 23:19:12 +02:00
settings,
},
});
});
};
2017-06-06 06:21:55 +02:00
}
2017-06-28 09:12:01 +02:00
export function doSetClientSetting(key, value) {
lbry.setClientSetting(key, value);
return {
type: types.CLIENT_SETTING_CHANGED,
data: {
key,
value,
},
};
}
2017-08-07 02:55:31 +02:00
2017-08-24 18:11:39 +02:00
export function doGetThemes() {
const dir = `${remote.app.getAppPath()}/dist/themes`;
// Get all .css files
const files = readdirSync(dir).filter(file => extname(file) === ".css");
return function(dispatch, getState) {
// Find themes
const themes = files.map(file => ({
name: file.replace(".css", ""),
path: `./themes/${file}`,
}));
2017-08-24 18:14:30 +02:00
dispatch(doSetClientSetting(settings.THEMES, themes));
2017-08-24 18:11:39 +02:00
};
}
2017-08-20 01:59:48 +02:00
export function doSetTheme(name) {
return function(dispatch, getState) {
2017-08-24 18:55:24 +02:00
// Find a theme from themes list
const find = themeName => themes.find(theme => theme.name === themeName);
2017-08-20 01:59:48 +02:00
// Get themes
const themes = lbry.getClientSetting(settings.THEMES);
2017-08-24 18:55:24 +02:00
// Find theme and set fallback
const theme = find(name) || find("light");
2017-08-07 02:55:31 +02:00
2017-08-20 01:59:48 +02:00
if (theme.path) {
2017-08-24 18:55:24 +02:00
// load css
2017-08-20 01:59:48 +02:00
const link = document.getElementById("theme");
link.href = theme.path;
2017-08-20 00:03:40 +02:00
2017-08-24 18:55:24 +02:00
// update theme
2017-08-20 01:59:48 +02:00
dispatch(doSetClientSetting(settings.THEME, theme.name));
}
2017-08-24 20:28:05 +02:00
}
2017-08-19 20:03:51 +02:00
export function doDownloadLanguage(langFile) {
2017-08-08 11:36:14 +02:00
return function(dispatch, getState) {
2017-08-19 20:03:51 +02:00
const destinationPath = `app/locales/${langFile}`;
const language = langFile.replace(".json", "");
const req = http.get(
{
headers: {
"Content-Type": "text/html",
},
host: "i18n.lbry.io",
path: `/langs/${langFile}`,
},
response => {
if (response.statusCode === 200) {
const file = fs.createWriteStream(destinationPath);
file.on("error", errorHandler);
2017-08-08 11:36:14 +02:00
file.on("finish", () => {
file.close();
// push to our local list
dispatch({
type: types.DOWNLOAD_LANGUAGE_SUCCEEDED,
2017-08-19 20:03:51 +02:00
data: { language: language },
2017-08-08 11:36:14 +02:00
});
});
response.pipe(file);
2017-08-19 20:03:51 +02:00
} else {
errorHandler(new Error("Language request failed."));
2017-08-08 11:36:14 +02:00
}
2017-08-19 20:03:51 +02:00
}
);
2017-08-08 11:36:14 +02:00
2017-08-19 20:03:51 +02:00
const errorHandler = err => {
fs.unlink(destinationPath, () => {}); // Delete the file async. (But we don't check the result)
2017-08-08 11:36:14 +02:00
2017-08-19 20:03:51 +02:00
dispatch({
type: types.DOWNLOAD_LANGUAGE_FAILED,
data: { language },
});
};
2017-08-08 11:36:14 +02:00
2017-08-19 20:03:51 +02:00
req.setTimeout(30000, function() {
req.abort();
2017-08-08 11:36:14 +02:00
});
2017-08-19 20:03:51 +02:00
req.on("error", errorHandler);
req.end();
2017-08-08 11:36:14 +02:00
};
}
export function doDownloadLanguages() {
return function(dispatch, getState) {
if (!fs.existsSync(app.i18n.directory)) {
fs.mkdirSync(app.i18n.directory);
2017-08-08 11:36:14 +02:00
}
const xhr = new XMLHttpRequest();
xhr.onreadystatechange = () => {
if (xhr.readyState === XMLHttpRequest.DONE) {
if (xhr.status === 200) {
try {
const files = JSON.parse(xhr.responseText);
const actions = [];
files.forEach(file => {
actions.push(doDownloadLanguage(file));
});
2017-08-19 20:03:51 +02:00
dispatch(batchActions(...actions));
} catch (err) {
throw err;
}
} else {
throw new Error(
__("The list of available languages could not be retrieved.")
);
}
}
};
xhr.open("get", "http://i18n.lbry.io");
xhr.send();
2017-08-19 20:03:51 +02:00
};
}
export function doChangeLanguage(language) {
return function(dispatch, getState) {
2017-08-24 19:33:41 +02:00
lbry.setClientSetting(settings.LANGUAGE, language);
2017-08-19 20:03:51 +02:00
app.i18n.setLocale(language);
2017-08-07 02:55:31 +02:00
};
}