mirror of
https://github.com/YunoHost-Apps/kanboard_ynh.git
synced 2024-09-03 19:36:17 +02:00
80 lines
2.1 KiB
JavaScript
80 lines
2.1 KiB
JavaScript
function Popover(app) {
|
|
this.app = app;
|
|
this.router = new Router();
|
|
this.router.addRoute('screenshot-zone', Screenshot);
|
|
}
|
|
|
|
Popover.prototype.isOpen = function() {
|
|
return $('#popover-container').size() > 0;
|
|
};
|
|
|
|
Popover.prototype.open = function(link) {
|
|
var self = this;
|
|
self.app.dropdown.close();
|
|
|
|
$.get(link, function(content) {
|
|
$("body").append('<div id="popover-container"><div id="popover-content">' + content + '</div></div>');
|
|
self.app.refresh();
|
|
self.router.dispatch(this.app);
|
|
self.afterOpen();
|
|
});
|
|
};
|
|
|
|
Popover.prototype.close = function(e) {
|
|
if (this.isOpen()) {
|
|
|
|
if (e) {
|
|
e.preventDefault();
|
|
}
|
|
|
|
$('#popover-container').remove();
|
|
}
|
|
};
|
|
|
|
Popover.prototype.onClick = function(e) {
|
|
e.preventDefault();
|
|
e.stopPropagation();
|
|
|
|
var link = e.target.getAttribute("href");
|
|
|
|
if (! link) {
|
|
link = e.target.getAttribute("data-href");
|
|
}
|
|
|
|
if (link) {
|
|
this.open(link);
|
|
}
|
|
};
|
|
|
|
Popover.prototype.listen = function() {
|
|
$(document).on("click", ".popover", this.onClick.bind(this));
|
|
$(document).on("click", ".close-popover", this.close.bind(this));
|
|
$(document).on("click", "#popover-container", this.close.bind(this));
|
|
$(document).on("click", "#popover-content", function(e) { e.stopPropagation(); });
|
|
};
|
|
|
|
Popover.prototype.afterOpen = function() {
|
|
var self = this;
|
|
var taskForm = $("#task-form");
|
|
|
|
if (taskForm) {
|
|
taskForm.on("submit", function(e) {
|
|
e.preventDefault();
|
|
|
|
$.ajax({
|
|
type: "POST",
|
|
url: taskForm.attr("action"),
|
|
data: taskForm.serialize(),
|
|
success: function(data, textStatus, request) {
|
|
if (request.getResponseHeader("X-Ajax-Redirect")) {
|
|
window.location = request.getResponseHeader("X-Ajax-Redirect");
|
|
}
|
|
else {
|
|
$("#popover-content").html(data);
|
|
self.afterOpen();
|
|
}
|
|
}
|
|
});
|
|
});
|
|
}
|
|
};
|