suneditor
Version:
Vanilla JavaScript based WYSIWYG web editor
92 lines (78 loc) • 2.3 kB
JavaScript
import { PluginDropdown } from '../../interfaces';
import { dom } from '../../helper';
/**
* @typedef {Object} TemplatePluginOptions
* @property {Array<{name: string, html: string}>} [items] - Template list
* ```js
* [{ name: 'Greeting', html: '<p>Hello! Thank you for contacting us.</p>' }]
* ```
*/
/**
* @class
* @description Template Plugin, Apply a template to the selection.
*/
class Template extends PluginDropdown {
static key = 'template';
static className = '';
/**
* @constructor
* @param {SunEditor.Kernel} kernel - The Kernel instance
* @param {TemplatePluginOptions} pluginOptions - Plugin options
*/
constructor(kernel, pluginOptions) {
// plugin bisic properties
super(kernel);
this.title = this.$.lang.template;
this.icon = 'template';
// members
this.selectedIndex = -1;
this.items = pluginOptions.items;
// create HTML
const menu = CreateHTML(this.items);
// init
this.$.menu.initDropdownTarget(Template, menu);
}
/**
* @override
* @type {PluginDropdown['action']}
*/
action(target) {
const index = Number(target.getAttribute('data-value'));
const temp = this.items[(this.selectedIndex = index)];
if (temp.html) {
this.$.html.insert(temp.html, { selectInserted: false, skipCharCount: false, skipCleaning: false });
} else {
this.$.menu.dropdownOff();
throw Error('[SUNEDITOR.template.fail] cause : "templates[i].html not found"');
}
this.$.menu.dropdownOff();
}
}
/**
* @param {Array<{name: string, html: string}>} templateList - Template items
* @returns {HTMLElement}
*/
function CreateHTML(templateList) {
if (!templateList || templateList.length === 0) {
console.warn('[SUNEDITOR.plugins.template.warn] To use the "template" plugin, please define the "templates" option.');
}
let list = '<div class="se-dropdown se-list-inner"><ul class="se-list-basic">';
for (let i = 0, len = (templateList || []).length, t; i < len; i++) {
t = templateList[i];
list += /*html*/ `
<li>
<button
type="button"
class="se-btn se-btn-list"
data-value="${i}"
title="${t.name}"
aria-label="${t.name}"
>
${t.name}
</button>
</li>`;
}
list += '</ul></div>';
return dom.utils.createElement('DIV', { class: 'se-list-layer' }, list);
}
export default Template;