var eventURL = "/plugins/dynamix.docker.manager/include/Events.php";
function addDockerContainerContext(container, image, template, started, update, autostart, webui, id) {
var opts = [{header: container, image: "/plugins/dynamix.docker.manager/images/dynamix.docker.manager.png"}];
if (started && (webui !== "" && webui != "#")) {
opts.push({text: 'WebUI', icon: 'fa-globe', href: webui, target: '_blank'});
opts.push({divider: true});
}
if (!update) {
opts.push({text: 'Update', icon: 'fa-arrow-down', action: function(e){ e.preventDefault(); execUpContainer(container); }});
opts.push({divider: true});
}
if (started) {
opts.push({text: 'Stop', icon: 'fa-stop', action: function(e){ e.preventDefault(); eventControl({action: "stop", container: id}); }});
opts.push({text: 'Restart', icon: 'fa-refresh', action: function(e){ e.preventDefault(); eventControl({action: "restart", container: id}); }});
} else {
opts.push({text: 'Start', icon: 'fa-play', action: function(e){ e.preventDefault(); eventControl({action: "start", container: id}); }});
}
opts.push({divider: true});
if (location.pathname.indexOf("/Dashboard") === 0) {
opts.push({text: 'Logs', icon: 'fa-navicon', action: function(e){ e.preventDefault(); containerLogs(container, id); }});
}
if (template) {
opts.push({text: 'Edit', icon: 'fa-wrench', action: function(e){ e.preventDefault(); editContainer(container, template); }});
}
opts.push({divider: true});
opts.push({text: 'Remove', icon: 'fa-trash', action: function(e){ e.preventDefault(); rmContainer(container, image, id); }});
context.attach('#context-'+container, opts);
}
function addDockerImageContext(image, imageTag) {
var opts = [{header: '(orphan image)'}];
opts.push({text: "Remove", icon: "fa-trash", action: function(e){ e.preventDefault(); rmImage(image, imageTag); }});
context.attach('#context-'+image, opts);
}
function execUpContainer(container) {
var title = "Updating the container: " + container;
var address = "/plugins/dynamix.docker.manager/include/CreateDocker.php?updateContainer=true&ct[]=" + encodeURIComponent(container);
popupWithIframe(title, address, true);
}
function popupWithIframe(title, cmd, reload) {
pauseEvents();
$("#iframe-popup").html('');
$("#iframe-popup").dialog({
autoOpen: true,
title: title,
draggable: true,
width: 800,
height: ((screen.height / 5) * 4) || 0,
resizable: true,
modal: true,
show: {effect: "fade", duration: 250},
hide: {effect: "fade", duration: 250},
open: function(ev, ui) {
$("#myIframe").attr("src", cmd);
},
close: function(event, ui) {
if (reload && !$("#myIframe").contents().find("#canvas").length) {
location = window.location.href;
} else {
resumeEvents();
}
}
});
$(".ui-dialog .ui-dialog-titlebar").addClass("menu");
$(".ui-dialog .ui-dialog-title").css("text-align", "center").css("width", "100%");
$(".ui-dialog .ui-dialog-content").css("padding", "0");
//$('.ui-widget-overlay').click(function() { $("#iframe-popup").dialog("close"); });
}
function addContainer() {
var path = location.pathname;
var x = path.indexOf("?");
if (x!=-1) path = path.substring(0, x);
location = path + "/AddContainer";
}
function editContainer(container, template) {
var path = location.pathname;
var x = path.indexOf("?");
if (x!=-1) path = path.substring(0, x);
location = path + "/UpdateContainer?xmlTemplate=edit:" + template;
}
function updateContainer(container) {
var body = "Update container: "+container;
swal({
title: "Are you sure?",
text: body,
type: "warning",
showCancelButton: true,
confirmButtonColor: "#8CD4F5",
confirmButtonText: "Yes, update it!"
}, function() {
execUpContainer(container);
});
}
function rmContainer(container, image, id) {
var body = "Remove container: "+container+"
";
swal({
title: "Are you sure?",
text: body,
type: "warning",
html: true,
showCancelButton: true,
confirmButtonColor: "#DD6B55",
confirmButtonText: "Yes, delete it!",
closeOnConfirm: false,
showLoaderOnConfirm: true
}, function() {
if ($("#removeimagechk").prop('checked')) {
eventControl({action: "remove_all", container: id, image: image});
} else {
eventControl({action: "remove_container", container: id});
}
});
}
function rmImage(image, imageName) {
var body = "Remove image: "+$('').html(imageName).text();
swal({
title: "Are you sure?",
text: body,
type: "warning",
showCancelButton: true,
confirmButtonColor: "#DD6B55",
confirmButtonText: "Yes, delete it!",
closeOnConfirm: false,
showLoaderOnConfirm: true
}, function() {
eventControl({action: "remove_image", image: image});
});
}
function eventControl(params, reload) {
if (typeof reload == "undefined") reload = true;
$.post(eventURL, params, function(data) {
if (data.success === true) {
if (reload) location.reload();
} else {
swal({title: "Execution error", text: data.success, type: "error"});
}
}, "json");
}
function reloadUpdate() {
$(".updatecolumn").html(" checking...");
$("#cmdStartStop").val("/plugins/dynamix.docker.manager/scripts/dockerupdate.php");
$("#cmdArg1").remove();
$("#cmdArg2").remove();
$("#formStartStop").submit();
}
function autoStart(container, event) {
document.getElementsByName("container")[0].value = container;
$("#formStartStop").submit();
}
function containerLogs(container, id) {
var height = 600;
var width = 900;
var run = eventURL + "?action=log&container=" + id + "&title=Log for: " + container;
var top = (screen.height-height) / 2;
var left = (screen.width-width) / 2;
var options = 'resizeable=yes,scrollbars=yes,height='+height+',width='+width+',top='+top+',left='+left;
window.open(run, 'log', options);
}