TinyBase logoTinyBase

setContent

The setContent method takes an array of two objects and sets the entire data of the Store.

setContent(content: Content | () => Content): this
TypeDescription
contentContent | () => Content

An array containing the tabular and keyed-value data of the Store to be set, or a function that returns the array.

returnsthis

A reference to the Store.

This method will cause listeners to be called for any Table, Row, Cell, Value, or Id changes resulting from it.

Any part of the provided objects that are invalid (either according to the Tables or Values type, or because it does not match a TablesSchema or ValuesSchema associated with the Store), will be ignored silently.

Assuming that at least some of the provided Tables object or Values object is valid, any data that was already present in that part of the Store will be completely overwritten. If either object is completely invalid, no change will be made to the corresponding part of the Store.

The method returns a reference to the Store so that subsequent operations can be chained in a fluent style.

Since v5.4.2, this method can also take a function that returns the content.

Examples

This example sets the data of a Store.

import {createStore} from 'tinybase';

const store = createStore().setContent([
  {pets: {fido: {species: 'dog'}}},
  {open: true, employees: 3},
]);
console.log(store.getTables());
// -> {pets: {fido: {species: 'dog'}}}
console.log(store.getValues());
// -> {open: true, employees: 3}

This example sets the data of a Store with the results of a function.

import {createStore} from 'tinybase';

const store = createStore().setContent(() => [
  {pets: {fido: {species: 'dog'}}},
  {open: true, employees: 3},
]);
console.log(store.getTables());
// -> {pets: {fido: {species: 'dog'}}}
console.log(store.getValues());
// -> {open: true, employees: 3}

This example attempts to set the data of an existing Store with partly invalid, and then completely invalid objects.

import {createStore} from 'tinybase';

const store = createStore().setContent([
  {pets: {fido: {species: 'dog'}}},
  {open: true, employees: 3},
]);

store.setContent([{pets: {felix: {species: 'cat', bug: []}}}, '']);
console.log(store.getTables());
// -> {pets: {felix: {species: 'cat'}}}
console.log(store.getValues());
// -> {open: true, employees: 3}

store.setContent([{meaning: 42}]);
console.log(store.getTables());
// -> {pets: {felix: {species: 'cat'}}}

Since

v4.0.0