2018-03-09 20:59:12 +00:00
|
|
|
const Setting = require('lib/models/Setting.js');
|
2018-03-26 17:52:49 +00:00
|
|
|
const { Platform } = require('react-native');
|
2017-08-01 17:59:01 +00:00
|
|
|
|
2017-07-21 22:40:02 +01:00
|
|
|
const globalStyle = {
|
2017-07-30 23:04:26 +02:00
|
|
|
fontSize: 16,
|
2017-07-21 22:40:02 +01:00
|
|
|
margin: 15, // No text and no interactive component should be within this margin
|
2017-07-30 23:04:26 +02:00
|
|
|
itemMarginTop: 10,
|
|
|
|
itemMarginBottom: 10,
|
2019-07-29 15:43:53 +02:00
|
|
|
backgroundColor: '#ffffff',
|
|
|
|
color: '#555555', // For regular text
|
|
|
|
colorError: 'red',
|
|
|
|
colorWarn: '#9A5B00',
|
|
|
|
colorFaded: '#777777', // For less important text
|
2017-07-30 23:04:26 +02:00
|
|
|
fontSizeSmaller: 14,
|
2019-07-29 15:43:53 +02:00
|
|
|
dividerColor: '#dddddd',
|
|
|
|
strongDividerColor: '#aaaaaa',
|
2018-03-09 20:59:12 +00:00
|
|
|
selectedColor: '#e5e5e5',
|
2019-06-08 00:23:17 +01:00
|
|
|
headerBackgroundColor: '#F0F0F0',
|
2018-01-25 19:01:14 +00:00
|
|
|
disabledOpacity: 0.2,
|
2018-12-15 01:42:19 +01:00
|
|
|
colorUrl: '#7B81FF',
|
2019-07-29 15:43:53 +02:00
|
|
|
textSelectionColor: '#0096FF',
|
2017-07-21 22:40:02 +01:00
|
|
|
|
2019-07-29 15:43:53 +02:00
|
|
|
raisedBackgroundColor: '#0080EF',
|
|
|
|
raisedColor: '#003363',
|
|
|
|
raisedHighlightedColor: '#ffffff',
|
2017-07-27 18:25:42 +01:00
|
|
|
|
2019-07-29 15:43:53 +02:00
|
|
|
warningBackgroundColor: '#FFD08D',
|
2017-12-30 20:57:34 +01:00
|
|
|
|
2017-07-21 22:40:02 +01:00
|
|
|
// For WebView - must correspond to the properties above
|
2018-03-09 20:59:12 +00:00
|
|
|
htmlFontSize: '16px',
|
2019-02-06 23:52:29 +00:00
|
|
|
htmlColor: '#222222',
|
2018-03-09 20:59:12 +00:00
|
|
|
htmlBackgroundColor: 'white',
|
2019-02-06 23:52:29 +00:00
|
|
|
htmlDividerColor: 'rgb(230,230,230)',
|
|
|
|
htmlLinkColor: 'rgb(80,130,190)',
|
|
|
|
htmlLineHeight: '1.6em',
|
|
|
|
|
|
|
|
htmlCodeBackgroundColor: 'rgb(243, 243, 243)',
|
|
|
|
htmlCodeBorderColor: 'rgb(220, 220, 220)',
|
|
|
|
htmlCodeColor: 'rgb(0,0,0)',
|
2019-03-08 17:14:17 +00:00
|
|
|
|
2019-12-29 18:58:40 +01:00
|
|
|
codeThemeCss: 'atom-one-light.css',
|
2017-07-21 22:40:02 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
globalStyle.marginRight = globalStyle.margin;
|
|
|
|
globalStyle.marginLeft = globalStyle.margin;
|
2017-07-22 16:55:09 +01:00
|
|
|
globalStyle.marginTop = globalStyle.margin;
|
|
|
|
globalStyle.marginBottom = globalStyle.margin;
|
2019-09-19 22:51:18 +01:00
|
|
|
globalStyle.htmlMarginLeft = `${((globalStyle.marginLeft / 10) * 0.6).toFixed(2)}em`;
|
2017-07-21 22:40:02 +01:00
|
|
|
|
2017-08-01 17:59:01 +00:00
|
|
|
let themeCache_ = {};
|
|
|
|
|
2018-03-26 17:52:49 +00:00
|
|
|
function addExtraStyles(style) {
|
|
|
|
style.icon = {
|
|
|
|
color: style.color,
|
|
|
|
fontSize: 30,
|
|
|
|
};
|
|
|
|
|
|
|
|
style.lineInput = {
|
|
|
|
color: style.color,
|
|
|
|
backgroundColor: style.backgroundColor,
|
2018-12-15 01:42:19 +01:00
|
|
|
borderBottomWidth: 1,
|
|
|
|
borderColor: style.strongDividerColor,
|
|
|
|
paddingBottom: 0,
|
2018-03-26 17:52:49 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
if (Platform.OS === 'ios') {
|
2019-02-03 16:57:29 +00:00
|
|
|
delete style.lineInput.borderBottomWidth;
|
|
|
|
delete style.lineInput.borderColor;
|
2018-03-26 17:52:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
style.buttonRow = {
|
|
|
|
flexDirection: 'row',
|
|
|
|
borderTopWidth: 1,
|
|
|
|
borderTopColor: style.dividerColor,
|
|
|
|
paddingTop: 10,
|
|
|
|
};
|
|
|
|
|
|
|
|
style.normalText = {
|
|
|
|
color: style.color,
|
|
|
|
fontSize: style.fontSize,
|
|
|
|
};
|
|
|
|
|
2018-03-27 17:41:19 +00:00
|
|
|
style.urlText = {
|
|
|
|
color: style.colorUrl,
|
|
|
|
fontSize: style.fontSize,
|
|
|
|
};
|
|
|
|
|
2019-06-08 00:23:17 +01:00
|
|
|
style.headerStyle = {
|
|
|
|
color: style.color,
|
|
|
|
fontSize: style.fontSize * 1.2,
|
|
|
|
fontWeight: 'bold',
|
|
|
|
};
|
|
|
|
|
|
|
|
style.headerWrapperStyle = {
|
|
|
|
backgroundColor: style.headerBackgroundColor,
|
|
|
|
};
|
|
|
|
|
2018-03-26 17:52:49 +00:00
|
|
|
return style;
|
|
|
|
}
|
|
|
|
|
2019-09-17 13:32:00 -07:00
|
|
|
function editorFont(fontId) {
|
|
|
|
// IMPORTANT: The font mapping must match the one in Setting.js
|
|
|
|
const fonts = {
|
|
|
|
[Setting.FONT_DEFAULT]: null,
|
|
|
|
[Setting.FONT_MENLO]: 'Menlo',
|
|
|
|
[Setting.FONT_COURIER_NEW]: 'Courier New',
|
|
|
|
[Setting.FONT_AVENIR]: 'Avenir',
|
|
|
|
[Setting.FONT_MONOSPACE]: 'monospace',
|
|
|
|
};
|
|
|
|
if (!fontId) {
|
|
|
|
console.warn('Editor font not set! Falling back to default font."');
|
|
|
|
fontId = Setting.FONT_DEFAULT;
|
|
|
|
}
|
|
|
|
return fonts[fontId];
|
|
|
|
}
|
|
|
|
|
2017-08-01 17:59:01 +00:00
|
|
|
function themeStyle(theme) {
|
2018-04-16 15:15:29 +02:00
|
|
|
if (!theme) {
|
2019-09-17 13:32:00 -07:00
|
|
|
console.warn('Theme not set! Defaulting to Light theme.');
|
2018-04-16 15:15:29 +02:00
|
|
|
theme = Setting.THEME_LIGHT;
|
|
|
|
}
|
2018-03-27 17:41:19 +00:00
|
|
|
|
2017-08-01 17:59:01 +00:00
|
|
|
if (themeCache_[theme]) return themeCache_[theme];
|
|
|
|
|
|
|
|
let output = Object.assign({}, globalStyle);
|
2018-03-26 17:52:49 +00:00
|
|
|
if (theme == Setting.THEME_LIGHT) return addExtraStyles(output);
|
2020-02-12 00:32:15 +01:00
|
|
|
else if (theme == Setting.THEME_OLED_DARK) {
|
|
|
|
output.backgroundColor = '#000000';
|
|
|
|
output.color = '#dddddd';
|
|
|
|
output.colorFaded = '#777777';
|
|
|
|
output.dividerColor = '#555555';
|
|
|
|
output.strongDividerColor = '#888888';
|
|
|
|
output.selectedColor = '#333333';
|
|
|
|
output.textSelectionColor = '#00AEFF';
|
|
|
|
output.headerBackgroundColor = '#2D3136';
|
|
|
|
|
|
|
|
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)';
|
|
|
|
|
|
|
|
output.htmlDividerColor = '#3D444E';
|
|
|
|
output.htmlLinkColor = 'rgb(166,166,255)';
|
|
|
|
output.htmlCodeColor = '#ffffff';
|
|
|
|
output.htmlCodeBackgroundColor = 'rgb(47, 48, 49)';
|
|
|
|
output.htmlCodeBorderColor = 'rgb(70, 70, 70)';
|
|
|
|
|
|
|
|
output.codeThemeCss = 'hljs-atom-one-dark-reasonable.css';
|
|
|
|
|
|
|
|
output.colorUrl = '#7B81FF';
|
|
|
|
|
|
|
|
themeCache_[theme] = output;
|
|
|
|
return addExtraStyles(themeCache_[theme]);
|
|
|
|
}
|
2017-08-01 17:59:01 +00:00
|
|
|
|
2018-03-09 20:59:12 +00:00
|
|
|
output.backgroundColor = '#1D2024';
|
|
|
|
output.color = '#dddddd';
|
|
|
|
output.colorFaded = '#777777';
|
|
|
|
output.dividerColor = '#555555';
|
2018-12-15 01:42:19 +01:00
|
|
|
output.strongDividerColor = '#888888';
|
2018-03-09 20:59:12 +00:00
|
|
|
output.selectedColor = '#333333';
|
2018-04-11 19:25:07 +02:00
|
|
|
output.textSelectionColor = '#00AEFF';
|
2019-06-08 00:23:17 +01:00
|
|
|
output.headerBackgroundColor = '#2D3136';
|
2017-08-01 17:59:01 +00:00
|
|
|
|
2019-07-29 15:43:53 +02:00
|
|
|
output.raisedBackgroundColor = '#0F2051';
|
|
|
|
output.raisedColor = '#788BC3';
|
|
|
|
output.raisedHighlightedColor = '#ffffff';
|
2017-08-01 17:59:01 +00:00
|
|
|
|
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-08-01 18:53:50 +00:00
|
|
|
|
2019-02-06 23:52:29 +00:00
|
|
|
output.htmlDividerColor = '#3D444E';
|
|
|
|
output.htmlLinkColor = 'rgb(166,166,255)';
|
|
|
|
output.htmlCodeColor = '#ffffff';
|
|
|
|
output.htmlCodeBackgroundColor = 'rgb(47, 48, 49)';
|
|
|
|
output.htmlCodeBorderColor = 'rgb(70, 70, 70)';
|
|
|
|
|
2020-02-08 11:31:22 +00:00
|
|
|
output.codeThemeCss = 'atom-one-dark-reasonable.css';
|
2019-03-08 17:14:17 +00:00
|
|
|
|
2018-12-15 01:42:19 +01:00
|
|
|
output.colorUrl = '#7B81FF';
|
|
|
|
|
2017-08-01 17:59:01 +00:00
|
|
|
themeCache_[theme] = output;
|
2018-03-26 17:52:49 +00:00
|
|
|
return addExtraStyles(themeCache_[theme]);
|
2017-08-01 17:59:01 +00:00
|
|
|
}
|
|
|
|
|
2019-09-17 13:32:00 -07:00
|
|
|
module.exports = { globalStyle, themeStyle, editorFont };
|