1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-02 12:47:41 +02:00
joplin/packages/app-desktop/gui/ToggleEditorsButton/styles/index.ts

71 lines
1.9 KiB
TypeScript
Raw Normal View History

2020-09-15 15:01:07 +02:00
import { Props, Value } from '../ToggleEditorsButton';
import { buildStyle } from '@joplin/lib/theme';
2020-09-15 15:01:07 +02:00
export default function styles(props: Props) {
return buildStyle(['ToggleEditorsButton', props.value], props.themeId, theme => {
2020-09-15 15:01:07 +02:00
const iconSize = 15;
const mdIconWidth = iconSize * 1.25;
const buttonHeight = theme.toolbarHeight - 7;
2020-09-15 15:01:07 +02:00
const mdIconPadding = Math.round((buttonHeight - iconSize) / 2) + 3;
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
const innerButton: any = {
2020-09-15 15:01:07 +02:00
borderStyle: 'solid',
borderColor: theme.color3,
borderWidth: 1,
borderRadius: 0,
width: mdIconWidth + mdIconPadding * 2,
height: buttonHeight,
display: 'flex',
justifyContent: 'center',
};
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
const output: any = {
2020-09-15 15:01:07 +02:00
button: {
border: 'none',
padding: 0,
display: 'flex',
flexDirection: 'row',
alignItems: 'center',
background: 'none',
},
leftInnerButton: {
...innerButton,
borderTopLeftRadius: 4,
borderBottomLeftRadius: 4,
},
rightInnerButton: {
...innerButton,
borderTopRightRadius: 4,
borderBottomRightRadius: 4,
},
leftIcon: {
fontSize: iconSize,
position: 'relative',
top: 1,
2020-09-15 15:01:07 +02:00
color: theme.color3,
},
rightIcon: {
fontSize: iconSize - 1,
borderLeft: 'none',
position: 'relative',
top: 1,
2020-09-15 15:01:07 +02:00
color: theme.color3,
},
};
if (props.value === Value.Markdown) {
output.leftInnerButton.backgroundColor = theme.color3;
output.leftIcon.color = theme.backgroundColor3;
output.rightInnerButton.opacity = 0.5;
} else if (props.value === Value.RichText) {
output.rightInnerButton.backgroundColor = theme.color3;
output.rightIcon.color = theme.backgroundColor3;
output.leftInnerButton.opacity = 0.5;
}
return output;
});
}