1
0
mirror of https://github.com/laurent22/joplin.git synced 2024-12-30 10:36:35 +02:00
joplin/packages/app-mobile/components/global-style.ts

116 lines
2.5 KiB
TypeScript
Raw Normal View History

2022-09-09 16:06:03 +02:00
import Setting from '@joplin/lib/models/Setting';
const { Platform } = require('react-native');
2022-09-09 16:06:03 +02:00
import { themeById } from '@joplin/lib/theme';
export interface Style {
[key: string]: any;
}
interface Fonts {
[key: number]: string;
}
interface ThemeCache {
[key: string]: any;
}
2017-08-01 19:59:01 +02:00
const baseStyle = {
appearance: 'light',
2017-07-30 23:04:26 +02:00
fontSize: 16,
noteViewerFontSize: 16,
2017-07-21 23:40:02 +02: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,
fontSizeSmaller: 14,
disabledOpacity: 0.2,
lineHeight: '1.6em',
2017-07-21 23:40:02 +02:00
};
2022-09-09 16:06:03 +02:00
const themeCache_: ThemeCache = {};
2017-08-01 19:59:01 +02:00
2022-09-09 16:06:03 +02:00
function addExtraStyles(style: Style) {
style.marginRight = style.margin;
style.marginLeft = style.margin;
style.marginTop = style.margin;
style.marginBottom = style.margin;
style.icon = {
color: style.color,
fontSize: 30,
};
style.lineInput = {
color: style.color,
backgroundColor: style.backgroundColor,
borderBottomWidth: 1,
borderColor: style.dividerColor,
paddingBottom: 0,
};
if (Platform.OS === 'ios') {
2019-02-03 18:57:29 +02:00
delete style.lineInput.borderBottomWidth;
delete style.lineInput.borderColor;
}
style.buttonRow = {
flexDirection: 'row',
borderTopWidth: 1,
borderTopColor: style.dividerColor,
paddingTop: 10,
};
style.normalText = {
color: style.color,
fontSize: style.fontSize,
};
2018-03-27 19:41:19 +02:00
style.urlText = {
color: style.urlColor,
2018-03-27 19:41:19 +02:00
fontSize: style.fontSize,
};
style.headerStyle = {
color: style.color,
fontSize: style.fontSize * 1.2,
fontWeight: 'bold',
};
style.headerWrapperStyle = {
backgroundColor: style.headerBackgroundColor,
};
style.keyboardAppearance = style.appearance;
return style;
}
2022-09-09 16:06:03 +02:00
export function editorFont(fontId?: number) {
// IMPORTANT: The font mapping must match the one in Setting.js
2022-09-09 16:06:03 +02:00
const fonts: 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];
}
2022-09-09 16:06:03 +02:00
export function themeStyle(theme?: number) {
if (!theme) {
console.warn('Theme not set! Defaulting to Light theme.');
theme = Setting.THEME_LIGHT;
}
2018-03-27 19:41:19 +02:00
const cacheKey = [theme].join('-');
if (themeCache_[cacheKey]) return themeCache_[cacheKey];
const output = Object.assign({}, baseStyle, themeById(theme));
themeCache_[cacheKey] = addExtraStyles(output);
return themeCache_[cacheKey];
2017-08-01 19:59:01 +02:00
}