Skip to content

[core] Add mapStates(…)#5429

Merged
davidkpiano merged 9 commits intomainfrom
davidkpiano/state-mapping
Apr 27, 2026
Merged

[core] Add mapStates(…)#5429
davidkpiano merged 9 commits intomainfrom
davidkpiano/state-mapping

Conversation

@davidkpiano
Copy link
Copy Markdown
Member

@davidkpiano davidkpiano commented Dec 11, 2025

Add mapState(snapshot, mapper) to map a snapshot to values based on active state(s).

import { mapState } from 'xstate';

const results = mapState(snapshot, {
  states: {
    loading: { map: () => 'Loading...' },
    success: { map: (snap) => snap.context.data },
    error: { map: (snap) => snap.context.error.message }
  }
});

console.log(results);
// E.g. if snapshot.value === 'loading', then:
// [
//   { stateNode: { key: 'loading' }, result: 'Loading...' }
// ]

@changeset-bot
Copy link
Copy Markdown

changeset-bot Bot commented Dec 11, 2025

🦋 Changeset detected

Latest commit: d220665

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 5 packages
Name Type
xstate Minor
@xstate/react Major
@xstate/solid Major
@xstate/svelte Major
@xstate/vue Major

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@davidkpiano davidkpiano marked this pull request as ready for review February 1, 2026 22:39
@davidkpiano davidkpiano merged commit 9d9c1fe into main Apr 27, 2026
1 check passed
@davidkpiano davidkpiano deleted the davidkpiano/state-mapping branch April 27, 2026 09:47
@github-actions github-actions Bot mentioned this pull request Apr 27, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant