mirror of
https://github.com/status-im/react-navigation-stack.git
synced 2025-01-27 14:56:02 +00:00
Use padding instead of negative margin in StackViewLayout
This commit is contained in:
parent
b3e95f3006
commit
7da0b8cc41
@ -50,8 +50,8 @@ exports[`Nested navigators renders succesfully as direct child 1`] = `
|
|||||||
"backgroundColor": "#E9E9EF",
|
"backgroundColor": "#E9E9EF",
|
||||||
"bottom": 0,
|
"bottom": 0,
|
||||||
"left": 0,
|
"left": 0,
|
||||||
"marginTop": 0,
|
|
||||||
"opacity": 1,
|
"opacity": 1,
|
||||||
|
"paddingTop": 64,
|
||||||
"position": "absolute",
|
"position": "absolute",
|
||||||
"right": 0,
|
"right": 0,
|
||||||
"shadowColor": "black",
|
"shadowColor": "black",
|
||||||
@ -122,8 +122,8 @@ exports[`Nested navigators renders succesfully as direct child 1`] = `
|
|||||||
"backgroundColor": "#E9E9EF",
|
"backgroundColor": "#E9E9EF",
|
||||||
"bottom": 0,
|
"bottom": 0,
|
||||||
"left": 0,
|
"left": 0,
|
||||||
"marginTop": 0,
|
|
||||||
"opacity": 1,
|
"opacity": 1,
|
||||||
|
"paddingTop": 64,
|
||||||
"position": "absolute",
|
"position": "absolute",
|
||||||
"right": 0,
|
"right": 0,
|
||||||
"shadowColor": "black",
|
"shadowColor": "black",
|
||||||
@ -149,6 +149,14 @@ exports[`Nested navigators renders succesfully as direct child 1`] = `
|
|||||||
<View
|
<View
|
||||||
onLayout={[Function]}
|
onLayout={[Function]}
|
||||||
pointerEvents="box-none"
|
pointerEvents="box-none"
|
||||||
|
style={
|
||||||
|
Object {
|
||||||
|
"left": 0,
|
||||||
|
"position": "absolute",
|
||||||
|
"right": 0,
|
||||||
|
"top": 0,
|
||||||
|
}
|
||||||
|
}
|
||||||
>
|
>
|
||||||
<View
|
<View
|
||||||
collapsable={undefined}
|
collapsable={undefined}
|
||||||
@ -248,6 +256,14 @@ exports[`Nested navigators renders succesfully as direct child 1`] = `
|
|||||||
<View
|
<View
|
||||||
onLayout={[Function]}
|
onLayout={[Function]}
|
||||||
pointerEvents="box-none"
|
pointerEvents="box-none"
|
||||||
|
style={
|
||||||
|
Object {
|
||||||
|
"left": 0,
|
||||||
|
"position": "absolute",
|
||||||
|
"right": 0,
|
||||||
|
"top": 0,
|
||||||
|
}
|
||||||
|
}
|
||||||
>
|
>
|
||||||
<View
|
<View
|
||||||
collapsable={undefined}
|
collapsable={undefined}
|
||||||
|
@ -50,8 +50,8 @@ exports[`StackNavigator applies correct values when headerRight is present 1`] =
|
|||||||
"backgroundColor": "#E9E9EF",
|
"backgroundColor": "#E9E9EF",
|
||||||
"bottom": 0,
|
"bottom": 0,
|
||||||
"left": 0,
|
"left": 0,
|
||||||
"marginTop": 0,
|
|
||||||
"opacity": 1,
|
"opacity": 1,
|
||||||
|
"paddingTop": 64,
|
||||||
"position": "absolute",
|
"position": "absolute",
|
||||||
"right": 0,
|
"right": 0,
|
||||||
"shadowColor": "black",
|
"shadowColor": "black",
|
||||||
@ -77,6 +77,14 @@ exports[`StackNavigator applies correct values when headerRight is present 1`] =
|
|||||||
<View
|
<View
|
||||||
onLayout={[Function]}
|
onLayout={[Function]}
|
||||||
pointerEvents="box-none"
|
pointerEvents="box-none"
|
||||||
|
style={
|
||||||
|
Object {
|
||||||
|
"left": 0,
|
||||||
|
"position": "absolute",
|
||||||
|
"right": 0,
|
||||||
|
"top": 0,
|
||||||
|
}
|
||||||
|
}
|
||||||
>
|
>
|
||||||
<View
|
<View
|
||||||
collapsable={undefined}
|
collapsable={undefined}
|
||||||
@ -244,8 +252,8 @@ exports[`StackNavigator renders successfully 1`] = `
|
|||||||
"backgroundColor": "#E9E9EF",
|
"backgroundColor": "#E9E9EF",
|
||||||
"bottom": 0,
|
"bottom": 0,
|
||||||
"left": 0,
|
"left": 0,
|
||||||
"marginTop": 0,
|
|
||||||
"opacity": 1,
|
"opacity": 1,
|
||||||
|
"paddingTop": 64,
|
||||||
"position": "absolute",
|
"position": "absolute",
|
||||||
"right": 0,
|
"right": 0,
|
||||||
"shadowColor": "black",
|
"shadowColor": "black",
|
||||||
@ -271,6 +279,14 @@ exports[`StackNavigator renders successfully 1`] = `
|
|||||||
<View
|
<View
|
||||||
onLayout={[Function]}
|
onLayout={[Function]}
|
||||||
pointerEvents="box-none"
|
pointerEvents="box-none"
|
||||||
|
style={
|
||||||
|
Object {
|
||||||
|
"left": 0,
|
||||||
|
"position": "absolute",
|
||||||
|
"right": 0,
|
||||||
|
"top": 0,
|
||||||
|
}
|
||||||
|
}
|
||||||
>
|
>
|
||||||
<View
|
<View
|
||||||
collapsable={undefined}
|
collapsable={undefined}
|
||||||
|
@ -440,7 +440,11 @@ class StackViewLayout extends React.Component {
|
|||||||
if (headerMode === 'float') {
|
if (headerMode === 'float') {
|
||||||
const { scene } = this.props.transitionProps;
|
const { scene } = this.props.transitionProps;
|
||||||
floatingHeader = (
|
floatingHeader = (
|
||||||
<View pointerEvents="box-none" onLayout={this._onFloatingHeaderLayout}>
|
<View
|
||||||
|
style={styles.floatingHeader}
|
||||||
|
pointerEvents="box-none"
|
||||||
|
onLayout={this._onFloatingHeaderLayout}
|
||||||
|
>
|
||||||
{this._renderHeader(scene, headerMode)}
|
{this._renderHeader(scene, headerMode)}
|
||||||
</View>
|
</View>
|
||||||
);
|
);
|
||||||
@ -595,22 +599,21 @@ class StackViewLayout extends React.Component {
|
|||||||
screenInterpolator &&
|
screenInterpolator &&
|
||||||
screenInterpolator({ ...this.props.transitionProps, scene });
|
screenInterpolator({ ...this.props.transitionProps, scene });
|
||||||
|
|
||||||
// If this screen has "header" set to `null` in it's navigation options, but
|
// When using a floating header, we need to add some top
|
||||||
// it exists in a stack with headerMode float, add a negative margin to
|
// padding on the scene.
|
||||||
// compensate for the hidden header
|
|
||||||
const { options } = scene.descriptor;
|
const { options } = scene.descriptor;
|
||||||
const hasHeader = options.header !== null;
|
const hasHeader = options.header !== null;
|
||||||
const headerMode = this._getHeaderMode();
|
const headerMode = this._getHeaderMode();
|
||||||
let marginTop = 0;
|
let paddingTop = 0;
|
||||||
if (!hasHeader && headerMode === 'float') {
|
if (hasHeader && headerMode === 'float') {
|
||||||
marginTop = -this.state.floatingHeaderHeight;
|
paddingTop = this.state.floatingHeaderHeight;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Card
|
<Card
|
||||||
{...this.props.transitionProps}
|
{...this.props.transitionProps}
|
||||||
key={`card_${scene.key}`}
|
key={`card_${scene.key}`}
|
||||||
style={[style, { marginTop }, this.props.cardStyle]}
|
style={[style, { paddingTop }, this.props.cardStyle]}
|
||||||
scene={scene}
|
scene={scene}
|
||||||
>
|
>
|
||||||
{this._renderInnerScene(scene)}
|
{this._renderInnerScene(scene)}
|
||||||
@ -631,6 +634,12 @@ const styles = StyleSheet.create({
|
|||||||
scenes: {
|
scenes: {
|
||||||
flex: 1,
|
flex: 1,
|
||||||
},
|
},
|
||||||
|
floatingHeader: {
|
||||||
|
position: 'absolute',
|
||||||
|
left: 0,
|
||||||
|
top: 0,
|
||||||
|
right: 0,
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
export default withOrientation(StackViewLayout);
|
export default withOrientation(StackViewLayout);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user