<!DOCTYPE HTML>
|
|
<html>
|
|
<head>
|
|
<title>Timeline | Data serialization</title>
|
|
|
|
<style>
|
|
body, html {
|
|
font-family: arial, sans-serif;
|
|
font-size: 11pt;
|
|
}
|
|
|
|
textarea {
|
|
width: 800px;
|
|
height: 200px;
|
|
}
|
|
|
|
.buttons {
|
|
margin: 20px 0;
|
|
}
|
|
|
|
.buttons input {
|
|
padding: 10px;
|
|
}
|
|
</style>
|
|
|
|
<script src="../../../dist/vis.js"></script>
|
|
<link href="../../../dist/vis.css" rel="stylesheet" type="text/css" />
|
|
<script src="../../googleAnalytics.js"></script>
|
|
</head>
|
|
<body>
|
|
|
|
<h1>Serialization and deserialization</h1>
|
|
|
|
<p>This example shows how to serialize and deserialize JSON data, and load this in the Timeline via a DataSet. Serialization and deserialization is needed when loading or saving data from a server.</p>
|
|
|
|
<textarea id="data">
|
|
[
|
|
{"id": 1, "content": "item 1<br>start", "start": "2014-01-23"},
|
|
{"id": 2, "content": "item 2", "start": "2014-01-18"},
|
|
{"id": 3, "content": "item 3", "start": "2014-01-21"},
|
|
{"id": 4, "content": "item 4", "start": "2014-01-19", "end": "2014-01-24"},
|
|
{"id": 5, "content": "item 5", "start": "2014-01-28", "type": "point"},
|
|
{"id": 6, "content": "item 6", "start": "2014-01-26"}
|
|
]
|
|
</textarea>
|
|
|
|
<div class="buttons">
|
|
<input type="button" id="load" value="↓ Load" title="Load data from textarea into the Timeline">
|
|
<input type="button" id="save" value="↑ Save" title="Save data from the Timeline into the textarea">
|
|
</div>
|
|
|
|
<div id="visualization"></div>
|
|
|
|
<script>
|
|
var txtData = document.getElementById('data');
|
|
var btnLoad = document.getElementById('load');
|
|
var btnSave = document.getElementById('save');
|
|
|
|
// Create an empty DataSet.
|
|
// This DataSet is used for two way data binding with the Timeline.
|
|
var items = new vis.DataSet();
|
|
|
|
// create a timeline
|
|
var container = document.getElementById('visualization');
|
|
var options = {
|
|
editable: true
|
|
};
|
|
var timeline = new vis.Timeline(container, items, options);
|
|
|
|
function loadData () {
|
|
// get and deserialize the data
|
|
var data = JSON.parse(txtData.value);
|
|
|
|
// update the data in the DataSet
|
|
//
|
|
// Note: when retrieving updated data from a server instead of a complete
|
|
// new set of data, one can simply update the existing data like:
|
|
//
|
|
// items.update(data);
|
|
//
|
|
// Existing items will then be updated, and new items will be added.
|
|
items.clear();
|
|
items.add(data);
|
|
|
|
// adjust the timeline window such that we see the loaded data
|
|
timeline.fit();
|
|
}
|
|
btnLoad.onclick = loadData;
|
|
|
|
function saveData() {
|
|
// get the data from the DataSet
|
|
// Note that we specify the output type of the fields start and end
|
|
// as ISODate, which is safely serializable. Other serializable types
|
|
// are Number (unix timestamp) or ASPDate.
|
|
//
|
|
// Alternatively, it is possible to configure the DataSet to convert
|
|
// the output automatically to ISODates like:
|
|
//
|
|
// var options = {
|
|
// type: {start: 'ISODate', end: 'ISODate'}
|
|
// };
|
|
// var items = new vis.DataSet(options);
|
|
// // now items.get() will automatically convert start and end to ISO dates.
|
|
//
|
|
var data = items.get({
|
|
type: {
|
|
start: 'ISODate',
|
|
end: 'ISODate'
|
|
}
|
|
});
|
|
|
|
// serialize the data and put it in the textarea
|
|
txtData.value = JSON.stringify(data, null, 2);
|
|
}
|
|
btnSave.onclick = saveData;
|
|
|
|
// load the initial data
|
|
loadData();
|
|
</script>
|
|
</body>
|
|
</html>
|