devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
91 lines (86 loc) • 3.06 kB
JavaScript
/**
* DevExtreme (cjs/ui/html_editor/formats/mention.js)
* Version: 21.1.4
* Build date: Mon Jun 21 2021
*
* Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
;
exports.default = void 0;
var _devextremeQuill = _interopRequireDefault(require("devextreme-quill"));
var _renderer = _interopRequireDefault(require("../../../core/renderer"));
function _interopRequireDefault(obj) {
return obj && obj.__esModule ? obj : {
default: obj
}
}
function _inheritsLoose(subClass, superClass) {
subClass.prototype = Object.create(superClass.prototype);
subClass.prototype.constructor = subClass;
_setPrototypeOf(subClass, superClass)
}
function _setPrototypeOf(o, p) {
_setPrototypeOf = Object.setPrototypeOf || function(o, p) {
o.__proto__ = p;
return o
};
return _setPrototypeOf(o, p)
}
var Mention = {};
if (_devextremeQuill.default) {
var Embed = _devextremeQuill.default.import("blots/embed");
var MENTION_CLASS = "dx-mention";
Mention = function(_Embed) {
_inheritsLoose(Mention, _Embed);
function Mention() {
return _Embed.apply(this, arguments) || this
}
Mention.create = function(data) {
var node = _Embed.create.call(this);
node.setAttribute("spellcheck", false);
node.dataset.marker = data.marker;
node.dataset.mentionValue = data.value;
node.dataset.id = data.id;
this.renderContent(node, data);
return node
};
Mention.value = function(node) {
return {
marker: node.dataset.marker,
id: node.dataset.id,
value: node.dataset.mentionValue
}
};
Mention.renderContent = function(node, data) {
var template = this._templates.get(data.marker);
if (template) {
template.render({
model: data,
container: node
})
} else {
this.baseContentRender(node, data)
}
};
Mention.baseContentRender = function(node, data) {
var $marker = (0, _renderer.default)("<span>").text(data.marker);
(0, _renderer.default)(node).append($marker).append(data.value)
};
Mention.addTemplate = function(marker, template) {
this._templates.set(marker, template)
};
Mention.removeTemplate = function(marker) {
this._templates.delete(marker)
};
return Mention
}(Embed);
Mention.blotName = "mention";
Mention.tagName = "span";
Mention.className = MENTION_CLASS;
Mention._templates = new Map
}
var _default = Mention;
exports.default = _default;
module.exports = exports.default;
module.exports.default = exports.default;