1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-08 13:06:15 +02:00
joplin/ElectronClient/app/theme.js

109 lines
3.0 KiB
JavaScript
Raw Normal View History

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