Files
DocumentServer-v-9.2.0/web-apps/apps/common/main/lib/component/MonacoEditor.js
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

193 lines
6.6 KiB
JavaScript

/*
* (c) Copyright Ascensio System SIA 2010-2024
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
* street, Riga, Latvia, EU, LV-1050.
*
* 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
*
*/
if (Common === undefined)
var Common = {};
define([], function () {
'use strict';
Common.UI.MonacoEditor = Common.UI.BaseView.extend({
initialize : function(options) {
Common.UI.BaseView.prototype.initialize.call(this, options);
this.id = _.uniqueId();
this.parentEl = options.parentEl;
this.language = options.language || 'javascript';
this.parentEl && this.render(this.parentEl);
},
render: function (parentEl) {
this.parentEl = typeof parentEl === 'string' ? $(parentEl) : parentEl;
this.iframe = document.createElement("iframe");
this.iframe.width = '100%';
this.iframe.height = '100%';
this.iframe.align = "top";
this.iframe.frameBorder = 0;
this.iframe.scrolling = "no";
this.iframe.onload = _.bind(this._onLoad,this);
this.parentEl.append(this.iframe);
this.loadMask = new Common.UI.LoadMask({owner: this.parentEl});
this.loadMask.show();
var src = '../../../vendor/monaco/MonacoEditor.html';
src += '?editorType=' + (window.SSE ? 'cell' : window.PE ? 'slide' : 'word');
src += '&language=' + this.language;
src += '&id=' + this.id;
this.iframe.src = src;
var me = this;
this._eventfunc = function(msg) {
me._onMessage(msg);
};
this._updatebind = function() {
me.updateTheme();
};
this._bindWindowEvents.call(this);
},
_bindWindowEvents: function() {
if (window.addEventListener) {
window.addEventListener("message", this._eventfunc, false)
} else if (window.attachEvent) {
window.attachEvent("onmessage", this._eventfunc);
}
Common.NotificationCenter.on('uitheme:changed', this._updatebind);
},
_unbindWindowEvents: function() {
if (window.removeEventListener) {
window.removeEventListener("message", this._eventfunc)
} else if (window.detachEvent) {
window.detachEvent("onmessage", this._eventfunc);
}
Common.NotificationCenter.off('uitheme:changed', this._updatebind);
},
_postMessage: function(wnd, msg) {
if (wnd && wnd.postMessage && window.JSON) {
msg.referer = 'monaco-editor-' + this.id;
wnd.postMessage(window.JSON.stringify(msg), "*");
}
},
_onMessage: function(msg) {
var data = msg.data;
if (Object.prototype.toString.apply(data) !== '[object String]' || !window.JSON) {
return;
}
var cmd, handler;
try {
cmd = window.JSON.parse(data)
} catch(e) {
cmd = '';
}
if (cmd && cmd.referer == 'monaco-editor-' + this.id) {
switch (cmd.command) {
case 'changeValue':
data = cmd.data || {};
this.fireEvent('change', data.value, data.pos);
break;
case 'monacoEditorReady':
this.fireEvent('ready', cmd.data);
break;
}
}
},
_onLoad: function() {
this.updateTheme();
if (this.loadMask)
this.loadMask.hide();
},
setValue: function(value, currentPos, readonly) {
this._postMessage(this.iframe.contentWindow, {
command: 'setValue',
data: {
value: value,
readonly: readonly,
currentPos: currentPos
}
});
},
updateTheme: function() {
this._postMessage(this.iframe.contentWindow, {
command: 'setTheme',
data: Common.UI.Themes.getThemeColors()
});
},
disableDrop: function(disable) {
this._postMessage(this.iframe.contentWindow, {
command: 'disableDrop',
data: disable
});
},
revealPositionInCenter: function() {
this._postMessage(this.iframe.contentWindow, {
command: 'revealPositionInCenter',
data: {}
});
},
undo: function() {
this._postMessage(this.iframe.contentWindow, {
command: 'undo',
data: {}
});
},
redo: function() {
this._postMessage(this.iframe.contentWindow, {
command: 'redo',
data: {}
});
},
enablePointerEvents: function(enable) {
this.iframe && (this.iframe.style.pointerEvents = enable ? "" : "none");
},
destroyEditor: function() {
this._unbindWindowEvents();
}
});
});