2018-03-09 20:59:12 +00:00
|
|
|
const Setting = require('lib/models/Setting.js');
|
2017-11-06 20:54:58 +00:00
|
|
|
|
|
|
|
const globalStyle = {
|
2018-03-09 20:59:12 +00:00
|
|
|
fontSize: 12 * Setting.value('style.zoom')/100,
|
|
|
|
fontFamily: 'sans-serif',
|
2017-11-06 20:54:58 +00:00
|
|
|
margin: 15, // No text and no interactive component should be within this margin
|
|
|
|
itemMarginTop: 10,
|
|
|
|
itemMarginBottom: 10,
|
|
|
|
backgroundColor: "#ffffff",
|
2018-03-09 20:59:12 +00:00
|
|
|
backgroundColorTransparent: 'rgba(255,255,255,0.9)',
|
2017-11-08 17:51:55 +00:00
|
|
|
oddBackgroundColor: "#dddddd",
|
2017-11-08 22:23:26 +00:00
|
|
|
color: "#222222", // For regular text
|
2017-11-06 20:54:58 +00:00
|
|
|
colorError: "red",
|
|
|
|
colorWarn: "#9A5B00",
|
|
|
|
colorFaded: "#777777", // For less important text
|
|
|
|
fontSizeSmaller: 14,
|
|
|
|
dividerColor: "#dddddd",
|
2018-03-09 20:59:12 +00:00
|
|
|
selectedColor: '#e5e5e5',
|
2017-11-06 20:54:58 +00:00
|
|
|
disabledOpacity: 0.3,
|
2017-11-08 17:51:55 +00:00
|
|
|
buttonMinWidth: 50,
|
|
|
|
buttonMinHeight: 30,
|
|
|
|
textAreaLineHeight: 17,
|
2017-11-06 20:54:58 +00:00
|
|
|
|
2017-11-12 17:53:26 +00:00
|
|
|
backgroundColor2: "#2B2634",
|
2017-11-08 22:48:19 +00:00
|
|
|
color2: "#ffffff",
|
2017-11-12 17:53:26 +00:00
|
|
|
selectedColor2: "#5A4D70",
|
2017-11-12 18:57:59 +00:00
|
|
|
colorError2: "#ff6c6c",
|
2017-11-08 22:48:19 +00:00
|
|
|
|
2017-12-04 23:57:13 +00:00
|
|
|
warningBackgroundColor: "#FFD08D",
|
|
|
|
|
2017-11-08 22:23:26 +00:00
|
|
|
headerHeight: 35,
|
|
|
|
headerButtonHPadding: 6,
|
|
|
|
|
2017-11-29 23:03:10 +00:00
|
|
|
toolbarHeight: 35,
|
|
|
|
|
2017-11-06 20:54:58 +00:00
|
|
|
raisedBackgroundColor: "#0080EF",
|
|
|
|
raisedColor: "#003363",
|
|
|
|
raisedHighlightedColor: "#ffffff",
|
|
|
|
};
|
|
|
|
|
2017-11-08 22:23:26 +00:00
|
|
|
// For WebView - must correspond to the properties above
|
2018-03-09 20:59:12 +00:00
|
|
|
globalStyle.htmlFontSize = globalStyle.fontSize + 'px';
|
|
|
|
globalStyle.htmlColor ='black'; // Note: CSS in WebView component only supports named colors or rgb() notation
|
|
|
|
globalStyle.htmlBackgroundColor ='white';
|
|
|
|
globalStyle.htmlDividerColor = 'rgb(150,150,150)';
|
|
|
|
globalStyle.htmlLinkColor ='blue';
|
|
|
|
globalStyle.htmlLineHeight ='20px';
|
2017-11-08 22:23:26 +00:00
|
|
|
|
2017-11-06 20:54:58 +00:00
|
|
|
globalStyle.marginRight = globalStyle.margin;
|
|
|
|
globalStyle.marginLeft = globalStyle.margin;
|
|
|
|
globalStyle.marginTop = globalStyle.margin;
|
|
|
|
globalStyle.marginBottom = globalStyle.margin;
|
2018-03-09 20:59:12 +00:00
|
|
|
globalStyle.htmlMarginLeft = ((globalStyle.marginLeft / 10) * 0.6).toFixed(2) + 'em';
|
2017-11-06 20:54:58 +00:00
|
|
|
|
|
|
|
globalStyle.icon = {
|
|
|
|
color: globalStyle.color,
|
|
|
|
fontSize: 30,
|
|
|
|
};
|
|
|
|
|
|
|
|
globalStyle.lineInput = {
|
|
|
|
color: globalStyle.color,
|
|
|
|
backgroundColor: globalStyle.backgroundColor,
|
|
|
|
};
|
|
|
|
|
2017-11-11 23:13:14 +00:00
|
|
|
globalStyle.textStyle = {
|
|
|
|
color: globalStyle.color,
|
|
|
|
fontFamily: globalStyle.fontFamily,
|
|
|
|
fontSize: globalStyle.fontSize,
|
2018-03-09 20:59:12 +00:00
|
|
|
lineHeight: '1.6em',
|
2017-11-11 23:13:14 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
globalStyle.textStyle2 = Object.assign({}, globalStyle.textStyle, {
|
|
|
|
color: globalStyle.color2,
|
|
|
|
});
|
|
|
|
|
2017-12-24 09:36:31 +01:00
|
|
|
globalStyle.h1Style = Object.assign({}, globalStyle.textStyle);
|
|
|
|
globalStyle.h1Style.fontSize *= 1.5;
|
|
|
|
|
2017-12-05 18:56:39 +00:00
|
|
|
globalStyle.h2Style = Object.assign({}, globalStyle.textStyle);
|
|
|
|
globalStyle.h2Style.fontSize *= 1.3;
|
|
|
|
|
2017-11-06 20:54:58 +00:00
|
|
|
let themeCache_ = {};
|
|
|
|
|
|
|
|
function themeStyle(theme) {
|
2018-03-09 20:59:12 +00:00
|
|
|
if (!theme) throw new Error('Theme must be specified');
|
2017-11-06 20:54:58 +00:00
|
|
|
if (themeCache_[theme]) return themeCache_[theme];
|
|
|
|
|
|
|
|
let output = Object.assign({}, globalStyle);
|
|
|
|
if (theme == Setting.THEME_LIGHT) return output;
|
|
|
|
|
2018-03-09 20:59:12 +00:00
|
|
|
output.backgroundColor = '#1D2024';
|
|
|
|
output.color = '#dddddd';
|
|
|
|
output.colorFaded = '#777777';
|
|
|
|
output.dividerColor = '#555555';
|
|
|
|
output.selectedColor = '#333333';
|
2017-11-06 20:54:58 +00:00
|
|
|
|
|
|
|
output.raisedBackgroundColor = "#0F2051";
|
|
|
|
output.raisedColor = "#788BC3";
|
|
|
|
output.raisedHighlightedColor = "#ffffff";
|
|
|
|
|
2018-03-09 20:59:12 +00:00
|
|
|
output.htmlColor = 'rgb(220,220,220)';
|
|
|
|
output.htmlBackgroundColor = 'rgb(29,32,36)';
|
|
|
|
output.htmlLinkColor = 'rgb(166,166,255)';
|
2017-11-06 20:54:58 +00:00
|
|
|
|
|
|
|
themeCache_[theme] = output;
|
|
|
|
return themeCache_[theme];
|
|
|
|
}
|
|
|
|
|
2018-03-09 20:59:12 +00:00
|
|
|
module.exports = { themeStyle };
|