Skip to content

๐Ÿ“ค Helpers for managing state effects in boardgame.io

License

Notifications You must be signed in to change notification settings

delucis/bgio-effects

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

bgio-effects

NPM Version Build Status Coverage Status

๐Ÿ“ค Helpers for managing state effects in boardgame.io.

This package provides a structured approach to triggering ephemeral โ€œeffectsโ€ in game code that can be consumed from state on the client. It provides a game plugin and a client-side extension that emits events for your effects.

๐Ÿ’พ Installation

npm i bgio-effects

๐Ÿ‘€ At a glance

Call effects from your moves or other game code:

function move(G, ctx) {
  ctx.effects.explode();
}

Listen for effects on the client:

const onExplode = () => {
  // render explosion/play sound/etc.
};

// With the plain JS emitter
emitter.on('explode', onExplode);

// With the React hook
useEffectListener('explode', onExplode, []);

๐Ÿ“š Documentation

See the full documentation website โ†’

๐Ÿ™Œ Contributing

This is an experimental project and feedback is welcome. Please open an issue if you run into any problems, have a question, or want to suggest features/improvements. PRs are welcome too ๐Ÿ˜Š.

Please also note the code of conduct and be kind to each other.

๐Ÿ“„ License

The code in this repository is provided under the terms of an Anti-Fascist MIT License.

About

๐Ÿ“ค Helpers for managing state effects in boardgame.io

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Languages