2022-09-09 07:11:58 -07:00
|
|
|
|
|
|
|
// On some devices, the SafeAreaView conflicts with the KeyboardAvoidingView, creating
|
|
|
|
// additional (or a lack of additional) space at the bottom of the screen. Because this
|
|
|
|
// is different on different devices, this button allows toggling additional space a the bottom
|
|
|
|
// of the screen to compensate.
|
|
|
|
|
|
|
|
// Works around https://github.com/facebook/react-native/issues/13393 by adding additional
|
|
|
|
// space below the given component when the keyboard is visible unless a button is pressed.
|
|
|
|
|
|
|
|
import Setting from '@joplin/lib/models/Setting';
|
|
|
|
import { themeStyle } from '@joplin/lib/theme';
|
|
|
|
import { Theme } from '@joplin/lib/themes/type';
|
|
|
|
|
|
|
|
import * as React from 'react';
|
|
|
|
import { ReactNode, useCallback, useState, useEffect } from 'react';
|
|
|
|
import { View, ViewStyle } from 'react-native';
|
2024-05-25 06:41:27 -07:00
|
|
|
import IconButton from '../../IconButton';
|
2022-09-09 07:11:58 -07:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
children: ReactNode;
|
|
|
|
spaceApplicable: boolean;
|
|
|
|
themeId: number;
|
|
|
|
style?: ViewStyle;
|
|
|
|
}
|
|
|
|
|
|
|
|
const ToggleSpaceButton = (props: Props) => {
|
|
|
|
const [additionalSpace, setAdditionalSpace] = useState(0);
|
|
|
|
const [decreaseSpaceBtnVisible, setDecreaseSpaceBtnVisible] = useState(true);
|
|
|
|
|
|
|
|
// Some devices need space added, others need space removed.
|
|
|
|
const additionalPositiveSpace = 14;
|
|
|
|
const additionalNegativeSpace = -14;
|
|
|
|
|
|
|
|
// Switch from adding +14px to -14px.
|
|
|
|
const onDecreaseSpace = useCallback(() => {
|
|
|
|
setAdditionalSpace(additionalNegativeSpace);
|
|
|
|
setDecreaseSpaceBtnVisible(false);
|
|
|
|
Setting.setValue('editor.mobile.removeSpaceBelowToolbar', true);
|
|
|
|
}, [setAdditionalSpace, setDecreaseSpaceBtnVisible, additionalNegativeSpace]);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (Setting.value('editor.mobile.removeSpaceBelowToolbar')) {
|
|
|
|
onDecreaseSpace();
|
|
|
|
}
|
|
|
|
}, [onDecreaseSpace]);
|
|
|
|
|
|
|
|
const theme: Theme = themeStyle(props.themeId);
|
|
|
|
|
|
|
|
const decreaseSpaceButton = (
|
|
|
|
<>
|
|
|
|
<View style={{
|
|
|
|
height: additionalPositiveSpace,
|
|
|
|
zIndex: -2,
|
|
|
|
}} />
|
2024-05-25 06:41:27 -07:00
|
|
|
<IconButton
|
2022-09-09 07:11:58 -07:00
|
|
|
themeId={props.themeId}
|
|
|
|
description={'Move toolbar to bottom of screen'}
|
2024-05-25 06:41:27 -07:00
|
|
|
containerStyle={{
|
2022-09-09 07:11:58 -07:00
|
|
|
height: additionalPositiveSpace,
|
|
|
|
width: '100%',
|
|
|
|
|
|
|
|
// Ensure that the icon is near the bottom of the screen,
|
|
|
|
// and thus invisible on devices where it isn't necessary.
|
|
|
|
position: 'absolute',
|
|
|
|
bottom: 0,
|
|
|
|
|
|
|
|
// Don't show the button on top of views with content.
|
|
|
|
zIndex: -1,
|
|
|
|
|
|
|
|
alignItems: 'center',
|
|
|
|
}}
|
|
|
|
onPress={onDecreaseSpace}
|
2024-05-25 06:41:27 -07:00
|
|
|
|
|
|
|
iconName='material chevron-down'
|
|
|
|
iconStyle={{ color: theme.color }}
|
|
|
|
/>
|
2022-09-09 07:11:58 -07:00
|
|
|
</>
|
|
|
|
);
|
|
|
|
|
|
|
|
const style: ViewStyle = {
|
|
|
|
marginBottom: props.spaceApplicable ? additionalSpace : 0,
|
|
|
|
...props.style,
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<View style={style}>
|
|
|
|
{props.children}
|
|
|
|
{ decreaseSpaceBtnVisible && props.spaceApplicable ? decreaseSpaceButton : null }
|
|
|
|
</View>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ToggleSpaceButton;
|