From 11cfac96c12ed5eecf9a29369a1e7b017fc414c7 Mon Sep 17 00:00:00 2001 From: Azim Gadzhiagayev Date: Wed, 3 Nov 2021 12:45:22 +0500 Subject: [PATCH] Removed flatlist inversion (by inverted=true prop) which used [transform: translate] css hack and instead adding flatlist array items in reverse order [unshift instead of push]; It also reverses ScrollView event response received from browser [e.nativeEvent.configOffset *= -1]; --- .../react-native/VirtualizedList/index.js | 43 ++++++++++++------- 1 file changed, 28 insertions(+), 15 deletions(-) diff --git a/packages/react-native-web/src/vendor/react-native/VirtualizedList/index.js b/packages/react-native-web/src/vendor/react-native/VirtualizedList/index.js index 23a9ccea5..91dac46da 100644 --- a/packages/react-native-web/src/vendor/react-native/VirtualizedList/index.js +++ b/packages/react-native-web/src/vendor/react-native/VirtualizedList/index.js @@ -361,6 +361,14 @@ type State = { class VirtualizedList extends React.PureComponent { static contextType: typeof VirtualizedListContext = VirtualizedListContext; + pushOrUnshift(input: Array, item: Item) { + if (this.props.inverted) { + input.unshift(item) + } else { + input.push(item) + } + } + // scrollToEnd may be janky without getItemLayout prop scrollToEnd(params?: ?{animated?: ?boolean, ...}) { const animated = params ? params.animated : true; @@ -707,7 +715,7 @@ class VirtualizedList extends React.PureComponent { ); } else if (this.props.onViewableItemsChanged) { const onViewableItemsChanged = this.props.onViewableItemsChanged - this._viewabilityTuples.push({ + this.pushOrUnshift(this._viewabilityTuples, { viewabilityHelper: new ViewabilityHelper(this.props.viewabilityConfig), onViewableItemsChanged, }); @@ -807,9 +815,9 @@ class VirtualizedList extends React.PureComponent { const key = keyExtractor(item, ii); this._indicesToKeys.set(ii, key); if (stickyIndicesFromProps.has(ii + stickyOffset)) { - stickyHeaderIndices.push(cells.length); + this.pushOrUnshift(stickyHeaderIndices, cells.length); } - cells.push( + this.pushOrUnshift(cells, { const stickyHeaderIndices = []; if (ListHeaderComponent) { if (stickyIndicesFromProps.has(0)) { - stickyHeaderIndices.push(0); + this.pushOrUnshift(stickyHeaderIndices, 0); } const element = React.isValidElement(ListHeaderComponent) ? ( ListHeaderComponent @@ -887,7 +895,7 @@ class VirtualizedList extends React.PureComponent { // $FlowFixMe ); - cells.push( + this.pushOrUnshift(cells, @@ -936,7 +944,7 @@ class VirtualizedList extends React.PureComponent { stickyBlock.offset - initBlock.offset - (this.props.initialScrollIndex ? 0 : initBlock.length); - cells.push( + this.pushOrUnshift(cells, /* $FlowFixMe(>=0.111.0 site=react_native_fb) This comment * suppresses an error found when Flow v0.111 was deployed. To * see the error, delete this comment and run Flow. */ @@ -953,7 +961,7 @@ class VirtualizedList extends React.PureComponent { const trailSpace = this._getFrameMetricsApprox(first).offset - (stickyBlock.offset + stickyBlock.length); - cells.push( + this.pushOrUnshift(cells, /* $FlowFixMe(>=0.111.0 site=react_native_fb) This comment * suppresses an error found when Flow v0.111 was deployed. To * see the error, delete this comment and run Flow. */ @@ -969,7 +977,7 @@ class VirtualizedList extends React.PureComponent { const firstSpace = this._getFrameMetricsApprox(first).offset - (initBlock.offset + initBlock.length); - cells.push( + this.pushOrUnshift(cells, /* $FlowFixMe(>=0.111.0 site=react_native_fb) This comment * suppresses an error found when Flow v0.111 was deployed. To see * the error, delete this comment and run Flow. */ @@ -1006,7 +1014,7 @@ class VirtualizedList extends React.PureComponent { endFrame.offset + endFrame.length - (lastFrame.offset + lastFrame.length); - cells.push( + this.pushOrUnshift(cells, /* $FlowFixMe(>=0.111.0 site=react_native_fb) This comment suppresses * an error found when Flow v0.111 was deployed. To see the error, * delete this comment and run Flow. */ @@ -1022,7 +1030,7 @@ class VirtualizedList extends React.PureComponent { // $FlowFixMe )): any); - cells.push( + this.pushOrUnshift(cells, React.cloneElement(element, { key: '$empty', onLayout: event => { @@ -1042,7 +1050,7 @@ class VirtualizedList extends React.PureComponent { // $FlowFixMe ); - cells.push( + this.pushOrUnshift(cells, @@ -1367,7 +1375,7 @@ class VirtualizedList extends React.PureComponent { * error found when Flow v0.68 was deployed. To see the error delete this * comment and run Flow. */ if (frame.inLayout) { - framesInLayout.push(frame); + this.pushOrUnshift(framesInLayout, frame); } } const windowTop = this._getFrameMetricsApprox(this.state.first).offset; @@ -1505,6 +1513,11 @@ class VirtualizedList extends React.PureComponent { }; _onScroll = (e: Object) => { + var contentOffset = (this.props.inverted) ? { + x: - e.nativeEvent.contentOffset.x, + y: - e.nativeEvent.contentOffset.y, + } : e.nativeEvent.contentOffset + this._nestedChildLists.forEach(childList => { childList.ref && childList.ref._onScroll(e); }); @@ -1514,7 +1527,7 @@ class VirtualizedList extends React.PureComponent { const timestamp = e.timeStamp; let visibleLength = this._selectLength(e.nativeEvent.layoutMeasurement); let contentLength = this._selectLength(e.nativeEvent.contentSize); - let offset = this._selectOffset(e.nativeEvent.contentOffset); + let offset = this._selectOffset(contentOffset); let dOffset = offset - this._scrollMetrics.offset; if (this._isNestedWithSameOrientation()) { @@ -2048,10 +2061,10 @@ function describeNestedLists(childList: { const styles = StyleSheet.create({ verticallyInverted: { - transform: [{scaleY: -1}], + flexDirection: 'column-reverse', }, horizontallyInverted: { - transform: [{scaleX: -1}], + flexDirection: 'row-reverse', }, row: { flexDirection: 'row',