web-apps/apps/presentationeditor/mobile/app/controller/toolbar/View.js
2016-09-16 11:04:48 +03:00

251 lines
8.2 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('PE.controller.toolbar.View', {
extend: 'Ext.app.Controller',
config: {
refs: {
viewToolbar : 'viewtoolbar',
fullscreenButton: '#id-tb-btn-fullscreen',
shareButton : '#id-tb-btn-view-share',
btnPrevSlide : '#id-tb-btn-prev-slide',
btnNextSlide : '#id-tb-btn-next-slide',
btnPlaySlide : '#id-tb-btn-play',
overlayContainer: '#id-preview-overlay-container',
doneButton : '#id-tb-btn-view-done'
},
control: {
fullscreenButton: {
tap : 'onTapFullscreenButton'
},
shareButton : {
tap : 'onTapShareButton'
},
btnPrevSlide: {
tap : 'onPrevSlide'
},
btnNextSlide: {
tap : 'onNextSlide'
},
btnPlaySlide: {
tap : 'onPlaySlide'
},
doneButton: {
tap : 'onTapDoneButton'
}
},
isFullscreen : false
},
launch: function() {
this.callParent(arguments);
var overlayContainer = this.getOverlayContainer();
if (overlayContainer){
overlayContainer.element.on('singletap', this.onSingleTapDocument, this);
overlayContainer.element.on('touchstart', this.onTouchStartDocument, this);
overlayContainer.element.on('touchend', this.onTouchEndDocument, 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._startX = 0;
this.callParent(arguments);
},
initApi: function() {
//
},
setApi: function(o){
this.api = o;
if (this.api) {
this.api.asc_registerCallback('asc_onEndDemonstration', Ext.bind(this.onApiEndDemonstration, this));
this.api.asc_registerCallback('asc_onDemonstrationSlideChanged',Ext.bind(this.onApiDemonstrationSlideChanged, this));
this.api.DemonstrationEndShowMessage(this.txtFinalMessage);
}
},
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();
}
},
onTapDoneButton: function() {
if (this.gobackUrl) window.parent.location.href = this.gobackUrl;
},
onTapFullscreenButton: function(btn) {
var viewToolbar = this.getViewToolbar();
if (viewToolbar) {
this.setIsFullscreen(!this.getIsFullscreen());
if (this.getIsFullscreen()) {
btn.addCls('x-button-pressing');
viewToolbar.setStyle({
position : 'absolute',
left : 0,
top : 0,
right : 0,
opacity : 0.9,
'z-index' : 7
});
this.onSingleTapDocument();
} else {
viewToolbar.setStyle({
position : 'initial',
opacity : 1
});
viewToolbar.setDocked('top');
}
}
},
onTapShareButton: function() {
this.api && this.api.asc_Print();
Common.component.Analytics.trackEvent('ToolBar View', 'Share');
},
onSingleTapDocument: function() {
if (this.getIsFullscreen()) {
var viewToolbar = this.getViewToolbar();
if (viewToolbar){
if (viewToolbar.isHidden()){
viewToolbar.show({
preserveEndState: true,
easing : 'ease-in',
from : {opacity : 0},
to : {opacity : 0.9}
});
} else {
viewToolbar.hide({
easing : 'ease-out',
from : {opacity : 0.9},
to : {opacity : 0}
});
}
}
}
},
onTouchStartDocument: function(event, node, options, eOpts){
this._startX = event.pageX;
},
onTouchEndDocument: function(event, node, options, eOpts){
if (event.pageX - this._startX<-50) {
this.api.DemonstrationNextSlide();
} else if (event.pageX - this._startX>50) {
this.api.DemonstrationPrevSlide();
}
},
onPrevSlide: function(){
if (this.api){
this.api.DemonstrationPrevSlide();
}
},
onNextSlide: function(){
if (this.api){
this.api.DemonstrationNextSlide();
}
},
onPlaySlide: function(){
var btnPlay = this.getBtnPlaySlide();
if (this.api && btnPlay){
if (btnPlay.getIconCls() == 'play'){
this.api.DemonstrationPlay();
btnPlay.setIconCls('pause');
} else {
this.api.DemonstrationPause();
btnPlay.setIconCls('play');
}
}
},
onApiEndDemonstration: function( ) {
if (this.api)
this.api.StartDemonstration('id-presentation-preview', 0);
},
onApiDemonstrationSlideChanged: function(slideNum) {
if (this.api && Ext.isNumber(slideNum)) {
var count = this.api.getCountPages(),
btnNextSlide = this.getBtnNextSlide(),
btnPrevSlide = this.getBtnPrevSlide();
if (btnPrevSlide)
btnPrevSlide.setDisabled(slideNum <= 0);
if (btnNextSlide)
btnNextSlide.setDisabled(slideNum >= count-1);
}
},
txtFinalMessage: 'The end of slide preview'
});