@ucd-lib/spa-router-middleware

0.2.3 • Public • Published

spa-router-middleware

Handles static routes for SPAs in Express

Problem. In your spa, you update your path using history state api. So instead of routes like /#foo /#bar you have routes list /foo and /bar. But your apps resources are served from /, so on refresh of /foo a 404 is returned. This middleware handles the routing by allowing you to set the routes your app uses.

This middleware then allows for a small mustache template to insert 1) known routes by the server and 2) any additional json info you would like to insert on load (ie, user info if the user is logged in, etc).

example:

Node Helper Module static.js

const express = require('express');
const path = require('path');
const fs = require('fs');
const spaMiddleware = require('@ucd-lib/spa-router-middleware');
const config = require('../config');

module.exports = (app) => {
  // path to your spa assets dir
  let assetsDir = path.join(__dirname, '..', 'public');

  /**
   * Setup SPA app routes
   */
  spaMiddleware({
    // pass the express app
    app, 
    
    // pass the file you want to use
    htmlFile : path.join(assetsDir, 'index.html'), 
    
    // are we serving from host root (/)?
    isRoot : true, 
    
    // array of root paths.  ie appRoutes = ['foo', 'bar'] to server /foo/* /bar/*
    appRoutes : config.appRoutes, 
    
    // options for express.static(dir, opts)
    static : {
      dir : assetsDir
      // opts : {}  // additional opts for express.static
    },

    // do you want to manually handle 404 for requests to unknown resources
    // this lets you render your own 404 page using the index.html
    enable404 : false,

    getConfig : async (req, res, next) => {
      let user;
      if( req.session.user ) {
        user = {
          loggedIn : true,
          username : req.session.user
        };
      } else {
        user = {loggedIn: false};
      }

      next({
        user : user,
        appRoutes : config.appRoutes
      });
    },
    
    template : (req, res, next) => {
      next({title: 'spa test'});
    }
  });

}

express index.js

const express = require('express');
const app = express();

// setup static routes
require('./static')(app);

app.listen(3000, () => {
  console.log('server ready on port 3000');
});

index.html

<!doctype html>
<html>
  <head>
    <!-- template variable -->
    <title>{{title}}</title>
    <meta name="viewport" content="width=device-width, minimum-scale=1, initial-scale=1, user-scalable=no">

    <!-- 
        spa-router-middleware will replace this with
        <script>var APP_CONFIG = {"user":{"loggedIn":false},"appRoutes":["foo","bar"]};</script>
     -->
    {{config}}
  </head>

  <body>
    <!-- stuff -->
  </body>
</html>

Readme

Keywords

none

Package Sidebar

Install

npm i @ucd-lib/spa-router-middleware

Weekly Downloads

24

Version

0.2.3

License

ISC

Unpacked Size

7.49 kB

Total Files

4

Last publish

Collaborators

  • ucdust
  • jrmerz
  • qjhart
  • steveisgreat