Documentation
Storable

Storable

⚠️

This page is under construction.

⚠️

Beta feature, subject to change.

Storable allows you to store data in the game's state. Data stored in Storable will be saved and loaded with current game state.

If you are looking for creating actions to operate data, you can use Persistent abstraction.

Data stored in Storable are separated by namespace. You can use the same key in different namespaces.
For example, you can store the player1's name in the player1 namespace and the player2's name in the player2 namespace.

Namespace game is already defined and can store data, you can add your own by instantiating a new Namespace.

For example, create a new namespace player1 and store the player1's name in it:

type Player1Content = {
    name: string;
};
 
const storable = game.getLiveGame().getStorable();
 
// initialize a new namespace
const player1namespace = new Namespace<Player1Content>();
storable.addNamespace('player1', player1namespace);
 
// set data from the namespace
const namespace = storable.getNamespace<Player1Content>('player1');
namespace.set('name', 'John Doe');
 
// get data from the namespace
const name = namespace.get('name');
console.log(name); // John Doe

Public Methods

addNamespace<T extends NameSpaceContent<keyof T>>

  • namespace: Namespace<T>
  • Returns this

getNamespace<T extends NameSpaceContent<keyof T> = any>

  • key: string - The namespace key
  • Returns Namespace<T>

setNamespace<T extends NameSpaceContent<keyof T> = any>

  • key: string - The namespace key
  • namespace: Namespace<T>
  • Returns this

getNamespaces

  • Returns { [key: string]: Namespace<any>; }

hasNamespace

  • key: string
  • Returns boolean

removeNamespace

  • key: string
  • Returns this

keys

  • Returns string[]

values

  • Returns Namespace<any>[]

entries

  • Returns [string, Namespace<any>][]