diff --git a/apps/spreadsheeteditor/mobile/src/app.js b/apps/spreadsheeteditor/mobile/src/app.js index ff8dd9ae5..923799f29 100644 --- a/apps/spreadsheeteditor/mobile/src/app.js +++ b/apps/spreadsheeteditor/mobile/src/app.js @@ -36,9 +36,7 @@ Framework7.use(Framework7React); ReactDOM.render( - - - + , document.getElementById('app'), diff --git a/apps/spreadsheeteditor/mobile/src/controller/ContextMenu.jsx b/apps/spreadsheeteditor/mobile/src/controller/ContextMenu.jsx index a229b1b05..d152f875d 100644 --- a/apps/spreadsheeteditor/mobile/src/controller/ContextMenu.jsx +++ b/apps/spreadsheeteditor/mobile/src/controller/ContextMenu.jsx @@ -44,9 +44,11 @@ class ContextMenu extends ContextMenuController { super.componentWillUnmount(); const api = Common.EditorApi.get(); - api.asc_unregisterCallback('asc_onShowComment', this.onApiShowComment); - api.asc_unregisterCallback('asc_onHideComment', this.onApiHideComment); - api.asc_unregisterCallback('asc_onMouseMove', this.onApiMouseMove); + if ( api ) { + api.asc_unregisterCallback('asc_onShowComment', this.onApiShowComment); + api.asc_unregisterCallback('asc_onHideComment', this.onApiHideComment); + api.asc_unregisterCallback('asc_onMouseMove', this.onApiMouseMove); + } } diff --git a/apps/spreadsheeteditor/mobile/src/controller/Error.jsx b/apps/spreadsheeteditor/mobile/src/controller/Error.jsx index 7447d436a..bc4927c27 100644 --- a/apps/spreadsheeteditor/mobile/src/controller/Error.jsx +++ b/apps/spreadsheeteditor/mobile/src/controller/Error.jsx @@ -13,7 +13,7 @@ const ErrorController = inject('storeAppOptions')(({storeAppOptions, LoadingDocu }); return () => { const api = Common.EditorApi.get(); - api.asc_unregisterCallback('asc_onError', onError); + if ( api ) api.asc_unregisterCallback('asc_onError', onError); } }); diff --git a/apps/spreadsheeteditor/mobile/src/controller/FilterOptions.jsx b/apps/spreadsheeteditor/mobile/src/controller/FilterOptions.jsx index 1a214d32c..7c5b5a33d 100644 --- a/apps/spreadsheeteditor/mobile/src/controller/FilterOptions.jsx +++ b/apps/spreadsheeteditor/mobile/src/controller/FilterOptions.jsx @@ -19,7 +19,7 @@ const FilterOptionsController = () => { api.asc_registerCallback('asc_onSetAFDialog',onApiFilterOptions); } - if ( !Common.EditorApi ) { + if ( !Common.EditorApi.get() ) { Common.Notifications.on('document:ready',onDocumentReady); } else { onDocumentReady(); @@ -28,7 +28,9 @@ const FilterOptionsController = () => { return () => { Common.Notifications.off('document:ready', onDocumentReady); const api = Common.EditorApi.get(); - api.asc_unregisterCallback('asc_onSetAFDialog',onApiFilterOptions); + if ( api ) { + api.asc_unregisterCallback('asc_onSetAFDialog', onApiFilterOptions); + } } }, []); diff --git a/apps/spreadsheeteditor/mobile/src/controller/LongActions.jsx b/apps/spreadsheeteditor/mobile/src/controller/LongActions.jsx index 34d2f7d8f..9124ca9fe 100644 --- a/apps/spreadsheeteditor/mobile/src/controller/LongActions.jsx +++ b/apps/spreadsheeteditor/mobile/src/controller/LongActions.jsx @@ -36,10 +36,12 @@ const LongActionsController = () => { return ( () => { const api = Common.EditorApi.get(); - api.asc_unregisterCallback('asc_onStartAction', onLongActionBegin); - api.asc_unregisterCallback('asc_onEndAction', onLongActionEnd); - api.asc_unregisterCallback('asc_onOpenDocumentProgress', onOpenDocument); - api.asc_unregisterCallback('asc_onConfirmAction', onConfirmAction); + if ( api ) { + api.asc_unregisterCallback('asc_onStartAction', onLongActionBegin); + api.asc_unregisterCallback('asc_onEndAction', onLongActionEnd); + api.asc_unregisterCallback('asc_onOpenDocumentProgress', onOpenDocument); + api.asc_unregisterCallback('asc_onConfirmAction', onConfirmAction); + } Common.Notifications.off('preloader:endAction', onLongActionEnd); Common.Notifications.off('preloader:beginAction', onLongActionBegin); diff --git a/apps/spreadsheeteditor/mobile/src/controller/Main.jsx b/apps/spreadsheeteditor/mobile/src/controller/Main.jsx index 44adf3d14..e025854b2 100644 --- a/apps/spreadsheeteditor/mobile/src/controller/Main.jsx +++ b/apps/spreadsheeteditor/mobile/src/controller/Main.jsx @@ -20,6 +20,7 @@ import About from "../../../../common/mobile/lib/view/About"; import PluginsController from '../../../../common/mobile/lib/controller/Plugins.jsx'; import EncodingController from "./Encoding"; import { StatusbarController } from "./Statusbar"; +import { useTranslation } from 'react-i18next'; @inject( "users", @@ -281,7 +282,6 @@ class MainController extends Component { }); Common.Notifications.trigger('engineCreated', this.api); - Common.EditorApi = {get: () => this.api}; this.appOptions = {}; this.bindEvents(); @@ -507,8 +507,10 @@ class MainController extends Component { } applyLicense () { - const _t = this._t; - const warnNoLicense = _t.warnNoLicense.replace(/%1/g, __COMPANY_NAME__); + const { t } = this.props; + const _t = t('Controller.Main', {returnObjects:true}); + + const warnNoLicense = _t.warnNoLicense.replace(/%1/g, __COMPANY_NAME__); const warnNoLicenseUsers = _t.warnNoLicenseUsers.replace(/%1/g, __COMPANY_NAME__); const textNoLicenseTitle = _t.textNoLicenseTitle.replace(/%1/g, __COMPANY_NAME__); const warnLicenseExceeded = _t.warnLicenseExceeded.replace(/%1/g, __COMPANY_NAME__); @@ -851,6 +853,7 @@ class MainController extends Component { } componentDidMount() { + Common.EditorApi = {get: () => this.api}; this.initSdk(); } } diff --git a/apps/spreadsheeteditor/mobile/src/index_dev.html b/apps/spreadsheeteditor/mobile/src/index_dev.html index 18a92b021..43603bf9e 100644 --- a/apps/spreadsheeteditor/mobile/src/index_dev.html +++ b/apps/spreadsheeteditor/mobile/src/index_dev.html @@ -22,17 +22,28 @@ - - + + + +
+
+