sapper-template
This is a blank project for sapper to be deployed on firebase
- firebase functions serve the initial ssr load
- static files are handled by firebase hosting
- you can still dev locally (just need to try with firebase serve before deploying)
Get started
npm install
cd functions && npm install
Update all .example
files from the config folder with your firebase credentials, then remove the .example
extension. Next,
update src/firebase.config.example
with your client firebase credentials and then remove the .example
extension.
yarn dev
You should be good to go
Structure
Sapper expects to find two directories in the root of your project — src
and static
.
"functions" directory is meant for firebase functions
"config" directory is meant for firebase config files
static
The static directory contains any static assets that should be available. These are served using sirv. !Only in dev mode!
In your service-worker.js file, you can import these as files
from the generated manifest...
import { files } from '../__sapper__/service-worker.js';
...so that you can cache them (though you can choose not to, for example if you don't want to cache very large files). TODO figure out if firebase caching renders this process useless
Bundler config
Added rollup-plugin-node-globals
Production mode and deployment
To start a production version of your app, run npm run build && npm start
. This will disable live reloading, and activate the appropriate bundler plugins.
You can deploy your application to firebase with npm run deploy
or yarn deploy
this runs the predeploy.js script then deploys to firebase functions and hosting
predeploy.js just copies sapper to the functions folder
Bugs and feedback
Please let me know if this works for you or any improvements you would like to see