mirror of
https://github.com/status-im/react-native.git
synced 2025-02-23 22:58:19 +00:00
Fix behaviour of Header, Footer and Empty List components in VirtualizedList when it's inverted (#24167)
Summary: Fixes https://github.com/facebook/react-native/issues/23453 Fixes https://github.com/facebook/react-native/issues/21196 Basically, changes made in https://github.com/facebook/react-native/pull/21496 currently breaks behavior of `<VirtualizedList />` and any components that are based on it (`<SectionList />, <FlatList />`). This PR solves both issues listed above. Visual confirmation of the resolved issue: **Vertical, not inverted, not empty** data:image/s3,"s3://crabby-images/10a10/10a10657abce53f1cf2f775d0ce7c94b83f5e0ac" alt="image" **Vertical, not inverted, empty** data:image/s3,"s3://crabby-images/80171/801717ad975fee25535966a40b6940fe10c323a2" alt="image" **Vertical, inverted, not empty** data:image/s3,"s3://crabby-images/39b17/39b17c5259ad8e292a62556e31bde905d6bc2cc4" alt="image" **Vertical, inverted, empty** data:image/s3,"s3://crabby-images/25756/25756d386145a16babc275f8dce9bfc347f7f5ca" alt="image" **Horizontal, not inverted, not empty** data:image/s3,"s3://crabby-images/fbb25/fbb2549412e02b738b9c71eb02f038c831b2d0c0" alt="image" **Horizontal, not inverted, empty** data:image/s3,"s3://crabby-images/bf953/bf953c73ce683bd687e6b8d1bc35b16ca281ac68" alt="image" **Horizontal, inverted, not empty** data:image/s3,"s3://crabby-images/4feeb/4feeb0166fbf3e8ca7d9facbbec1778843130884" alt="image" **Horizontal, inverted, empty** data:image/s3,"s3://crabby-images/b8d42/b8d429c7f1a9007957f41680f6c0ac4282c5321b" alt="image" [General] [Fixed] - Fixed VirtualizedList, SectionList and FlatList behavior on rendering list headers with inverted prop and zero items Pull Request resolved: https://github.com/facebook/react-native/pull/24167 Differential Revision: D14642345 Pulled By: cpojer fbshipit-source-id: b530bbbd57f60e53a976ac5db272ea4b2d2b3e99
This commit is contained in:
parent
13cb5a91ed
commit
e94d3444dc
@ -885,16 +885,17 @@ class VirtualizedList extends React.PureComponent<Props, State> {
|
||||
<ListEmptyComponent />
|
||||
)): any);
|
||||
cells.push(
|
||||
React.cloneElement(element, {
|
||||
key: '$empty',
|
||||
onLayout: event => {
|
||||
this._onLayoutEmpty(event);
|
||||
if (element.props.onLayout) {
|
||||
element.props.onLayout(event);
|
||||
}
|
||||
},
|
||||
style: [element.props.style, inversionStyle],
|
||||
}),
|
||||
<View key="$empty" style={inversionStyle}>
|
||||
{React.cloneElement(element, {
|
||||
onLayout: event => {
|
||||
this._onLayoutEmpty(event);
|
||||
if (element.props.onLayout) {
|
||||
element.props.onLayout(event);
|
||||
}
|
||||
},
|
||||
style: element.props.style,
|
||||
})}
|
||||
</View>,
|
||||
);
|
||||
}
|
||||
if (ListFooterComponent) {
|
||||
@ -937,7 +938,7 @@ class VirtualizedList extends React.PureComponent<Props, State> {
|
||||
: this.props.inverted,
|
||||
stickyHeaderIndices,
|
||||
};
|
||||
if (inversionStyle && itemCount !== 0) {
|
||||
if (inversionStyle) {
|
||||
/* $FlowFixMe(>=0.70.0 site=react_native_fb) This comment suppresses an
|
||||
* error found when Flow v0.70 was deployed. To see the error delete
|
||||
* this comment and run Flow. */
|
||||
|
@ -668,7 +668,11 @@ exports[`VirtualizedList renders empty list with empty component 1`] = `
|
||||
>
|
||||
<header />
|
||||
</View>
|
||||
<empty />
|
||||
<View
|
||||
style={null}
|
||||
>
|
||||
<empty />
|
||||
</View>
|
||||
<View
|
||||
onLayout={[Function]}
|
||||
>
|
||||
|
Loading…
x
Reference in New Issue
Block a user