DocumentServer/OfficeWeb/apps/common/main/lib/component/Window.js

471 lines
22 KiB
JavaScript
Raw Normal View History

2015-04-28 14:59:00 +00:00
/*
* (c) Copyright Ascensio System SIA 2010-2015
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at Lubanas st. 125a-25, Riga, Latvia,
* EU, LV-1021.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
if (Common === undefined) {
var Common = {};
}
define(["common/main/lib/component/BaseView"], function () {
Common.UI.Window = Common.UI.BaseView.extend(_.extend((function () {
var config = {
closable: true,
header: true,
modal: true,
width: 300,
height: "auto",
title: "Title",
alias: "Window",
cls: "",
toolclose: "close"
};
var template = '<div class="asc-window<%= modal?" modal":"" %><%= cls?" "+cls:"" %>" id="<%= id %>" style="width:<%= width %>px;">' + "<% if (header==true) { %>" + '<div class="header">' + "<% if (closable!==false) %>" + '<div class="tool close"></div>' + "<% %>" + '<span class="title"><%= title %></span> ' + "</div>" + "<% } %>" + '<div class="body"><%= tpl %></div>' + "</div>";
function _getMask() {
var mask = $(".modals-mask");
if (mask.length == 0) {
mask = $("<div class='modals-mask'>").appendTo(document.body).hide();
}
return mask;
}
function _keydown(event) {
if (!this.isLocked() && this.isVisible()) {
switch (event.keyCode) {
case Common.UI.Keys.ESC:
event.preventDefault();
event.stopPropagation();
if (this.initConfig.closable !== false) {
this.initConfig.toolclose == "hide" ? this.hide() : this.close();
}
return false;
break;
case Common.UI.Keys.RETURN:
if (this.$window.find(".btn.primary").length) {
if ((this.initConfig.onprimary || this.onPrimary).call(this) === false) {
event.preventDefault();
return false;
}
}
break;
}
}
}
function _centre() {
if (window.innerHeight == undefined) {
var main_width = document.documentElement.offsetWidth;
var main_height = document.documentElement.offsetHeight;
} else {
main_width = window.innerWidth;
main_height = window.innerHeight;
}
if (this.initConfig.height == "auto") {
var win_height = parseInt(this.$window.find(".body").css("height"));
this.initConfig.header && (win_height += parseInt(this.$window.find(".header").css("height")));
} else {
win_height = this.initConfig.height;
}
var top = Math.floor(((parseInt(main_height) - parseInt(win_height)) / 2) * 0.9);
var left = Math.floor((parseInt(main_width) - parseInt(this.initConfig.width)) / 2);
this.$window.css("left", left);
this.$window.css("top", top);
}
function _getTransformation(end) {
return {
"-webkit-transition": "0.3s opacity",
"-moz-transition": "0.3s opacity",
"-ms-transition": "0.3s opacity",
"-o-transition": "0.3s opacity",
"opacity": end
};
}
function _dragstart(event) {
if ($(event.target).hasClass("close")) {
return;
}
Common.UI.Menu.Manager.hideAll();
this.dragging.enabled = true;
this.dragging.initx = event.pageX - parseInt(this.$window.css("left"));
this.dragging.inity = event.pageY - parseInt(this.$window.css("top"));
if (window.innerHeight == undefined) {
var main_width = document.documentElement.offsetWidth;
var main_height = document.documentElement.offsetHeight;
} else {
main_width = window.innerWidth;
main_height = window.innerHeight;
}
this.dragging.maxx = main_width - parseInt(this.$window.css("width"));
this.dragging.maxy = main_height - parseInt(this.$window.css("height"));
$(document).on("mousemove", this.binding.drag);
$(document).on("mouseup", this.binding.dragStop);
this.fireEvent("drag", [this, "start"]);
}
function _mouseup() {
$(document).off("mousemove", this.binding.drag);
$(document).off("mouseup", this.binding.dragStop);
this.dragging.enabled = false;
this.fireEvent("drag", [this, "end"]);
}
function _mousemove(event) {
if (this.dragging.enabled) {
var left = event.pageX - this.dragging.initx,
top = event.pageY - this.dragging.inity;
left < 0 ? (left = 0) : left > this.dragging.maxx && (left = this.dragging.maxx);
top < 0 ? (top = 0) : top > this.dragging.maxy && (top = this.dragging.maxy);
this.$window.css({
left: left,
top: top
});
}
}
Common.UI.alert = function (options) {
var me = this.Window.prototype;
var arrBtns = {
ok: me.okButtonText,
cancel: me.cancelButtonText,
yes: me.yesButtonText,
no: me.noButtonText,
close: me.closeButtonText
};
if (!options.buttons) {
options.buttons = {};
options.buttons["ok"] = arrBtns["ok"];
} else {
if (_.isArray(options.buttons)) {
var newBtns = {};
_.each(options.buttons, function (b) {
newBtns[b] = arrBtns[b];
});
options.buttons = newBtns;
}
}
var template = '<div class="info-box">' + '<div class="icon <%= iconCls %>" />' + '<div class="text"><span><%= msg %></span></div>' + "</div>" + '<div class="footer">' + '<button class="btn normal dlg-btn primary" result="ok">OK</button>' + "<% if (_.size(buttons) > 1) %>" + '<button class="btn normal dlg-btn" result="cancel">Cancel</button>' + "<% %>" + "</div>";
var win = new Common.UI.Window({
cls: "alert",
title: options.title,
onprimary: onKeyDown,
tpl: _.template(template, options)
});
function autoSize(window) {
var text_cnt = window.getChild(".info-box");
var text = window.getChild(".info-box span");
var footer = window.getChild(".footer");
var header = window.getChild(".header");
var body = window.getChild(".body");
var icon = window.getChild(".icon");
body.css("padding-bottom", "10px");
text_cnt.height(Math.max(text.height(), icon.height()));
body.height(parseInt(text_cnt.css("height")) + parseInt(footer.css("height")));
window.setSize(text.position().left + text.width() + parseInt(text_cnt.css("padding-right")), parseInt(body.css("height")) + parseInt(header.css("height")));
}
function onBtnClick(event) {
if (options.callback) {
options.callback.call(win, event.currentTarget.attributes["result"].value);
}
win.close(true);
}
function onKeyDown(event) {
onBtnClick({
currentTarget: win.getChild(".footer .dlg-btn")[0]
});
return false;
}
win.on({
"render:after": function (obj) {
autoSize(obj);
},
show: function (obj) {
obj.getChild(".footer .dlg-btn").focus();
obj.getChild(".footer .dlg-btn").on("click", onBtnClick);
},
close: function () {
options.callback && options.callback.call(win, "close");
}
});
win.show();
};
Common.UI.warning = function (options) {
options = options || {}; ! options.title && (options.title = this.Window.prototype.textWarning);
Common.UI.alert(_.extend(options, {
iconCls: "warn"
}));
};
Common.UI.error = function (options) {
options = options || {}; ! options.title && (options.title = this.Window.prototype.textError);
Common.UI.alert(_.extend(options, {
iconCls: "error"
}));
};
Common.UI.confirm = function (options) {
options = options || {}; ! options.title && (options.title = this.Window.prototype.textConfirmation);
Common.UI.alert(_.extend(options, {
iconCls: "confirm"
}));
};
Common.UI.info = function (options) {
options = options || {}; ! options.title && (options.title = this.Window.prototype.textInformation);
Common.UI.alert(_.extend(options, {
iconCls: "info"
}));
};
return {
$window: undefined,
$lastmodal: undefined,
dragging: {
enabled: false
},
initialize: function (options) {
this.initConfig = {};
this.binding = {};
_.extend(this.initConfig, config, options || {}); ! this.initConfig.id && (this.initConfig.id = "window-" + this.cid); ! this.initConfig.tpl && (this.initConfig.tpl = "");
Common.UI.BaseView.prototype.initialize.call(this, this.initConfig);
},
render: function () {
var renderto = this.initConfig.renderTo || document.body;
$(renderto).append(_.template(template, this.initConfig));
this.$window = $("#" + this.initConfig.id);
this.binding.keydown = _.bind(_keydown, this);
if (this.initConfig.header) {
this.binding.drag = _.bind(_mousemove, this);
this.binding.dragStop = _.bind(_mouseup, this);
this.binding.dragStart = _.bind(_dragstart, this);
var doclose = function () {
if (this.$window.find(".tool.close").hasClass("disabled")) {
return;
}
if (this.initConfig.toolcallback) {
this.initConfig.toolcallback.call(this);
} else {
(this.initConfig.toolclose == "hide") ? this.hide() : this.close();
}
};
this.$window.find(".header").on("mousedown", this.binding.dragStart);
this.$window.find(".tool.close").on("click", _.bind(doclose, this));
} else {
this.$window.find(".body").css({
top: 0,
"border-radius": "5px"
});
}
if (this.initConfig.height == "auto") {
var height = parseInt(this.$window.find("> .body").css("height"));
this.initConfig.header && (height += parseInt(this.$window.find("> .header").css("height")));
this.$window.height(height);
} else {
this.$window.css("height", this.initConfig.height);
}
this.fireEvent("render:after", this);
return this;
},
show: function (x, y) {
if (this.initConfig.modal) {
var mask = _getMask();
if (this.options.animate !== false) {
var opacity = mask.css("opacity");
mask.css("opacity", 0);
mask.show();
setTimeout(function () {
mask.css(_getTransformation(opacity));
},
1);
} else {
mask.show();
}
Common.NotificationCenter.trigger("modal:show", this);
this.$lastmodal = $(".asc-window.modal:not(.dethrone):visible").first().addClass("dethrone");
}
if (!this.$window) {
this.render();
if (_.isNumber(x) && _.isNumber(y)) {
this.$window.css("left", Math.floor(x));
this.$window.css("top", Math.floor(y));
} else {
_centre.call(this);
}
} else {
if (!this.$window.is(":visible")) {
this.$window.show();
}
}
$(document).on("keydown." + this.cid, this.binding.keydown);
var me = this;
if (this.options.animate !== false) {
this.$window.css({
"-webkit-transform": "scale(0.8)",
"-moz-transform": "scale(0.8)",
"-ms-transform": "scale(0.8)",
"-o-transform": "scale(0.8)",
opacity: 0
});
setTimeout(function () {
me.$window.css({
"-webkit-transition": "0.3s opacity, 0.3s -webkit-transform",
"-webkit-transform": "scale(1)",
"-moz-transition": "0.3s opacity, 0.3s -moz-transform",
"-moz-transform": "scale(1)",
"-ms-transition": "0.3s opacity, 0.3s -ms-transform",
"-ms-transform": "scale(1)",
"-o-transition": "0.3s opacity, 0.3s -o-transform",
"-o-transform": "scale(1)",
"opacity": "1"
});
},
1);
setTimeout(function () {
me.$window.css({
"-webkit-transform": "",
"-moz-transform": "",
"-ms-transition": "",
"-ms-transform": "",
"-o-transform": ""
});
me.fireEvent("show", me);
},
350);
} else {
this.fireEvent("show", this);
}
Common.NotificationCenter.trigger("window:show");
},
close: function (suppressevent) {
$(document).off("keydown." + this.cid);
if (this.initConfig.header) {
this.$window.find(".header").off("mousedown", this.binding.dragStart);
}
if (this.initConfig.modal) {
var hide_mask = true;
if (this.$lastmodal.size() > 0) {
this.$lastmodal.removeClass("dethrone");
hide_mask = !this.$lastmodal.hasClass("modal");
}
if (hide_mask) {
var mask = $(".modals-mask");
if (this.options.animate !== false) {
var opacity = mask.css("opacity");
mask.css(_getTransformation(0));
setTimeout(function () {
mask.css("opacity", opacity);
mask.hide();
},
300);
} else {
mask.hide();
}
}
Common.NotificationCenter.trigger("modal:close", this);
}
this.$window.remove();
suppressevent !== true && this.fireEvent("close", this);
},
hide: function () {
$(document).off("keydown." + this.cid);
if (this.$window) {
if (this.initConfig.modal) {
var hide_mask = true;
if (this.$lastmodal.size() > 0) {
this.$lastmodal.removeClass("dethrone");
hide_mask = !this.$lastmodal.hasClass("modal");
}
if (hide_mask) {
var mask = $(".modals-mask");
if (this.options.animate !== false) {
var opacity = mask.css("opacity");
mask.css(_getTransformation(0));
setTimeout(function () {
mask.css("opacity", opacity);
mask.hide();
},
300);
} else {
mask.hide();
}
}
Common.NotificationCenter.trigger("modal:hide", this);
}
this.$window.hide();
this.fireEvent("hide", this);
}
},
isLocked: function () {
return this.$window.hasClass("dethrone") || (!this.options.modal && this.$window.parent().find(".asc-window.modal:visible").length);
},
getChild: function (selector) {
return selector ? this.$window.find(selector) : this.$window;
},
setWidth: function (width) {
if (width >= 0) {
var min = parseInt(this.$window.css("min-width"));
width < min && (width = min);
this.$window.width(width);
}
},
getWidth: function () {
return parseInt(this.$window.css("width"));
},
setHeight: function (height) {
if (height >= 0) {
var min = parseInt(this.$window.css("min-height"));
height < min && (height = min);
this.$window.height(height);
if (this.initConfig.header) {
height -= parseInt(this.$window.find("> .header").css("height"));
}
this.$window.find("> .body").css("height", height);
}
},
getHeight: function () {
return parseInt(this.$window.css("height"));
},
setSize: function (w, h) {
this.setWidth(w);
this.setHeight(h);
},
getSize: function () {
return [this.getWidth(), this.getHeight()];
},
setTitle: function (title) {
this.$window.find("> .header > .title").text(title);
},
getTitle: function () {
return this.$window.find("> .header > .title").text();
},
isVisible: function () {
return this.$window && this.$window.is(":visible");
},
onPrimary: function () {},
cancelButtonText: "Cancel",
okButtonText: "OK",
yesButtonText: "Yes",
noButtonText: "No",
closeButtonText: "Close",
textWarning: "Warning",
textError: "Error",
textConfirmation: "Confirmation",
textInformation: "Information"
};
})(), Common.UI.Window || {}));
});