Skip to content

A simple fix for unwanted duplicate history entries on the frontend.

License

Notifications You must be signed in to change notification settings

solkimicreb/history-throttler

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

History Throttler

Build Package size JavaScript Style Guide Version Dependencies Status License

Accidentally pushing multiple new history items in quick succession is a common error in web apps. It breaks the history navigation and leads to frustrated users. History Throttler provides a simple fix for this issue.

Table of Contents

Installation

npm install history-throttler

Usage

History Throttler exposes an alternative to the native history.pushState, that does the following.

  • It has the exact same arguments as history.pushState.

  • It calls history.pushState, if no new history item was added since the last repaint and the document is fully loaded.

  • It calls history.replaceState otherwise.

As a result it never pushes more than one history item between two repaints, but it keeps the history fresh all the time.

import pushState from 'history-throttler'

// this adds a new history item
pushState({ historyProp: 'value' }, 'title', 'url')
// this replaces the above item, instead of adding a new
pushState({ historyProp: 'otherValue' }, 'title2', 'url/2')

Quick fixing broken apps

Simply overwrite history.pushState to fix unwanted double-history-entry issues in your app.

import pushState from 'history-throttler'

history.pushState = pushState

This only works if your routing solution uses the HTML5 History API, it does not work with older hashbang based solutions.

Platform support

  • Chrome: 23 and above
  • Firefox: 24 and above
  • Safari: 7 and above
  • Opera: 15 and above
  • Edge: 12 and above
  • IE: 10 and above

Alternative builds

This library detects if you use ES6 or commonJS modules and serve the right format to you. The exposed bundles are transpiled to ES5 to support common tools - like UglifyJS minifying. If you would like a finer control over the provided build, you can specify them in your imports.

  • history-throttler/dist/es.es6.js exposes an ES6 build with ES6 modules.
  • history-throttler/dist/es.es5.js exposes an ES5 build with ES6 modules.
  • history-throttler/dist/cjs.es6.js exposes an ES6 build with commonJS modules.
  • history-throttler/dist/cjs.es5.js exposes an ES5 build with commonJS modules.

If you use a bundler, set up an alias for history-throttler to point to your desired build. You can learn how to do it with webpack here and with rollup here.

Contributing

Contributions are always welcome. Just send a PR against the master branch or open a new issue. Please make sure that the tests and the linter pass. Thanks!