meshviewer/lib/infobox/main.js
2017-02-05 16:56:02 +01:00

71 lines
1.6 KiB
JavaScript

define(['infobox/link', 'infobox/node', 'infobox/location'], function (link, node, location) {
'use strict';
return function (config, sidebar, router) {
var self = this;
var el;
function destroy() {
if (el && el.parentNode) {
el.parentNode.removeChild(el);
el = undefined;
sidebar.reveal();
}
}
function create() {
destroy();
sidebar.ensureVisible();
sidebar.hide();
el = document.createElement('div');
sidebar.container.insertBefore(el, sidebar.container.firstChild);
el.scrollIntoView(false);
el.classList.add('infobox');
el.destroy = destroy;
var closeButton = document.createElement('button');
closeButton.classList.add('close');
closeButton.classList.add('ion-close');
closeButton.onclick = router.reset;
el.appendChild(closeButton);
}
function clear() {
var closeButton = el.firstChild;
while (el.firstChild) {
el.removeChild(el.firstChild);
}
el.appendChild(closeButton);
}
self.resetView = destroy;
self.gotoNode = function gotoNode(d, update) {
if (update !== true) {
create();
} else {
clear();
}
node(config, el, router, d);
};
self.gotoLink = function gotoLink(d, update) {
if (update !== true) {
create();
} else {
clear();
}
link(config, el, router, d);
};
self.gotoLocation = function gotoLocation(d) {
create();
location(config, el, router, d);
};
return self;
};
});