-
Notifications
You must be signed in to change notification settings - Fork 799
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
Document React Hot Loader 3 #243
Comments
To give some sense of perspective, if nobody contributes, the stable 3.0 might get out as late as June because I really don’t have the bandwidth to work on a good doc right now. It really is the biggest blocker to getting this version out! |
@gaearon What kind of documentation is needed? Maybe you can give a rough documentation outline or so… |
We need to update this intro. The new intro would be slightly longer because there is a bit more setup involved.
|
I can help out with the docs. I've been reading up and gathering as much info as I can. I'm about to go through both the old and 3.0 source to try and figure out what's going on under the hood. I'll see if I can get the ball rolling on the Intro, as well. |
Thanks! |
Can I suggest we get started on Hackpad first? I think it will get us started quicker, and then we can use something like the Hackpad downloader to download as markdown to commit, moving forward. I took an initial bash at https://hackpad.com/React-Hot-Loader-v3-CxSDMncWUnb. |
@gadicc @hedgerh Can I ask you to work it out between yourselves? I added you both as collaborators so you should be able to work on a single PR together without much hassle. (Up to you if you want to first take it somewhere else, but I would prefer reviewing on GitHub.) Just a reminder that the PR(s) would need to be sent against the |
I've been following everyone's work and gathering info as well, and would be more than happy to help with documentation. Below, I took the work you all have started and simply rearranged the JSX component tags to make the layout a little more familiar for folks new to this. We may want to clarify a couple of points that could prove to be confusing:
import 'react-hot-loader/patch';
import React from 'react';
import { render } from 'react-dom';
import { AppContainer } from 'react-hot-loader';
import RootContainer from './containers/rootContainer.js';
render((
<AppContainer>
<RootContainer />
</AppContainer>
), document.getElementById('react-root'));
if (module.hot) {
module.hot.accept('./containers/rootContainer.js', () => {
const NextRootContainer = require('./containers/rootContainer.js');
render((
<AppContainer>
<NextRootContainer />
</AppContainer>
), document.getElementById('react-root'));
})
} |
@gaearon, sure thing, thanks. @hedgerh, sorry, I probably should have checked with you first on your progress but I just wanted to get the ball rolling. But now we can collaborate together :) all, we'll track this in #257. @tsaiDavid, help would be most welcome, thanks! Everything is on github now so see the issue above for more info. In particular, I'll mention that I don't use or know how to use webpack, so help is very welcome in all webpack related content. |
@tsaiDavid, did you edit your post right like right now? :) Sorry, I only saw it when refreshing the page, I had left the page open and your edit didn't come through. Anyway, as you saw, everything is on GitHub now... your points are all great, would love you to submit it as a PR to |
Hey hey @gadicc no worries. I've been off all weekend so I'll need a little bit of time to get caught up. My progress so far was:
Totally open to any changes. Just did as much research as I could and piece things together as I understood it. |
In next-docs, Webpack is recommended as a fallback if you aren't already using Babel. Is there a difference in featureset or reliability between the two adaptors, or is it entirely personal preference? |
@appsforartists, the webpack loader only registers/patches react components that are exported by the module/file, whereas the babel plugin works on all top level variable assignments. This will be made clearer in the final version of the docs. |
@gadicc That was my hunch. Glad it will be documented. 😃 |
Hey @gaearon, just wanted to check in and see what the status on this was. I haven't checked in on it in a couple of months. I will take another look at them, but I think we just need you or someone that knows the lib to review the docs/site and see if anything needs to be added or removed. Obviously no rush on my end. Just wanted to touch base! |
Question about the module accept code, the current examples are not DRY and risk differing setup between first render and hot reload. Why not take the function that does the hot accept and run it on first render too? Because of import graph analysis? |
@wmertens I agree, its a bit wet so I've been doing something like:
|
Nice, I like it! @gaearon something to make official? BTW, WET stands for We Enjoy Typing 🙂 On Sun, Sep 4, 2016, 5:40 PM Janek Lasocki-Biczysko <
|
@wmaurer never heard that one before -- excellent :) |
…er> according to this gaearon/react-hot-loader#243. TODO: use webpack-dev-middleware instead of webpack-dev-server
A small optimization hack - I noticed that there are a bunch of places in my production javascript where my development env folder path is being included due to react-hot-loader. If you use the Uglify plugin in your webpack production build you can add a global def in the Uglify config to drop this stuff out. The react-hot-loader code itself could probably be modified to take better advantage of this by wrapping more of the module itself in
|
I'm on Windows so I was using DefinePlugin to define NODE_ENV. Looks like I can achieve what you suggested by using a combination of DefinePlugin and cross-env. |
@rvaidya Ah, forgot about Windows. 😉 Let me know if that doesn't work. |
Using both cross env and DefinePlugin does work. You'd think just using cross-env to set the environment variable would be enough, but my output file sizes are larger without the additional DefinePlugin entry setting process.env. |
I believe |
This was the only way I could get it to work, migrating from webpack 1 on a fairly simple project. Also, seems logical since you either need to render the new reference to App, or re-require it on every `render` call (see gaearon/react-hot-loader#243 (comment))
I ran into a really challenging issue to diagnose today. I was importing my API surface first (which imports a bunch of stuff in the correct order), then importing the root component explicitly. This ended up creating a dependency graph that HMR could (or would) not handle. In order to resolve the issue, I had to import my API surface as a namespace and access the root component via the import alias. This doesn't work: declare let module: any;
import * as React from 'react';
import { render } from 'react-dom';
import { AppContainer } from 'react-hot-loader';
// import framework API surface
import './webrx-react';
// import Root Component
import { AppView } from './Components';
const container = document.getElementById('app');
render(<AppContainer><AppView /></AppContainer>, container);
if ((module as any).hot) {
(module as any).hot.accept('./Components', () => {
// ...
}
} but this does: declare let module: any;
import * as React from 'react';
import { render } from 'react-dom';
import { AppContainer } from 'react-hot-loader';
// import framework API surface
import * as wxr from './webrx-react';
const container = document.getElementById('app');
render(<AppContainer><wxr.Components.AppView /></AppContainer>, container);
if ((module as any).hot) {
(module as any).hot.accept('./webrx-react', () => {
// ...
}
} I tried a number of combinations, but ultimately, if your root component has two parents it gets removed from I figured it's possible I'm not seeing something, so checking in with you guys. I should also mention i tried to import the import { AppView } from './Components/Common/App/AppView';
(module as any).hot.accept('./Components/Common/App/AppView', () => {
// ...
} |
So I followed the steps to convert a project to the new "3.x" version and the page is realoading entirely every time a change is made. It wasn't the case before. Any idea on what could be the cause to that? |
@tleunen want to open a new issue with a minimal reproduce project? There's a number of possibilities, with the most common being not pointing to RR routes in I'm working on updating the troubleshooting doc with common 3.0-specific problems. |
I'm in a fairly big project so I can try to reproduce it in a smaller one but I'm setting the AppContainer with the root component (which contains the redux provider and router).
|
The current code doesn't work with `[email protected]`, following this discussion gaearon/react-hot-loader#243 I could fix my own code with the changes on how the hot module replacement api was called.
We just merged #260 so I think we can close this general issue for now. If you can see that something in the docs is not right or there is some room for improvements, feel free to open either issue or PR. Thanks! |
It features two modes (
react-hot-loader/babel
andreact-hot-loader/webpack
), doesn’t hide HMR API (you have to addmodule.hot.accept
call yourself) and has a somewhat different API and setup process.There’s info in gaearon/react-hot-boilerplate#61 and reduxjs/redux-devtools@64f58b7 but we should create good step-by-step docs and update the website too.
This will take a while because it’s not a priority for me. If you want to contribute, you are very welcome!
Obviously we can’t release 3.0 without any docs.
The text was updated successfully, but these errors were encountered: