Skip to content

Latest commit

 

History

History
62 lines (39 loc) · 1.86 KB

File metadata and controls

62 lines (39 loc) · 1.86 KB

API

This hook can be used as a base to create hooks for different routers

useUrlStateBase hook

A custom React hook to create custom useUrlState hooks.

Parameters:

  • defaultState: object - An object representing the default state values.
  • router: object - Router object with push and replace methods
  • getInitialState?: function - Optional function that return initial state.

Returns:

An object containing:

  • state: object - The current state.
  • getState: Function - Function to get state.
  • updateState: Function - Function to update the state without updating the URL.
  • updateUrl: Function - Function to update both the state and the URL.
  • reset: Function - Function to reset state and url to default values

Example:

import { useUrlStateBase } from 'state-in-url/useUrlStateBase';

function useUrlStateCustom<T>(state: T) {
  const router = React.useMemo({
    push: (url: string) => window.history.pushState(url),
    replace: (url: string) => window.history.replaceState(url)
  }, []);
  return useUrlState(state, router);
}

updateState

Updates the state without modifying the URL.

Parameters:

  • value: T | Partial<T> | T => T - New state value or a function that receives the current state and returns the new state.

updateUrl

Updates both the state and the URL.

Parameters:

  • value?: T | Partial<T> | (currState: T) => T - Optional new state value or a function that receives the current state and returns the new state.
  • options?: Options - Optional options object. When replace is true it will use router.replace. Other nextjs native options for router's push/replace.

reset

Reset state and URL to default

Parameters:

  • options?: Options - Optional options object. When replace is true it will use router.replace. Other nextjs native options for router's push/replace.