react-native-pager-view
react-native-pager-view copied to clipboard
Wrong safe area in presence of absolute-positioned view
Bug report
Summary
As you can see from the screenshot, the safe area is computed wrongly when a view with position: absolute
is placed near the view pager.
Environment info
react-native info
output:
System:
OS: macOS 10.15.4
CPU: (4) x64 Intel(R) Core(TM) i5-7360U CPU @ 2.30GHz
Memory: 21.57 MB / 8.00 GB
Shell: 5.7.1 - /bin/zsh
Binaries:
Node: 12.14.1 - ~/.nvm/versions/node/v12.14.1/bin/node
Yarn: 1.22.4 - /usr/local/bin/yarn
npm: 6.13.7 - ~/.nvm/versions/node/v12.14.1/bin/npm
Watchman: 4.9.0 - /usr/local/bin/watchman
Managers:
CocoaPods: 1.8.4 - /usr/local/bin/pod
SDKs:
iOS SDK:
Platforms: iOS 13.5, DriverKit 19.0, macOS 10.15, tvOS 13.4, watchOS 6.2
Android SDK: Not Found
IDEs:
Android Studio: 4.0 AI-193.6911.18.40.6514223
Xcode: 11.5/11E608c - /usr/bin/xcodebuild
Languages:
Java: 9.0.4 - /usr/bin/javac
Python: 3.7.2 - /Users/federico/miniconda3/bin/python
npmPackages:
@react-native-community/cli: Not Found
react: 16.9.0 => 16.9.0
react-native: 0.62.2 => 0.62.2
npmGlobalPackages:
*react-native*: Not Found
Library version: "^4.0.0",
Steps to reproduce
const ViewPagerScreen = (props) => {
const pages = [
<View>
<View style={{flex: 1, backgroundColor: 'green'}}>
<SafeAreaView style={{flex: 1}}>
<Text style={{fontSize: 24}}>Title text</Text>
</SafeAreaView>
</View>
</View>
];
return (
<>
<View style={{...StyleSheet.absoluteFillObject, backgroundColor: 'black'}} />
<ViewPager initialPage={0} showPageIndicator={false}
orientation="horizontal"
style={{flex: 1}}
>
{pages}
</ViewPager>
// if you remove this problematic footer view, all works as expected
<SafeAreaView>
<View style={{position: "absolute", bottom: 0, left: 0, right: 0}}>
<View style={styles.footer}>
<View style={styles.footerSubContLeft}>
<Button title="Home" color='black' onPress={() => {}} />
</View>
<View style={styles.footerSubContRight}>
<Button title="Next" color='black' onPress={() => {}} />
</View>
</View>
</View>
</SafeAreaView>
</>
);
}
const styles = StyleSheet.create({
footer: {
flexDirection: "row",
marginBottom: 20,
backgroundColor: 'yellow'
},
footerSubContLeft: {
flex: 1,
alignItems: "flex-start",
},
footerSubContRight: {
flex: 1,
alignItems: "flex-end",
}
});
data:image/s3,"s3://crabby-images/302be/302be75856a7c466aea6f2ed534d11609ccd71f8" alt="image"
The text view should be inside the SafeArea. If I remove the yellow view (footer), this is respected.
data:image/s3,"s3://crabby-images/736bc/736bcb6c32e9e28d34d5a0333e5f97fd680f50b7" alt="image"
Hey 👋 Thank you for reporting an issue. Can you try to remove childrenWithOverriddenStyle in your node_modules ?
No, that happens also after having removed childrenWithOverriddenStyles :/
Is there any news regarding to this issue? :(
@keyblade95, you can bypass problem by removing absolute layout and setting negative margin on element which will be in front.
I don’t know if I understood well.. should I remove the absolute layout from the SafeArea child view? Can you provide a minimal example, please?
Can you try style={{width: "100%", height:"100%"}}
instead of flex:1
?
Additional, can you use SafeArea
instead of Fragment
? ViewPager
's parent here is fragment, so view inset can be wrong setup. Please add backgroundColor: "pink"
and check the safe area for this view
I cannot use SafeArea as the top parent because I want to achieve the following effect: the ViewPager pages have a background image and I want that to cover the entire screen. So, I set the pages to be fullscreen and the footer to be inside the safe area.
Anyway, I will try style={{width: "100%", height:"100%"}}
as soon as possible.
@keyblade95 , in your footer, remove absolute
in style, and then add marginTop: -50
for example. That will do the job.
<SafeAreaView>
<View style={{marginTop: -50}}>
<View style={styles.footer}>
<View style={styles.footerSubContLeft}>
<Button title="Home" color='black' onPress={() => {}} />
</View>
<View style={styles.footerSubContRight}>
<Button title="Next" color='black' onPress={() => {}} />
</View>
</View>
</View>
</SafeAreaView>
Is there any news to this?
I still have this issue on iOS in 2022. Was there any solution?