Fork me on GitHub
#re-frame
<
2023-05-02
>
achikin14:05:39

I’ve just heard some rumors from the clojure conj that reagent is becoming absolete and won’t be updated to the latest React 19 and that React is going to deprecate classes alongside with lifecycle methods. Being compatible with the current React is crucial for us because we have a lot of JS components. What are the current alternatives to reagent/re-frame?

👀 2
jacekschae15:05:47

Not sure how true this gossip is but https://github.com/pitch-io/uix by @U0FR82FU1 or https://github.com/lilactown/helix by @U4YGF4NGM seem pretty good. UIx has bindings to re-frame @U061V0GG2 is there anything behind this gossip?

kennytilton15:05:31

Hmm, The Google is letting me down. Where can I find info on React 19?

achikin15:05:23

I could have misinterpreted something. It’s an upcoming version.

achikin15:05:22

Rumors that React is going to drop lifecycle methods in 19

kennytilton16:05:46

Thx for the link. From the OP: "React is the only JS framework I know of that is compatible with functional programming." Not sure what the OP meant, but if we are talking about declarative/granular/efficient, there is MobX, SolidJS, and even https://tilton.medium.com/simplejx-aweb-un-framework-e9b59c12dcff and the CLJS version of that, Web/MX. Agreed on the UIx and Helix alternatives. Also not clear is how fast and/or dead-endish will be the "deprecated". That can take years, and I suspect React will not want to give users a reason to look elsewhere. Didn't Angular 2 take the wind out of Angular's sails and give React an opening? :thinking_face:

hifumi12318:05:18

I think class components will stay for quite a while considering React 18 still has no way to make error boundaries with function components. If you do want modernized React wrappers, take a look at Helix and how it was used in one of the Conj talks. You also can still use re-frame via #C041XN6DADU

hifumi12318:05:56

I think there was a second Conj talk that also mentioned use of Helix but my memory is slowly fading on that 😁

juhoteperi18:05:13

The linked discussion has valid points about some problems with Reagent, like runtime Hiccup conversion. And there are other of design choices in Reagent that are making further development really complicated. E.g. good React 18 support is hard to implement properly due to Reagents async rendering queue. (Though async render queue might be one of the things that could be removed from Reagent without breaking lots of apps... maybe.) If fixing these things means breaking all or most existing Reagent apps, there is no much reason to write such "Reagent 2" as Helix and UIx2 already exists.

juhoteperi18:05:05

I don't know if Reagent will be deprecated, that will depend on React 19, but there is probably good chance that Reagent will be somewhat usable with it, as Reagent can produce function components.

hifumi12318:05:14

if i had to guess, i think people using reagent today will be fine for a couple of years; i'd be surprised if react 19 releases as soon as next year, and I dont see any RFCs showing how to implement error boundaries with function components... not to mention the vast amount of legacy code out there that people rely on, which likely uses class components

juhoteperi18:05:48

Yeah, they've been careful about not breaking existing code.

juhoteperi18:05:04

I think I remember some discussion where they talk about introducing new features opt-in. (Which is what React 18 did.)

juhoteperi18:05:12

That would mean that Reagent should keep working quite well, but using the new React features might be inconvenient.

lilactown19:05:16

I responded in a reddit thread about FUD re: React breaking things based on what their docs now say https://www.reddit.com/r/Clojure/comments/11uluj4/reactdev_are_cljs_developers_using_reagent_in/jczh634/

lilactown19:05:50

it basically repeats a lot of what juho and hifumi123 say in this thread