2016-04-01 13:17:09 +00:00
/ *
*
2019-01-17 13:05:03 +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
*
2019-01-17 13:00:34 +00:00
* You can contact Ascensio System SIA at 20 A - 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
*
* /
2019-05-14 12:18:18 +00:00
PE . ApplicationController = new ( function ( ) {
2016-03-11 00:48:53 +00:00
var me ,
api ,
config = { } ,
docConfig = { } ,
embedConfig = { } ,
permissions = { } ,
2021-10-04 18:08:02 +00:00
appOptions = { } ,
2016-03-11 00:48:53 +00:00
maxPages = 0 ,
created = false ,
currentPage = 0 ,
2021-12-07 17:28:43 +00:00
ttOffset = [ 5 , - 10 ] ,
2021-05-19 13:35:59 +00:00
labelDocName ;
2016-03-11 00:48:53 +00:00
2021-06-24 21:48:20 +00:00
var LoadingDocument = - 256 ;
2016-03-11 00:48:53 +00:00
// Initialize analytics
// -------------------------
2019-02-22 12:28:39 +00:00
// Common.Analytics.initialize('UA-12442749-13', 'Embedded Presentation Editor');
2016-03-11 00:48:53 +00:00
// Check browser
// -------------------------
if ( typeof isBrowserSupported !== 'undefined' && ! isBrowserSupported ( ) ) {
2019-05-14 12:18:18 +00:00
Common . Gateway . reportError ( undefined , this . unsupportedBrowserErrorText ) ;
2016-03-11 00:48:53 +00:00
return ;
}
2021-05-25 13:40:40 +00:00
common . localStorage . setId ( 'text' ) ;
common . localStorage . setKeysFilter ( 'pe-,asc.presentation' ) ;
common . localStorage . sync ( ) ;
2016-03-11 00:48:53 +00:00
// Handlers
// -------------------------
function loadConfig ( data ) {
config = $ . extend ( config , data . config ) ;
embedConfig = $ . extend ( embedConfig , data . config . embedded ) ;
2016-11-03 15:22:26 +00:00
common . controller . modals . init ( embedConfig ) ;
2022-04-27 19:12:59 +00:00
common . controller . SearchBar . init ( embedConfig ) ;
2016-03-11 00:48:53 +00:00
// Docked toolbar
2017-04-11 11:05:56 +00:00
if ( embedConfig . toolbarDocked === 'bottom' ) {
2016-03-11 00:48:53 +00:00
$ ( '#toolbar' ) . addClass ( 'bottom' ) ;
$ ( '#editor_sdk' ) . addClass ( 'bottom' ) ;
2021-09-29 13:52:28 +00:00
$ ( '#box-preview' ) . addClass ( 'bottom' ) ;
2016-11-03 15:22:26 +00:00
$ ( '#box-tools' ) . removeClass ( 'dropdown' ) . addClass ( 'dropup' ) ;
ttOffset [ 1 ] = - 40 ;
2017-04-11 11:05:56 +00:00
} else {
$ ( '#toolbar' ) . addClass ( 'top' ) ;
$ ( '#editor_sdk' ) . addClass ( 'top' ) ;
2021-09-29 13:52:28 +00:00
$ ( '#box-preview' ) . addClass ( 'top' ) ;
2016-03-11 00:48:53 +00:00
}
2021-05-18 23:34:57 +00:00
config . canBackToFolder = ( config . canBackToFolder !== false ) && config . customization && config . customization . goback &&
( config . customization . goback . url || config . customization . goback . requestClose && config . canRequestClose ) ;
2016-03-11 00:48:53 +00:00
}
function loadDocument ( data ) {
docConfig = data . doc ;
if ( docConfig ) {
permissions = $ . extend ( permissions , docConfig . permissions ) ;
2022-05-16 16:53:13 +00:00
var docInfo = new Asc . asc _CDocInfo ( ) ,
2020-10-31 16:53:35 +00:00
_user = new Asc . asc _CUserInfo ( ) ;
2021-05-25 13:40:40 +00:00
var canRenameAnonymous = ! ( ( typeof ( config . customization ) == 'object' ) && ( typeof ( config . customization . anonymous ) == 'object' ) && ( config . customization . anonymous . request === false ) ) ,
guestName = ( typeof ( config . customization ) == 'object' ) && ( typeof ( config . customization . anonymous ) == 'object' ) &&
( typeof ( config . customization . anonymous . label ) == 'string' ) && config . customization . anonymous . label . trim ( ) !== '' ?
common . utils . htmlEncode ( config . customization . anonymous . label ) : me . textGuest ,
value = canRenameAnonymous ? common . localStorage . getItem ( "guest-username" ) : null ,
user = common . utils . fillUserInfo ( config . user , config . lang , value ? ( value + ' (' + guestName + ')' ) : me . textAnonymous ,
common . localStorage . getItem ( "guest-id" ) || ( 'uid-' + Date . now ( ) ) ) ;
user . anonymous && common . localStorage . setItem ( "guest-id" , user . id ) ;
_user . put _Id ( user . id ) ;
_user . put _FullName ( user . fullname ) ;
2021-05-25 13:57:56 +00:00
_user . put _IsAnonymousUser ( user . anonymous ) ;
2020-10-31 16:53:35 +00:00
2016-03-11 00:48:53 +00:00
docInfo . put _Id ( docConfig . key ) ;
docInfo . put _Url ( docConfig . url ) ;
2022-07-29 10:44:00 +00:00
docInfo . put _DirectUrl ( docConfig . directUrl ) ;
2016-03-11 00:48:53 +00:00
docInfo . put _Title ( docConfig . title ) ;
docInfo . put _Format ( docConfig . fileType ) ;
docInfo . put _VKey ( docConfig . vkey ) ;
2020-10-31 16:53:35 +00:00
docInfo . put _UserInfo ( _user ) ;
2021-11-26 11:10:44 +00:00
docInfo . put _CallbackUrl ( config . callbackUrl ) ;
2016-11-24 13:44:54 +00:00
docInfo . put _Token ( docConfig . token ) ;
2022-05-16 16:53:13 +00:00
docInfo . put _Permissions ( docConfig . permissions ) ;
2020-05-22 15:40:38 +00:00
docInfo . put _EncryptedInfo ( config . encryptionKeys ) ;
2021-08-31 13:12:30 +00:00
docInfo . put _Lang ( config . lang ) ;
docInfo . put _Mode ( config . mode ) ;
2016-03-11 00:48:53 +00:00
2020-05-22 15:34:00 +00:00
var enable = ! config . customization || ( config . customization . macros !== false ) ;
docInfo . asc _putIsEnabledMacroses ( ! ! enable ) ;
enable = ! config . customization || ( config . customization . plugins !== false ) ;
docInfo . asc _putIsEnabledPlugins ( ! ! enable ) ;
2016-03-11 00:48:53 +00:00
if ( api ) {
api . asc _registerCallback ( 'asc_onGetEditorPermissions' , onEditorPermissions ) ;
2020-05-22 15:34:00 +00:00
api . asc _registerCallback ( 'asc_onRunAutostartMacroses' , onRunAutostartMacroses ) ;
2016-03-11 00:48:53 +00:00
api . asc _setDocInfo ( docInfo ) ;
api . asc _getEditorPermissions ( config . licenseUrl , config . customerId ) ;
api . asc _enableKeyEvents ( true ) ;
Common . Analytics . trackEvent ( 'Load' , 'Start' ) ;
}
2016-11-18 15:00:46 +00:00
embedConfig . docTitle = docConfig . title ;
2021-05-18 23:34:57 +00:00
labelDocName = $ ( '#title-doc-name' ) ;
labelDocName . text ( embedConfig . docTitle || '' )
2016-03-11 00:48:53 +00:00
}
}
function onCountPages ( count ) {
maxPages = count ;
2019-05-14 12:18:18 +00:00
$ ( '#pages' ) . text ( me . textOf + " " + count ) ;
2016-03-11 00:48:53 +00:00
}
function onCurrentPage ( number ) {
$ ( '#page-number' ) . val ( number + 1 ) ;
currentPage = number ;
}
function onLongActionBegin ( type , id ) {
var text = '' ;
switch ( id )
{
2016-04-05 11:52:34 +00:00
case Asc . c _oAscAsyncAction [ 'Print' ] :
2019-05-14 12:18:18 +00:00
text = me . downloadTextText ;
2016-03-11 00:48:53 +00:00
break ;
2021-06-24 21:48:20 +00:00
case LoadingDocument :
text = me . textLoadingDocument + ' ' ;
break ;
2016-03-11 00:48:53 +00:00
default :
2019-05-14 12:18:18 +00:00
text = me . waitText ;
2016-03-11 00:48:53 +00:00
break ;
}
2016-04-05 11:52:34 +00:00
if ( type == Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] ) {
2021-06-24 21:48:20 +00:00
if ( ! me . loadMask )
me . loadMask = new common . view . LoadMask ( ) ;
me . loadMask . setTitle ( text ) ;
me . loadMask . show ( ) ;
2016-03-11 00:48:53 +00:00
}
}
function onLongActionEnd ( ) {
2021-06-24 21:48:20 +00:00
me . loadMask && me . loadMask . hide ( ) ;
2016-03-11 00:48:53 +00:00
}
function onDocMouseMoveStart ( ) {
me . isHideBodyTip = true ;
}
2016-11-03 15:22:26 +00:00
var $ttEl , $tooltip ;
2016-03-11 00:48:53 +00:00
function onDocMouseMoveEnd ( ) {
if ( me . isHideBodyTip ) {
2016-11-03 15:22:26 +00:00
if ( $tooltip ) {
$tooltip . tooltip ( 'hide' ) ;
$tooltip = false ;
2016-03-11 00:48:53 +00:00
}
}
}
function onDocMouseMove ( data ) {
if ( data ) {
if ( data . get _Type ( ) == 1 ) { // hyperlink
me . isHideBodyTip = false ;
2016-11-03 15:22:26 +00:00
if ( ! $ttEl ) {
$ttEl = $ ( '.hyperlink-tooltip' ) ;
$ttEl . tooltip ( { 'container' : 'body' , 'trigger' : 'manual' } ) ;
$ttEl . on ( 'shown.bs.tooltip' , function ( e ) {
$tooltip = $ttEl . data ( 'bs.tooltip' ) . tip ( ) ;
2021-12-07 17:28:43 +00:00
var pos = $ttEl . ttpos [ 1 ] - $tooltip . height ( ) + ttOffset [ 1 ] ;
( pos < 0 ) && ( pos = 0 ) ;
2016-11-03 15:22:26 +00:00
$tooltip . css ( {
left : $ttEl . ttpos [ 0 ] + ttOffset [ 0 ] ,
2021-12-07 17:28:43 +00:00
top : pos
2016-11-03 15:22:26 +00:00
} ) ;
2016-03-11 00:48:53 +00:00
2016-11-03 15:22:26 +00:00
$tooltip . find ( '.tooltip-arrow' ) . css ( { left : 10 } ) ;
} ) ;
2016-03-11 00:48:53 +00:00
}
2016-11-03 15:22:26 +00:00
if ( ! $tooltip ) {
$ttEl . ttpos = [ data . get _X ( ) , data . get _Y ( ) ] ;
$ttEl . tooltip ( 'show' ) ;
} else {
2021-12-07 17:28:43 +00:00
var pos = $ttEl . ttpos [ 1 ] - $tooltip . height ( ) + ttOffset [ 1 ] ;
( pos < 0 ) && ( pos = 0 ) ;
2016-11-03 15:22:26 +00:00
$tooltip . css ( {
left : data . get _X ( ) + ttOffset [ 0 ] ,
2021-12-07 17:28:43 +00:00
top : pos
2016-11-03 15:22:26 +00:00
} ) ;
}
2016-03-11 00:48:53 +00:00
}
}
}
2021-07-29 22:01:33 +00:00
function onDownloadUrl ( url , fileType ) {
Common . Gateway . downloadAs ( url , fileType ) ;
2016-03-11 00:48:53 +00:00
}
function onPrint ( ) {
2016-11-03 15:22:26 +00:00
if ( permissions . print !== false )
2021-04-20 15:46:41 +00:00
api . asc _Print ( new Asc . asc _CDownloadOptions ( null , $ . browser . chrome || $ . browser . safari || $ . browser . opera || $ . browser . mozilla && $ . browser . versionNumber > 86 ) ) ;
2016-03-11 00:48:53 +00:00
}
function onPrintUrl ( url ) {
2019-07-23 12:07:51 +00:00
common . utils . dialogPrint ( url , api ) ;
2016-03-11 00:48:53 +00:00
}
function hidePreloader ( ) {
$ ( '#loading-mask' ) . fadeOut ( 'slow' ) ;
}
function onDocumentContentReady ( ) {
2016-11-03 15:22:26 +00:00
api . ShowThumbnails ( false ) ;
api . asc _DeleteVerticalScroll ( ) ;
2016-03-11 00:48:53 +00:00
2016-11-14 11:38:41 +00:00
if ( ! embedConfig . autostart || embedConfig . autostart == 'player' ) {
api . SetDemonstrationModeOnly ( ) ;
onPlayStart ( ) ;
}
2016-11-03 15:22:26 +00:00
hidePreloader ( ) ;
2021-06-24 21:48:20 +00:00
onLongActionEnd ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
2016-03-11 00:48:53 +00:00
2018-04-04 09:19:20 +00:00
var zf = ( config . customization && config . customization . zoom ? parseInt ( config . customization . zoom ) : - 1 ) ;
( zf == - 1 ) ? api . zoomFitToPage ( ) : ( ( zf == - 2 ) ? api . zoomFitToWidth ( ) : api . zoom ( zf > 0 ? zf : 100 ) ) ;
2022-06-08 20:25:35 +00:00
var dividers = $ ( '#box-tools .divider' ) ;
var itemsCount = $ ( '#box-tools a' ) . length ;
$ ( '#idt-search' ) . hide ( ) ; // TO DO: remove when search will be ready
itemsCount -- ;
if ( permissions . print === false ) {
2020-09-08 17:40:18 +00:00
$ ( '#idt-print' ) . hide ( ) ;
2022-06-08 20:25:35 +00:00
itemsCount -- ;
}
2020-09-08 17:40:18 +00:00
2022-06-08 20:25:35 +00:00
if ( ! embedConfig . saveUrl || permissions . download === false ) {
2019-11-12 08:05:59 +00:00
$ ( '#idt-download' ) . hide ( ) ;
2022-06-08 20:25:35 +00:00
itemsCount -- ;
}
2019-11-12 08:05:59 +00:00
2022-06-08 20:25:35 +00:00
if ( ! embedConfig . shareUrl ) {
2016-11-03 15:22:26 +00:00
$ ( '#idt-share' ) . hide ( ) ;
2022-06-08 20:25:35 +00:00
itemsCount -- ;
}
2016-03-11 00:48:53 +00:00
2022-06-08 20:25:35 +00:00
if ( ! config . canBackToFolder ) {
2021-05-19 14:29:13 +00:00
$ ( '#idt-close' ) . hide ( ) ;
2022-06-08 20:25:35 +00:00
itemsCount -- ;
}
if ( itemsCount < 7 ) {
$ ( dividers [ 0 ] ) . hide ( ) ;
$ ( dividers [ 1 ] ) . hide ( ) ;
}
2021-05-18 23:34:57 +00:00
2022-06-08 20:25:35 +00:00
if ( ! embedConfig . embedUrl ) {
2016-11-03 15:22:26 +00:00
$ ( '#idt-embed' ) . hide ( ) ;
2022-06-08 20:25:35 +00:00
itemsCount -- ;
}
2016-11-03 15:22:26 +00:00
2022-06-08 20:25:35 +00:00
if ( ! embedConfig . fullscreenUrl ) {
2016-11-17 13:01:54 +00:00
$ ( '#idt-fullscreen' ) . hide ( ) ;
2022-06-08 20:25:35 +00:00
itemsCount -- ;
}
2016-11-03 15:22:26 +00:00
2022-06-08 20:25:35 +00:00
if ( itemsCount < 1 )
2019-11-12 08:05:59 +00:00
$ ( '#box-tools' ) . addClass ( 'hidden' ) ;
2021-05-18 23:34:57 +00:00
else if ( ! embedConfig . embedUrl && ! embedConfig . fullscreenUrl )
2022-06-08 20:25:35 +00:00
$ ( dividers [ 2 ] ) . hide ( ) ;
2019-11-12 08:05:59 +00:00
2016-11-03 15:22:26 +00:00
common . controller . modals . attach ( {
share : '#idt-share' ,
embed : '#idt-embed'
} ) ;
api . asc _registerCallback ( 'asc_onMouseMoveStart' , onDocMouseMoveStart ) ;
api . asc _registerCallback ( 'asc_onMouseMoveEnd' , onDocMouseMoveEnd ) ;
api . asc _registerCallback ( 'asc_onMouseMove' , onDocMouseMove ) ;
api . asc _registerCallback ( 'asc_onDownloadUrl' , onDownloadUrl ) ;
api . asc _registerCallback ( 'asc_onPrint' , onPrint ) ;
api . asc _registerCallback ( 'asc_onPrintUrl' , onPrintUrl ) ;
api . asc _registerCallback ( 'asc_onHyperlinkClick' , common . utils . openLink ) ;
api . asc _registerCallback ( 'asc_onStartAction' , onLongActionBegin ) ;
api . asc _registerCallback ( 'asc_onEndAction' , onLongActionEnd ) ;
api . asc _registerCallback ( 'asc_onEndDemonstration' , onPlayStop ) ;
api . asc _registerCallback ( 'asc_onDemonstrationSlideChanged' , onPlaySlideChanged ) ;
2016-03-11 00:48:53 +00:00
2016-11-03 15:22:26 +00:00
Common . Gateway . on ( 'processmouse' , onProcessMouse ) ;
Common . Gateway . on ( 'downloadas' , onDownloadAs ) ;
2021-03-29 11:30:31 +00:00
Common . Gateway . on ( 'requestclose' , onRequestClose ) ;
2016-11-03 15:22:26 +00:00
2019-05-14 12:18:18 +00:00
PE . ApplicationView . tools . get ( '#idt-fullscreen' )
2016-11-03 15:22:26 +00:00
. on ( 'click' , function ( ) {
common . utils . openLink ( embedConfig . fullscreenUrl ) ;
} ) ;
2019-05-14 12:18:18 +00:00
PE . ApplicationView . tools . get ( '#idt-download' )
2016-11-03 15:22:26 +00:00
. on ( 'click' , function ( ) {
2021-09-29 14:45:40 +00:00
if ( ! ! embedConfig . saveUrl && permissions . download !== false ) {
2016-11-03 15:22:26 +00:00
common . utils . openLink ( embedConfig . saveUrl ) ;
}
Common . Analytics . trackEvent ( 'Save' ) ;
} ) ;
2020-09-08 17:40:18 +00:00
PE . ApplicationView . tools . get ( '#idt-print' )
. on ( 'click' , function ( ) {
2021-04-20 15:46:41 +00:00
api . asc _Print ( new Asc . asc _CDownloadOptions ( null , $ . browser . chrome || $ . browser . safari || $ . browser . opera || $ . browser . mozilla && $ . browser . versionNumber > 86 ) ) ;
2020-09-08 17:40:18 +00:00
Common . Analytics . trackEvent ( 'Print' ) ;
} ) ;
2021-05-18 23:34:57 +00:00
PE . ApplicationView . tools . get ( '#idt-close' )
. on ( 'click' , function ( ) {
if ( config . customization && config . customization . goback ) {
if ( config . customization . goback . requestClose && config . canRequestClose )
Common . Gateway . requestClose ( ) ;
2021-11-23 11:35:22 +00:00
else if ( config . customization . goback . url ) {
if ( config . customization . goback . blank !== false ) {
window . open ( config . customization . goback . url , "_blank" ) ;
} else {
window . parent . location . href = config . customization . goback . url ;
}
}
2021-05-18 23:34:57 +00:00
}
} ) ;
2022-06-08 20:25:35 +00:00
PE . ApplicationView . tools . get ( '#idt-search' )
. on ( 'click' , function ( ) {
common . controller . SearchBar . show ( ) ;
} ) ;
2016-11-03 15:22:26 +00:00
var $pagenum = $ ( '#page-number' ) ;
$pagenum . on ( {
'keyup' : function ( e ) {
if ( e . keyCode == 13 ) {
var newPage = parseInt ( $ ( '#page-number' ) . val ( ) ) ;
2017-04-11 11:05:56 +00:00
if ( isNaN ( newPage ) ) {
$ ( '#page-number' ) . val ( currentPage + 1 ) ;
} else {
if ( newPage > maxPages ) newPage = maxPages ; else
if ( newPage < 2 ) newPage = 1 ;
if ( newPage == currentPage + 1 ) {
$ ( '#page-number' ) . val ( newPage ) ;
} else
if ( isplaymode ) {
currentPage = newPage - 1 ;
api . DemonstrationGoToSlide ( newPage - 1 ) ;
} else api . goToPage ( newPage - 1 ) ;
}
2016-11-03 15:22:26 +00:00
$pagenum . blur ( ) ;
}
}
, 'focusin' : function ( e ) {
$pagenum . removeClass ( 'masked' ) ;
}
, 'focusout' : function ( e ) {
! $pagenum . hasClass ( 'masked' ) && $pagenum . addClass ( 'masked' ) ;
}
} ) ;
$ ( '#pages' ) . on ( 'click' , function ( e ) {
$pagenum . focus ( ) ;
} ) ;
$ ( '#btn-left' ) . on ( 'click' , function ( ) {
if ( isplaymode ) {
api . DemonstrationPrevSlide ( ) ;
} else
if ( currentPage > 0 ) {
api . goToPage ( currentPage - 1 ) ;
}
} ) ;
$ ( '#btn-right' ) . on ( 'click' , function ( ) {
if ( isplaymode ) {
api . DemonstrationNextSlide ( ) ;
} else
if ( currentPage < maxPages - 1 ) {
api . goToPage ( currentPage + 1 ) ;
}
} ) ;
var documentMoveTimer ;
var ismoved = false ;
$ ( document ) . on ( {
'click' : function ( e ) {
clearTimeout ( documentMoveTimer ) ;
documentMoveTimer = undefined ;
} ,
'mousemove' : function ( e ) {
$ ( '#btn-left' ) . fadeIn ( ) ;
$ ( '#btn-right' ) . fadeIn ( ) ;
ismoved = true ;
if ( ! documentMoveTimer ) {
documentMoveTimer = setInterval ( function ( ) {
if ( ! ismoved ) {
// $('#btn-left').fadeOut();
// $('#btn-right').fadeOut();
clearInterval ( documentMoveTimer ) ;
documentMoveTimer = undefined ;
}
ismoved = false ;
} , 2000 ) ;
}
}
} ) ;
var ismodalshown = false ;
$ ( document . body ) . on ( 'show.bs.modal' , '.modal' ,
function ( e ) {
ismodalshown = true ;
api . asc _enableKeyEvents ( false ) ;
}
) . on ( 'hidden.bs.modal' , '.modal' ,
function ( e ) {
ismodalshown = false ;
api . asc _enableKeyEvents ( true ) ;
}
) . on ( 'hidden.bs.dropdown' , '.dropdown' ,
function ( e ) {
if ( ! ismodalshown )
api . asc _enableKeyEvents ( true ) ;
}
) . on ( 'blur' , 'input, textarea' ,
function ( e ) {
if ( ! ismodalshown ) {
if ( ! /area_id/ . test ( e . target . id ) ) {
api . asc _enableKeyEvents ( true ) ;
}
}
}
) ;
$ ( '#editor_sdk' ) . on ( 'click' , function ( e ) {
if ( e . target . localName == 'canvas' ) {
e . currentTarget . focus ( ) ;
}
} ) ;
$ ( '#btn-play' ) . on ( 'click' , onPlayStart ) ;
2019-01-10 08:20:53 +00:00
Common . Gateway . documentReady ( ) ;
2016-03-11 00:48:53 +00:00
Common . Analytics . trackEvent ( 'Load' , 'Complete' ) ;
}
function onEditorPermissions ( params ) {
2021-10-04 18:08:02 +00:00
appOptions . canBranding = params . asc _getCustomization ( ) ;
appOptions . canBranding && setBranding ( config . customization ) ;
2021-05-18 23:34:57 +00:00
var $parent = labelDocName . parent ( ) ;
var _left _width = $parent . position ( ) . left ,
_right _width = $parent . next ( ) . outerWidth ( ) ;
if ( _left _width < _right _width )
$parent . css ( 'padding-left' , _right _width - _left _width ) ;
else
$parent . css ( 'padding-right' , _left _width - _right _width ) ;
2021-05-19 13:35:59 +00:00
2021-06-24 21:48:20 +00:00
onLongActionBegin ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
2021-05-19 13:35:59 +00:00
api . asc _setViewMode ( true ) ;
2016-03-11 00:48:53 +00:00
api . asc _LoadDocument ( ) ;
api . Resize ( ) ;
}
2016-11-03 15:22:26 +00:00
function onOpenDocument ( progress ) {
var proc = ( progress . asc _getCurrentFont ( ) + progress . asc _getCurrentImage ( ) ) / ( progress . asc _getFontsCount ( ) + progress . asc _getImagesCount ( ) ) ;
2021-06-24 21:48:20 +00:00
me . loadMask && me . loadMask . setTitle ( me . textLoadingDocument + ': ' + common . utils . fixedDigits ( Math . min ( Math . round ( proc * 100 ) , 100 ) , 3 , " " ) + '%' ) ;
2016-11-03 15:22:26 +00:00
}
var isplaymode ;
function onPlayStart ( e ) {
if ( ! isplaymode ) {
2016-11-21 16:28:16 +00:00
$ ( '#box-preview' ) . show ( ) ;
api . StartDemonstration ( 'id-preview' , currentPage ) ;
2016-11-03 15:22:26 +00:00
} else {
2016-11-21 16:28:16 +00:00
isplaymode == 'play' ?
api . DemonstrationPause ( ) : api . DemonstrationPlay ( ) ;
2016-11-03 15:22:26 +00:00
}
2016-11-21 16:28:16 +00:00
isplaymode != 'play' ? ( $ ( '#btn-play button' ) . addClass ( 'pause' ) , isplaymode = 'play' ) :
( $ ( '#btn-play button' ) . removeClass ( 'pause' ) , isplaymode = 'pause' ) ;
2016-11-03 15:22:26 +00:00
}
function onPlayStop ( ) {
isplaymode = undefined ;
$ ( '#page-number' ) . val ( currentPage + 1 ) ;
$ ( '#btn-play button' ) . removeClass ( 'pause' ) ;
$ ( '#box-preview' ) . hide ( ) ;
}
function onPlaySlideChanged ( number ) {
if ( number ++ < maxPages )
$ ( '#page-number' ) . val ( number ) ;
}
2016-03-11 00:48:53 +00:00
function onError ( id , level , errData ) {
2018-10-08 14:06:37 +00:00
if ( id == Asc . c _oAscError . ID . LoadingScriptError ) {
$ ( '#id-critical-error-title' ) . text ( me . criticalErrorTitle ) ;
$ ( '#id-critical-error-message' ) . text ( me . scriptLoadError ) ;
2019-05-14 12:18:18 +00:00
$ ( '#id-critical-error-close' ) . text ( me . txtClose ) . off ( ) . on ( 'click' , function ( ) {
2018-10-08 14:06:37 +00:00
window . location . reload ( ) ;
} ) ;
$ ( '#id-critical-error-dialog' ) . css ( 'z-index' , 20002 ) . modal ( 'show' ) ;
return ;
}
2016-03-11 00:48:53 +00:00
hidePreloader ( ) ;
2021-06-24 21:48:20 +00:00
onLongActionEnd ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
2016-03-11 00:48:53 +00:00
var message ;
switch ( id )
{
2016-04-05 11:52:34 +00:00
case Asc . c _oAscError . ID . Unknown :
2016-03-11 00:48:53 +00:00
message = me . unknownErrorText ;
break ;
2016-04-05 11:52:34 +00:00
case Asc . c _oAscError . ID . ConvertationTimeout :
2016-03-11 00:48:53 +00:00
message = me . convertationTimeoutText ;
break ;
2016-04-05 11:52:34 +00:00
case Asc . c _oAscError . ID . ConvertationError :
2016-03-11 00:48:53 +00:00
message = me . convertationErrorText ;
break ;
2021-11-26 11:10:44 +00:00
case Asc . c _oAscError . ID . ConvertationOpenError :
message = me . openErrorText ;
break ;
2016-04-05 11:52:34 +00:00
case Asc . c _oAscError . ID . DownloadError :
2016-03-11 00:48:53 +00:00
message = me . downloadErrorText ;
break ;
2018-10-09 11:32:18 +00:00
case Asc . c _oAscError . ID . ConvertationPassword :
message = me . errorFilePassProtect ;
break ;
2019-03-29 09:21:43 +00:00
case Asc . c _oAscError . ID . UserDrop :
message = me . errorUserDrop ;
break ;
2019-08-28 14:29:39 +00:00
case Asc . c _oAscError . ID . ConvertationOpenLimitError :
message = me . errorFileSizeExceed ;
break ;
2019-11-13 11:14:41 +00:00
case Asc . c _oAscError . ID . UpdateVersion :
message = me . errorUpdateVersionOnDisconnect ;
break ;
2020-04-07 09:26:19 +00:00
case Asc . c _oAscError . ID . AccessDeny :
message = me . errorAccessDeny ;
break ;
2021-07-27 15:37:37 +00:00
case Asc . c _oAscError . ID . ForceSaveButton :
case Asc . c _oAscError . ID . ForceSaveTimeout :
message = me . errorForceSave ;
break ;
2021-08-19 19:03:44 +00:00
case Asc . c _oAscError . ID . LoadingFontError :
message = me . errorLoadingFont ;
break ;
2021-11-01 14:16:20 +00:00
case Asc . c _oAscError . ID . KeyExpire :
message = me . errorTokenExpire ;
break ;
2016-03-11 00:48:53 +00:00
default :
message = me . errorDefaultMessage . replace ( '%1' , id ) ;
break ;
}
2016-04-05 11:52:34 +00:00
if ( level == Asc . c _oAscError . Level . Critical ) {
2016-03-11 00:48:53 +00:00
// report only critical errors
Common . Gateway . reportError ( id , message ) ;
$ ( '#id-critical-error-title' ) . text ( me . criticalErrorTitle ) ;
2019-08-28 14:29:39 +00:00
$ ( '#id-critical-error-message' ) . html ( message ) ;
2019-05-14 12:18:18 +00:00
$ ( '#id-critical-error-close' ) . text ( me . txtClose ) . off ( ) . on ( 'click' , function ( ) {
2016-03-11 00:48:53 +00:00
window . location . reload ( ) ;
} ) ;
}
else {
2017-10-07 09:20:39 +00:00
Common . Gateway . reportWarning ( id , message ) ;
2016-03-11 00:48:53 +00:00
$ ( '#id-critical-error-title' ) . text ( me . notcriticalErrorTitle ) ;
2019-08-28 14:29:39 +00:00
$ ( '#id-critical-error-message' ) . html ( message ) ;
2019-05-14 12:18:18 +00:00
$ ( '#id-critical-error-close' ) . text ( me . txtClose ) . off ( ) . on ( 'click' , function ( ) {
2016-03-11 00:48:53 +00:00
$ ( '#id-critical-error-dialog' ) . modal ( 'hide' ) ;
} ) ;
}
$ ( '#id-critical-error-dialog' ) . modal ( 'show' ) ;
Common . Analytics . trackEvent ( 'Internal Error' , id . toString ( ) ) ;
}
2017-05-16 07:46:04 +00:00
function onExternalMessage ( error ) {
2016-03-11 00:48:53 +00:00
if ( error ) {
hidePreloader ( ) ;
2019-05-14 12:18:18 +00:00
$ ( '#id-error-mask-title' ) . text ( me . criticalErrorTitle ) ;
2016-03-11 00:48:53 +00:00
$ ( '#id-error-mask-text' ) . text ( error . msg ) ;
$ ( '#id-error-mask' ) . css ( 'display' , 'block' ) ;
2017-05-16 07:46:04 +00:00
Common . Analytics . trackEvent ( 'External Error' ) ;
2016-03-11 00:48:53 +00:00
}
}
function onProcessMouse ( data ) {
if ( data . type == 'mouseup' ) {
var e = document . getElementById ( 'editor_sdk' ) ;
if ( e ) {
var r = e . getBoundingClientRect ( ) ;
api . OnMouseUp (
data . x - r . left ,
data . y - r . top
) ;
}
}
}
2021-03-29 11:30:31 +00:00
function onRequestClose ( ) {
Common . Gateway . requestClose ( ) ;
}
2016-03-11 00:48:53 +00:00
function onDownloadAs ( ) {
2019-01-10 14:20:59 +00:00
if ( permissions . download === false ) {
Common . Gateway . reportError ( Asc . c _oAscError . ID . AccessDeny , me . errorAccessDeny ) ;
return ;
}
2019-07-24 08:36:13 +00:00
if ( api ) api . asc _DownloadAs ( new Asc . asc _CDownloadOptions ( Asc . c _oAscFileType . PPTX , true ) ) ;
2016-03-11 00:48:53 +00:00
}
2020-05-22 15:34:00 +00:00
function onRunAutostartMacroses ( ) {
if ( ! config . customization || ( config . customization . macros !== false ) )
if ( api ) api . asc _runAutostartMacroses ( ) ;
}
2021-05-25 13:40:40 +00:00
function onBeforeUnload ( ) {
common . localStorage . save ( ) ;
}
2021-10-04 18:08:02 +00:00
function setBranding ( value ) {
if ( value && value . logo ) {
var logo = $ ( '#header-logo' ) ;
if ( value . logo . image || value . logo . imageEmbedded ) {
logo . html ( '<img src="' + ( value . logo . image || value . logo . imageEmbedded ) + '" style="max-width:100px; max-height:20px;"/>' ) ;
logo . css ( { 'background-image' : 'none' , width : 'auto' , height : 'auto' } ) ;
value . logo . imageEmbedded && console . log ( "Obsolete: The 'imageEmbedded' parameter of the 'customization.logo' section is deprecated. Please use 'image' parameter instead." ) ;
}
if ( value . logo . url ) {
logo . attr ( 'href' , value . logo . url ) ;
} else if ( value . logo . url !== undefined ) {
logo . removeAttr ( 'href' ) ; logo . removeAttr ( 'target' ) ;
}
}
}
2016-03-11 00:48:53 +00:00
// Helpers
// -------------------------
function onDocumentResize ( ) {
if ( api ) {
api . Resize ( ) ;
}
}
function createController ( ) {
if ( created )
return me ;
me = this ;
created = true ;
// popover ui handlers
$ ( window ) . resize ( function ( ) {
onDocumentResize ( ) ;
} ) ;
2021-05-25 13:40:40 +00:00
window . onbeforeunload = onBeforeUnload ;
2016-05-13 08:37:54 +00:00
api = new Asc . asc _docs _api ( {
2016-11-14 11:38:41 +00:00
'id-view' : 'editor_sdk' ,
'embedded' : true
2016-05-13 08:37:54 +00:00
} ) ;
2016-03-11 00:48:53 +00:00
if ( api ) {
2016-03-25 13:38:31 +00:00
api . SetThemesPath ( "../../../../sdkjs/slide/themes/" ) ;
2016-03-11 00:48:53 +00:00
api . asc _registerCallback ( 'asc_onError' , onError ) ;
api . asc _registerCallback ( 'asc_onDocumentContentReady' , onDocumentContentReady ) ;
api . asc _registerCallback ( 'asc_onOpenDocumentProgress' , onOpenDocument ) ;
api . asc _registerCallback ( 'asc_onCountPages' , onCountPages ) ;
api . asc _registerCallback ( 'asc_onCurrentPage' , onCurrentPage ) ;
// Initialize api gateway
Common . Gateway . on ( 'init' , loadConfig ) ;
Common . Gateway . on ( 'opendocument' , loadDocument ) ;
2017-05-16 07:46:04 +00:00
Common . Gateway . on ( 'showmessage' , onExternalMessage ) ;
2017-09-20 11:32:18 +00:00
Common . Gateway . appReady ( ) ;
2022-04-27 19:12:59 +00:00
common . controller . SearchBar . setApi ( api ) ;
2016-03-11 00:48:53 +00:00
}
return me ;
}
return {
create : createController ,
errorDefaultMessage : 'Error code: %1' ,
unknownErrorText : 'Unknown error.' ,
2019-05-14 13:55:52 +00:00
convertationTimeoutText : 'Conversion timeout exceeded.' ,
convertationErrorText : 'Conversion failed.' ,
2016-03-11 00:48:53 +00:00
downloadErrorText : 'Download failed.' ,
criticalErrorTitle : 'Error' ,
2018-10-08 14:06:37 +00:00
notcriticalErrorTitle : 'Warning' ,
2018-10-09 11:32:18 +00:00
scriptLoadError : 'The connection is too slow, some of the components could not be loaded. Please reload the page.' ,
2019-01-10 14:20:59 +00:00
errorFilePassProtect : 'The file is password protected and cannot be opened.' ,
2019-03-29 09:21:43 +00:00
errorAccessDeny : 'You are trying to perform an action you do not have rights for.<br>Please contact your Document Server administrator.' ,
2019-05-14 12:18:18 +00:00
errorUserDrop : 'The file cannot be accessed right now.' ,
unsupportedBrowserErrorText : 'Your browser is not supported.' ,
textOf : 'of' ,
downloadTextText : 'Downloading presentation...' ,
waitText : 'Please, wait...' ,
textLoadingDocument : 'Loading presentation' ,
2019-08-28 14:29:39 +00:00
txtClose : 'Close' ,
2019-11-13 11:14:41 +00:00
errorFileSizeExceed : 'The file size exceeds the limitation set for your server.<br>Please contact your Document Server administrator for details.' ,
2021-05-25 13:40:40 +00:00
errorUpdateVersionOnDisconnect : 'Internet connection has been restored, and the file version has been changed.<br>Before you can continue working, you need to download the file or copy its content to make sure nothing is lost, and then reload this page.' ,
textGuest : 'Guest' ,
2021-07-27 15:37:37 +00:00
textAnonymous : 'Anonymous' ,
2021-08-19 19:03:44 +00:00
errorForceSave : "An error occurred while saving the file. Please use the 'Download as' option to save the file to your computer hard drive or try again later." ,
2021-11-01 14:16:20 +00:00
errorLoadingFont : 'Fonts are not loaded.<br>Please contact your Document Server administrator.' ,
2021-11-26 11:10:44 +00:00
errorTokenExpire : 'The document security token has expired.<br>Please contact your Document Server administrator.' ,
openErrorText : 'An error has occurred while opening the file'
2016-03-11 00:48:53 +00:00
}
} ) ( ) ;