x-shard
TypeScript icon, indicating that this package has built-in type declarations

0.0.28 • Public • Published

x-shard

GitHub

An event-driven tool that describes behavior relies on either domain or browser events. x-shard is a framework-agnostic tool that operates within the web environment, adhering to its standards.

yarn add x-shard
const $auth = createStore<{ session?: Session; logger?: Logger }>();

const session_defined = createEvent<Session>();

$auth.on('window:offline' , () => { /* do something */ })

$auth.on(session_defined, (store, payload) => {
    store.session = wrap(payload, $another_store.get().wallet);
    store.logger = new Logger();

    another_event(store.session?.id);
});

// subsequence events batches in one process so .track will be triggered once
$auth.track((snapshot) => {
    snapshot.logger?.stdout('session has been certificated');
});

session_defined(session); // emit domain event

React Bind

yarn add x-shard-react
const $main = createStore({ counter: 5 });
const incremented = createEvent();

$main.on(incremented, (store) => {
    store.counter += 1;
});
$main.on('document:DOMContentLoaded', (store) => {
    store.counter += 10;
});

function App() {
    const $ = useStore($main);
    return (
        <button onClick={() => incremented()}>count</button>
    )
}

Package Sidebar

Install

npm i x-shard

Weekly Downloads

1

Version

0.0.28

License

MIT

Unpacked Size

8.75 kB

Total Files

6

Last publish

Collaborators

  • arch1i