Socket
Socket
Sign inDemoInstall

better-state

Package Overview
Dependencies
0
Maintainers
1
Versions
26
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    better-state

A small wrapper that encapsulates history.pushState and window.onpopstate and offers extra features - including 'No Going Back'


Version published
Weekly downloads
4
decreased by-20%
Maintainers
1
Install size
14.9 kB
Created
Weekly downloads
 

Readme

Source

Better-State

Including "No Going Back"

This is a small wrapper that encapsulates

  • history.pushState()

  • history.replaceState(), and

  • window.onpopstate()

Features

  1. View the browser history1 for your app.

  2. Prevent the use of the browser's back and forward buttons. ("No Going Back")

  3. Get more information in the onpopstate event, such as whether the back button or forward button was pressed...

  4. Includes the current window.scroll for convenience (useful when using History.scrollRestoration = 'manual')

Installation

npm install better-state

Setup

import betterState from "better-state";


Known Issues

Preventing the browser back button is a bit of a hack - and definitely not supported by most modern browsers.

Please test thoroughly before using in a production environment.

(Because it's not possible to actually prevent the back button event, better-state forces an immediate history.go(1) )


Usage

To change the current browser URL and add to the browser history:

betterState.pushState(url)

betterState.pushState(url,{--some consumer-data})


To prevent the use of the browser's back and forward buttons:

("No Going Back")

betterState.preventBack = true

betterState.preventForward = true

NB - effects of this settings are stacked and cumulative. ie two calls to betterState.preventBack = true will require two calls to betterState.preventBack = false to take affect. Use betterState.resetPreventBack() and betterState.resetPreventForward() to negate previous calls.


To get the current known history1:

betterState.history


To subscribe to popstate events (i.e. back and forward button clicks...)

betterState.onPopState = (e) => { console.log(e); };

returns:

  • back: [ true | false ] if the back button was pressed.
  • forward: [ true | false ] if the forward button was pressed.
  • prevented: [ true | false ] if the pop was prevented.
  • forced: [ true | false ] if the pop was forced2
  • state: { Object } including:
    • url
    • scrollX
    • scrollY
    • data: { Object } any consumer data

To unsubscribe

betterState.offPopState();


To override preventBack and preventForward:

betterState.forceForward()

betterState.forceBack()


To replace the current state:

(i.e. to change the current URL without adding to the browser history)

betterState.replaceState(url)

betterState.replaceState(url,{--some consumer-data})


To get the current state:

betterState.state


Footnotes

  1. Only includes better-state history. 2

  2. See forceBack() and forceForward().

Keywords

FAQs

Last updated on 01 May 2022

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc