WYSIWYG is an HTML editor for easy content editing. WYSIWYG enables adding and formatting the content providing “What You See Is What You Get ” view. Preview the end result in the editing phase itself and thus avoid handling HTML tags! Interesting, isn’t it?
However, the default Magento 2 does not offer WYSIWYG editor in the system configuration. Admin may want to display messages in a certain manner in frontend. The WYSIWYG editor makes the task simpler.
To overcome the default Magento 2 limitation, implement the below method to add WYSIWYG editor in Magento 2 system configuration.
Method to Add WYSIWYG Editor in Magento 2 System Configuration:
- Add below code in the system.xml file
<field id="description" translate="label comment" type="editor" sortOrder="20" showInDefault="1" showInWebsite="1" showInStore="1"> <label>Description </label> <frontend_model>Vendor\Extension\Block\Adminhtml\Editor</frontend_model> </field>
- Create new file Editor.php at Vendor\Extension\Block\Adminhtml folder
<?php namespace Vendor\Extension\Block\Adminhtml; use Magento\Backend\Block\Template\Context; use Magento\Cms\Model\Wysiwyg\Config as WysiwygConfig; class Editor extends \Magento\Config\Block\System\Config\Form\Field { public function __construct( Context $context, WysiwygConfig $wysiwygConfig, array $data = [] ) { $this->_wysiwygConfig = $wysiwygConfig; parent::__construct($context, $data); } protected function _getElementHtml(\Magento\Framework\Data\Form\Element\AbstractElement $element) { $element->setWysiwyg(true); $element->setConfig($this->_wysiwygConfig->getConfig($element)); return parent::_getElementHtml($element); } }
That’s all about WYSIWYG editor in system configuration for Magento 2!
Once you implement this solution, please refer our blog Add WYSIWYG Editor in Magento 2 System Configuration
Thank you.