import { createCKEditor } from 'External/CKEditor.js'; const htmlre = /[&<>"']/g, htmlmap = { '&': '&', '<': '<', '>': '>', '"': '"', "'": ''' }; /** * @param {string} text * @returns {string} */ export function encodeHtml(text) { return (text && text.toString ? text.toString() : ''+text).replace(htmlre, m => htmlmap[m]); } class HtmlEditor { editor; blurTimer = 0; __resizable = false; __inited = false; onBlur = null; onReady = null; onModeChange = null; element; resize; /** * @param {Object} element * @param {Function=} onBlur * @param {Function=} onReady * @param {Function=} onModeChange */ constructor(element, onBlur = null, onReady = null, onModeChange = null) { this.onBlur = onBlur; this.onReady = onReady; this.onModeChange = onModeChange; this.element = element; this.resize = (() => { try { this.editor && this.__resizable && this.editor.resize(element.clientWidth, element.clientHeight); } catch (e) {} // eslint-disable-line no-empty }).throttle(100); this.init(); } blurTrigger() { if (this.onBlur) { clearTimeout(this.blurTimer); this.blurTimer = setTimeout(() => this.onBlur && this.onBlur(), 200); } } /** * @returns {boolean} */ isHtml() { return this.editor ? 'plain' !== this.editor.mode : false; } /** * @returns {void} */ clearCachedSignature() { this.editor && this.editor.execCommand('insertSignature', { clearCache: true }); } /** * @param {string} signature * @param {bool} html * @param {bool} insertBefore * @returns {void} */ setSignature(signature, html, insertBefore = false) { this.editor && this.editor.execCommand('insertSignature', { isHtml: html, insertBefore: insertBefore, signature: signature }); } /** * @param {boolean=} wrapIsHtml = false * @returns {string} */ getData(wrapIsHtml = false) { let result = ''; if (this.editor) { try { if ('plain' === this.editor.mode && this.editor.plugins.plain && this.editor.__plain) { result = this.editor.__plain.getRawData(); } else { result = wrapIsHtml ? '
' + this.editor.getData() + '
' : this.editor.getData(); } } catch (e) {} // eslint-disable-line no-empty } return result; } /** * @param {boolean=} wrapIsHtml = false * @returns {string} */ getDataWithHtmlMark(wrapIsHtml = false) { return (this.isHtml() ? ':HTML:' : '') + this.getData(wrapIsHtml); } modeToggle(plain) { if (this.editor) { try { if (plain) { if ('plain' === this.editor.mode) { this.editor.setMode('wysiwyg'); } } else if ('wysiwyg' === this.editor.mode) { this.editor.setMode('plain'); } } catch (e) {} // eslint-disable-line no-empty } } setHtmlOrPlain(text, focus) { if (':HTML:' === text.substr(0, 6)) { this.setHtml(text.substr(6), focus); } else { this.setPlain(text, focus); } } setHtml(html, focus) { if (this.editor && this.__inited) { this.clearCachedSignature(); this.modeToggle(true); html = html.replace(/]*><\/p>/gi, ''); try { this.editor.setData(html); } catch (e) {} // eslint-disable-line no-empty focus && this.focus(); } } setPlain(plain, focus) { if (this.editor && this.__inited) { this.clearCachedSignature(); this.modeToggle(false); if ('plain' === this.editor.mode && this.editor.plugins.plain && this.editor.__plain) { this.editor.__plain.setRawData(plain); } else { try { this.editor.setData(plain); } catch (e) {} // eslint-disable-line no-empty } focus && this.focus(); } } init() { if (this.element && !this.editor) { const onReady = () => { if (this.editor.removeMenuItem) { this.editor.removeMenuItem('cut'); this.editor.removeMenuItem('copy'); this.editor.removeMenuItem('paste'); } this.__resizable = true; this.__inited = true; this.resize(); this.onReady && this.onReady(); }; if (window.CKEDITOR) { this.editor = createCKEditor(this.element); this.editor.on('instanceReady', onReady); } else { this.editor = new SquireUI(this.element, this.editor); setTimeout(onReady,1); } if (this.editor) { this.editor.on('blur', () => this.blurTrigger()); this.editor.on('focus', () => this.blurTimer && clearTimeout(this.blurTimer)); this.editor.on('mode', () => { this.blurTrigger(); this.onModeChange && this.onModeChange('plain' !== this.editor.mode); }); } } } focus() { try { this.editor && this.editor.focus(); } catch (e) {} // eslint-disable-line no-empty } hasFocus() { try { return this.editor && !!this.editor.focusManager.hasFocus; } catch (e) { return false; } } blur() { try { this.editor && this.editor.focusManager.blur(true); } catch (e) {} // eslint-disable-line no-empty } clear(focus) { this.setHtml('', focus); } } export { HtmlEditor, HtmlEditor as default };