web-apps/apps/common/main/lib/controller/ExternalMergeEditor.js

273 lines
12 KiB
JavaScript
Raw Normal View History

2016-04-01 13:17:09 +00:00
/*
*
* (c) Copyright Ascensio System SIA 2010-2019
2016-04-01 13:17:09 +00:00
*
* 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 20A-12 Ernesta Birznieka-Upisha
* street, Riga, Latvia, EU, LV-1050.
2016-04-01 13:17:09 +00:00
*
* 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
*
*/
2016-03-11 00:48:53 +00:00
/**
* ExternalDiagramEditor.js
*
* Created by Julia Radzhabova on 4/08/14
2018-03-01 12:16:38 +00:00
* Copyright (c) 2018 Ascensio System SIA. All rights reserved.
2016-03-11 00:48:53 +00:00
*
*/
if (Common === undefined)
var Common = {};
Common.Controllers = Common.Controllers || {};
define([
'core',
'common/main/lib/view/ExternalMergeEditor'
], function () { 'use strict';
Common.Controllers.ExternalMergeEditor = Backbone.Controller.extend(_.extend((function() {
var appLang = '{{DEFAULT_LANG}}',
2016-03-11 00:48:53 +00:00
customization = undefined,
2016-04-11 12:58:51 +00:00
targetApp = '',
2022-06-22 16:18:39 +00:00
externalEditor = null,
isAppFirstOpened = true;
2016-03-11 00:48:53 +00:00
var createExternalEditor = function() {
externalEditor = new DocsAPI.DocEditor('id-merge-editor-placeholder', {
width : '100%',
height : '100%',
documentType: 'cell',
2016-03-11 00:48:53 +00:00
document : {
2017-12-06 07:06:45 +00:00
url : '_chart_',
2016-03-11 00:48:53 +00:00
permissions : {
edit : true,
download: false
}
},
editorConfig: {
mode : 'editmerge',
2016-04-11 12:58:51 +00:00
targetApp : targetApp,
2016-03-11 00:48:53 +00:00
lang : appLang,
canCoAuthoring : false,
canBackToFolder : false,
canCreateNew : false,
customization : customization,
user : {id: ('uid-'+Date.now())}
},
events: {
'onAppReady' : function() {},
2016-03-11 00:48:53 +00:00
'onDocumentStateChange' : function() {},
'onError' : function() {},
'onInternalMessage' : _.bind(this.onInternalMessage, this)
}
});
Common.Gateway.on('processmouse', _.bind(this.onProcessMouse, this));
};
return {
views: ['Common.Views.ExternalMergeEditor'],
initialize: function() {
this.addListeners({
'Common.Views.ExternalMergeEditor': {
'setmergedata': _.bind(this.setMergeData, this),
'drag': _.bind(function(o, state){
2016-12-01 09:59:02 +00:00
externalEditor && externalEditor.serviceCommand('window:drag', state == 'start');
2016-03-11 00:48:53 +00:00
},this),
2022-06-22 16:37:33 +00:00
'resize': _.bind(function(o, state){
externalEditor && externalEditor.serviceCommand('window:resize', state == 'start');
},this),
2016-03-11 00:48:53 +00:00
'show': _.bind(function(cmp){
var h = this.mergeEditorView.getHeight(),
innerHeight = Common.Utils.innerHeight();
2022-06-22 16:37:33 +00:00
if (innerHeight<h) {
this.mergeEditorView.setHeight(innerHeight);
2016-03-11 00:48:53 +00:00
}
if (externalEditor) {
externalEditor.serviceCommand('setAppDisabled',false);
2022-06-22 16:18:39 +00:00
if (isAppFirstOpened && this.mergeEditorView._isExternalDocReady) {
isAppFirstOpened = false;
this.mergeEditorView._mergeData && this.setMergeData();
}
2016-03-11 00:48:53 +00:00
if (this.needDisableEditing && this.mergeEditorView._isExternalDocReady) {
this.onMergeEditingDisabled();
}
externalEditor.attachMouseEvents();
} else {
2022-11-24 14:47:05 +00:00
require(['api'], function () {
createExternalEditor.apply(this);
}.bind(this))
2016-03-11 00:48:53 +00:00
}
this.isExternalEditorVisible = true;
2022-06-22 16:18:39 +00:00
this.isHandlerCalled = false;
2016-03-11 00:48:53 +00:00
}, this),
'hide': _.bind(function(cmp){
if (externalEditor) {
externalEditor.detachMouseEvents();
this.isExternalEditorVisible = false;
}
}, this)
}
});
},
onLaunch: function() {
this.mergeEditorView = this.createView('Common.Views.ExternalMergeEditor', {handler: _.bind(this.handler, this)});
},
setApi: function(api) {
this.api = api;
this.api.asc_registerCallback('asc_onCloseMergeEditor', _.bind(this.onMergeEditingDisabled, this));
this.api.asc_registerCallback('asc_sendFromGeneralToFrameEditor', _.bind(this.onSendFromGeneralToFrameEditor, this));
2016-03-11 00:48:53 +00:00
return this;
},
handler: function(result, value) {
2022-06-22 16:18:39 +00:00
if (this.isHandlerCalled) return;
this.isHandlerCalled = true;
if (this.mergeEditorView._isExternalDocReady)
externalEditor && externalEditor.serviceCommand('queryClose',{mr:result});
else {
this.mergeEditorView.hide();
this.isHandlerCalled = false;
}
2016-03-11 00:48:53 +00:00
},
setMergeData: function() {
2022-06-22 16:18:39 +00:00
if (!isAppFirstOpened) {
externalEditor && externalEditor.serviceCommand('setMergeData', this.mergeEditorView._mergeData);
this.mergeEditorView.setEditMode(true);
this.mergeEditorView._mergeData = null;
}
2016-03-11 00:48:53 +00:00
},
loadConfig: function(data) {
if (data && data.config) {
if (data.config.lang) appLang = data.config.lang;
if (data.config.customization) customization = data.config.customization;
2016-04-11 12:58:51 +00:00
if (data.config.targetApp) targetApp = data.config.targetApp;
2016-03-11 00:48:53 +00:00
}
},
onMergeEditingDisabled: function() {
if ( !this.mergeEditorView.isVisible() || !this.mergeEditorView._isExternalDocReady ) {
this.needDisableEditing = true;
return;
}
this.mergeEditorView.setControlsDisabled(true);
Common.UI.alert({
title: this.warningTitle,
msg : this.warningText,
iconCls: 'warn',
buttons: ['ok'],
callback: _.bind(function(btn){
2022-09-08 15:23:46 +00:00
this.mergeEditorView.setControlsDisabled(false);
2016-03-11 00:48:53 +00:00
this.mergeEditorView.hide();
}, this)
});
this.needDisableEditing = false;
},
onInternalMessage: function(data) {
var eventData = data.data;
if (this.mergeEditorView) {
if (eventData.type == 'documentReady') {
this.mergeEditorView._isExternalDocReady = true;
2022-06-22 16:18:39 +00:00
this.isExternalEditorVisible && (isAppFirstOpened = false);
2016-03-11 00:48:53 +00:00
this.mergeEditorView.setControlsDisabled(false);
if (this.mergeEditorView._mergeData) {
externalEditor && externalEditor.serviceCommand('setMergeData', this.mergeEditorView._mergeData);
this.mergeEditorView._mergeData = null;
}
if (this.needDisableEditing) {
this.onMergeEditingDisabled();
}
} else
if (eventData.type == "shortcut") {
if (eventData.data.key == 'escape')
this.mergeEditorView.hide();
} else
if (eventData.type == "canClose") {
if (eventData.data.answer === true) {
if (externalEditor) {
externalEditor.serviceCommand('setAppDisabled',true);
if (eventData.data.mr == 'ok')
externalEditor.serviceCommand('getMergeData');
}
this.mergeEditorView.hide();
}
2022-06-22 16:18:39 +00:00
this.isHandlerCalled = false;
2016-03-11 00:48:53 +00:00
} else
if (eventData.type == "processMouse") {
if (eventData.data.event == 'mouse:up') {
this.mergeEditorView.binding.dragStop();
2022-06-22 16:37:33 +00:00
if (this.mergeEditorView.binding.resizeStop) this.mergeEditorView.binding.resizeStop();
2016-03-11 00:48:53 +00:00
} else
if (eventData.data.event == 'mouse:move') {
var x = parseInt(this.mergeEditorView.$window.css('left')) + eventData.data.pagex,
y = parseInt(this.mergeEditorView.$window.css('top')) + eventData.data.pagey + 34;
this.mergeEditorView.binding.drag({pageX:x, pageY:y});
2022-06-22 16:37:33 +00:00
if (this.mergeEditorView.binding.resize) this.mergeEditorView.binding.resize({pageX:x, pageY:y});
2016-03-11 00:48:53 +00:00
}
2022-06-22 16:37:33 +00:00
} else
if (eventData.type == "resize") {
var w = eventData.data.width,
h = eventData.data.height;
if (w>0 && h>0)
this.mergeEditorView.setInnerSize(w, h);
} else
if (eventData.type == "frameToGeneralData") {
this.api && this.api.asc_getInformationBetweenFrameAndGeneralEditor(eventData.data);
2016-03-11 00:48:53 +00:00
} else
this.mergeEditorView.fireEvent('internalmessage', this.mergeEditorView, eventData);
}
} ,
onProcessMouse: function(data) {
if (data.type == 'mouseup' && this.isExternalEditorVisible) {
externalEditor && externalEditor.serviceCommand('processmouse', data);
}
},
onSendFromGeneralToFrameEditor: function(data) {
externalEditor && externalEditor.serviceCommand('generalToFrameData', data);
},
2016-03-11 00:48:53 +00:00
warningTitle: 'Warning',
warningText: 'The object is disabled because of editing by another user.',
textClose: 'Close',
textAnonymous: 'Anonymous'
}
})(), Common.Controllers.ExternalMergeEditor || {}));
});