pressbooks aldine theme the theme used for the front page or default book
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

68 lines
1.6 KiB

8 years ago
import camelCase from './camelCase';
/**
* DOM-based Routing
*
* Based on {@link http://goo.gl/EUTi53|Markup-based Unobtrusive Comprehensive DOM-ready Execution} by Paul Irish
*
* The routing fires all common scripts, followed by the page specific scripts.
* Add additional events for more control over timing e.g. a finalize event
*/
class Router {
/**
* Create a new Router
*
* @param {object} routes
*/
constructor( routes ) {
this.routes = routes;
}
8 years ago
/**
* Fire Router events
*
* @param {string} route DOM-based route derived from body classes (`<body class="...">`)
* @param {string} [event] Events on the route. By default, `init` and `finalize` events are called.
* @param {string} [arg] Any custom argument to be passed to the event.
*/
fire( route, event = 'init', arg ) {
const fire =
route !== '' &&
this.routes[route] &&
typeof this.routes[route][event] === 'function';
if ( fire ) {
this.routes[route][event]( arg );
}
}
8 years ago
/**
* Automatically load and fire Router events
*
* Events are fired in the following order:
* common init
* page-specific init
* page-specific finalize
* common finalize
*/
loadEvents() {
// Fire common init JS
this.fire( 'common' );
8 years ago
// Fire page-specific init JS, and then finalize JS
document.body.className
.toLowerCase()
.replace( /-/g, '_' )
.split( /\s+/ )
.map( camelCase )
.forEach( className => {
this.fire( className );
this.fire( className, 'finalize' );
} );
8 years ago
// Fire common finalize JS
this.fire( 'common', 'finalize' );
}
8 years ago
}
export default Router;