You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
3.1 KiB
83 lines
3.1 KiB
9 years ago
|
(function() {
|
||
|
function closeOnTop() {
|
||
|
document.documentElement.removeAttribute('data-ontop');
|
||
|
document.getElementById('guest_id').value = '';
|
||
|
var target = document.querySelector('.on-top-target');
|
||
|
target.removeAttribute('style');
|
||
|
document.querySelector('body').removeAttribute('style');
|
||
|
forEachElement('.on-top-control', function(control) {
|
||
|
control.classList.remove('on-top-control');
|
||
|
});
|
||
|
}
|
||
|
forEachElement('#guests .guest', function(guest) {
|
||
|
var button = guest.querySelector('.set-host');
|
||
|
button.addEventListener('click', function(event) {
|
||
|
var target = document.querySelector('.on-top-target');
|
||
|
var body = document.querySelector('body');
|
||
|
// maintain our current height
|
||
|
body.setAttribute('style', 'height: ' + body.clientHeight + 'px');
|
||
|
document.documentElement.setAttribute('data-ontop', 'set-host');
|
||
|
guest.classList.add('on-top-control');
|
||
|
target.setAttribute('style', 'bottom: ' + guest.clientHeight + 'px');
|
||
|
document.getElementById('guest_id').value = guest.dataset.id;
|
||
|
});
|
||
|
});
|
||
|
forEachElement('#hosts .host', function(host) {
|
||
|
initHost(host);
|
||
|
});
|
||
|
|
||
|
function initHost(host) {
|
||
|
forEachElement('.place-guest', function(button) {
|
||
|
button.addEventListener('click', function(event) {
|
||
|
var guest_id = document.getElementById('guest_id').value;
|
||
|
if (guest_id) {
|
||
|
var guest = document.getElementById('guest-' + guest_id);
|
||
|
var form = document.getElementById('hosts');
|
||
|
var data = new FormData(form);
|
||
|
|
||
|
host.classList.add('requesting');
|
||
|
if (guest.dataset.affectedHosts) {
|
||
|
data.append('affected-hosts', guest.dataset.affectedHosts);
|
||
|
forEach(guest.dataset.affectedHosts.split(','), function(host_id) {
|
||
|
h = document.getElementById('host-' + host_id);
|
||
|
if (h) {
|
||
|
h.classList.add('requesting');
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
data.append('button', button.value);
|
||
|
|
||
|
var request = new XMLHttpRequest();
|
||
|
request.onreadystatechange = function() {
|
||
|
if (request.readyState == 4) {
|
||
|
if (request.status == 200) {
|
||
|
var response = JSON.parse(request.responseText);
|
||
|
for (var host_id in response.hosts) {
|
||
|
host_element = document.getElementById('host-' + host_id);
|
||
|
widget = response.hosts[host_id];
|
||
|
host_element.className = widget.class;
|
||
|
host_element.querySelector('.guests').innerHTML = widget.html;
|
||
|
initHost(host_element);
|
||
|
host_element.classList.remove('requesting');
|
||
|
}
|
||
|
for (var guest_id in response.affected_hosts) {
|
||
|
guest_element = document.getElementById('guest-' + guest_id);
|
||
|
if (guest_element) {
|
||
|
guest_element.setAttribute('data-affected-hosts', response.affected_hosts[guest_id].join(','));
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
request.open('POST', form.getAttribute('action'), true);
|
||
|
request.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
|
||
|
request.send(data);
|
||
|
}
|
||
|
});
|
||
|
}, host);
|
||
|
}
|
||
|
forEachElement('.on-top-close', function(button) {
|
||
|
button.addEventListener('click', closeOnTop);
|
||
|
});
|
||
|
})();
|