Skip to content

Latest commit

 

History

History
63 lines (48 loc) · 1.3 KB

README.md

File metadata and controls

63 lines (48 loc) · 1.3 KB

Statefulia

npm version npm downloads

JavaScript/TypeScript library for state management.

Installation

npm i @lilbunnyrabbit/statefulia

Example

const state = new State({
  useChangeEvent: true,
  useLogs: true,
});

// ...

const stateElement = state.init("clicks", {
  defaultValue: 0,
  config: {
    useLocalStorage: true,
    useEvents: true,
  },
});

// Increment "clicks" element in State.
document.getElementById("clicks-button").addEventListener("click", () => {
  stateElement.set(stateElement.get() + 1);
});

// ...

class App extends StateComponent {
  constructor() {
    super(state);
  }

  $onStateChange(key, value) {
    switch (key) {
      case "clicks":
        document.getElementById("clicks-display").innerText = `${value} clicks.`;
        break;
      default:
        break;
    }
  }
}

TODO

  • TypeScript generics
  • Documentation

License

MIT © Andraž Mesarič-Sirec

"Buy Me A Coffee"