web-apps/apps/documenteditor/mobile/app/controller/toolbar/Edit.js
2016-09-16 11:52:37 +03:00

315 lines
11 KiB
JavaScript

/*
*
* (c) Copyright Ascensio System Limited 2010-2016
*
* 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
*
*/
Ext.define('DE.controller.toolbar.Edit', {
extend: 'Ext.app.Controller',
requires: ([
'Ext.MessageBox',
'Ext.util.Point',
'Ext.util.Region',
'DE.view.tablet.panel.Font',
'DE.view.tablet.panel.FontStyle',
'DE.view.tablet.panel.Insert',
'DE.view.tablet.panel.ListStyle',
'DE.view.tablet.panel.ParagraphAlignment',
'DE.view.tablet.panel.Spacing',
'DE.view.tablet.panel.TextColor'
]),
config: {
refs: {
doneButton : '#id-tb-btn-done',
saveButton : '#id-tb-btn-save',
undoButton : '#id-tb-btn-undo',
fontButton : '#id-tb-btn-font',
fontStyleButton : '#id-tb-btn-style',
textColorButton : '#id-tb-btn-color',
paragraphAlignmentButton: '#id-tb-btn-align',
listStyleButton : '#id-tb-btn-liststyle',
paragraphButton : '#id-tb-btn-paragraph',
tableButton : '#id-tb-btn-table',
shareButton : '#id-tb-btn-share',
textColorPanel : '#id-panel-text-color',
paragraphPanel : '#id-panel-spacing',
paragraphAlignmentPanel : '#id-panel-paragraph-alignment',
fontStylePanel : '#id-panel-font-style',
listStylePanel : '#id-panel-liststyle',
insertPanel : '#id-panel-insert',
fontPanel : '#id-panel-font'
},
control: {
doneButton: {
tap : 'onTapDone'
},
saveButton: {
tap : 'onTapSave'
},
undoButton: {
tap : 'onTapUndo'
},
fontButton: {
tap : 'onTapFont'
},
fontStyleButton: {
tap : 'onTapFontStyle'
},
textColorButton: {
tap : 'onTapTextColor'
},
paragraphAlignmentButton: {
tap : 'onTabParagraphAlignment'
},
listStyleButton: {
tap : 'onTapListStyle'
},
paragraphButton: {
tap : 'onTapParagraphButton'
},
tableButton: {
tap : 'onTapTable'
},
shareButton: {
tap : 'onTapShare'
}
}
},
launch: function() {
this.callParent(arguments);
Ext.getCmp('id-conteiner-document').on('resize', this.onEditorResize, this);
var toolbarButtons = Ext.ComponentQuery.query('edittoolbar > button, edittoolbar > toolbar > button');
Ext.each(Ext.ComponentQuery.query('commonpopoverpanel'), function(panel) {
var modal = panel.getModal();
if (modal) {
modal.on('tap', function(mask, event) {
Ext.each(toolbarButtons, function(button) {
if (button !== panel.alignByCmp) {
var mousePoint = Ext.util.Point.fromEvent(event),
buttonRect = Ext.util.Region.from(button.element.getPageBox());
if (!buttonRect.isOutOfBound(mousePoint)) {
button.fireEvent('tap', button, event);
}
}
}, this);
}, this);
}
}, this);
if (Ext.os.is.iOS) {
Ext.each(Ext.ComponentQuery.query('button'), function(button) {
button.element.dom.ontouchstart = Ext.emptyFn();
button.element.dom.ontouchmove = Ext.emptyFn();
button.element.dom.ontouchend = Ext.emptyFn();
}, this);
Ext.each(Ext.ComponentQuery.query('toolbar'), function(toolbar) {
var preventFn = function(e){
e.preventDefault();
};
toolbar.element.dom.ontouchstart = preventFn;
toolbar.element.dom.ontouchmove = preventFn;
toolbar.element.dom.ontouchend = preventFn;
}, this);
}
Common.Gateway.on('init', Ext.bind(this.loadConfig, this));
},
initControl: function() {
this.callParent(arguments);
},
initApi: function() {
//
},
setApi: function(o){
this.api = o;
if (this.api) {
this.api.asc_registerCallback('asc_onCanUndo', Ext.bind(this.onApiCanUndo, this));
this.api.asc_registerCallback('asc_onCoAuthoringDisconnect', Ext.bind(this.onCoAuthoringDisconnect, this));
this.api.asc_registerCallback('asc_onDocumentModifiedChanged', Ext.bind(this.onApiDocumentModified, this));
}
},
loadConfig: function(data) {
var doneButton = this.getDoneButton();
if (doneButton && data && data.config && data.config.canBackToFolder !== false &&
data.config.customization && data.config.customization.goback && data.config.customization.goback.url){
this.gobackUrl = data.config.customization.goback.url;
doneButton.show();
}
},
onApiCanUndo: function(can) {
var undoButton = this.getUndoButton();
undoButton && undoButton.setDisabled(!can);
},
onCoAuthoringDisconnect: function() {
Ext.each(Ext.ComponentQuery.query('commonpopoverpanel'), function(panel) {
panel.hide();
});
Ext.each(Ext.ComponentQuery.query('edittoolbar > button, edittoolbar > toolbar > button'), function(btn) {
btn.removeCls('x-button-pressing');
btn.disable();
});
var shareButton = this.getShareButton();
shareButton && shareButton.enable();
},
onApiDocumentModified: function() {
var isModified = this.api.isDocumentModified();
if (this.isDocModified !== isModified) {
if (this.getSaveButton()) {
this.getSaveButton().setDisabled(!isModified);
}
Common.Gateway.setDocumentModified(isModified);
this.isDocModified = isModified;
}
},
showToolbarPanel: function(panel, button){
if (panel && button){
panel.on('hide', Ext.bind(function(){
button.removeCls('x-button-pressing');
}, this), this, {single: true});
button.addCls('x-button-pressing');
Ext.each(Ext.ComponentQuery.query('popclip'), function(cmp) {
cmp.hide(true);
}, this);
panel.alignByCmp = button;
panel.setLeft(0);
panel.setTop(0);
panel.showBy(button);
}
},
onTapDone: function() {
var me = this;
if (this.api.isDocumentModified()) {
Ext.Msg.show({
title : this.dlgLeaveTitleText,
message : this.dlgLeaveMsgText,
buttons : [
{text: this.leaveButtonText, itemId: 'cancel', ui: 'base'},
{text: this.stayButtonText, itemId: 'ok', ui: 'base-blue'}
],
promptConfig: false,
scope : this,
fn : function(button) {
if (button == 'cancel') {
me.goBack();
}
}
});
} else {
me.goBack();
}
},
goBack: function() {
if (this.gobackUrl) window.parent.location.href = this.gobackUrl;
},
onTapSave: function() {
this.api && this.api.asc_Save();
this.getSaveButton().setDisabled(true);
Common.component.Analytics.trackEvent('ToolBar', 'Save');
},
onTapUndo: function() {
this.api && this.api.Undo();
Common.component.Analytics.trackEvent('ToolBar', 'Undo');
},
onTapShare: function() {
this.api && this.api.asc_Print();
Common.component.Analytics.trackEvent('ToolBar', 'Share');
},
onTapFont: function() {
this.showToolbarPanel(this.getFontPanel(), this.getFontButton());
},
onTapFontStyle: function() {
this.showToolbarPanel(this.getFontStylePanel(), this.getFontStyleButton());
},
onTapTextColor: function() {
this.showToolbarPanel(this.getTextColorPanel(), this.getTextColorButton());
},
onTabParagraphAlignment: function() {
this.showToolbarPanel(this.getParagraphAlignmentPanel(), this.getParagraphAlignmentButton());
},
onTapListStyle: function() {
this.showToolbarPanel(this.getListStylePanel(), this.getListStyleButton());
},
onTapParagraphButton: function() {
this.showToolbarPanel(this.getParagraphPanel(), this.getParagraphButton());
},
onTapTable: function() {
this.showToolbarPanel(this.getInsertPanel(), this.getTableButton());
},
onEditorResize: function(cmp) {
var overlayPanels = Ext.ComponentQuery.query('commonpopoverpanel');
Ext.each(overlayPanels, function(panel){
panel.hide();
});
},
dlgLeaveTitleText : 'You leave the application',
dlgLeaveMsgText : 'You have unsaved changes in this document. Click \'Stay on this Page\' then \'Save\' to save them. Click \'Leave this Page\' to discard all the unsaved changes.',
leaveButtonText : 'Leave this Page',
stayButtonText : 'Stay on this Page'
});