501 lines
20 KiB
JavaScript
501 lines
20 KiB
JavaScript
/*
|
|
* (c) Copyright Ascensio System SIA 2010-2014
|
|
*
|
|
* 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
|
|
*
|
|
*/
|
|
var ApplicationController = new(function () {
|
|
var me, api, docConfig = {},
|
|
embedConfig = {},
|
|
permissions = {},
|
|
maxPages = 0,
|
|
minToolbarWidth = 550,
|
|
minEmbedWidth = 400,
|
|
minEmbedHeight = 600,
|
|
embedCode = '<iframe allowtransparency="true" frameborder="0" scrolling="no" src="{embed-url}" width="{width}" height="{height}"></iframe>',
|
|
maxZIndex = 9090,
|
|
created = false;
|
|
if (typeof isBrowserSupported !== "undefined" && !isBrowserSupported()) {
|
|
Common.Gateway.reportError(undefined, "Your browser is not supported.");
|
|
return;
|
|
}
|
|
ZeroClipboard.setMoviePath("../../../3rdparty/ZeroClipboard/ZeroClipboard10.swf");
|
|
var clipShortUrl = new ZeroClipboard.Client();
|
|
var clipEmbedObj = new ZeroClipboard.Client();
|
|
clipShortUrl.zIndex = maxZIndex;
|
|
clipEmbedObj.zIndex = maxZIndex;
|
|
function emptyFn() {}
|
|
function createBuffered(fn, buffer, scope, args) {
|
|
return function () {
|
|
var timerId;
|
|
return function () {
|
|
var me = this;
|
|
if (timerId) {
|
|
clearTimeout(timerId);
|
|
timerId = null;
|
|
}
|
|
timerId = setTimeout(function () {
|
|
fn.apply(scope || me, args || arguments);
|
|
},
|
|
buffer);
|
|
};
|
|
} ();
|
|
}
|
|
function updateSocial() {
|
|
var $socialPanel = $("#id-popover-social-container");
|
|
if ($socialPanel.length > 0) {
|
|
if ($socialPanel.attr("data-loaded") == "false") {
|
|
typeof FB !== "undefined" && FB.XFBML && FB.XFBML.parse();
|
|
typeof twttr !== "undefined" && twttr.widgets && twttr.widgets.load();
|
|
$socialPanel.attr("data-loaded", "true");
|
|
}
|
|
}
|
|
}
|
|
function loadConfig(data) {
|
|
embedConfig = $.extend(embedConfig, data.config.embedded);
|
|
$("#id-short-url").text(embedConfig.shareUrl || "Unavailable");
|
|
$("#id-textarea-embed").text(embedCode.replace("{embed-url}", embedConfig.embedUrl).replace("{width}", minEmbedWidth).replace("{height}", minEmbedHeight));
|
|
if (typeof embedConfig.shareUrl !== "undefined" && embedConfig.shareUrl != "") {
|
|
if ($("#id-popover-social-container ul")) {
|
|
$("#id-popover-social-container ul").append('<li><div class="fb-like" data-href="' + embedConfig.shareUrl + '" data-send="false" data-layout="button_count" data-width="450" data-show-faces="false"></div></li>');
|
|
$("#id-popover-social-container ul").append('<li class="share-twitter"><a href="https://twitter.com/share" class="twitter-share-button" data-url="' + embedConfig.shareUrl + '">Tweet</a></li>');
|
|
$("#id-popover-social-container ul").append('<li class="share-mail"><a class="btn btn-mini" href="mailto:?subject=I have shared a document with you: ' + embedConfig.docTitle + "&body=I have shared a document with you: " + embedConfig.shareUrl + '"><i class="icon-envelope"></i>Email</a></li>');
|
|
}
|
|
}
|
|
if (typeof embedConfig.shareUrl === "undefined") {
|
|
$("#id-btn-share").hide();
|
|
}
|
|
if (typeof embedConfig.embedUrl === "undefined") {
|
|
$("#id-btn-embed").hide();
|
|
}
|
|
if (typeof embedConfig.fullscreenUrl === "undefined") {
|
|
$("#id-btn-fullscreen").hide();
|
|
}
|
|
if (typeof data.config.canBackToFolder === "undefined" || !data.config.canBackToFolder) {
|
|
$("#id-btn-close").hide();
|
|
}
|
|
if (embedConfig.toolbarDocked === "top") {
|
|
$("#toolbar").addClass("top");
|
|
$(".viewer").addClass("top");
|
|
} else {
|
|
$("#toolbar").addClass("bottom");
|
|
$(".viewer").addClass("bottom");
|
|
}
|
|
}
|
|
function loadDocument(data) {
|
|
docConfig = data.doc;
|
|
if (docConfig) {
|
|
permissions = $.extend(permissions, docConfig.permissions);
|
|
var docInfo = {};
|
|
docInfo.Id = docConfig.key;
|
|
docInfo.Url = docConfig.url;
|
|
docInfo.Title = docConfig.title;
|
|
docInfo.Format = docConfig.fileType;
|
|
docInfo.VKey = docConfig.vkey;
|
|
docInfo.Origin = docConfig.origin;
|
|
if (api) {
|
|
api.asc_enableKeyEvents(true);
|
|
api.asc_setViewerMode(true);
|
|
api.asc_LoadDocument(docInfo);
|
|
Common.Analytics.trackEvent("Load", "Start");
|
|
}
|
|
}
|
|
}
|
|
function onSheetsChanged() {
|
|
if (api) {
|
|
maxPages = api.asc_getWorksheetsCount();
|
|
var setActiveWorkSheet = function (index) {
|
|
$.each($("#worksheets").children("li"), function () {
|
|
$(this).removeClass("active");
|
|
});
|
|
$("#worksheet-" + index).addClass("active");
|
|
api.asc_showWorksheet(index);
|
|
};
|
|
var handleWorksheet = function (e) {
|
|
var $worksheet = $(this);
|
|
var index = $worksheet.attr("id").match(/\d+/);
|
|
if (index.length > 0) {
|
|
index = parseInt(index[0]);
|
|
if (index > -1 && index < maxPages) {
|
|
setActiveWorkSheet(index);
|
|
}
|
|
}
|
|
};
|
|
$.each($("#worksheets").children("li"), function () {
|
|
$(this).unbind("click");
|
|
$(this).remove();
|
|
});
|
|
for (var i = 0; i < maxPages; i++) {
|
|
$("#worksheets").append('<li id="worksheet-' + i + '">' + api.asc_getWorksheetName(i).replace(/\s/g, " ") + "</li>");
|
|
var $worksheet = $("#worksheet-" + i);
|
|
$worksheet && $worksheet.bind("click", handleWorksheet);
|
|
}
|
|
setActiveWorkSheet(api.asc_getActiveWorksheetIndex());
|
|
}
|
|
}
|
|
function onHyperlinkClick(url) {
|
|
if (url) {
|
|
var newDocumentPage = window.open(url, "_blank");
|
|
if (newDocumentPage) {
|
|
newDocumentPage.focus();
|
|
}
|
|
}
|
|
}
|
|
function hidePreloader() {
|
|
$("#loading-mask").fadeOut("slow");
|
|
}
|
|
function onDocumentContentReady() {
|
|
setVisiblePopover($("#id-popover-share"), false);
|
|
setVisiblePopover($("#id-popover-embed"), false);
|
|
handlerToolbarSize();
|
|
hidePreloader();
|
|
Common.Analytics.trackEvent("Load", "Complete");
|
|
}
|
|
function showMask() {
|
|
$("#id-loadmask").modal({
|
|
backdrop: "static",
|
|
keyboard: false
|
|
});
|
|
}
|
|
function hideMask() {
|
|
$("#id-loadmask").modal("hide");
|
|
}
|
|
function onOpenDocument(progress) {
|
|
var proc = (progress.CurrentFont + progress.CurrentImage) / (progress.FontsCount + progress.ImagesCount);
|
|
$("#loadmask-text").html("LOADING DOCUMENT: " + Math.round(proc * 100) + "%");
|
|
}
|
|
function onLongActionBegin(type, id) {
|
|
var text = "";
|
|
switch (id) {
|
|
case c_oAscAsyncAction["Print"]:
|
|
text = "Downloading document...";
|
|
break;
|
|
default:
|
|
text = "Please wait...";
|
|
break;
|
|
}
|
|
if (type == c_oAscAsyncActionType["BlockInteraction"]) {
|
|
$("#id-loadmask .cmd-loader-title").html(text);
|
|
showMask();
|
|
}
|
|
}
|
|
function onLongActionEnd(type, id) {
|
|
if (type === c_oAscAsyncActionType.BlockInteraction) {
|
|
switch (id) {
|
|
case c_oAscAsyncAction.Open:
|
|
if (api) {
|
|
api.asc_Resize();
|
|
}
|
|
onDocumentContentReady();
|
|
onSheetsChanged();
|
|
break;
|
|
}
|
|
hideMask();
|
|
}
|
|
}
|
|
function onError(id, level, errData) {
|
|
hidePreloader();
|
|
var message;
|
|
switch (id) {
|
|
case c_oAscError.ID.Unknown:
|
|
message = me.unknownErrorText;
|
|
break;
|
|
case c_oAscError.ID.ConvertationTimeout:
|
|
message = me.convertationTimeoutText;
|
|
break;
|
|
case c_oAscError.ID.ConvertationError:
|
|
message = me.convertationErrorText;
|
|
break;
|
|
case c_oAscError.ID.DownloadError:
|
|
message = me.downloadErrorText;
|
|
break;
|
|
default:
|
|
message = me.errorDefaultMessage.replace("%1", id);
|
|
break;
|
|
}
|
|
if (level == c_oAscError.Level.Critical) {
|
|
Common.Gateway.reportError(id, message);
|
|
$("#id-critical-error-title").text(me.criticalErrorTitle);
|
|
$("#id-critical-error-message").text(message);
|
|
$("#id-critical-error-close").off();
|
|
$("#id-critical-error-close").on("click", function () {
|
|
window.location.reload();
|
|
});
|
|
} else {
|
|
$("#id-critical-error-title").text(me.notcriticalErrorTitle);
|
|
$("#id-critical-error-message").text(message);
|
|
$("#id-critical-error-close").off();
|
|
$("#id-critical-error-close").on("click", function () {
|
|
$("#id-critical-error-dialog").modal("hide");
|
|
});
|
|
}
|
|
$("#id-critical-error-dialog").modal("show");
|
|
Common.Analytics.trackEvent("Internal Error", id.toString());
|
|
}
|
|
function onExternalError(error) {
|
|
if (error) {
|
|
hidePreloader();
|
|
$("#id-error-mask-title").text(error.title);
|
|
$("#id-error-mask-text").text(error.msg);
|
|
$("#id-error-mask").css("display", "block");
|
|
Common.Analytics.trackEvent("External Error", error.title);
|
|
}
|
|
}
|
|
var handlerToolbarSize = createBuffered(function (size) {
|
|
var visibleCaption = function (btn, visible) {
|
|
if (visible) {
|
|
$(btn + " button").addClass("no-caption");
|
|
$(btn + " button span").css("display", "none");
|
|
} else {
|
|
$(btn + " button").removeClass("no-caption");
|
|
$(btn + " button span").css("display", "inline");
|
|
}
|
|
};
|
|
var isMinimize = $("#toolbar").width() < minToolbarWidth;
|
|
visibleCaption("#id-btn-copy", isMinimize);
|
|
visibleCaption("#id-btn-share", isMinimize);
|
|
visibleCaption("#id-btn-embed", isMinimize);
|
|
},
|
|
10);
|
|
function onDocumentResize() {
|
|
if (api) {
|
|
api.asc_Resize();
|
|
}
|
|
handlerToolbarSize();
|
|
}
|
|
function isVisiblePopover(popover) {
|
|
return popover.hasClass("in");
|
|
}
|
|
function setVisiblePopover(popover, visible, owner) {
|
|
api && api.asc_enableKeyEvents(!visible);
|
|
if (visible) {
|
|
if (owner) {
|
|
popover.css("display", "block");
|
|
var popoverData = owner.data("popover"),
|
|
$tip = popoverData.tip(),
|
|
pos = popoverData.getPosition(false),
|
|
actualHeight = $tip[0].offsetHeight,
|
|
placement = (embedConfig.toolbarDocked === "top") ? "bottom" : "top",
|
|
tp;
|
|
$tip.removeClass("fade in top bottom left right");
|
|
switch (placement) {
|
|
case "bottom":
|
|
tp = {
|
|
top: pos.top + pos.height,
|
|
left: owner.position().left + (owner.width() - popover.width()) * 0.5
|
|
};
|
|
break;
|
|
default:
|
|
case "top":
|
|
tp = {
|
|
top: pos.top - actualHeight,
|
|
left: owner.position().left + (owner.width() - popover.width()) * 0.5
|
|
};
|
|
break;
|
|
}
|
|
$tip.css(tp).addClass(placement).addClass("in");
|
|
}
|
|
if (popover.hasClass("embed")) {
|
|
clipEmbedObj.show();
|
|
}
|
|
if (popover.hasClass("share")) {
|
|
clipShortUrl.show();
|
|
updateSocial();
|
|
}
|
|
} else {
|
|
popover.removeClass("in");
|
|
popover.css("display", "none");
|
|
popover.hasClass("embed") && clipEmbedObj.hide();
|
|
popover.hasClass("share") && clipShortUrl.hide();
|
|
}
|
|
}
|
|
function updateEmbedCode() {
|
|
var newWidth = parseInt($("#id-input-embed-width").val()),
|
|
newHeight = parseInt($("#id-input-embed-height").val());
|
|
if (newWidth < minEmbedWidth) {
|
|
newWidth = minEmbedWidth;
|
|
}
|
|
if (newHeight < minEmbedHeight) {
|
|
newHeight = minEmbedHeight;
|
|
}
|
|
$("#id-textarea-embed").text(embedCode.replace("{embed-url}", embedConfig.embedUrl).replace("{width}", newWidth).replace("{height}", newHeight));
|
|
$("#id-input-embed-width").val(newWidth + "px");
|
|
$("#id-input-embed-height").val(newHeight + "px");
|
|
}
|
|
function openLink(url) {
|
|
var newDocumentPage = window.open(url);
|
|
if (newDocumentPage) {
|
|
newDocumentPage.focus();
|
|
}
|
|
}
|
|
function createController() {
|
|
if (created) {
|
|
return me;
|
|
}
|
|
me = this;
|
|
created = true;
|
|
var documentMoveTimer;
|
|
clipShortUrl.addEventListener("mousedown", function () {
|
|
if ($("#id-btn-copy-short").hasClass("copied")) {
|
|
return;
|
|
}
|
|
$("#id-btn-copy-short").button("copied");
|
|
$("#id-btn-copy-short").addClass("copied");
|
|
clipShortUrl.setText($("#id-short-url").text());
|
|
setTimeout(function () {
|
|
$("#id-btn-copy-short").button("reset");
|
|
$("#id-btn-copy-short").removeClass("copied");
|
|
},
|
|
2000);
|
|
});
|
|
clipEmbedObj.addEventListener("mousedown", function () {
|
|
if ($("#id-btn-copy-embed").hasClass("copied")) {
|
|
return;
|
|
}
|
|
$("#id-btn-copy-embed").button("copied");
|
|
$("#id-btn-copy-embed").addClass("copied");
|
|
clipEmbedObj.setText($("#id-textarea-embed").text());
|
|
setTimeout(function () {
|
|
$("#id-btn-copy-embed").button("reset");
|
|
$("#id-btn-copy-embed").removeClass("copied");
|
|
},
|
|
2000);
|
|
});
|
|
clipShortUrl.glue("id-btn-copy-short");
|
|
clipEmbedObj.glue("id-btn-copy-embed");
|
|
$("#id-btn-copy").on("click", function () {
|
|
var saveUrl = embedConfig.saveUrl;
|
|
if (typeof saveUrl !== "undefined" && saveUrl.length > 0) {
|
|
openLink(saveUrl);
|
|
} else {
|
|
if (api) {
|
|
api.asc_Print();
|
|
}
|
|
}
|
|
Common.Analytics.trackEvent("Save");
|
|
});
|
|
$("#id-btn-share").on("click", function (event) {
|
|
setVisiblePopover($("#id-popover-share"), !isVisiblePopover($("#id-popover-share")), $("#id-btn-share"));
|
|
setVisiblePopover($("#id-popover-embed"), false);
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
});
|
|
$("#id-btn-embed").on("click", function (event) {
|
|
setVisiblePopover($("#id-popover-embed"), !isVisiblePopover($("#id-popover-embed")), $("#id-btn-embed"));
|
|
setVisiblePopover($("#id-popover-share"), false);
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
});
|
|
$("#id-input-embed-width").on("keypress", function (e) {
|
|
if (e.keyCode == 13) {
|
|
updateEmbedCode();
|
|
}
|
|
});
|
|
$("#id-input-embed-height").on("keypress", function (e) {
|
|
if (e.keyCode == 13) {
|
|
updateEmbedCode();
|
|
}
|
|
});
|
|
$("#id-input-embed-width").on("focusin", function (e) {
|
|
api && api.asc_enableKeyEvents(false);
|
|
});
|
|
$("#id-input-embed-height").on("focusin", function (e) {
|
|
api && api.asc_enableKeyEvents(false);
|
|
});
|
|
$("#id-input-embed-width").on("focusout", function (e) {
|
|
updateEmbedCode();
|
|
api && api.asc_enableKeyEvents(true);
|
|
});
|
|
$("#id-input-embed-height").on("focusout", function (e) {
|
|
updateEmbedCode();
|
|
api && api.asc_enableKeyEvents(true);
|
|
});
|
|
$("#id-btn-fullscreen").on("click", function () {
|
|
openLink(embedConfig.fullscreenUrl);
|
|
});
|
|
$("#id-btn-close").on("click", function () {
|
|
Common.Gateway.goBack();
|
|
});
|
|
$("#id-btn-zoom-in").on("click", function () {
|
|
if (api) {
|
|
var f = api.asc_getZoom() + 0.1;
|
|
f > 0 && !(f > 2) && api.asc_setZoom(f);
|
|
}
|
|
});
|
|
$("#id-btn-zoom-out").on("click", function () {
|
|
if (api) {
|
|
var f = api.asc_getZoom() - 0.1; ! (f < 0.5) && api.asc_setZoom(f);
|
|
}
|
|
});
|
|
$(window).resize(function () {
|
|
onDocumentResize();
|
|
});
|
|
$(document).click(function (event) {
|
|
if (event && event.target && $(event.target).closest(".popover").length > 0) {
|
|
return;
|
|
}
|
|
setVisiblePopover($("#id-popover-share"), false);
|
|
setVisiblePopover($("#id-popover-embed"), false);
|
|
});
|
|
$(document).mousemove(function (event) {
|
|
$("#id-btn-zoom-in").fadeIn();
|
|
$("#id-btn-zoom-out").fadeIn();
|
|
clearTimeout(documentMoveTimer);
|
|
documentMoveTimer = setTimeout(function () {
|
|
$("#id-btn-zoom-in").fadeOut();
|
|
$("#id-btn-zoom-out").fadeOut();
|
|
},
|
|
2000);
|
|
});
|
|
api = new Asc.spreadsheet_api("editor_sdk");
|
|
if (api) {
|
|
api.asc_Init("../../../sdk/Fonts/");
|
|
api.asc_registerCallback("asc_onStartAction", onLongActionBegin);
|
|
api.asc_registerCallback("asc_onEndAction", onLongActionEnd);
|
|
api.asc_registerCallback("asc_onError", onError);
|
|
api.asc_registerCallback("asc_onOpenDocumentProgress", onOpenDocument);
|
|
api.asc_registerCallback("asc_onSheetsChanged", onSheetsChanged);
|
|
api.asc_registerCallback("asc_onHyperlinkClick", onHyperlinkClick);
|
|
Common.Gateway.on("init", loadConfig);
|
|
Common.Gateway.on("opendocument", loadDocument);
|
|
Common.Gateway.on("showerror", onExternalError);
|
|
Common.Gateway.ready();
|
|
}
|
|
return me;
|
|
}
|
|
return {
|
|
create: createController,
|
|
errorDefaultMessage: "Error code: %1",
|
|
unknownErrorText: "Unknown error.",
|
|
convertationTimeoutText: "Convertation timeout exceeded.",
|
|
convertationErrorText: "Convertation failed.",
|
|
downloadErrorText: "Download failed.",
|
|
criticalErrorTitle: "Error",
|
|
notcriticalErrorTitle: "Warning"
|
|
};
|
|
})(); |