-
Notifications
You must be signed in to change notification settings - Fork 292
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
New architecture support #550
Changes from 6 commits
60a048a
acda193
9c36e0a
ade08ac
a77dc81
c12786f
2c7f3c7
ddb6c6a
eb5cfad
8c212ee
c7528cd
44302e9
25abbb7
e5d3bde
03815c9
c740e67
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
package com.shopify.reactnative.flash_list | ||
|
||
import com.facebook.react.bridge.ReactContext | ||
import com.facebook.react.fabric.FabricUIManager | ||
import com.facebook.react.uimanager.UIManagerHelper | ||
import com.facebook.react.uimanager.common.UIManagerType | ||
import com.facebook.react.bridge.WritableMap | ||
|
||
fun ReactContext.dispatchEvent(nativeTag: Int, eventName: String, event: WritableMap) { | ||
val fabricUIManager = UIManagerHelper.getUIManager(this, UIManagerType.FABRIC) as FabricUIManager | ||
fabricUIManager.receiveEvent(nativeTag, eventName, event) | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
/** | ||
* This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen). | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. is the generator always creating code for paper as well? 🤔 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. No, it's not. I copied those files without modifying them. Do you think those comments should be removed? |
||
* | ||
* Do not edit this file as changes may cause incorrect behavior and will be lost | ||
* once the code is regenerated. | ||
* | ||
* @generated by codegen project: GeneratePropsJavaDelegate.js | ||
*/ | ||
|
||
package com.facebook.react.viewmanagers; | ||
|
||
import android.view.View; | ||
import androidx.annotation.Nullable; | ||
import com.facebook.react.uimanager.BaseViewManagerDelegate; | ||
import com.facebook.react.uimanager.BaseViewManagerInterface; | ||
|
||
public class AutoLayoutViewManagerDelegate<T extends View, U extends BaseViewManagerInterface<T> & AutoLayoutViewManagerInterface<T>> extends BaseViewManagerDelegate<T, U> { | ||
public AutoLayoutViewManagerDelegate(U viewManager) { | ||
super(viewManager); | ||
} | ||
@Override | ||
public void setProperty(T view, String propName, @Nullable Object value) { | ||
switch (propName) { | ||
case "horizontal": | ||
mViewManager.setHorizontal(view, value == null ? false : (boolean) value); | ||
break; | ||
case "scrollOffset": | ||
mViewManager.setScrollOffset(view, value == null ? 0f : ((Double) value).doubleValue()); | ||
break; | ||
case "windowSize": | ||
mViewManager.setWindowSize(view, value == null ? 0f : ((Double) value).doubleValue()); | ||
break; | ||
case "renderAheadOffset": | ||
mViewManager.setRenderAheadOffset(view, value == null ? 0f : ((Double) value).doubleValue()); | ||
break; | ||
case "enableInstrumentation": | ||
mViewManager.setEnableInstrumentation(view, value == null ? false : (boolean) value); | ||
break; | ||
case "disableAutoLayout": | ||
mViewManager.setDisableAutoLayout(view, value == null ? false : (boolean) value); | ||
break; | ||
default: | ||
super.setProperty(view, propName, value); | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
/** | ||
* This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen). | ||
* | ||
* Do not edit this file as changes may cause incorrect behavior and will be lost | ||
* once the code is regenerated. | ||
* | ||
* @generated by codegen project: GeneratePropsJavaInterface.js | ||
*/ | ||
|
||
package com.facebook.react.viewmanagers; | ||
|
||
import android.view.View; | ||
|
||
public interface AutoLayoutViewManagerInterface<T extends View> { | ||
void setHorizontal(T view, boolean value); | ||
void setScrollOffset(T view, double value); | ||
void setWindowSize(T view, double value); | ||
void setRenderAheadOffset(T view, double value); | ||
void setEnableInstrumentation(T view, boolean value); | ||
void setDisableAutoLayout(T view, boolean value); | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,31 @@ | ||
/** | ||
* This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen). | ||
* | ||
* Do not edit this file as changes may cause incorrect behavior and will be lost | ||
* once the code is regenerated. | ||
* | ||
* @generated by codegen project: GeneratePropsJavaDelegate.js | ||
*/ | ||
|
||
package com.facebook.react.viewmanagers; | ||
|
||
import android.view.View; | ||
import androidx.annotation.Nullable; | ||
import com.facebook.react.uimanager.BaseViewManagerDelegate; | ||
import com.facebook.react.uimanager.BaseViewManagerInterface; | ||
|
||
public class CellContainerManagerDelegate<T extends View, U extends BaseViewManagerInterface<T> & CellContainerManagerInterface<T>> extends BaseViewManagerDelegate<T, U> { | ||
public CellContainerManagerDelegate(U viewManager) { | ||
super(viewManager); | ||
} | ||
@Override | ||
public void setProperty(T view, String propName, @Nullable Object value) { | ||
switch (propName) { | ||
case "index": | ||
mViewManager.setIndex(view, value == null ? 0 : ((Double) value).intValue()); | ||
break; | ||
default: | ||
super.setProperty(view, propName, value); | ||
} | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
/** | ||
* This code was generated by [react-native-codegen](https://www.npmjs.com/package/react-native-codegen). | ||
* | ||
* Do not edit this file as changes may cause incorrect behavior and will be lost | ||
* once the code is regenerated. | ||
* | ||
* @generated by codegen project: GeneratePropsJavaInterface.js | ||
*/ | ||
|
||
package com.facebook.react.viewmanagers; | ||
|
||
import android.view.View; | ||
|
||
public interface CellContainerManagerInterface<T extends View> { | ||
void setIndex(T view, int value); | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
|
||
package com.shopify.reactnative.flash_list | ||
|
||
import com.facebook.react.bridge.ReactContext | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
import com.facebook.react.bridge.WritableMap | ||
|
||
fun ReactContext.dispatchEvent(nativeTag: Int, eventName: String, event: WritableMap) { | ||
this.getJSModule(RCTEventEmitter::class.java) | ||
.receiveEvent(nativeTag, eventName, event) | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,6 +5,10 @@ import UIKit | |
/// Container for all RecyclerListView children. This will automatically remove all gaps and overlaps for GridLayouts with flexible spans. | ||
/// Note: This cannot work for masonry layouts i.e, pinterest like layout | ||
@objc public class AutoLayoutView: UIView { | ||
#if RCT_NEW_ARCH_ENABLED | ||
@objc public var onBlankAreaEventHandler: ((CGFloat, CGFloat) -> Void)? | ||
#endif | ||
|
||
@objc(onBlankAreaEvent) | ||
var onBlankAreaEvent: RCTDirectEventBlock? | ||
|
||
|
@@ -68,13 +72,17 @@ import UIKit | |
distanceFromWindowStart: distanceFromWindowStart, | ||
distanceFromWindowEnd: distanceFromWindowEnd | ||
) | ||
|
||
|
||
#if RCT_NEW_ARCH_ENABLED | ||
onBlankAreaEventHandler?(blankOffsetStart, blankOffsetEnd) | ||
#else | ||
onBlankAreaEvent?( | ||
[ | ||
"offsetStart": blankOffsetStart, | ||
"offsetEnd": blankOffsetEnd, | ||
] | ||
) | ||
#endif | ||
} | ||
|
||
func getScrollView() -> UIScrollView? { | ||
|
@@ -274,6 +282,13 @@ import UIKit | |
} | ||
|
||
private func footer() -> UIView? { | ||
return superview?.subviews.first(where:{($0 as? CellContainerComponentView)?.index == -1}) | ||
// On the new arch, AutoLayoutView is wrapped with AutoLayoutViewComponentView, so we need to go up one more level | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can you explain why do we need the extra view? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. On the new architecture a lot of the code needed by views is implemented inside
Instead of that, it's possible to create a wrapper view that inherits after |
||
#if RCT_NEW_ARCH_ENABLED | ||
let parentSubviews = superview?.superview?.subviews | ||
#else | ||
let parentSubviews = superview?.subviews | ||
#endif | ||
|
||
return parentSubviews?.first(where:{($0 as? CellContainerComponentView)?.index == -1}) | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do you need here both
onBlankAreaEvent
andtopOnBlankAreaEvent
?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To be honest, I don't remember 😅. It's been a while since I've written this, but it doesn't seem to be causing any issues when I removed
topOnBlankAreaEvent
.