We're doing some consulting work at the moment. Advising a large client on a digital transformation project. It's made me look more closely at non-RN mobile app development options more closely. This NuBank article makes a good pitch for the strengths of Flutter. https://building.nubank.com.br/scaling-with-flutter/
Wondering if anyone has switched from Flutter to RN and has viceral reactions to the claims.... "After gathering evidence, the team decided to adopt Flutter, thanks to its excellent testing capabilities, such as built-in testing infrastructure for Unit, Integration, and End-to-End tests without the need for rendering to the screen. Overall, — compared to other options — they also found the Flutter development experience to be superior, with better hot reload capabilities, robust official documentation, and a more stable API."
sorry i can't provide more pros and cons it was 2 years ago and maybe situation improved but when i tried it i really really didn't like it. I was playing with it for a month and when i switched to RN i was much much happier. Never looked back since
Christophe Grand is working on a port of Flutter to Clojure. Not publicly available yet... best to speak to him about the details
Here the tweet from @cgrand about this https://twitter.com/cgrand/status/1350063059864346624?s=20
And he tweeted recently that he’s been busy with work recently to get this out of the door/open sourced
I'm interested to see what he produces. Also curious what dev experience is like.
Thanks for your thoughts everyone.
Very surprised, @olivergeorge, to see testing wagging the UI framework selection dog. Are they otherwise that interchangeable?
I haven’t tried Flutter. Wondering what the library/ecosystem looks like for it?
I’m trying to use the options prop to have a right header button and a custom title, something like the following https://reactnavigation.org/docs/header-buttons/:
function StackScreen() {
return (
<Stack.Navigator>
<Stack.Screen
name="Home"
component={HomeScreen}
options={({ navigation, route }) => ({
headerTitle: props => <LogoTitle {...props} />,
})}
/>
</Stack.Navigator>
);
}
And this is what I have:
[:> (.-Screen Stack) {:name "Event Title"
:options (fn [navigation]
{:headerTitle (fn [props] "Some Title")
:headerRight
(r/as-element
[button {:title "Next"
;;:onPress #(dispatch [:add-thumbnail navigation])
}])})
:component (r/reactify-component event-title)}]
However, neither am I seeing the custom headerTitle nor am I seeing the headerRight which should be the button component. What am I doing wrong?I think you might need to wrap the return value of the function in (clj->js …)
, @ps
@pez now I have the following:
[:> (.-Screen Stack) {:name "Event Title"
:options (fn [navigation]
(clj->js
{:headerTitle (fn [props] "Some Title")
:headerRight
(r/as-element
[button {:title "Next"
;;:onPress #(dispatch [:add-thumbnail])
}])}))
:component (r/reactify-component event-title)}]
But I get the following error:Wild guess: try with r/as-component
@pez where should I put as-component?
Sorry, instead of r/as-element
, I meant.
@pez That gives the following
I’m out of guess, unfortunately. I haven’t used that API myself. (But I’m pretty sure the clj->js
is needed there.)