first commit
This commit is contained in:
		
							
								
								
									
										159
									
								
								media/plg_editors_none/js/joomla-editor-none.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								media/plg_editors_none/js/joomla-editor-none.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,159 @@ | ||||
| import { JoomlaEditor, JoomlaEditorDecorator } from 'editor-api'; | ||||
|  | ||||
| /** | ||||
|  * @copyright  (C) 2018 Open Source Matters, Inc. <https://www.joomla.org> | ||||
|  * @license    GNU General Public License version 2 or later; see LICENSE.txt | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  * EditorNone Decorator for Joomla.Editor | ||||
|  */ | ||||
| // eslint-disable-next-line max-classes-per-file | ||||
| class EditorNoneDecorator extends JoomlaEditorDecorator { | ||||
|   /** | ||||
|    * @returns {string} | ||||
|    */ | ||||
|   getValue() { | ||||
|     return this.instance.getValue(); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * @param {string} value | ||||
|    * @returns {EditorNoneDecorator} | ||||
|    */ | ||||
|   setValue(value) { | ||||
|     this.instance.setValue(value); | ||||
|     return this; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * @returns {string} | ||||
|    */ | ||||
|   getSelection() { | ||||
|     return this.instance.getSelection(); | ||||
|   } | ||||
|   replaceSelection(value) { | ||||
|     this.instance.replaceSelection(value); | ||||
|     return this; | ||||
|   } | ||||
|   disable(enable) { | ||||
|     if (this.instance.editor) { | ||||
|       this.instance.editor.disabled = !enable; | ||||
|       this.instance.editor.readOnly = !enable; | ||||
|     } | ||||
|     return this; | ||||
|   } | ||||
| } | ||||
| class JoomlaEditorNone extends HTMLElement { | ||||
|   constructor() { | ||||
|     super(); | ||||
|  | ||||
|     // Properties | ||||
|     this.editor = ''; | ||||
|  | ||||
|     // Bindings | ||||
|     this.unregisterEditor = this.unregisterEditor.bind(this); | ||||
|     this.registerEditor = this.registerEditor.bind(this); | ||||
|     this.childrenChange = this.childrenChange.bind(this); | ||||
|     this.getSelection = this.getSelection.bind(this); | ||||
|  | ||||
|     // Watch for children changes. | ||||
|     // eslint-disable-next-line no-return-assign | ||||
|     new MutationObserver(() => this.childrenChange()).observe(this, { | ||||
|       childList: true | ||||
|     }); | ||||
|  | ||||
|     // Find out when editor is interacted | ||||
|     this.interactionCallback = () => { | ||||
|       if (this.editor) { | ||||
|         JoomlaEditor.setActive(this.editor.id); | ||||
|       } | ||||
|     }; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Lifecycle | ||||
|    */ | ||||
|   connectedCallback() { | ||||
|     // Note the mutation observer won't fire for initial contents, | ||||
|     // so childrenChange is also called here. | ||||
|     this.childrenChange(); | ||||
|     this.addEventListener('click', this.interactionCallback); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Lifecycle | ||||
|    */ | ||||
|   disconnectedCallback() { | ||||
|     this.unregisterEditor(); | ||||
|     this.removeEventListener('click', this.interactionCallback); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Get editor value | ||||
|    */ | ||||
|   getValue() { | ||||
|     return this.editor.value; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Set editor value | ||||
|    * @param {string} text | ||||
|    */ | ||||
|   setValue(text) { | ||||
|     this.editor.value = text; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Get the selected text | ||||
|    */ | ||||
|   getSelection() { | ||||
|     if (this.editor.selectionStart || this.editor.selectionStart === 0) { | ||||
|       return this.editor.value.substring(this.editor.selectionStart, this.editor.selectionEnd); | ||||
|     } | ||||
|     return this.editor.value; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Replace selected text | ||||
|    * @param {string} text | ||||
|    */ | ||||
|   replaceSelection(text) { | ||||
|     const ed = this.editor; | ||||
|     if (ed.selectionStart || ed.selectionStart === 0) { | ||||
|       ed.value = ed.value.substring(0, ed.selectionStart) + text + ed.value.substring(ed.selectionEnd, ed.value.length); | ||||
|     } else { | ||||
|       ed.value += text; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Register the editor | ||||
|    */ | ||||
|   registerEditor() { | ||||
|     const jEditor = new EditorNoneDecorator(this, 'none', this.editor.id); | ||||
|     JoomlaEditor.register(jEditor); | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Remove the editor from the Joomla API | ||||
|    */ | ||||
|   unregisterEditor() { | ||||
|     if (this.editor) { | ||||
|       JoomlaEditor.unregister(this.editor.id); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Called when element's child list changes | ||||
|    */ | ||||
|   childrenChange() { | ||||
|     // Ensure the first child is an input with a textarea type. | ||||
|     if (this.firstElementChild && this.firstElementChild.tagName && this.firstElementChild.tagName.toLowerCase() === 'textarea' && this.firstElementChild.getAttribute('id')) { | ||||
|       this.editor = this.firstElementChild; | ||||
|       this.unregisterEditor(); | ||||
|       this.registerEditor(); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| customElements.define('joomla-editor-none', JoomlaEditorNone); | ||||
		Reference in New Issue
	
	Block a user