State
Persist the state (scale, position, min/max nodes) in the url or indexedDB
Default value: null
Options:
- name
- readFromLocalStorage
- writeToLocalStorage
- readFromIndexedDB
- writeToIndexedDB
- readFromUrlParams
- writeToUrlParams
Code example:
let family = new FamilyTree(document.getElementById('tree'), { state: { name: 'StateForMyTree', readFromLocalStorage: true, writeToLocalStorage: true, readFromIndexedDB: true, writeToIndexedDB: true, readFromUrlParams: true, writeToUrlParams: true }, nodes: [ { id: 1 }, { id: 2, pid: 1 } ] });
1. Local storage
Use name to save a state name
Code example:
state: { name: 'StateForMyTree', readFromLocalStorage: true, writeToLocalStorage: true, },You can see the result here:
You can test the state here by changing the position of the tree and refreshing the page (F5)
Limitation: most browsers has 5MB limit of the local storage.
2.IndexedDB
Usage is the same as Local storage.
Limitations: does not work in iframe.
Code example:
state: { name: 'StateForMyTree', readFromIndexedDB: true, writeToIndexedDB: true, },
3.URL
Use stateToUrl method to open the saved state in the browser:
Signature:
family.stateToUrl();
Priority
- readFromUrlParams
- readFromLocalStorage
- readFromIndexedDB