The Fastify app bundle src/server.js -> rollup -> build/server.js uses src/preact/pages/index.js to render the html for each page on the server side using preact-render-to-string and serve via the correct url path.
The Preact bundle (src/client.js -> rollup -> public/client.js) is referrenced in the html and once loaded will Hydrate the DOM with all the juicy Preact goodness with preact-router src/preact/components/Router.js to hydrate the correct content for the page.
$ npm run dev- rollup src/client.js into public/client.js and src/server.js into build/server.js with sourcemaps and file-watching & run build/server.js with nodemon. App available at localhost:8888.$ npm build- rollup src/client.js into public/client.js and src/server.js into build/server.js.$ npm start- run build/server.js
To build on this codebase check out src/client.js and src/server.js then have a go at editing:
src/preact/componentssrc/preact/pagessrc/preact/layouts
Make sure you update src/preact/pages/index.js if you add new pages.
WARNING: This has not been tested in production. Use at your own risk.
Codebase inspired by Kyle Macquarrie.
