- Added
--stagingCLI argument toreact-static buildthat does not perform build-time optimizations like siteRoot replacement on links assets, etc. If you are testing your site locally, you will likely want to use this option to allow your production site to be navigable on localhost.
- Automatic Route Splitting. From here on out as long a project is using the automatic component-based static routing, all route templates will be automatically deduped and split into separate modules. These modules are statically-rendered into every page that uses them, are preloaded asynchronously with React-Static built-in prefetching utiliies, and are also loaded on demand if needed as the client navigates through your site. Carry on!
- Automatic prefetching of templates and assets. Any eligible
Linkcomponent to a code/data-split destination will automatically queue a prefetch for the appropriate assets. - Render prop versions of
withRouteDataandwithSiteDataare now available asRouteDataandSiteData. These support inline access to their respective props, instead of having to set up an HOC. They also support all three major render prop syntaxes, so render those props however you want!. See the README for more information. - Added a new
Loadingrender prop component and a companionwithLoadingHOC component to easily display React-Static's loading state (that probably won't happen much, but still... ;). - Added a new
Loading/withLoadingrender prop / HOC component pair. You can render this component to gain access to theloadingprop, which was previously only accessible via theRouter.subscribecallback. - Path changes now automatically scroll to the top of the page. Duration defaults to
0ms, but can be modifed via thescrollToTopDurationprop on theRoutercomponent. - Hash routing changes now automatically scroll to the element (or top of the page if the hash is removed but the path stays the same). Duration defaults to
800ms, but can be modifed via thescrollToHashDurationprop on theRoutercomponent.
- In some previous scenarios the window's
location.searchwould be taken into account when matching a path. That is now not the case. You could never previously rely on URL parameters for static paths, but now we're letting you know :) - The
getRoutePropsandgetSiteDataHOC's have both been renamed towithRouteDataandwithSiteData. Using the old methods will result in a deprecation notice and a broken app. Luckily this is an easy find and replace :) Router.subscribehas been deprecated. Though, if you still need programmatic access to a loading event, you can use the newonLoadingsubscriber that functions the same way.
- In your components:
- Replace all instances of
getRoutePropswithwithRouteData - Replace all instances of
getSitePropswithwithSiteData - Replace all instances of
Router.subscribewithonLoading, and importonLoading.
- Replace all instances of
- In your
static.config.js:- Replace all instances of
getPropswithgetData - Replace
getSitePropswithgetSiteData - If you are using a custom
Documentbe sure to replace thesitePropsprop withsiteData.
- Replace all instances of
- Note: To take advantage of auto-code-splitting, you cannot use custom routing for your static routes. I suggest migrating to the automatic routing strategy asap.
getRoutePropswas fixed to always have access to the router props, thus supportinggetRoutePropsas nested components instead of top-level page components.
- Node version was rolled back to
<=6.10.0, to allow some existing users continued usage.
- Preact can now be used in production by setting
preact: truein yourstatic.config.js! Remember to useReactDOM.renderinstead ofhydratein production too :) - Added the
preactexample.
getRoutePropsnow functions as it should when it's wrapped component receives new props without remounting. (Thanks @EmilTholin!)- Node
>=7.5.0<=6.10.0is now stated as required, instead of implied. - When building for
nodestage, themainis now preferred in package imports, instead ofmodule - Better module resolution locations, which allows overriding react-static module versions by installing them locally.
- Added Firebase Authentication example (Thanks @deden!)
- Better error logging for unhandled promise rejections
- Handle Routes with spaces (Thanks @etimberg!)
- Add shouldPrefetch() method to avoid setting loading state (Thanks @chrisbrown-io!)
- Pass DOM props through in links (Thanks @denis-sokolov!)
- Pass additional CLI arguments through to getSiteData() (Thanks @etimberg!)
- Common props returned by
getRouteProps(props that===one another) now promoted to shared props and only requested once per session. Learn more in the docs: Automatic Data and Prop Splitting. Depending on your site, this may significantly decrease site bandwidth and increase both initial page load speed and subsequent page load performance.
<Routes>now accepts a render prop for custom rendering of automatic routes.- Added
animated-routesexample.
LinkandNavLinknow properly render hash links and external links. (Thanks @denis-sokolov!)sassexample now uses a proper webpack loader configuration for style extraction. (Thanks @talves!)
LinkandNavLinknow properly render hash links and external links. (Thanks @denis-sokolov!)sassexample now uses a proper webpack loader configuration for style extraction. (Thanks @talves!)
- Added
sassexample. (Thanks @2metres!) - Added
glamorous-tailwindexample. (Thanks @deden!) - The
REACT_STATIC_ENVenvironment variable is now used internally (and set deterministically via usage of thestartandbuildcommands) instead ofNODE_ENV. This means you can finally set your ownNODE_ENVvariables and use tools likecross-env. Yay!
- Fixed some misleading phrasing where a route component path could be assumed to be compatible with a class, function, or react component, when in fact it is the path to that. (Thanks @Jonarod!)
config.path.srcis now taken into account when constructing theconfig.path.entrypath. (Thanks @crubier!)- Added
manta.lifeto list of sites built with React Static. (Thanks @hql287!) - Updated the
graphql-requestexample to usereact-markdowninstead ofdangerouslySetInnterHTML. (Thanks @hmeissner!)
- Added
graphql-requestexample. (Thanks @ChrisNLott!)
- Use ReactDOM.render instead of ReactDOM.hydrate in dev (Thanks @EmilTholin!)
- Cordova example's
resdirectory is no longer included in the npm distribution making releases and installations much faster.
- Fixed a bug where windows users could not serve or build a project. (Thanks @karland!)
- Fixed a bug where some directories or files weren't being included in npm distributions
- Fixed a bug where component names with numbers would not render propertly. (Thanks @muloka!)
config.paths.devDistcan now be set to specify a different scratch output directory when in development mode.
react-static-routesimports are now relative, thus avoiding absolute path madness... hopefully? :)
- Added Probot to the github repo! Hooray!
- Better yarn/npm colors in cli. @cgmx
- Router now uses
componentDidCatchto gracefully display runtime errors for you.
react-static-routesnow uses dynamic template imports. @EmilTholin- Helmet meta tags are more reliably extracted. @EmilTholin
- Config server is no longer served separately, but piggybacks on webpack dev server. @rileylnapier
- Added
config.paths, which can now be used to customizedistfolder location and other file locations used by react-static - Added
onStarthook. Fires after the first successful dev build when runningreact-static start - Added
onBuildhook. Fires after a successful production build when runningreact-static build - Added
config.devServer, which can be used to customize the configuration for the webpack-dev-server used in development. (Thanks @rywils21!) - Added TypeScript typings for React-Static core exports (Thanks @D1no!)
- Allow customization of dev server PORT and HOST via those environment variables. (Thanks @rywils21!)
config.getRoutesis no longer required and will default to exporting a single root path.- Webpack configurations can now be exported and used externally. (Thanks @crubier!)
<Router>component now supports atypeprop that can be:browser,hash, ormemory, which defines which type ofhistoryobject to create and use internally. Useful for non-web environments or situations where your app will be accessed in a filesystem or nested domain as opposed to a web server.- Added Redux example (Thanks @crubier!)
- Added Apollo GraphQL example (Thanks @crubier!)
- Added Redux + Apollo example (Thanks @crubier!)
- Added Typscript example (Thanks @D1no!)
- The
Document's<title>tag can now be used as a fallback to any<title>tag produced via the<Head>component. (Thanks @EmilTholin!) - Fixed a bug where not defining a 404 component resulted in an error during production build. (Thanks @mplis!)
- Fixed a bug where the webpack dev server would rebuild the app multiple times in a row when started up for the first time. (Thanks @cgmx!)
- The
webpackfunction instatic.config.jshas a new function signature.- Each function is now not required to return a new config object. If a falsey value is returned, the transformation will be ignored, and the next transformation will carry on as normal. Even so, avoid mutating the config object at all costs ;)
- A new argument is now available in the
argsparameter calleddefaultLoaders:
These loaders are here for convenience. Please read the documentation for more information.webpack: ( config, { defaultLoaders: { jsLoader, cssLoader, fileLoader } } ) => {...}
- A dynamic code-splitting example and typescript example are now available! Huzzah!
- Webpack files are now hashed for better cache invalidation. It's about time right?!
- Your
index.jsfile must now export your app in NON-JSX form, eg.export default App, not<App />. With this change, builds can be faster, leaner, and have more control over the build pipeline. - The optional
Htmlcomponent instatic.config.jswas renamed toDocument. - The
preRenderMetaandpostRenderMetahooks instatic.config.jshave been deprecated in favor of the newrenderToHtmlhook. This is a very important change, so please check the readme if you are using these hooks! - The new
renderToHtmlhook now uses a mutable meta object. This object is passed as a prop to the baseDocumentcomponent asrenderMetanow, instead of the previousstaticMeta.
- New
PrefetchWhenSeencomponent allows for prefetching when component becomes visible in the viewport.
- Exporting is now up to 2x faster after switching from a dual pass to a single pass render strategy.
- Fixed a very elusive and angering bug where imported node_modules were not being shared between the node context and the node webpack build of the app used for exporting.
- The
webpackfunction instatic.config.jshas a new function signature.- The new value can be an array of functions or a single function.
- Each function passed will receive the previous resulting (or built-in) webpack config, and expect a modified or new config to be returned. See Webpack Config and Plugins
Now that the webpack callback accepts an array of transformer functions, the concept of plugins has been introduced. These transformer functions are applied in order from top to bottom and have total control over the webpack config. For more information see Webpack Config and Plugins
webpack: [
withCssLoader,
withFileLoader
]
All route exporting is now done via a node bundle that is packaged with webpack. This should dramatically increase reliability in customization and cross-platform usability.