Skip to main content

API

globalState

Creates a global state that can optionally be persistent.

src/stores/example.ts
import { globalState } from '@codeleap/store'

export const state = globalState(value, config)

Parameters

  • value: The initial state value.
  • config (GlobalStateConfig): Optional configuration.
    • persistKey (string | null): If defined, it activates the persistence of the state.

Methods

The globalState is an atom that can be modified, so it includes all the methods described in nanostores

  • use: React hook for consuming the global state. You can pass a selector to extract a specific value, which is useful for object states to avoid unnecessary re-renders:
src/stores/example.tsx
import { globalState } from '@codeleap/store'

const state = globalState({ value: 1, value2: 2 })

function Component() {
const value1 = state.use(state => state.value)

// re-renders if value1 changes and never if value2 changes

return null
}

function Component2() {
const values = state.use()

// re-renders if value1 or value2 changes

return null
}
  • set: Updates the global state immutably.
src/stores/example.tsx

const count = globalState(1)

count.set(2)

  • get: Retrieves the global state.
src/stores/example.tsx

const count = globalState(1)

const value = count.get()

  • value: Accesses the current value of the global state.
src/stores/example.tsx

const count = globalState(1)

const value = count.value

Array

If the state value is an array, you will have access to the default array methods for manipulation, in addition to the ones provided above.