/* * (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(); } }); });