@dependable/cache v0.11.0
@dependable/cache
Reactive cache for storing entities using @dependable/state.
Install
# npm
npm install --save @dependable/cache
# yarn
yarn add @dependable/cacheUsage
Create a cache
Let's create a cache for storing todo's.
import { Cache } from "@dependable/cache";
import { observable } from "@dependable/state";
const todos = new Cache("todos");Loading state into the cache
Now we can load a todo into the cache using a resolver.
todos.load(42, async () => {
  const response = await fetch("https://example.com/todos/42");
  if (!response.ok) {
    throw new Error(response.statusText);
  }
  const data = await response.json();
  return {
    id: data.id,
    title: observable(data.title),
    completed: observable(data.completed),
  };
});If you only would like to initialize a value, you can use the initialize method. It will only run the resolver if the value hasn't been initialized already.
todos.initialize(42, async () => {
  const response = await fetch("https://example.com/todos/42");
  if (!response.ok) {
    throw new Error(response.statusText);
  }
  const data = await response.json();
  return {
    id: data.id,
    title: observable(data.title),
    completed: observable(data.completed),
  };
});Retrieving a value from the cache
We can get a value from the cache the following way.
import { UNINITIALIZED, LOADING, LOADED, FAILED } from "@dependable/cache";
const [todo, status, error] = todos.byId(42);
if (status === FAILED) {
  // Loading the todo failed.
  // If this was a reload, you will still have the old value.
  console.log(error);
} else if (status === LOADING) {
  // The todo is loading.
  // If this was a reload, you will still have the old value.
} else if (status === UNINITIALIZED) {
  // Loading the todo hasn't been started yet.
} else if (status === LOADED) {
  // The todo finished loading.
}If the above call is done inside of a @dependable/state computed or a @dependable/view component, it will update every time the status changes.
Getting only the status
If you just need the status of a cache entry, you can use the statusById method.
import { UNINITIALIZED, LOADING, LOADED, FAILED } from "@dependable/cache";
const status = todos.statusById(42);
if (status === FAILED) {
  // Loading the todo failed.
  // If this was a reload, you will still have the old value.
  console.log(error);
} else if (status === LOADING) {
  // The todo is loading.
} else if (status === UNINITIALIZED) {
  // Loading the todo hasn't been started yet.
} else if (status === LOADED) {
  // The todo finished loading.
}Evicting values
You can evict the a value the following way that will turn it back to be uninitialized.
todos.evict(42);
const [todo, status, error] = todos.byId(42);
// will have null for the todo and a status of UNINITIALIZED.You can also clear the entire cache with the clear method.
Storing non-serializable objects
In case you need to store non-serializable objects in a cache, you can create a cache without giving it a name. This way the observable backing the cache will be anonymous and it's values will not be handled by the development tools.
This is useful for lazy loading components.
const components = new Cache();
components.load("editor", import("./editor.js"));
const [module, status, error] = components.byId("editor");