-
Notifications
You must be signed in to change notification settings - Fork 641
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
Idea: Rewrite project as a "patch" on top of create-react-native-app/react-native init #217
Comments
create-react-native-app
/ react-native init
Proof of concept in Currently it's just a |
Interesting stuff. I've enjoyed working with this over the last few weeks but have certainly noticed that it would be nigh impossible to keep a forked repo in sync with the origin. |
That would indeed be interesting. I for one am in support of this idea. |
Here's some progress so far: https://goo.gl/photos/47AfGWG3MxoKUQPH8 Each tab is the result of running a plop generator. |
Looks great! So redux-persist for snapshotting to/from AsyncStorage? Do you have an opinion on redux-loop/saga/redux-effects integration? I see that the redux-loop 2.x used in the current master has been deprecated with a 3.0 version that replaces Effects with Cmd. |
Yeah, figured using redux-persist makes sense instead of a home-grown solution like what we have in master. redux-persist also has extra features through addons such as blacklisting/whitelisting, migrations, filtering, expiring properties etc. |
As for redux-loop, yeah definitely either upgrade to 3.0 or leave it out / use something else. I haven't made any decisions here yet. One possibility is leveraging the generator framework and letting the user choose which async Redux library they would like to use. From my experience, the most common async operation is API requests. In my opinion we should pick a solution where API requests are as easy as possible to make and track the progress of (+error handling). The solution could be a similar service as we have in utils/api.js. In the ideal case, someone who hasn't ever heard of Redux should be able to make API requests and fetch the results/error/status in their components, just based on some usage examples we provide and without a lot of boilerplate. :) Again, ideas are welcome! Nothing has been decided on yet. |
I like the redux-persist inclusion. I can see issues arising already from using the simplistic solution in the master branch and redux-persist offers ways arounds this (in particular, the ability to control state serialization at the reducer granularity). The async redux challenge is a bit stickier - I guess the question is who is the target audience for the app kit? Are you providing an opinionated solution or a more robust/flexible framework that allows users to craft a solution. I was new to react-native (but not react/redux) when I created an app from Pepperoni a month ago and very much appreciated the opinions expressed therein. I suppose I was under the impression this used by Futurice to kick start mobile development engagements. While I see the value of solving the rest api asyncronous problem, I was interested by redux-loop's ability to "schedule" actions from within reducers. It sort of flirts with the redux anti-pattern of reducer side effects but I liked it as a inter-reducer communication paradigm that supported a clear separation of concerns in the architecture. One thing I never got around to sorting out with it was the logging of Effects-spawned actions to the console and having them actually dispatched in jest. You can confirm they are created by the reducer, but they aren't dispatched. This gets back to the anti-pattern I suppose - it is good to be able to test the direct output of the reducer, but validating the complete set of state changes when the Effects were actually processed was a challenge. All that to say that I like the idea of a shrink wrap solution for REST calls, but would like to see an action scheduling capability like redux-saga, redux-loop or redux-effects included. |
On the high level CRNA decision, master now includes |
@dominictracey |
Ah - I didn't really get the dependency/integration on Expo in CRNA. Now the I've pulled your branch and messed around with it, it makes a lot more sense. I just cloned the branch,
It doesn't seem like CRNA is versioned, but it just tracks the underlying dependencies. |
Yeah, something like that flow, although as a shorter & easier alternative I would provide a shortcut in the pepperoni CLI that takes care of creating a project for you from scratch using CRNA / react-native init. |
I am liking this very much @FruitieX Please do keep us informed! |
Is this still a thing? |
I'm currently working on a client project based off of the CRNA branch and it's working fine. The project ends soon-ish (before end of year), and I will cherry pick anything useful and generic enough from there into the CRNA branch. Maybe after that we can start thinking about releasing this as a separate starter kit? |
To add to the previous comment, we still need to fix/decide on a few things to make this branch useful for others:
|
I have no strong opinions about all of the above except TypeScript |
What's the status of this? Has there been any work on it? Is this still a potential goal? Can Pepperoni work with Expo? |
Ideas welcome!
I'm thinking about rewriting this project as a "patch" you apply on top of a fresh
create-react-native-app
and/orreact-native init
project. This would bring the following advantages:create-react-native-app
)Downsides:
I'm not really sure about the details yet, trying to come up with a prototype ASAP.
The text was updated successfully, but these errors were encountered: