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
*
2016-11-21 11:13:27 +00:00
* /
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
/ * *
* Main . js
* Document Editor
*
* Created by Alexander Yuzhin on 9 / 22 / 16
2018-03-01 12:16:38 +00:00
* Copyright ( c ) 2018 Ascensio System SIA . All rights reserved .
2016-11-21 11:13:27 +00:00
*
* /
define ( [
'core' ,
2016-12-22 14:28:19 +00:00
'jquery' ,
'underscore' ,
'backbone' ,
2016-11-21 11:13:27 +00:00
'irregularstack' ,
'common/main/lib/util/LocalStorage'
2016-12-22 14:28:19 +00:00
] , function ( core , $ , _ , Backbone ) {
2016-11-21 11:13:27 +00:00
'use strict' ;
PE . Controllers . Main = Backbone . Controller . extend ( _ . extend ( ( function ( ) {
var ApplyEditRights = - 255 ;
var LoadingDocument = - 256 ;
Common . localStorage . setId ( 'presentation' ) ;
Common . localStorage . setKeysFilter ( 'pe-,asc.presentation' ) ;
Common . localStorage . sync ( ) ;
return {
models : [ ] ,
collections : [ ] ,
views : [ ] ,
initialize : function ( ) {
//
} ,
onLaunch : function ( ) {
var me = this ;
me . stackLongActions = new Common . IrregularStack ( {
strongCompare : function ( obj1 , obj2 ) { return obj1 . id === obj2 . id && obj1 . type === obj2 . type ; } ,
weakCompare : function ( obj1 , obj2 ) { return obj1 . type === obj2 . type ; }
} ) ;
this . _state = {
isDisconnected : false ,
usersCount : 1 ,
fastCoauth : true ,
lostEditingRights : false ,
2018-05-28 10:00:03 +00:00
licenseType : false
2016-11-21 11:13:27 +00:00
} ;
// Initialize viewport
// if (!Common.Utils.isBrowserSupported()){
// Common.Utils.showBrowserRestriction();
// Common.Gateway.reportError(undefined, this.unsupportedBrowserErrorText);
// return;
// }
// Initialize api
window [ "flat_desine" ] = true ;
me . api = new Asc . asc _docs _api ( {
'id-view' : 'editor_sdk' ,
2017-06-23 13:43:21 +00:00
'mobile' : true ,
'translate' : {
'Series' : me . txtSeries ,
'Diagram Title' : me . txtDiagramTitle ,
'X Axis' : me . txtXAxis ,
'Y Axis' : me . txtYAxis ,
2017-06-23 13:49:29 +00:00
'Your text here' : me . txtArt ,
'Slide text' : this . txtSlideText ,
'Chart' : this . txtSldLtTChart ,
'ClipArt' : this . txtClipArt ,
'Diagram' : this . txtDiagram ,
'Date and time' : this . txtDateTime ,
'Footer' : this . txtFooter ,
'Header' : this . txtHeader ,
'Media' : this . txtMedia ,
'Picture' : this . txtPicture ,
'Image' : this . txtImage ,
'Slide number' : this . txtSlideNumber ,
'Slide subtitle' : this . txtSlideSubtitle ,
'Table' : this . txtSldLtTTbl ,
2020-12-25 20:56:00 +00:00
'Slide title' : this . txtSlideTitle ,
'Click to add first slide' : this . txtAddFirstSlide
2017-06-23 13:43:21 +00:00
}
2016-11-21 11:13:27 +00:00
} ) ;
2017-01-23 14:38:53 +00:00
// Localization uiApp params
uiApp . params . modalButtonOk = me . textOK ;
uiApp . params . modalButtonCancel = me . textCancel ;
uiApp . params . modalPreloaderTitle = me . textPreloader ;
uiApp . params . modalUsernamePlaceholder = me . textUsername ;
uiApp . params . modalPasswordPlaceholder = me . textPassword ;
uiApp . params . smartSelectBackText = me . textBack ;
uiApp . params . smartSelectPopupCloseText = me . textClose ;
uiApp . params . smartSelectPickerCloseText = me . textDone ;
uiApp . params . notificationCloseButtonText = me . textClose ;
2016-11-21 11:13:27 +00:00
if ( me . api ) {
2020-02-17 08:57:44 +00:00
var value = Common . localStorage . getItem ( "pe-settings-fontrender" ) ;
if ( value === null ) value = window . devicePixelRatio > 1 ? '1' : '3' ;
me . api . SetFontRenderingMode ( parseInt ( value ) ) ;
2016-11-21 11:13:27 +00:00
Common . Utils . Metric . setCurrentMetric ( 1 ) ; //pt
me . api . SetDrawingFreeze ( true ) ;
me . api . SetThemesPath ( "../../../../sdkjs/slide/themes/" ) ;
me . api . asc _registerCallback ( 'asc_onError' , _ . bind ( me . onError , me ) ) ;
me . api . asc _registerCallback ( 'asc_onDocumentContentReady' , _ . bind ( me . onDocumentContentReady , me ) ) ;
me . api . asc _registerCallback ( 'asc_onOpenDocumentProgress' , _ . bind ( me . onOpenDocument , me ) ) ;
me . api . asc _registerCallback ( 'asc_onDocumentUpdateVersion' , _ . bind ( me . onUpdateVersion , me ) ) ;
2017-04-11 11:05:56 +00:00
me . api . asc _registerCallback ( 'asc_onServerVersion' , _ . bind ( me . onServerVersion , me ) ) ;
2016-11-21 11:13:27 +00:00
me . api . asc _registerCallback ( 'asc_onAdvancedOptions' , _ . bind ( me . onAdvancedOptions , me ) ) ;
me . api . asc _registerCallback ( 'asc_onDocumentName' , _ . bind ( me . onDocumentName , me ) ) ;
me . api . asc _registerCallback ( 'asc_onPrintUrl' , _ . bind ( me . onPrintUrl , me ) ) ;
me . api . asc _registerCallback ( 'asc_onThumbnailsShow' , _ . bind ( me . onThumbnailsShow , me ) ) ;
me . api . asc _registerCallback ( 'asc_onMeta' , _ . bind ( me . onMeta , me ) ) ;
Common . NotificationCenter . on ( 'api:disconnect' , _ . bind ( me . onCoAuthoringDisconnect , me ) ) ;
Common . NotificationCenter . on ( 'goback' , _ . bind ( me . goBack , me ) ) ;
// Initialize descendants
_ . each ( me . getApplication ( ) . controllers , function ( controller ) {
if ( controller && _ . isFunction ( controller . setApi ) ) {
controller . setApi ( me . api ) ;
}
} ) ;
// Initialize api gateway
me . editorConfig = { } ;
me . appOptions = { } ;
me . plugins = undefined ;
Common . Gateway . on ( 'init' , _ . bind ( me . loadConfig , me ) ) ;
Common . Gateway . on ( 'showmessage' , _ . bind ( me . onExternalMessage , me ) ) ;
Common . Gateway . on ( 'opendocument' , _ . bind ( me . loadDocument , me ) ) ;
2017-09-20 11:32:18 +00:00
Common . Gateway . appReady ( ) ;
2018-06-25 08:17:31 +00:00
Common . Gateway . on ( 'internalcommand' , function ( data ) {
if ( data . command == 'hardBack' ) {
if ( $ ( '.modal-in' ) . length > 0 ) {
if ( ! $ ( me . loadMask ) . hasClass ( 'modal-in' ) )
uiApp . closeModal ( ) ;
Common . Gateway . internalMessage ( 'hardBack' , false ) ;
} else
Common . Gateway . internalMessage ( 'hardBack' , true ) ;
}
} ) ;
Common . Gateway . internalMessage ( 'listenHardBack' ) ;
2016-11-21 11:13:27 +00:00
}
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
me . initNames ( ) ;
2019-08-02 08:47:28 +00:00
me . defaultTitleText = '{{APP_TITLE_TEXT}}' ;
2020-07-14 09:46:15 +00:00
me . warnNoLicense = me . warnNoLicense . replace ( /%1/g , '{{COMPANY_NAME}}' ) ;
me . warnNoLicenseUsers = me . warnNoLicenseUsers . replace ( /%1/g , '{{COMPANY_NAME}}' ) ;
me . textNoLicenseTitle = me . textNoLicenseTitle . replace ( /%1/g , '{{COMPANY_NAME}}' ) ;
me . warnLicenseExceeded = me . warnLicenseExceeded . replace ( /%1/g , '{{COMPANY_NAME}}' ) ;
me . warnLicenseUsersExceeded = me . warnLicenseUsersExceeded . replace ( /%1/g , '{{COMPANY_NAME}}' ) ;
2016-11-21 11:13:27 +00:00
} ,
loadConfig : function ( data ) {
var me = this ;
me . editorConfig = $ . extend ( me . editorConfig , data . config ) ;
me . editorConfig . user =
2016-11-24 14:13:27 +00:00
me . appOptions . user = Common . Utils . fillUserInfo ( me . editorConfig . user , me . editorConfig . lang , me . textAnonymous ) ;
2016-11-21 11:13:27 +00:00
me . appOptions . isDesktopApp = me . editorConfig . targetApp == 'desktop' ;
me . appOptions . canCreateNew = ! _ . isEmpty ( me . editorConfig . createUrl ) && ! me . appOptions . isDesktopApp ;
2019-07-15 08:01:29 +00:00
me . appOptions . canOpenRecent = me . editorConfig . recent !== undefined && ! me . appOptions . isDesktopApp ;
2016-11-21 11:13:27 +00:00
me . appOptions . templates = me . editorConfig . templates ;
me . appOptions . recent = me . editorConfig . recent ;
me . appOptions . createUrl = me . editorConfig . createUrl ;
me . appOptions . lang = me . editorConfig . lang ;
me . appOptions . location = ( typeof ( me . editorConfig . location ) == 'string' ) ? me . editorConfig . location . toLowerCase ( ) : '' ;
me . appOptions . sharingSettingsUrl = me . editorConfig . sharingSettingsUrl ;
me . appOptions . fileChoiceUrl = me . editorConfig . fileChoiceUrl ;
me . appOptions . mergeFolderUrl = me . editorConfig . mergeFolderUrl ;
me . appOptions . canAnalytics = false ;
2019-11-27 07:22:25 +00:00
me . appOptions . canRequestClose = me . editorConfig . canRequestClose ;
2016-11-21 11:13:27 +00:00
me . appOptions . customization = me . editorConfig . customization ;
2019-11-27 07:22:25 +00:00
me . appOptions . canBackToFolder = ( me . editorConfig . canBackToFolder !== false ) && ( typeof ( me . editorConfig . customization ) == 'object' ) && ( typeof ( me . editorConfig . customization . goback ) == 'object' )
&& ( ! _ . isEmpty ( me . editorConfig . customization . goback . url ) || me . editorConfig . customization . goback . requestClose && me . appOptions . canRequestClose ) ;
2019-07-15 08:01:29 +00:00
me . appOptions . canBack = me . appOptions . canBackToFolder === true ;
2016-11-21 11:13:27 +00:00
me . appOptions . canPlugins = false ;
me . plugins = me . editorConfig . plugins ;
if ( me . editorConfig . lang )
me . api . asc _setLocale ( me . editorConfig . lang ) ;
2019-09-13 08:39:50 +00:00
if ( ! me . editorConfig . customization || ! ( me . editorConfig . customization . loaderName || me . editorConfig . customization . loaderLogo ) )
2019-09-27 15:43:55 +00:00
$ ( '#editor_sdk' ) . append ( '<div class="doc-placeholder"><div class="slide-h"><div class="slide-v"><div class="slide-container"><div class="line"></div><div class="line empty"></div><div class="line"></div></div></div></div></div>' ) ;
2019-09-13 08:39:50 +00:00
2020-06-01 14:55:54 +00:00
var value = Common . localStorage . getItem ( "pe-mobile-macros-mode" ) ;
if ( value === null ) {
value = this . editorConfig . customization ? this . editorConfig . customization . macrosMode : 'warn' ;
value = ( value == 'enable' ) ? 1 : ( value == 'disable' ? 2 : 0 ) ;
} else
value = parseInt ( value ) ;
Common . Utils . InternalSettings . set ( "pe-mobile-macros-mode" , value ) ;
2016-11-21 11:13:27 +00:00
// if (this.appOptions.location == 'us' || this.appOptions.location == 'ca')
// Common.Utils.Metric.setDefaultMetric(Common.Utils.Metric.c_MetricUnits.inch);
} ,
loadDocument : function ( data ) {
this . permissions = { } ;
this . document = data . doc ;
var docInfo = { } ;
if ( data . doc ) {
this . permissions = $ . extend ( this . permissions , data . doc . permissions ) ;
2017-10-30 11:50:59 +00:00
var _permissions = $ . extend ( { } , data . doc . permissions ) ,
_user = new Asc . asc _CUserInfo ( ) ;
2016-11-21 11:13:27 +00:00
_user . put _Id ( this . appOptions . user . id ) ;
_user . put _FullName ( this . appOptions . user . fullname ) ;
docInfo = new Asc . asc _CDocInfo ( ) ;
docInfo . put _Id ( data . doc . key ) ;
docInfo . put _Url ( data . doc . url ) ;
docInfo . put _Title ( data . doc . title ) ;
docInfo . put _Format ( data . doc . fileType ) ;
docInfo . put _VKey ( data . doc . vkey ) ;
docInfo . put _Options ( data . doc . options ) ;
docInfo . put _UserInfo ( _user ) ;
docInfo . put _CallbackUrl ( this . editorConfig . callbackUrl ) ;
2016-11-24 13:56:12 +00:00
docInfo . put _Token ( data . doc . token ) ;
2017-10-30 11:50:59 +00:00
docInfo . put _Permissions ( _permissions ) ;
2020-05-08 08:58:31 +00:00
docInfo . put _EncryptedInfo ( this . editorConfig . encryptionKeys ) ;
2020-05-22 15:38:03 +00:00
var enable = ! this . editorConfig . customization || ( this . editorConfig . customization . macros !== false ) ;
docInfo . asc _putIsEnabledMacroses ( ! ! enable ) ;
enable = ! this . editorConfig . customization || ( this . editorConfig . customization . plugins !== false ) ;
docInfo . asc _putIsEnabledPlugins ( ! ! enable ) ;
2016-11-21 11:13:27 +00:00
}
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
this . api . asc _registerCallback ( 'asc_onGetEditorPermissions' , _ . bind ( this . onEditorPermissions , this ) ) ;
2017-11-23 09:01:27 +00:00
this . api . asc _registerCallback ( 'asc_onLicenseChanged' , _ . bind ( this . onLicenseChanged , this ) ) ;
2020-05-22 15:38:03 +00:00
this . api . asc _registerCallback ( 'asc_onRunAutostartMacroses' , _ . bind ( this . onRunAutostartMacroses , this ) ) ;
2016-11-21 11:13:27 +00:00
this . api . asc _setDocInfo ( docInfo ) ;
this . api . asc _getEditorPermissions ( this . editorConfig . licenseUrl , this . editorConfig . customerId ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
Common . SharedSettings . set ( 'document' , data . doc ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( data . doc ) {
PE . getController ( 'Toolbar' ) . setDocumentTitle ( data . doc . title ) ;
2019-07-30 09:05:48 +00:00
if ( data . doc . info ) {
data . doc . info . author && console . log ( "Obsolete: The 'author' parameter of the document 'info' section is deprecated. Please use 'owner' instead." ) ;
data . doc . info . created && console . log ( "Obsolete: The 'created' parameter of the document 'info' section is deprecated. Please use 'uploaded' instead." ) ;
}
2016-11-21 11:13:27 +00:00
}
} ,
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
setMode : function ( mode ) {
var me = this ;
2016-03-11 00:48:53 +00:00
2017-05-25 09:55:29 +00:00
Common . SharedSettings . set ( 'mode' , mode . isEdit ? 'edit' : 'view' ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( me . api ) {
2017-05-25 09:55:29 +00:00
me . api . asc _enableKeyEvents ( mode . isEdit ) ;
2020-11-02 16:23:54 +00:00
me . api . asc _setViewMode ( ! mode . isEdit && ! mode . isRestrictedEdit ) ;
2016-11-21 11:13:27 +00:00
}
} ,
onProcessSaveResult : function ( data ) {
this . api . asc _OnSaveEnd ( data . result ) ;
if ( data && data . result === false ) {
uiApp . alert (
_ . isEmpty ( data . message ) ? this . errorProcessSaveResult : data . message ,
this . criticalErrorTitle
) ;
}
} ,
onProcessRightsChange : function ( data ) {
if ( data && data . enabled === false ) {
var me = this ,
old _rights = this . _state . lostEditingRights ;
this . _state . lostEditingRights = ! this . _state . lostEditingRights ;
this . api . asc _coAuthoringDisconnect ( ) ;
Common . NotificationCenter . trigger ( 'api:disconnect' ) ;
if ( ! old _rights ) {
uiApp . alert (
_ . isEmpty ( data . message ) ? this . warnProcessRightsChange : data . message ,
this . notcriticalErrorTitle ,
function ( ) {
me . _state . lostEditingRights = false ;
me . onEditComplete ( ) ;
}
) ;
}
}
} ,
onDownloadAs : function ( ) {
2019-01-10 14:20:59 +00:00
if ( ! this . appOptions . canDownload ) {
Common . Gateway . reportError ( Asc . c _oAscError . ID . AccessDeny , this . errorAccessDeny ) ;
return ;
}
this . _state . isFromGatewayDownloadAs = true ;
2019-07-24 08:36:13 +00:00
this . api . asc _DownloadAs ( new Asc . asc _CDownloadOptions ( Asc . c _oAscFileType . PPTX , true ) ) ;
2016-11-21 11:13:27 +00:00
} ,
2019-01-10 13:20:27 +00:00
goBack : function ( current ) {
2019-11-27 07:22:25 +00:00
if ( this . appOptions . customization . goback . requestClose && this . appOptions . canRequestClose ) {
Common . Gateway . requestClose ( ) ;
2016-11-21 11:13:27 +00:00
} else {
2019-11-27 07:22:25 +00:00
var href = this . appOptions . customization . goback . url ;
if ( ! current && this . appOptions . customization . goback . blank !== false ) {
window . open ( href , "_blank" ) ;
} else {
parent . location . href = href ;
}
2016-11-21 11:13:27 +00:00
}
} ,
onEditComplete : function ( cmp ) {
//
} ,
onLongActionBegin : function ( type , id ) {
var action = { id : id , type : type } ;
this . stackLongActions . push ( action ) ;
this . setLongActionView ( action ) ;
} ,
onLongActionEnd : function ( type , id ) {
var me = this ,
action = { id : id , type : type } ;
me . stackLongActions . pop ( action ) ;
me . updateWindowTitle ( true ) ;
action = me . stackLongActions . get ( { type : Asc . c _oAscAsyncActionType . Information } ) ;
if ( action ) {
me . setLongActionView ( action )
} else {
if ( me . _state . fastCoauth && me . _state . usersCount > 1 && id == Asc . c _oAscAsyncAction [ 'Save' ] ) {
2017-04-11 11:05:56 +00:00
// me._state.timerSave = setTimeout(function () {
//console.debug('End long action');
// }, 500);
2016-11-21 11:13:27 +00:00
} else {
// console.debug('End long action');
}
}
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
action = me . stackLongActions . get ( { type : Asc . c _oAscAsyncActionType . BlockInteraction } ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( action ) {
me . setLongActionView ( action )
} else {
_ . delay ( function ( ) {
$ ( me . loadMask ) . hasClass ( 'modal-in' ) && uiApp . closeModal ( me . loadMask ) ;
} , 300 ) ;
}
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( id == Asc . c _oAscAsyncAction [ 'Save' ] && ( ! me . _state . fastCoauth || me . _state . usersCount < 2 ) ) {
// me.synchronizeChanges();
}
} ,
setLongActionView : function ( action ) {
var me = this ,
title = '' ,
text = '' ;
switch ( action . id ) {
case Asc . c _oAscAsyncAction [ 'Open' ] :
title = me . openTitleText ;
text = me . openTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'Save' ] :
2017-04-11 11:05:56 +00:00
// clearTimeout(me._state.timerSave);
2016-11-21 11:13:27 +00:00
title = me . saveTitleText ;
text = me . saveTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'LoadDocumentFonts' ] :
title = me . loadFontsTitleText ;
text = me . loadFontsTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'LoadDocumentImages' ] :
title = me . loadImagesTitleText ;
text = me . loadImagesTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'LoadFont' ] :
title = me . loadFontTitleText ;
text = me . loadFontTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'LoadImage' ] :
title = me . loadImageTitleText ;
text = me . loadImageTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'DownloadAs' ] :
title = me . downloadTitleText ;
text = me . downloadTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'Print' ] :
title = me . printTitleText ;
text = me . printTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'UploadImage' ] :
title = me . uploadImageTitleText ;
text = me . uploadImageTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'LoadTheme' ] :
title = this . loadThemeTitleText ;
text = this . loadThemeTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'ApplyChanges' ] :
title = me . applyChangesTitleText ;
text = me . applyChangesTextText ;
break ;
case Asc . c _oAscAsyncAction [ 'PrepareToSave' ] :
title = me . savePreparingText ;
text = me . savePreparingTitle ;
break ;
2019-05-08 11:52:35 +00:00
case Asc . c _oAscAsyncAction [ 'Waiting' ] :
title = me . waitText ;
text = me . waitText ;
break ;
2016-11-21 11:13:27 +00:00
case ApplyEditRights :
title = me . txtEditingMode ;
text = me . txtEditingMode ;
break ;
case LoadingDocument :
title = me . loadingDocumentTitleText ;
text = me . loadingDocumentTextText ;
break ;
2018-02-05 09:22:03 +00:00
default :
if ( typeof action . id == 'string' ) {
title = action . id ;
text = action . id ;
}
break ;
2016-11-21 11:13:27 +00:00
}
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( action . type == Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] ) {
2016-12-28 13:48:14 +00:00
if ( action . id == Asc . c _oAscAsyncAction [ 'ApplyChanges' ] || action . id == Asc . c _oAscAsyncAction [ 'LoadDocumentFonts' ] ) {
return ;
}
2016-11-21 11:13:27 +00:00
if ( me . loadMask && $ ( me . loadMask ) . hasClass ( 'modal-in' ) ) {
$$ ( me . loadMask ) . find ( '.modal-title' ) . text ( title ) ;
} else {
me . loadMask = uiApp . showPreloader ( title ) ;
}
}
else {
// this.getApplication().getController('Statusbar').setStatusCaption(text);
}
} ,
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
onDocumentContentReady : function ( ) {
if ( this . _isDocReady )
return ;
2016-03-11 00:48:53 +00:00
2017-09-08 10:41:04 +00:00
if ( this . _state . openDlg )
uiApp . closeModal ( this . _state . openDlg ) ;
2016-11-21 11:13:27 +00:00
var me = this ,
value ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
me . _isDocReady = true ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
me . api . SetDrawingFreeze ( false ) ;
me . hidePreloader ( ) ;
me . onLongActionEnd ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
value = Common . localStorage . getItem ( "pe-settings-zoom" ) ;
var zf = ( value !== null ) ? parseInt ( value ) : ( me . appOptions . customization && me . appOptions . customization . zoom ? parseInt ( me . appOptions . customization . zoom ) : - 1 ) ;
( zf == - 1 ) ? me . api . zoomFitToPage ( ) : ( ( zf == - 2 ) ? me . api . zoomFitToWidth ( ) : me . api . zoom ( zf > 0 ? zf : 100 ) ) ;
2016-03-11 00:48:53 +00:00
2019-09-04 12:51:09 +00:00
value = Common . localStorage . getBool ( "pe-mobile-spellcheck" , ! ( this . appOptions . customization && this . appOptions . customization . spellcheck === false ) ) ;
Common . Utils . InternalSettings . set ( "pe-mobile-spellcheck" , value ) ;
2019-02-12 11:26:30 +00:00
me . api . asc _setSpellCheck ( value ) ;
2017-05-26 08:34:18 +00:00
2016-11-21 11:13:27 +00:00
me . api . asc _registerCallback ( 'asc_onStartAction' , _ . bind ( me . onLongActionBegin , me ) ) ;
me . api . asc _registerCallback ( 'asc_onEndAction' , _ . bind ( me . onLongActionEnd , me ) ) ;
me . api . asc _registerCallback ( 'asc_onCoAuthoringDisconnect' , _ . bind ( me . onCoAuthoringDisconnect , me ) ) ;
me . api . asc _registerCallback ( 'asc_onPrint' , _ . bind ( me . onPrint , me ) ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
me . updateWindowTitle ( true ) ;
2016-03-11 00:48:53 +00:00
2017-04-21 09:56:11 +00:00
me . api . SetTextBoxInputMode ( Common . localStorage . getBool ( "pe-settings-inputmode" ) ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
/** coauthoring begin **/
if ( me . appOptions . isEdit && me . appOptions . canLicense && ! me . appOptions . isOffline && me . appOptions . canCoAuthoring ) {
// Force ON fast co-authoring mode
me . _state . fastCoauth = true ;
} else {
me . _state . fastCoauth = false ;
}
me . api . asc _SetFastCollaborative ( me . _state . fastCoauth ) ;
/** coauthoring end **/
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( me . appOptions . isEdit ) {
value = me . _state . fastCoauth ; // Common.localStorage.getItem("de-settings-autosave");
value = ( ! me . _state . fastCoauth && value !== null ) ? parseInt ( value ) : ( me . appOptions . canCoAuthoring ? 1 : 0 ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
me . api . asc _setAutoSaveGap ( value ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( me . needToUpdateVersion ) {
Common . NotificationCenter . trigger ( 'api:disconnect' ) ;
}
2016-03-11 00:48:53 +00:00
}
2016-11-21 11:13:27 +00:00
// if (this.appOptions.canAnalytics && false)
// Common.component.Analytics.initialize('UA-12442749-13', 'Document Editor');
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
Common . Gateway . on ( 'processsaveresult' , _ . bind ( me . onProcessSaveResult , me ) ) ;
Common . Gateway . on ( 'processrightschange' , _ . bind ( me . onProcessRightsChange , me ) ) ;
Common . Gateway . on ( 'downloadas' , _ . bind ( me . onDownloadAs , me ) ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
Common . Gateway . sendInfo ( {
mode : me . appOptions . isEdit ? 'edit' : 'view'
} ) ;
2016-03-11 00:48:53 +00:00
2016-11-21 11:13:27 +00:00
if ( me . api ) {
me . api . Resize ( ) ;
2017-01-25 09:55:17 +00:00
me . api . zoomFitToPage ( ) ;
2020-01-31 14:29:02 +00:00
me . api . asc _GetDefaultTableStyles && _ . defer ( function ( ) { me . api . asc _GetDefaultTableStyles ( ) } ) ;
2016-11-21 11:13:27 +00:00
}
2017-11-23 09:01:27 +00:00
me . applyLicense ( ) ;
2018-06-22 10:22:57 +00:00
$ ( document ) . on ( 'contextmenu' , _ . bind ( me . onContextMenu , me ) ) ;
2019-01-10 08:20:53 +00:00
Common . Gateway . documentReady ( ) ;
2019-07-22 14:09:53 +00:00
$ ( '.doc-placeholder' ) . remove ( ) ;
2017-11-23 09:01:27 +00:00
} ,
onLicenseChanged : function ( params ) {
var licType = params . asc _getLicenseType ( ) ;
2018-05-28 10:00:03 +00:00
if ( licType !== undefined && this . appOptions . canEdit && this . editorConfig . mode !== 'view' &&
2020-11-09 11:52:21 +00:00
( licType === Asc . c _oLicenseResult . Connections || licType === Asc . c _oLicenseResult . UsersCount || licType === Asc . c _oLicenseResult . ConnectionsOS || licType === Asc . c _oLicenseResult . UsersCountOS
2020-11-24 11:54:41 +00:00
|| licType === Asc . c _oLicenseResult . SuccessLimit && ( this . appOptions . trialMode & Asc . c _oLicenseMode . Limited ) !== 0 ) )
2018-05-28 10:00:03 +00:00
this . _state . licenseType = licType ;
2017-11-23 09:01:27 +00:00
2018-05-28 10:00:03 +00:00
if ( this . _isDocReady && this . _state . licenseType )
2017-11-23 09:01:27 +00:00
this . applyLicense ( ) ;
} ,
2017-07-07 08:41:19 +00:00
2017-11-23 09:01:27 +00:00
applyLicense : function ( ) {
var me = this ;
2020-02-10 06:49:58 +00:00
if ( this . editorConfig . mode !== 'view' && ! this . isSupportEditFeature ( ) ) {
var value = Common . localStorage . getItem ( "pe-opensource-warning" ) ;
value = ( value !== null ) ? parseInt ( value ) : 0 ;
var now = ( new Date ) . getTime ( ) ;
2020-02-10 11:43:42 +00:00
if ( now - value > 86400000 ) {
2020-02-10 06:49:58 +00:00
Common . localStorage . setItem ( "pe-opensource-warning" , now ) ;
uiApp . modal ( {
title : me . notcriticalErrorTitle ,
text : me . errorOpensource ,
buttons : [ { text : 'OK' } ]
} ) ;
}
PE . getController ( 'Toolbar' ) . activateControls ( ) ;
return ;
}
2018-05-28 10:00:03 +00:00
if ( this . _state . licenseType ) {
var license = this . _state . licenseType ,
buttons = [ { text : 'OK' } ] ;
2020-11-25 14:27:53 +00:00
if ( ( this . appOptions . trialMode & Asc . c _oLicenseMode . Limited ) !== 0 &&
( license === Asc . c _oLicenseResult . SuccessLimit || license === Asc . c _oLicenseResult . ExpiredLimited || this . appOptions . permissionsLicense === Asc . c _oLicenseResult . SuccessLimit ) ) {
2020-11-09 11:52:21 +00:00
license = ( license === Asc . c _oLicenseResult . ExpiredLimited ) ? this . warnLicenseLimitedNoAccess : this . warnLicenseLimitedRenewed ;
} else if ( license === Asc . c _oLicenseResult . Connections || license === Asc . c _oLicenseResult . UsersCount ) {
2018-05-28 10:00:03 +00:00
license = ( license === Asc . c _oLicenseResult . Connections ) ? this . warnLicenseExceeded : this . warnLicenseUsersExceeded ;
} else {
license = ( license === Asc . c _oLicenseResult . ConnectionsOS ) ? this . warnNoLicense : this . warnNoLicenseUsers ;
buttons = [ {
text : me . textBuyNow ,
bold : true ,
onClick : function ( ) {
2019-02-22 12:52:33 +00:00
window . open ( '{{PUBLISHER_URL}}' , "_blank" ) ;
2018-05-28 10:00:03 +00:00
}
} ,
{
text : me . textContactUs ,
onClick : function ( ) {
2019-02-22 12:52:33 +00:00
window . open ( 'mailto:{{SALES_EMAIL}}' , "_blank" ) ;
2018-05-28 10:00:03 +00:00
}
} ] ;
}
2020-11-10 10:44:46 +00:00
if ( this . _state . licenseType === Asc . c _oLicenseResult . SuccessLimit ) {
PE . getController ( 'Toolbar' ) . activateControls ( ) ;
} else {
PE . getController ( 'Toolbar' ) . activateViewControls ( ) ;
PE . getController ( 'Toolbar' ) . deactivateEditControls ( ) ;
Common . NotificationCenter . trigger ( 'api:disconnect' ) ;
}
2017-11-23 09:01:27 +00:00
var value = Common . localStorage . getItem ( "pe-license-warning" ) ;
2016-11-21 11:13:27 +00:00
value = ( value !== null ) ? parseInt ( value ) : 0 ;
var now = ( new Date ) . getTime ( ) ;
if ( now - value > 86400000 ) {
2017-11-23 09:01:27 +00:00
Common . localStorage . setItem ( "pe-license-warning" , now ) ;
2016-11-21 11:13:27 +00:00
uiApp . modal ( {
title : me . textNoLicenseTitle ,
2018-05-28 10:00:03 +00:00
text : license ,
buttons : buttons
2016-11-21 11:13:27 +00:00
} ) ;
}
2019-03-15 10:30:01 +00:00
} else {
if ( ! me . appOptions . isDesktopApp && ! me . appOptions . canBrandingExt &&
me . editorConfig && me . editorConfig . customization && ( me . editorConfig . customization . loaderName || me . editorConfig . customization . loaderLogo ) ) {
uiApp . modal ( {
title : me . textPaidFeature ,
text : me . textCustomLoader ,
buttons : [ {
text : me . textContactUs ,
bold : true ,
onClick : function ( ) {
2019-06-10 08:56:27 +00:00
window . open ( 'mailto:{{SALES_EMAIL}}' , "_blank" ) ;
2019-03-15 10:30:01 +00:00
}
} ,
{ text : me . textClose } ]
} ) ;
}
2017-11-23 09:01:27 +00:00
PE . getController ( 'Toolbar' ) . activateControls ( ) ;
2019-03-15 10:30:01 +00:00
}
2016-11-21 11:13:27 +00:00
} ,
onOpenDocument : function ( progress ) {
if ( this . loadMask ) {
var $title = $$ ( this . loadMask ) . find ( '.modal-title' ) ,
proc = ( progress . asc _getCurrentFont ( ) + progress . asc _getCurrentImage ( ) ) / ( progress . asc _getFontsCount ( ) + progress . asc _getImagesCount ( ) ) ;
$title . text ( this . textLoadingDocument + ': ' + Math . min ( Math . round ( proc * 100 ) , 100 ) + '%' ) ;
}
} ,
onEditorPermissions : function ( params ) {
var me = this ,
licType = params . asc _getLicenseType ( ) ;
if ( Asc . c _oLicenseResult . Expired === licType ||
Asc . c _oLicenseResult . Error === licType ||
Asc . c _oLicenseResult . ExpiredTrial === licType ) {
uiApp . modal ( {
title : me . titleLicenseExp ,
text : me . warnLicenseExp
} ) ;
return ;
}
2020-11-24 11:54:41 +00:00
if ( Asc . c _oLicenseResult . ExpiredLimited === licType )
me . _state . licenseType = licType ;
2016-11-21 11:13:27 +00:00
2017-04-11 11:05:56 +00:00
if ( me . onServerVersion ( params . asc _getBuildVersion ( ) ) ) return ;
2020-11-25 14:27:53 +00:00
me . appOptions . permissionsLicense = licType ;
2016-11-21 11:13:27 +00:00
me . permissions . review = ( me . permissions . review === undefined ) ? ( me . permissions . edit !== false ) : me . permissions . review ;
me . appOptions . canAnalytics = params . asc _getIsAnalyticsEnable ( ) ;
2017-04-21 08:44:23 +00:00
me . appOptions . canLicense = ( licType === Asc . c _oLicenseResult . Success || licType === Asc . c _oLicenseResult . SuccessLimit ) ;
2016-11-21 11:13:27 +00:00
me . appOptions . isLightVersion = params . asc _getIsLight ( ) ;
/** coauthoring begin **/
me . appOptions . canCoAuthoring = ! me . appOptions . isLightVersion ;
/** coauthoring end **/
me . appOptions . isOffline = me . api . asc _isOffline ( ) ;
me . appOptions . isReviewOnly = ( me . permissions . review === true ) && ( me . permissions . edit === false ) ;
me . appOptions . canRequestEditRights = me . editorConfig . canRequestEditRights ;
me . appOptions . canEdit = ( me . permissions . edit !== false || me . permissions . review === true ) && // can edit or review
( me . editorConfig . canRequestEditRights || me . editorConfig . mode !== 'view' ) && // if mode=="view" -> canRequestEditRights must be defined
2020-02-10 06:49:58 +00:00
( ! me . appOptions . isReviewOnly || me . appOptions . canLicense ) && // if isReviewOnly==true -> canLicense must be true
me . isSupportEditFeature ( ) ;
2016-11-21 11:13:27 +00:00
me . appOptions . isEdit = me . appOptions . canLicense && me . appOptions . canEdit && me . editorConfig . mode !== 'view' ;
me . appOptions . canReview = me . appOptions . canLicense && me . appOptions . isEdit && ( me . permissions . review === true ) ;
me . appOptions . canUseHistory = me . appOptions . canLicense && ! me . appOptions . isLightVersion && me . editorConfig . canUseHistory && me . appOptions . canCoAuthoring && ! me . appOptions . isDesktopApp ;
me . appOptions . canHistoryClose = me . editorConfig . canHistoryClose ;
me . appOptions . canUseMailMerge = me . appOptions . canLicense && me . appOptions . canEdit && ! me . appOptions . isDesktopApp ;
me . appOptions . canSendEmailAddresses = me . appOptions . canLicense && me . editorConfig . canSendEmailAddresses && me . appOptions . canEdit && me . appOptions . canCoAuthoring ;
2020-04-10 15:58:59 +00:00
me . appOptions . canComments = me . appOptions . canLicense && ( me . permissions . comment === undefined ? me . appOptions . isEdit : me . permissions . comment ) && ( me . editorConfig . mode !== 'view' ) ;
me . appOptions . canComments = me . appOptions . canComments && ! ( ( typeof ( me . editorConfig . customization ) == 'object' ) && me . editorConfig . customization . comments === false ) ;
me . appOptions . canViewComments = me . appOptions . canComments || ! ( ( typeof ( me . editorConfig . customization ) == 'object' ) && me . editorConfig . customization . comments === false ) ;
me . appOptions . canEditComments = me . appOptions . isOffline || ! ( typeof ( me . editorConfig . customization ) == 'object' && me . editorConfig . customization . commentAuthorOnly ) ;
2016-11-21 11:13:27 +00:00
me . appOptions . canChat = me . appOptions . canLicense && ! me . appOptions . isOffline && ! ( ( typeof ( me . editorConfig . customization ) == 'object' ) && me . editorConfig . customization . chat === false ) ;
me . appOptions . canEditStyles = me . appOptions . canLicense && me . appOptions . canEdit ;
me . appOptions . canPrint = ( me . permissions . print !== false ) ;
2020-11-02 16:23:54 +00:00
me . appOptions . isRestrictedEdit = ! me . appOptions . isEdit && me . appOptions . canComments ;
2020-11-09 11:52:21 +00:00
me . appOptions . trialMode = params . asc _getLicenseMode ( ) ;
2016-11-21 11:13:27 +00:00
var type = /^(?:(pdf|djvu|xps))$/ . exec ( me . document . fileType ) ;
2019-07-15 08:01:29 +00:00
me . appOptions . canDownloadOrigin = me . permissions . download !== false && ( type && typeof type [ 1 ] === 'string' ) ;
me . appOptions . canDownload = me . permissions . download !== false && ( ! type || typeof type [ 1 ] !== 'string' ) ;
2016-11-21 11:13:27 +00:00
2019-04-18 09:18:14 +00:00
me . appOptions . canBranding = params . asc _getCustomization ( ) ;
2017-06-14 10:57:02 +00:00
me . appOptions . canBrandingExt = params . asc _getCanBranding ( ) && ( typeof me . editorConfig . customization == 'object' ) ;
2016-11-21 11:13:27 +00:00
2020-08-05 13:36:35 +00:00
me . appOptions . canUseReviewPermissions = me . appOptions . canLicense && me . editorConfig . customization && me . editorConfig . customization . reviewPermissions && ( typeof ( me . editorConfig . customization . reviewPermissions ) == 'object' ) ;
Common . Utils . UserInfoParser . setParser ( me . appOptions . canUseReviewPermissions ) ;
2016-11-21 11:13:27 +00:00
me . applyModeCommonElements ( ) ;
me . applyModeEditorElements ( ) ;
2020-11-02 16:23:54 +00:00
me . api . asc _setViewMode ( ! me . appOptions . isEdit && ! me . appOptions . isRestrictedEdit ) ;
( me . appOptions . isRestrictedEdit && me . appOptions . canComments ) && me . api . asc _setRestriction ( Asc . c _oAscRestrictionType . OnlyComments ) ;
2016-11-21 11:13:27 +00:00
me . api . asc _LoadDocument ( ) ;
me . api . Resize ( ) ;
if ( ! me . appOptions . isEdit ) {
me . hidePreloader ( ) ;
me . onLongActionBegin ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
}
2020-01-16 08:08:38 +00:00
if ( me . appOptions . canBrandingExt && ( me . editorConfig . customization && ( me . editorConfig . customization . loaderName || me . editorConfig . customization . loaderLogo ) ) ) {
$ ( '#editor-navbar #navbar-logo' ) . hide ( ) ;
$ ( '#editor-navbar' ) . removeClass ( 'logo-navbar' ) ;
$ ( '#editor_sdk' ) . removeClass ( 'with-logo' ) ;
}
2016-11-21 11:13:27 +00:00
} ,
applyModeCommonElements : function ( ) {
var me = this ;
window . editor _elements _prepared = true ;
_ . each ( me . getApplication ( ) . controllers , function ( controller ) {
if ( controller && _ . isFunction ( controller . setMode ) ) {
2017-05-25 09:55:29 +00:00
controller . setMode ( me . appOptions ) ;
2016-11-21 11:13:27 +00:00
}
} ) ;
if ( me . api ) {
2017-04-11 11:05:56 +00:00
me . api . asc _registerCallback ( 'asc_onSendThemeColors' , _ . bind ( me . onSendThemeColors , me ) ) ;
me . api . asc _registerCallback ( 'asc_onDownloadUrl' , _ . bind ( me . onDownloadUrl , me ) ) ;
2019-06-07 07:29:43 +00:00
me . api . asc _registerCallback ( 'asc_onAuthParticipantsChanged' , _ . bind ( me . onAuthParticipantsChanged , me ) ) ;
me . api . asc _registerCallback ( 'asc_onParticipantsChanged' , _ . bind ( me . onAuthParticipantsChanged , me ) ) ;
2016-11-21 11:13:27 +00:00
}
} ,
applyModeEditorElements : function ( ) {
if ( this . appOptions . isEdit ) {
var me = this ,
value ;
2019-12-16 11:02:22 +00:00
value = Common . localStorage . getItem ( 'pe-mobile-settings-unit' ) ;
2019-12-16 12:01:09 +00:00
value = ( value !== null ) ? parseInt ( value ) : ( me . appOptions . customization && me . appOptions . customization . unit ? Common . Utils . Metric . c _MetricUnits [ me . appOptions . customization . unit . toLocaleLowerCase ( ) ] : Common . Utils . Metric . getDefaultMetric ( ) ) ;
2019-12-16 11:02:22 +00:00
( value === undefined ) && ( value = Common . Utils . Metric . getDefaultMetric ( ) ) ;
Common . Utils . Metric . setCurrentMetric ( value ) ;
me . api . asc _SetDocumentUnits ( ( value == Common . Utils . Metric . c _MetricUnits . inch ) ? Asc . c _oAscDocumentUnits . Inch : ( ( value == Common . Utils . Metric . c _MetricUnits . pt ) ? Asc . c _oAscDocumentUnits . Point : Asc . c _oAscDocumentUnits . Millimeter ) ) ;
2016-11-21 11:13:27 +00:00
2016-11-22 07:10:34 +00:00
// value = Common.localStorage.getItem('pe-hidden-rulers');
// if (me.api.asc_SetViewRulers) me.api.asc_SetViewRulers(value===null || parseInt(value) === 0);
2016-11-21 11:13:27 +00:00
me . api . asc _registerCallback ( 'asc_onChangeObjectLock' , _ . bind ( me . _onChangeObjectLock , me ) ) ;
me . api . asc _registerCallback ( 'asc_onDocumentModifiedChanged' , _ . bind ( me . onDocumentModifiedChanged , me ) ) ;
me . api . asc _registerCallback ( 'asc_onDocumentCanSaveChanged' , _ . bind ( me . onDocumentCanSaveChanged , me ) ) ;
/** coauthoring begin **/
me . api . asc _registerCallback ( 'asc_onCollaborativeChanges' , _ . bind ( me . onCollaborativeChanges , me ) ) ;
me . api . asc _registerCallback ( 'asc_OnTryUndoInFastCollaborative' , _ . bind ( me . onTryUndoInFastCollaborative , me ) ) ;
/** coauthoring end **/
if ( me . stackLongActions . exist ( { id : ApplyEditRights , type : Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] } ) ) {
me . onLongActionEnd ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , ApplyEditRights ) ;
} else if ( ! this . _isDocReady ) {
me . hidePreloader ( ) ;
me . onLongActionBegin ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
}
// Message on window close
window . onbeforeunload = _ . bind ( me . onBeforeUnload , me ) ;
window . onunload = _ . bind ( me . onUnload , me ) ;
}
} ,
onExternalMessage : function ( msg ) {
if ( msg && msg . msg ) {
msg . msg = ( msg . msg ) . toString ( ) ;
uiApp . addNotification ( {
2019-02-26 17:57:23 +00:00
title : uiApp . params . modalTitle ,
2016-11-21 11:13:27 +00:00
message : [ msg . msg . charAt ( 0 ) . toUpperCase ( ) + msg . msg . substring ( 1 ) ]
} ) ;
2017-05-16 07:46:04 +00:00
Common . component . Analytics . trackEvent ( 'External Error' ) ;
2016-11-21 11:13:27 +00:00
}
} ,
onError : function ( id , level , errData ) {
2018-10-08 14:06:37 +00:00
if ( id == Asc . c _oAscError . ID . LoadingScriptError ) {
uiApp . addNotification ( {
title : this . criticalErrorTitle ,
message : this . scriptLoadError
} ) ;
return ;
}
2016-11-21 11:13:27 +00:00
this . hidePreloader ( ) ;
this . onLongActionEnd ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
var config = {
closable : false
} ;
switch ( id )
{
case Asc . c _oAscError . ID . Unknown :
config . msg = this . unknownErrorText ;
break ;
case Asc . c _oAscError . ID . ConvertationTimeout :
config . msg = this . convertationTimeoutText ;
break ;
case Asc . c _oAscError . ID . ConvertationOpenError :
config . msg = this . openErrorText ;
break ;
case Asc . c _oAscError . ID . ConvertationSaveError :
config . msg = this . saveErrorText ;
break ;
case Asc . c _oAscError . ID . DownloadError :
config . msg = this . downloadErrorText ;
break ;
case Asc . c _oAscError . ID . UplImageSize :
config . msg = this . uploadImageSizeMessage ;
break ;
case Asc . c _oAscError . ID . UplImageExt :
config . msg = this . uploadImageExtMessage ;
break ;
case Asc . c _oAscError . ID . UplImageFileCount :
config . msg = this . uploadImageFileCountMessage ;
break ;
case Asc . c _oAscError . ID . SplitCellMaxRows :
config . msg = this . splitMaxRowsErrorText . replace ( '%1' , errData . get _Value ( ) ) ;
break ;
case Asc . c _oAscError . ID . SplitCellMaxCols :
config . msg = this . splitMaxColsErrorText . replace ( '%1' , errData . get _Value ( ) ) ;
break ;
case Asc . c _oAscError . ID . SplitCellRowsDivider :
config . msg = this . splitDividerErrorText . replace ( '%1' , errData . get _Value ( ) ) ;
break ;
case Asc . c _oAscError . ID . VKeyEncrypt :
config . msg = this . errorKeyEncrypt ;
break ;
case Asc . c _oAscError . ID . KeyExpire :
config . msg = this . errorKeyExpire ;
break ;
case Asc . c _oAscError . ID . UserCountExceed :
config . msg = this . errorUsersExceed ;
break ;
case Asc . c _oAscError . ID . CoAuthoringDisconnect :
2019-01-09 13:42:35 +00:00
config . msg = this . errorViewerDisconnect ;
2016-11-21 11:13:27 +00:00
break ;
case Asc . c _oAscError . ID . ConvertationPassword :
config . msg = this . errorFilePassProtect ;
break ;
case Asc . c _oAscError . ID . StockChartError :
config . msg = this . errorStockChart ;
break ;
case Asc . c _oAscError . ID . DataRangeError :
config . msg = this . errorDataRange ;
break ;
case Asc . c _oAscError . ID . Database :
config . msg = this . errorDatabaseConnection ;
break ;
case Asc . c _oAscError . ID . UserDrop :
if ( this . _state . lostEditingRights ) {
this . _state . lostEditingRights = false ;
return ;
}
this . _state . lostEditingRights = true ;
config . msg = this . errorUserDrop ;
break ;
case Asc . c _oAscError . ID . Warning :
2019-11-01 14:43:24 +00:00
config . msg = this . errorConnectToServer ;
2016-11-21 11:13:27 +00:00
break ;
2017-04-11 11:05:56 +00:00
case Asc . c _oAscError . ID . UplImageUrl :
config . msg = this . errorBadImageUrl ;
break ;
2020-08-13 15:49:01 +00:00
case Asc . c _oAscError . ID . SessionAbsolute :
config . msg = this . errorSessionAbsolute ;
break ;
case Asc . c _oAscError . ID . SessionIdle :
config . msg = this . errorSessionIdle ;
break ;
case Asc . c _oAscError . ID . SessionToken :
config . msg = this . errorSessionToken ;
break ;
2018-06-28 10:16:35 +00:00
case Asc . c _oAscError . ID . DataEncrypted :
config . msg = this . errorDataEncrypted ;
break ;
2019-01-10 14:20:59 +00:00
case Asc . c _oAscError . ID . AccessDeny :
config . msg = this . errorAccessDeny ;
break ;
2019-02-15 13:43:42 +00:00
case Asc . c _oAscError . ID . EditingError :
config . msg = this . errorEditingDownloadas ;
break ;
2019-08-28 14:29:39 +00:00
case Asc . c _oAscError . ID . ConvertationOpenLimitError :
config . msg = this . errorFileSizeExceed ;
break ;
2019-11-13 11:14:41 +00:00
case Asc . c _oAscError . ID . UpdateVersion :
config . msg = this . errorUpdateVersionOnDisconnect ;
break ;
2016-11-21 11:13:27 +00:00
default :
config . msg = this . errorDefaultMessage . replace ( '%1' , id ) ;
break ;
}
if ( level == Asc . c _oAscError . Level . Critical ) {
// report only critical errors
Common . Gateway . reportError ( id , config . msg ) ;
config . title = this . criticalErrorTitle ;
// config.iconCls = 'error';
2018-02-07 09:21:10 +00:00
if ( this . appOptions . canBackToFolder && ! this . appOptions . isDesktopApp ) {
2016-11-21 11:13:27 +00:00
config . msg += '</br></br>' + this . criticalErrorExtText ;
config . callback = function ( ) {
2019-01-10 13:20:27 +00:00
Common . NotificationCenter . trigger ( 'goback' , true ) ;
2016-11-21 11:13:27 +00:00
}
}
2018-06-28 12:56:44 +00:00
if ( id == Asc . c _oAscError . ID . DataEncrypted ) {
this . api . asc _coAuthoringDisconnect ( ) ;
Common . NotificationCenter . trigger ( 'api:disconnect' ) ;
}
2016-11-21 11:13:27 +00:00
} else {
2017-10-07 09:20:39 +00:00
Common . Gateway . reportWarning ( id , config . msg ) ;
2016-11-21 11:13:27 +00:00
config . title = this . notcriticalErrorTitle ;
config . callback = _ . bind ( function ( btn ) {
if ( id == Asc . c _oAscError . ID . Warning && btn == 'ok' && ( this . appOptions . canDownload || this . appOptions . canDownloadOrigin ) ) {
Common . UI . Menu . Manager . hideAll ( ) ;
if ( this . appOptions . isDesktopApp && this . appOptions . isOffline )
this . api . asc _DownloadAs ( ) ;
else
( this . appOptions . canDownload ) ? this . getApplication ( ) . getController ( 'LeftMenu' ) . leftMenu . showMenu ( 'file:saveas' ) : this . api . asc _DownloadOrigin ( ) ;
}
this . _state . lostEditingRights = false ;
this . onEditComplete ( ) ;
} , this ) ;
}
uiApp . modal ( {
title : config . title ,
text : config . msg ,
buttons : [
{
text : 'OK' ,
onClick : config . callback
}
]
} ) ;
Common . component . Analytics . trackEvent ( 'Internal Error' , id . toString ( ) ) ;
} ,
onCoAuthoringDisconnect : function ( ) {
this . _state . isDisconnected = true ;
} ,
updateWindowTitle : function ( force ) {
var isModified = this . api . isDocumentModified ( ) ;
if ( this . _state . isDocModified !== isModified || force ) {
var title = this . defaultTitleText ;
if ( window . document . title != title )
window . document . title = title ;
2017-04-11 11:05:56 +00:00
Common . Gateway . setDocumentModified ( isModified ) ;
2016-11-21 11:13:27 +00:00
this . _state . isDocModified = isModified ;
}
} ,
onDocumentModifiedChanged : function ( ) {
var isModified = this . api . asc _isDocumentCanSave ( ) ;
if ( this . _state . isDocModified !== isModified ) {
Common . Gateway . setDocumentModified ( this . api . isDocumentModified ( ) ) ;
}
this . updateWindowTitle ( ) ;
} ,
onDocumentCanSaveChanged : function ( isCanSave ) {
//
} ,
onBeforeUnload : function ( ) {
Common . localStorage . save ( ) ;
if ( this . api . isDocumentModified ( ) ) {
var me = this ;
this . api . asc _stopSaving ( ) ;
this . continueSavingTimer = window . setTimeout ( function ( ) {
me . api . asc _continueSaving ( ) ;
} , 500 ) ;
return this . leavePageText ;
}
} ,
onUnload : function ( ) {
if ( this . continueSavingTimer )
clearTimeout ( this . continueSavingTimer ) ;
} ,
hidePreloader : function ( ) {
$ ( '#loading-mask' ) . hide ( ) . remove ( ) ;
} ,
onDownloadUrl : function ( url ) {
if ( this . _state . isFromGatewayDownloadAs ) {
Common . Gateway . downloadAs ( url ) ;
}
this . _state . isFromGatewayDownloadAs = false ;
} ,
onUpdateVersion : function ( callback ) {
var me = this ;
me . needToUpdateVersion = true ;
me . onLongActionEnd ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
uiApp . alert (
me . errorUpdateVersion ,
me . titleUpdateVersion ,
function ( ) {
_ . defer ( function ( ) {
Common . Gateway . updateVersion ( ) ;
if ( callback ) {
callback . call ( me ) ;
}
me . onLongActionBegin ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
} )
} ) ;
} ,
2017-04-11 11:05:56 +00:00
onServerVersion : function ( buildVersion ) {
var me = this ;
if ( me . changeServerVersion ) return true ;
if ( DocsAPI . DocEditor . version ( ) !== buildVersion && ! window . compareVersions ) {
me . changeServerVersion = true ;
uiApp . alert (
me . errorServerVersion ,
me . titleServerVersion ,
function ( ) {
_ . defer ( function ( ) {
Common . Gateway . updateVersion ( ) ;
} )
} ) ;
return true ;
}
return false ;
} ,
2016-11-21 11:13:27 +00:00
onCollaborativeChanges : function ( ) {
//
} ,
/** coauthoring end **/
initNames : function ( ) {
this . shapeGroupNames = [
this . txtBasicShapes ,
this . txtFiguredArrows ,
this . txtMath ,
this . txtCharts ,
this . txtStarsRibbons ,
this . txtCallouts ,
this . txtButtons ,
this . txtRectangles ,
this . txtLines
] ;
this . layoutNames = [
this . txtSldLtTBlank , this . txtSldLtTChart , this . txtSldLtTChartAndTx , this . txtSldLtTClipArtAndTx ,
this . txtSldLtTClipArtAndVertTx , this . txtSldLtTCust , this . txtSldLtTDgm , this . txtSldLtTFourObj ,
this . txtSldLtTMediaAndTx , this . txtSldLtTObj , this . txtSldLtTObjAndTwoObj , this . txtSldLtTObjAndTx ,
this . txtSldLtTObjOnly , this . txtSldLtTObjOverTx , this . txtSldLtTObjTx , this . txtSldLtTPicTx ,
this . txtSldLtTSecHead , this . txtSldLtTTbl , this . txtSldLtTTitle , this . txtSldLtTTitleOnly ,
this . txtSldLtTTwoColTx , this . txtSldLtTTwoObj , this . txtSldLtTTwoObjAndObj , this . txtSldLtTTwoObjAndTx ,
this . txtSldLtTTwoObjOverTx , this . txtSldLtTTwoTxTwoObj , this . txtSldLtTTx , this . txtSldLtTTxAndChart ,
this . txtSldLtTTxAndClipArt , this . txtSldLtTTxAndMedia , this . txtSldLtTTxAndObj ,
this . txtSldLtTTxAndTwoObj , this . txtSldLtTTxOverObj , this . txtSldLtTVertTitleAndTx ,
this . txtSldLtTVertTitleAndTxOverChart , this . txtSldLtTVertTx
] ;
} ,
updateThemeColors : function ( ) {
//
} ,
onSendThemeColors : function ( colors , standart _colors ) {
} ,
onFocusObject : function ( SelectedObjects ) {
// if (SelectedObjects.length>0) {
// var rightpan = this.getApplication().getController('RightMenu');
// // var docPreview = this.getApplication().getController('Viewport').getView('DocumentPreview');
// if (rightpan /*&& !docPreview.isVisible()*/) rightpan.onFocusObject.call(rightpan, SelectedObjects);
// }
} ,
_onChangeObjectLock : function ( ) {
var elements = this . api . getSelectedElements ( ) ;
this . onFocusObject ( elements ) ;
} ,
onThumbnailsShow : function ( isShow ) {
this . isThumbnailsShow = isShow ;
} ,
2019-07-25 07:14:45 +00:00
onAdvancedOptions : function ( type , advOptions ) {
2017-09-08 10:41:04 +00:00
if ( this . _state . openDlg ) return ;
2019-07-25 07:14:45 +00:00
var me = this ;
2016-11-21 11:13:27 +00:00
if ( type == Asc . c _oAscAdvancedOptionsID . DRM ) {
2017-09-08 09:06:17 +00:00
$ ( me . loadMask ) . hasClass ( 'modal-in' ) && uiApp . closeModal ( me . loadMask ) ;
me . onLongActionEnd ( Asc . c _oAscAsyncActionType . BlockInteraction , LoadingDocument ) ;
2018-05-25 08:32:48 +00:00
var buttons = [ {
text : 'OK' ,
bold : true ,
2020-11-30 21:38:33 +00:00
close : false ,
2018-05-25 08:32:48 +00:00
onClick : function ( ) {
2020-11-30 21:38:33 +00:00
if ( ! me . _state . openDlg ) return ;
$ ( me . _state . openDlg ) . hasClass ( 'modal-in' ) && uiApp . closeModal ( me . _state . openDlg ) ;
2018-05-25 08:32:48 +00:00
var password = $ ( me . _state . openDlg ) . find ( '.modal-text-input[name="modal-password"]' ) . val ( ) ;
me . api . asc _setAdvancedOptions ( type , new Asc . asc _CDRMAdvancedOptions ( password ) ) ;
if ( ! me . _isDocReady ) {
me . onLongActionBegin ( Asc . c _oAscAsyncActionType [ 'BlockInteraction' ] , LoadingDocument ) ;
}
me . _state . openDlg = null ;
}
} ] ;
if ( me . appOptions . canRequestClose )
buttons . push ( {
text : me . closeButtonText ,
onClick : function ( ) {
Common . Gateway . requestClose ( ) ;
me . _state . openDlg = null ;
}
} ) ;
2017-09-08 10:41:04 +00:00
me . _state . openDlg = uiApp . modal ( {
2016-11-21 11:13:27 +00:00
title : me . advDRMOptions ,
2018-04-27 13:05:38 +00:00
text : me . txtProtected ,
2016-11-21 11:13:27 +00:00
afterText : '<div class="input-field"><input type="password" name="modal-password" placeholder="' + me . advDRMPassword + '" class="modal-text-input"></div>' ,
2018-05-25 08:32:48 +00:00
buttons : buttons
2016-11-21 11:13:27 +00:00
} ) ;
2017-09-08 09:06:17 +00:00
// Vertical align
2017-09-08 10:41:04 +00:00
$$ ( me . _state . openDlg ) . css ( {
marginTop : - Math . round ( $$ ( me . _state . openDlg ) . outerHeight ( ) / 2 ) + 'px'
2017-09-08 09:06:17 +00:00
} ) ;
2016-11-21 11:13:27 +00:00
}
} ,
onTryUndoInFastCollaborative : function ( ) {
uiApp . alert (
this . textTryUndoRedo ,
this . notcriticalErrorTitle
) ;
} ,
onAuthParticipantsChanged : function ( users ) {
var length = 0 ;
_ . each ( users , function ( item ) {
if ( ! item . asc _getView ( ) )
length ++ ;
} ) ;
this . _state . usersCount = length ;
} ,
onDocumentName : function ( name ) {
// this.getApplication().getController('Viewport').getView('Common.Views.Header').setDocumentCaption(name);
this . updateWindowTitle ( true ) ;
} ,
onMeta : function ( meta ) {
// var app = this.getApplication(),
// filemenu = app.getController('LeftMenu').getView('LeftMenu').getMenu('file');
// app.getController('Viewport').getView('Common.Views.Header').setDocumentCaption(meta.title);
this . updateWindowTitle ( true ) ;
// this.document.title = meta.title;
// filemenu.loadDocument({doc:this.document});
// filemenu.panels['info'].updateInfo(this.document);
Common . Gateway . metaChange ( meta ) ;
} ,
onPrint : function ( ) {
if ( ! this . appOptions . canPrint ) return ;
if ( this . api )
2019-02-13 12:21:31 +00:00
this . api . asc _Print ( ) ;
2016-11-21 11:13:27 +00:00
Common . component . Analytics . trackEvent ( 'Print' ) ;
} ,
onPrintUrl : function ( url ) {
var me = this ;
if ( me . iframePrint ) {
me . iframePrint . parentNode . removeChild ( me . iframePrint ) ;
me . iframePrint = null ;
}
if ( ! me . iframePrint ) {
me . iframePrint = document . createElement ( "iframe" ) ;
me . iframePrint . id = "id-print-frame" ;
me . iframePrint . style . display = 'none' ;
me . iframePrint . style . visibility = "hidden" ;
me . iframePrint . style . position = "fixed" ;
me . iframePrint . style . right = "0" ;
me . iframePrint . style . bottom = "0" ;
document . body . appendChild ( me . iframePrint ) ;
me . iframePrint . onload = function ( ) {
me . iframePrint . contentWindow . focus ( ) ;
me . iframePrint . contentWindow . print ( ) ;
me . iframePrint . contentWindow . blur ( ) ;
window . focus ( ) ;
} ;
}
if ( url ) {
me . iframePrint . src = url ;
}
} ,
2018-06-22 10:22:57 +00:00
onContextMenu : function ( event ) {
var canCopyAttr = event . target . getAttribute ( 'data-can-copy' ) ,
isInputEl = ( event . target instanceof HTMLInputElement ) || ( event . target instanceof HTMLTextAreaElement ) ;
if ( ( isInputEl && canCopyAttr === 'false' ) ||
( ! isInputEl && canCopyAttr !== 'true' ) ) {
event . stopPropagation ( ) ;
event . preventDefault ( ) ;
return false ;
}
} ,
2020-02-10 06:49:58 +00:00
isSupportEditFeature : function ( ) {
return false ;
} ,
2020-05-22 15:38:03 +00:00
onRunAutostartMacroses : function ( ) {
2020-06-01 14:55:54 +00:00
var me = this ,
enable = ! this . editorConfig . customization || ( this . editorConfig . customization . macros !== false ) ;
if ( enable ) {
var value = Common . Utils . InternalSettings . get ( "pe-mobile-macros-mode" ) ;
if ( value == 1 )
this . api . asc _runAutostartMacroses ( ) ;
else if ( value === 0 ) {
uiApp . modal ( {
title : this . notcriticalErrorTitle ,
text : this . textHasMacros ,
afterText : '<label class="label-checkbox item-content no-ripple">' +
'<input type="checkbox" name="checkbox-show-macros">' +
'<div class="item-media" style="margin-top: 10px; display: flex; align-items: center;">' +
'<i class="icon icon-form-checkbox"></i><span style="margin-left: 10px;">' + this . textRemember + '</span>' +
'</div>' +
'</label>' ,
buttons : [ {
text : this . textYes ,
onClick : function ( ) {
var dontshow = $ ( 'input[name="checkbox-show-macros"]' ) . prop ( 'checked' ) ;
if ( dontshow ) {
Common . Utils . InternalSettings . set ( "pe-mobile-macros-mode" , 1 ) ;
Common . localStorage . setItem ( "pe-mobile-macros-mode" , 1 ) ;
}
setTimeout ( function ( ) {
me . api . asc _runAutostartMacroses ( ) ;
} , 1 ) ;
}
} ,
{
text : this . textNo ,
onClick : function ( ) {
var dontshow = $ ( 'input[name="checkbox-show-macros"]' ) . prop ( 'checked' ) ;
if ( dontshow ) {
Common . Utils . InternalSettings . set ( "pe-mobile-macros-mode" , 2 ) ;
Common . localStorage . setItem ( "pe-mobile-macros-mode" , 2 ) ;
}
}
} ]
} ) ;
}
}
2020-05-22 15:38:03 +00:00
} ,
2016-11-21 11:13:27 +00:00
// Translation
leavePageText : 'You have unsaved changes in this document. Click \'Stay on this Page\' to await the autosave of the document. Click \'Leave this Page\' to discard all the unsaved changes.' ,
criticalErrorTitle : 'Error' ,
notcriticalErrorTitle : 'Warning' ,
errorDefaultMessage : 'Error code: %1' ,
2019-04-29 11:42:58 +00:00
criticalErrorExtText : 'Press "OK" to to back to document list.' ,
2016-11-21 11:13:27 +00:00
openTitleText : 'Opening Document' ,
openTextText : 'Opening document...' ,
saveTitleText : 'Saving Document' ,
saveTextText : 'Saving document...' ,
loadFontsTitleText : 'Loading Data' ,
loadFontsTextText : 'Loading data...' ,
loadImagesTitleText : 'Loading Images' ,
loadImagesTextText : 'Loading images...' ,
loadFontTitleText : 'Loading Data' ,
loadFontTextText : 'Loading data...' ,
loadImageTitleText : 'Loading Image' ,
loadImageTextText : 'Loading image...' ,
downloadTitleText : 'Downloading Document' ,
downloadTextText : 'Downloading document...' ,
printTitleText : 'Printing Document' ,
printTextText : 'Printing document...' ,
uploadImageTitleText : 'Uploading Image' ,
uploadImageTextText : 'Uploading image...' ,
uploadImageSizeMessage : 'Maximium image size limit exceeded.' ,
uploadImageExtMessage : 'Unknown image format.' ,
uploadImageFileCountMessage : 'No images uploaded.' ,
reloadButtonText : 'Reload Page' ,
unknownErrorText : 'Unknown error.' ,
convertationTimeoutText : 'Convertation timeout exceeded.' ,
downloadErrorText : 'Download failed.' ,
2019-04-29 11:02:52 +00:00
unsupportedBrowserErrorText : 'Your browser is not supported.' ,
2016-11-21 11:13:27 +00:00
splitMaxRowsErrorText : 'The number of rows must be less than %1' ,
splitMaxColsErrorText : 'The number of columns must be less than %1' ,
splitDividerErrorText : 'The number of rows must be a divisor of %1' ,
requestEditFailedTitleText : 'Access denied' ,
requestEditFailedMessageText : 'Someone is editing this document right now. Please try again later.' ,
txtSldLtTBlank : 'Blank' ,
txtSldLtTChart : 'Chart' ,
txtSldLtTChartAndTx : 'Chart and Text' ,
txtSldLtTClipArtAndTx : 'Clip Art and Text' ,
txtSldLtTClipArtAndVertTx : 'Clip Art and Vertical Text' ,
txtSldLtTCust : 'Custom' ,
txtSldLtTDgm : 'Diagram' ,
txtSldLtTFourObj : 'Four Objects' ,
txtSldLtTMediaAndTx : 'Media and Text' ,
txtSldLtTObj : 'Title and Object' ,
txtSldLtTObjAndTwoObj : 'Object and Two Object' ,
txtSldLtTObjAndTx : 'Object and Text' ,
txtSldLtTObjOnly : 'Object' ,
txtSldLtTObjOverTx : 'Object over Text' ,
txtSldLtTObjTx : 'Title, Object, and Caption' ,
txtSldLtTPicTx : 'Picture and Caption' ,
txtSldLtTSecHead : 'Section Header' ,
txtSldLtTTbl : 'Table' ,
txtSldLtTTitle : 'Title' ,
txtSldLtTTitleOnly : 'Title Only' ,
txtSldLtTTwoColTx : 'Two Column Text' ,
txtSldLtTTwoObj : 'Two Objects' ,
txtSldLtTTwoObjAndObj : 'Two Objects and Object' ,
txtSldLtTTwoObjAndTx : 'Two Objects and Text' ,
txtSldLtTTwoObjOverTx : 'Two Objects over Text' ,
txtSldLtTTwoTxTwoObj : 'Two Text and Two Objects' ,
txtSldLtTTx : 'Text' ,
txtSldLtTTxAndChart : 'Text and Chart' ,
txtSldLtTTxAndClipArt : 'Text and Clip Art' ,
txtSldLtTTxAndMedia : 'Text and Media' ,
txtSldLtTTxAndObj : 'Text and Object' ,
txtSldLtTTxAndTwoObj : 'Text and Two Objects' ,
txtSldLtTTxOverObj : 'Text over Object' ,
txtSldLtTVertTitleAndTx : 'Vertical Title and Text' ,
txtSldLtTVertTitleAndTxOverChart : 'Vertical Title and Text Over Chart' ,
txtSldLtTVertTx : 'Vertical Text' ,
textLoadingDocument : 'Loading presentation' ,
loadThemeTitleText : 'Loading Theme' ,
loadThemeTextText : 'Loading theme...' ,
txtBasicShapes : 'Basic Shapes' ,
txtFiguredArrows : 'Figured Arrows' ,
txtMath : 'Math' ,
txtCharts : 'Charts' ,
txtStarsRibbons : 'Stars & Ribbons' ,
txtCallouts : 'Callouts' ,
txtButtons : 'Buttons' ,
txtRectangles : 'Rectangles' ,
txtLines : 'Lines' ,
errorKeyEncrypt : 'Unknown key descriptor' ,
errorKeyExpire : 'Key descriptor expired' ,
errorUsersExceed : 'Count of users was exceed' ,
txtEditingMode : 'Set editing mode...' ,
errorCoAuthoringDisconnect : 'Server connection lost. You can\'t edit anymore.' ,
2018-04-26 10:27:08 +00:00
errorFilePassProtect : 'The file is password protected and cannot be opened.' ,
2016-11-21 11:13:27 +00:00
textAnonymous : 'Anonymous' ,
txtNeedSynchronize : 'You have an updates' ,
applyChangesTitleText : 'Loading Data' ,
applyChangesTextText : 'Loading data...' ,
savePreparingText : 'Preparing to save' ,
savePreparingTitle : 'Preparing to save. Please wait...' ,
loadingDocumentTitleText : 'Loading presentation' ,
loadingDocumentTextText : 'Loading presentation...' ,
warnProcessRightsChange : 'You have been denied the right to edit the file.' ,
errorProcessSaveResult : 'Saving is failed.' ,
textCloseTip : '\nClick to close the tip.' ,
textShape : 'Shape' ,
errorStockChart : 'Incorrect row order. To build a stock chart place the data on the sheet in the following order:<br> opening price, max price, min price, closing price.' ,
errorDataRange : 'Incorrect data range.' ,
errorDatabaseConnection : 'External error.<br>Database connection error. Please, contact support.' ,
errorUpdateVersion : 'The file version has been changed. The page will be reloaded.' ,
errorUserDrop : 'The file cannot be accessed right now.' ,
txtDiagramTitle : 'Chart Title' ,
txtXAxis : 'X Axis' ,
txtYAxis : 'Y Axis' ,
txtSeries : 'Seria' ,
txtArt : 'Your text here' ,
2019-11-01 14:43:24 +00:00
errorConnectToServer : ' The document could not be saved. Please check connection settings or contact your administrator.<br>When you click the \'OK\' button, you will be prompted to download the document.' ,
2016-12-22 12:11:32 +00:00
textTryUndoRedo : 'The Undo/Redo functions are disabled for the Fast co-editing mode.' ,
2016-11-21 11:13:27 +00:00
textBuyNow : 'Visit website' ,
2020-07-14 09:46:15 +00:00
textNoLicenseTitle : 'License limit reached' ,
2016-11-21 11:13:27 +00:00
textContactUs : 'Contact sales' ,
2019-10-30 14:27:57 +00:00
errorViewerDisconnect : 'Connection is lost. You can still view the document,<br>but will not be able to download until the connection is restored and page is reloaded.' ,
2016-11-21 11:13:27 +00:00
warnLicenseExp : 'Your license has expired.<br>Please update your license and refresh the page.' ,
titleLicenseExp : 'License expired' ,
openErrorText : 'An error has occurred while opening the file' ,
saveErrorText : 'An error has occurred while saving the file' ,
advDRMOptions : 'Protected File' ,
advDRMEnterPassword : 'You password please:' ,
2017-01-23 14:38:53 +00:00
advDRMPassword : 'Password' ,
textOK : 'OK' ,
textCancel : 'Cancel' ,
textPreloader : 'Loading... ' ,
textUsername : 'Username' ,
textPassword : 'Password' ,
textBack : 'Back' ,
textClose : 'Close' ,
2017-04-11 11:05:56 +00:00
textDone : 'Done' ,
titleServerVersion : 'Editor updated' ,
errorServerVersion : 'The editor version has been updated. The page will be reloaded to apply the changes.' ,
2017-06-23 13:49:29 +00:00
errorBadImageUrl : 'Image url is incorrect' ,
txtSlideText : 'Slide text' ,
txtClipArt : 'Clip Art' ,
2017-06-27 10:49:39 +00:00
txtDiagram : 'SmartArt' ,
2017-06-23 13:49:29 +00:00
txtDateTime : 'Date and time' ,
txtFooter : 'Footer' ,
txtHeader : 'Header' ,
txtMedia : 'Media' ,
txtPicture : 'Picture' ,
txtImage : 'Image' ,
txtSlideNumber : 'Slide number' ,
txtSlideSubtitle : 'Slide subtitle' ,
2017-11-23 09:01:27 +00:00
txtSlideTitle : 'Slide title' ,
2018-05-28 10:00:03 +00:00
txtProtected : 'Once you enter the password and open the file, the current password to the file will be reset' ,
2020-07-14 09:46:15 +00:00
warnNoLicense : "You've reached the limit for simultaneous connections to %1 editors. This document will be opened for viewing only.<br>Contact %1 sales team for personal upgrade terms." ,
warnNoLicenseUsers : "You've reached the user limit for %1 editors. Contact %1 sales team for personal upgrade terms." ,
warnLicenseExceeded : "You've reached the limit for simultaneous connections to %1 editors. This document will be opened for viewing only.<br>Contact your administrator to learn more." ,
warnLicenseUsersExceeded : "You've reached the user limit for %1 editors. Contact your administrator to learn more." ,
2018-07-18 07:03:33 +00:00
errorDataEncrypted : 'Encrypted changes have been received, they cannot be deciphered.' ,
2018-10-08 14:06:37 +00:00
closeButtonText : 'Close File' ,
2019-01-10 14:20:59 +00:00
scriptLoadError : 'The connection is too slow, some of the components could not be loaded. Please reload the page.' ,
2019-02-15 13:43:42 +00:00
errorAccessDeny : 'You are trying to perform an action you do not have rights for.<br>Please contact your Document Server administrator.' ,
2019-03-15 10:30:01 +00:00
errorEditingDownloadas : 'An error occurred during the work with the document.<br>Use the \'Download\' option to save the file backup copy to your computer hard drive.' ,
textPaidFeature : 'Paid feature' ,
2019-05-08 11:52:35 +00:00
textCustomLoader : 'Please note that according to the terms of the license you are not entitled to change the loader.<br>Please contact our Sales Department to get a quote.' ,
2019-08-28 14:29:39 +00:00
waitText : 'Please, wait...' ,
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.' ,
2020-02-10 06:49:58 +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.' ,
2020-07-28 19:15:23 +00:00
errorOpensource : 'Using the free Community version you can open documents for viewing only. To access mobile web editors, a commercial license is required.' ,
2020-06-01 14:55:54 +00:00
textHasMacros : 'The file contains automatic macros.<br>Do you want to run macros?' ,
textRemember : 'Remember my choice' ,
textYes : 'Yes' ,
2020-08-13 15:49:01 +00:00
textNo : 'No' ,
errorSessionAbsolute : 'The document editing session has expired. Please reload the page.' ,
errorSessionIdle : 'The document has not been edited for quite a long time. Please reload the page.' ,
2020-11-09 11:52:21 +00:00
errorSessionToken : 'The connection to the server has been interrupted. Please reload the page.' ,
warnLicenseLimitedRenewed : 'License needs to be renewed.<br>You have a limited access to document editing functionality.<br>Please contact your administrator to get full access' ,
2020-12-25 20:56:00 +00:00
warnLicenseLimitedNoAccess : 'License expired.<br>You have no access to document editing functionality.<br>Please contact your administrator.' ,
txtAddFirstSlide : 'Click to add first slide'
2016-03-11 00:48:53 +00:00
}
2016-11-21 11:13:27 +00:00
} ) ( ) , PE . Controllers . Main || { } ) )
2016-03-11 00:48:53 +00:00
} ) ;