Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/neurosnap/starfx

A modern approach to side-effect and state management for web apps.
https://github.com/neurosnap/starfx

front-end react redux side-effects state-management structured-concurrency web-app

Last synced: about 1 month ago
JSON representation

A modern approach to side-effect and state management for web apps.

Awesome Lists containing this project

README

        

![starfx](./docs/static/logo.svg)

# starfx

A micro-mvc framework for react apps.

If we think in terms of MVC, if `react` is the **View**, then `starfx` is the
**Model** and **Controller**.

[Get started](https://starfx.bower.sh)

Features:

- A powerful middleware system to fetch API data
- An immutable and reactive data store
- A task tree side-effect system for handling complex business logic using
structured concurrency
- React integration

```tsx
import { createApi, createSchema, createStore, mdw, timer } from "starfx";
import { Provider, useCache } from "starfx/react";

const [schema, initialState] = createSchema();
const store = createStore({ initialState });

const api = createApi();
// mdw = middleware
api.use(mdw.api({ schema }));
api.use(api.routes());
api.use(mdw.fetch({ baseUrl: "https://api.github.com" }));

const fetchRepo = api.get(
"/repos/neurosnap/starfx",
{ supervisor: timer() },
api.cache(),
);

store.run(api.bootup);

function App() {
return (



);
}

function Example() {
const { isInitialLoading, isError, message, data } = useCache(fetchRepo());

if (isInitialLoading) return "Loading ...";

if (isError) return `An error has occurred: ${message}`;

return (


{data.name}


{data.description}


👀 {data.subscribers_count}{" "}
✨ {data.stargazers_count}{" "}
🍴 {data.forks_count}

);
}
```