Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
package.dist.toastui-editor.js Maven / Gradle / Ivy
/*!
* @toast-ui/editor
* @version 3.2.0 | Fri Aug 05 2022
* @author NHN Cloud FE Development Lab
* @license MIT
*/
(function webpackUniversalModuleDefinition(root, factory) {
if(typeof exports === 'object' && typeof module === 'object')
module.exports = factory(require("prosemirror-commands"), require("prosemirror-history"), require("prosemirror-inputrules"), require("prosemirror-keymap"), require("prosemirror-model"), require("prosemirror-state"), require("prosemirror-transform"), require("prosemirror-view"));
else if(typeof define === 'function' && define.amd)
define(["prosemirror-commands", "prosemirror-history", "prosemirror-inputrules", "prosemirror-keymap", "prosemirror-model", "prosemirror-state", "prosemirror-transform", "prosemirror-view"], factory);
else if(typeof exports === 'object')
exports["toastui"] = factory(require("prosemirror-commands"), require("prosemirror-history"), require("prosemirror-inputrules"), require("prosemirror-keymap"), require("prosemirror-model"), require("prosemirror-state"), require("prosemirror-transform"), require("prosemirror-view"));
else
root["toastui"] = root["toastui"] || {}, root["toastui"]["Editor"] = factory(root[undefined], root[undefined], root[undefined], root[undefined], root[undefined], root[undefined], root[undefined], root[undefined]);
})(self, function(__WEBPACK_EXTERNAL_MODULE__695__, __WEBPACK_EXTERNAL_MODULE__412__, __WEBPACK_EXTERNAL_MODULE__479__, __WEBPACK_EXTERNAL_MODULE__481__, __WEBPACK_EXTERNAL_MODULE__43__, __WEBPACK_EXTERNAL_MODULE__814__, __WEBPACK_EXTERNAL_MODULE__785__, __WEBPACK_EXTERNAL_MODULE__311__) {
return /******/ (function() { // webpackBootstrap
/******/ var __webpack_modules__ = ({
/***/ 368:
/***/ (function(module) {
/*! @license DOMPurify 2.3.3 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/2.3.3/LICENSE */
(function (global, factory) {
true ? module.exports = factory() :
0;
}(this, function () { 'use strict';
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
var hasOwnProperty = Object.hasOwnProperty,
setPrototypeOf = Object.setPrototypeOf,
isFrozen = Object.isFrozen,
getPrototypeOf = Object.getPrototypeOf,
getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;
var freeze = Object.freeze,
seal = Object.seal,
create = Object.create; // eslint-disable-line import/no-mutable-exports
var _ref = typeof Reflect !== 'undefined' && Reflect,
apply = _ref.apply,
construct = _ref.construct;
if (!apply) {
apply = function apply(fun, thisValue, args) {
return fun.apply(thisValue, args);
};
}
if (!freeze) {
freeze = function freeze(x) {
return x;
};
}
if (!seal) {
seal = function seal(x) {
return x;
};
}
if (!construct) {
construct = function construct(Func, args) {
return new (Function.prototype.bind.apply(Func, [null].concat(_toConsumableArray(args))))();
};
}
var arrayForEach = unapply(Array.prototype.forEach);
var arrayPop = unapply(Array.prototype.pop);
var arrayPush = unapply(Array.prototype.push);
var stringToLowerCase = unapply(String.prototype.toLowerCase);
var stringMatch = unapply(String.prototype.match);
var stringReplace = unapply(String.prototype.replace);
var stringIndexOf = unapply(String.prototype.indexOf);
var stringTrim = unapply(String.prototype.trim);
var regExpTest = unapply(RegExp.prototype.test);
var typeErrorCreate = unconstruct(TypeError);
function unapply(func) {
return function (thisArg) {
for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
args[_key - 1] = arguments[_key];
}
return apply(func, thisArg, args);
};
}
function unconstruct(func) {
return function () {
for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
args[_key2] = arguments[_key2];
}
return construct(func, args);
};
}
/* Add properties to a lookup table */
function addToSet(set, array) {
if (setPrototypeOf) {
// Make 'in' and truthy checks like Boolean(set.constructor)
// independent of any properties defined on Object.prototype.
// Prevent prototype setters from intercepting set as a this value.
setPrototypeOf(set, null);
}
var l = array.length;
while (l--) {
var element = array[l];
if (typeof element === 'string') {
var lcElement = stringToLowerCase(element);
if (lcElement !== element) {
// Config presets (e.g. tags.js, attrs.js) are immutable.
if (!isFrozen(array)) {
array[l] = lcElement;
}
element = lcElement;
}
}
set[element] = true;
}
return set;
}
/* Shallow clone an object */
function clone(object) {
var newObject = create(null);
var property = void 0;
for (property in object) {
if (apply(hasOwnProperty, object, [property])) {
newObject[property] = object[property];
}
}
return newObject;
}
/* IE10 doesn't support __lookupGetter__ so lets'
* simulate it. It also automatically checks
* if the prop is function or getter and behaves
* accordingly. */
function lookupGetter(object, prop) {
while (object !== null) {
var desc = getOwnPropertyDescriptor(object, prop);
if (desc) {
if (desc.get) {
return unapply(desc.get);
}
if (typeof desc.value === 'function') {
return unapply(desc.value);
}
}
object = getPrototypeOf(object);
}
function fallbackValue(element) {
console.warn('fallback value for', element);
return null;
}
return fallbackValue;
}
var html = freeze(['a', 'abbr', 'acronym', 'address', 'area', 'article', 'aside', 'audio', 'b', 'bdi', 'bdo', 'big', 'blink', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'center', 'cite', 'code', 'col', 'colgroup', 'content', 'data', 'datalist', 'dd', 'decorator', 'del', 'details', 'dfn', 'dialog', 'dir', 'div', 'dl', 'dt', 'element', 'em', 'fieldset', 'figcaption', 'figure', 'font', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'img', 'input', 'ins', 'kbd', 'label', 'legend', 'li', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meter', 'nav', 'nobr', 'ol', 'optgroup', 'option', 'output', 'p', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'section', 'select', 'shadow', 'small', 'source', 'spacer', 'span', 'strike', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'template', 'textarea', 'tfoot', 'th', 'thead', 'time', 'tr', 'track', 'tt', 'u', 'ul', 'var', 'video', 'wbr']);
// SVG
var svg = freeze(['svg', 'a', 'altglyph', 'altglyphdef', 'altglyphitem', 'animatecolor', 'animatemotion', 'animatetransform', 'circle', 'clippath', 'defs', 'desc', 'ellipse', 'filter', 'font', 'g', 'glyph', 'glyphref', 'hkern', 'image', 'line', 'lineargradient', 'marker', 'mask', 'metadata', 'mpath', 'path', 'pattern', 'polygon', 'polyline', 'radialgradient', 'rect', 'stop', 'style', 'switch', 'symbol', 'text', 'textpath', 'title', 'tref', 'tspan', 'view', 'vkern']);
var svgFilters = freeze(['feBlend', 'feColorMatrix', 'feComponentTransfer', 'feComposite', 'feConvolveMatrix', 'feDiffuseLighting', 'feDisplacementMap', 'feDistantLight', 'feFlood', 'feFuncA', 'feFuncB', 'feFuncG', 'feFuncR', 'feGaussianBlur', 'feMerge', 'feMergeNode', 'feMorphology', 'feOffset', 'fePointLight', 'feSpecularLighting', 'feSpotLight', 'feTile', 'feTurbulence']);
// List of SVG elements that are disallowed by default.
// We still need to know them so that we can do namespace
// checks properly in case one wants to add them to
// allow-list.
var svgDisallowed = freeze(['animate', 'color-profile', 'cursor', 'discard', 'fedropshadow', 'feimage', 'font-face', 'font-face-format', 'font-face-name', 'font-face-src', 'font-face-uri', 'foreignobject', 'hatch', 'hatchpath', 'mesh', 'meshgradient', 'meshpatch', 'meshrow', 'missing-glyph', 'script', 'set', 'solidcolor', 'unknown', 'use']);
var mathMl = freeze(['math', 'menclose', 'merror', 'mfenced', 'mfrac', 'mglyph', 'mi', 'mlabeledtr', 'mmultiscripts', 'mn', 'mo', 'mover', 'mpadded', 'mphantom', 'mroot', 'mrow', 'ms', 'mspace', 'msqrt', 'mstyle', 'msub', 'msup', 'msubsup', 'mtable', 'mtd', 'mtext', 'mtr', 'munder', 'munderover']);
// Similarly to SVG, we want to know all MathML elements,
// even those that we disallow by default.
var mathMlDisallowed = freeze(['maction', 'maligngroup', 'malignmark', 'mlongdiv', 'mscarries', 'mscarry', 'msgroup', 'mstack', 'msline', 'msrow', 'semantics', 'annotation', 'annotation-xml', 'mprescripts', 'none']);
var text = freeze(['#text']);
var html$1 = freeze(['accept', 'action', 'align', 'alt', 'autocapitalize', 'autocomplete', 'autopictureinpicture', 'autoplay', 'background', 'bgcolor', 'border', 'capture', 'cellpadding', 'cellspacing', 'checked', 'cite', 'class', 'clear', 'color', 'cols', 'colspan', 'controls', 'controlslist', 'coords', 'crossorigin', 'datetime', 'decoding', 'default', 'dir', 'disabled', 'disablepictureinpicture', 'disableremoteplayback', 'download', 'draggable', 'enctype', 'enterkeyhint', 'face', 'for', 'headers', 'height', 'hidden', 'high', 'href', 'hreflang', 'id', 'inputmode', 'integrity', 'ismap', 'kind', 'label', 'lang', 'list', 'loading', 'loop', 'low', 'max', 'maxlength', 'media', 'method', 'min', 'minlength', 'multiple', 'muted', 'name', 'noshade', 'novalidate', 'nowrap', 'open', 'optimum', 'pattern', 'placeholder', 'playsinline', 'poster', 'preload', 'pubdate', 'radiogroup', 'readonly', 'rel', 'required', 'rev', 'reversed', 'role', 'rows', 'rowspan', 'spellcheck', 'scope', 'selected', 'shape', 'size', 'sizes', 'span', 'srclang', 'start', 'src', 'srcset', 'step', 'style', 'summary', 'tabindex', 'title', 'translate', 'type', 'usemap', 'valign', 'value', 'width', 'xmlns', 'slot']);
var svg$1 = freeze(['accent-height', 'accumulate', 'additive', 'alignment-baseline', 'ascent', 'attributename', 'attributetype', 'azimuth', 'basefrequency', 'baseline-shift', 'begin', 'bias', 'by', 'class', 'clip', 'clippathunits', 'clip-path', 'clip-rule', 'color', 'color-interpolation', 'color-interpolation-filters', 'color-profile', 'color-rendering', 'cx', 'cy', 'd', 'dx', 'dy', 'diffuseconstant', 'direction', 'display', 'divisor', 'dur', 'edgemode', 'elevation', 'end', 'fill', 'fill-opacity', 'fill-rule', 'filter', 'filterunits', 'flood-color', 'flood-opacity', 'font-family', 'font-size', 'font-size-adjust', 'font-stretch', 'font-style', 'font-variant', 'font-weight', 'fx', 'fy', 'g1', 'g2', 'glyph-name', 'glyphref', 'gradientunits', 'gradienttransform', 'height', 'href', 'id', 'image-rendering', 'in', 'in2', 'k', 'k1', 'k2', 'k3', 'k4', 'kerning', 'keypoints', 'keysplines', 'keytimes', 'lang', 'lengthadjust', 'letter-spacing', 'kernelmatrix', 'kernelunitlength', 'lighting-color', 'local', 'marker-end', 'marker-mid', 'marker-start', 'markerheight', 'markerunits', 'markerwidth', 'maskcontentunits', 'maskunits', 'max', 'mask', 'media', 'method', 'mode', 'min', 'name', 'numoctaves', 'offset', 'operator', 'opacity', 'order', 'orient', 'orientation', 'origin', 'overflow', 'paint-order', 'path', 'pathlength', 'patterncontentunits', 'patterntransform', 'patternunits', 'points', 'preservealpha', 'preserveaspectratio', 'primitiveunits', 'r', 'rx', 'ry', 'radius', 'refx', 'refy', 'repeatcount', 'repeatdur', 'restart', 'result', 'rotate', 'scale', 'seed', 'shape-rendering', 'specularconstant', 'specularexponent', 'spreadmethod', 'startoffset', 'stddeviation', 'stitchtiles', 'stop-color', 'stop-opacity', 'stroke-dasharray', 'stroke-dashoffset', 'stroke-linecap', 'stroke-linejoin', 'stroke-miterlimit', 'stroke-opacity', 'stroke', 'stroke-width', 'style', 'surfacescale', 'systemlanguage', 'tabindex', 'targetx', 'targety', 'transform', 'text-anchor', 'text-decoration', 'text-rendering', 'textlength', 'type', 'u1', 'u2', 'unicode', 'values', 'viewbox', 'visibility', 'version', 'vert-adv-y', 'vert-origin-x', 'vert-origin-y', 'width', 'word-spacing', 'wrap', 'writing-mode', 'xchannelselector', 'ychannelselector', 'x', 'x1', 'x2', 'xmlns', 'y', 'y1', 'y2', 'z', 'zoomandpan']);
var mathMl$1 = freeze(['accent', 'accentunder', 'align', 'bevelled', 'close', 'columnsalign', 'columnlines', 'columnspan', 'denomalign', 'depth', 'dir', 'display', 'displaystyle', 'encoding', 'fence', 'frame', 'height', 'href', 'id', 'largeop', 'length', 'linethickness', 'lspace', 'lquote', 'mathbackground', 'mathcolor', 'mathsize', 'mathvariant', 'maxsize', 'minsize', 'movablelimits', 'notation', 'numalign', 'open', 'rowalign', 'rowlines', 'rowspacing', 'rowspan', 'rspace', 'rquote', 'scriptlevel', 'scriptminsize', 'scriptsizemultiplier', 'selection', 'separator', 'separators', 'stretchy', 'subscriptshift', 'supscriptshift', 'symmetric', 'voffset', 'width', 'xmlns']);
var xml = freeze(['xlink:href', 'xml:id', 'xlink:title', 'xml:space', 'xmlns:xlink']);
// eslint-disable-next-line unicorn/better-regex
var MUSTACHE_EXPR = seal(/\{\{[\s\S]*|[\s\S]*\}\}/gm); // Specify template detection regex for SAFE_FOR_TEMPLATES mode
var ERB_EXPR = seal(/<%[\s\S]*|[\s\S]*%>/gm);
var DATA_ATTR = seal(/^data-[\-\w.\u00B7-\uFFFF]/); // eslint-disable-line no-useless-escape
var ARIA_ATTR = seal(/^aria-[\-\w]+$/); // eslint-disable-line no-useless-escape
var IS_ALLOWED_URI = seal(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i // eslint-disable-line no-useless-escape
);
var IS_SCRIPT_OR_DATA = seal(/^(?:\w+script|data):/i);
var ATTR_WHITESPACE = seal(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g // eslint-disable-line no-control-regex
);
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
function _toConsumableArray$1(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
var getGlobal = function getGlobal() {
return typeof window === 'undefined' ? null : window;
};
/**
* Creates a no-op policy for internal use only.
* Don't export this function outside this module!
* @param {?TrustedTypePolicyFactory} trustedTypes The policy factory.
* @param {Document} document The document object (to determine policy name suffix)
* @return {?TrustedTypePolicy} The policy created (or null, if Trusted Types
* are not supported).
*/
var _createTrustedTypesPolicy = function _createTrustedTypesPolicy(trustedTypes, document) {
if ((typeof trustedTypes === 'undefined' ? 'undefined' : _typeof(trustedTypes)) !== 'object' || typeof trustedTypes.createPolicy !== 'function') {
return null;
}
// Allow the callers to control the unique policy name
// by adding a data-tt-policy-suffix to the script element with the DOMPurify.
// Policy creation with duplicate names throws in Trusted Types.
var suffix = null;
var ATTR_NAME = 'data-tt-policy-suffix';
if (document.currentScript && document.currentScript.hasAttribute(ATTR_NAME)) {
suffix = document.currentScript.getAttribute(ATTR_NAME);
}
var policyName = 'dompurify' + (suffix ? '#' + suffix : '');
try {
return trustedTypes.createPolicy(policyName, {
createHTML: function createHTML(html$$1) {
return html$$1;
}
});
} catch (_) {
// Policy creation failed (most likely another DOMPurify script has
// already run). Skip creating the policy, as this will only cause errors
// if TT are enforced.
console.warn('TrustedTypes policy ' + policyName + ' could not be created.');
return null;
}
};
function createDOMPurify() {
var window = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getGlobal();
var DOMPurify = function DOMPurify(root) {
return createDOMPurify(root);
};
/**
* Version label, exposed for easier checks
* if DOMPurify is up to date or not
*/
DOMPurify.version = '2.3.3';
/**
* Array of elements that DOMPurify removed during sanitation.
* Empty if nothing was removed.
*/
DOMPurify.removed = [];
if (!window || !window.document || window.document.nodeType !== 9) {
// Not running in a browser, provide a factory function
// so that you can pass your own Window
DOMPurify.isSupported = false;
return DOMPurify;
}
var originalDocument = window.document;
var document = window.document;
var DocumentFragment = window.DocumentFragment,
HTMLTemplateElement = window.HTMLTemplateElement,
Node = window.Node,
Element = window.Element,
NodeFilter = window.NodeFilter,
_window$NamedNodeMap = window.NamedNodeMap,
NamedNodeMap = _window$NamedNodeMap === undefined ? window.NamedNodeMap || window.MozNamedAttrMap : _window$NamedNodeMap,
Text = window.Text,
Comment = window.Comment,
DOMParser = window.DOMParser,
trustedTypes = window.trustedTypes;
var ElementPrototype = Element.prototype;
var cloneNode = lookupGetter(ElementPrototype, 'cloneNode');
var getNextSibling = lookupGetter(ElementPrototype, 'nextSibling');
var getChildNodes = lookupGetter(ElementPrototype, 'childNodes');
var getParentNode = lookupGetter(ElementPrototype, 'parentNode');
// As per issue #47, the web-components registry is inherited by a
// new document created via createHTMLDocument. As per the spec
// (http://w3c.github.io/webcomponents/spec/custom/#creating-and-passing-registries)
// a new empty registry is used when creating a template contents owner
// document, so we use that as our parent document to ensure nothing
// is inherited.
if (typeof HTMLTemplateElement === 'function') {
var template = document.createElement('template');
if (template.content && template.content.ownerDocument) {
document = template.content.ownerDocument;
}
}
var trustedTypesPolicy = _createTrustedTypesPolicy(trustedTypes, originalDocument);
var emptyHTML = trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML('') : '';
var _document = document,
implementation = _document.implementation,
createNodeIterator = _document.createNodeIterator,
createDocumentFragment = _document.createDocumentFragment,
getElementsByTagName = _document.getElementsByTagName;
var importNode = originalDocument.importNode;
var documentMode = {};
try {
documentMode = clone(document).documentMode ? document.documentMode : {};
} catch (_) {}
var hooks = {};
/**
* Expose whether this browser supports running the full DOMPurify.
*/
DOMPurify.isSupported = typeof getParentNode === 'function' && implementation && typeof implementation.createHTMLDocument !== 'undefined' && documentMode !== 9;
var MUSTACHE_EXPR$$1 = MUSTACHE_EXPR,
ERB_EXPR$$1 = ERB_EXPR,
DATA_ATTR$$1 = DATA_ATTR,
ARIA_ATTR$$1 = ARIA_ATTR,
IS_SCRIPT_OR_DATA$$1 = IS_SCRIPT_OR_DATA,
ATTR_WHITESPACE$$1 = ATTR_WHITESPACE;
var IS_ALLOWED_URI$$1 = IS_ALLOWED_URI;
/**
* We consider the elements and attributes below to be safe. Ideally
* don't add any new ones but feel free to remove unwanted ones.
*/
/* allowed element names */
var ALLOWED_TAGS = null;
var DEFAULT_ALLOWED_TAGS = addToSet({}, [].concat(_toConsumableArray$1(html), _toConsumableArray$1(svg), _toConsumableArray$1(svgFilters), _toConsumableArray$1(mathMl), _toConsumableArray$1(text)));
/* Allowed attribute names */
var ALLOWED_ATTR = null;
var DEFAULT_ALLOWED_ATTR = addToSet({}, [].concat(_toConsumableArray$1(html$1), _toConsumableArray$1(svg$1), _toConsumableArray$1(mathMl$1), _toConsumableArray$1(xml)));
/* Explicitly forbidden tags (overrides ALLOWED_TAGS/ADD_TAGS) */
var FORBID_TAGS = null;
/* Explicitly forbidden attributes (overrides ALLOWED_ATTR/ADD_ATTR) */
var FORBID_ATTR = null;
/* Decide if ARIA attributes are okay */
var ALLOW_ARIA_ATTR = true;
/* Decide if custom data attributes are okay */
var ALLOW_DATA_ATTR = true;
/* Decide if unknown protocols are okay */
var ALLOW_UNKNOWN_PROTOCOLS = false;
/* Output should be safe for common template engines.
* This means, DOMPurify removes data attributes, mustaches and ERB
*/
var SAFE_FOR_TEMPLATES = false;
/* Decide if document with ... should be returned */
var WHOLE_DOCUMENT = false;
/* Track whether config is already set on this instance of DOMPurify. */
var SET_CONFIG = false;
/* Decide if all elements (e.g. style, script) must be children of
* document.body. By default, browsers might move them to document.head */
var FORCE_BODY = false;
/* Decide if a DOM `HTMLBodyElement` should be returned, instead of a html
* string (or a TrustedHTML object if Trusted Types are supported).
* If `WHOLE_DOCUMENT` is enabled a `HTMLHtmlElement` will be returned instead
*/
var RETURN_DOM = false;
/* Decide if a DOM `DocumentFragment` should be returned, instead of a html
* string (or a TrustedHTML object if Trusted Types are supported) */
var RETURN_DOM_FRAGMENT = false;
/* If `RETURN_DOM` or `RETURN_DOM_FRAGMENT` is enabled, decide if the returned DOM
* `Node` is imported into the current `Document`. If this flag is not enabled the
* `Node` will belong (its ownerDocument) to a fresh `HTMLDocument`, created by
* DOMPurify.
*
* This defaults to `true` starting DOMPurify 2.2.0. Note that setting it to `false`
* might cause XSS from attacks hidden in closed shadowroots in case the browser
* supports Declarative Shadow: DOM https://web.dev/declarative-shadow-dom/
*/
var RETURN_DOM_IMPORT = true;
/* Try to return a Trusted Type object instead of a string, return a string in
* case Trusted Types are not supported */
var RETURN_TRUSTED_TYPE = false;
/* Output should be free from DOM clobbering attacks? */
var SANITIZE_DOM = true;
/* Keep element content when removing element? */
var KEEP_CONTENT = true;
/* If a `Node` is passed to sanitize(), then performs sanitization in-place instead
* of importing it into a new Document and returning a sanitized copy */
var IN_PLACE = false;
/* Allow usage of profiles like html, svg and mathMl */
var USE_PROFILES = {};
/* Tags to ignore content of when KEEP_CONTENT is true */
var FORBID_CONTENTS = null;
var DEFAULT_FORBID_CONTENTS = addToSet({}, ['annotation-xml', 'audio', 'colgroup', 'desc', 'foreignobject', 'head', 'iframe', 'math', 'mi', 'mn', 'mo', 'ms', 'mtext', 'noembed', 'noframes', 'noscript', 'plaintext', 'script', 'style', 'svg', 'template', 'thead', 'title', 'video', 'xmp']);
/* Tags that are safe for data: URIs */
var DATA_URI_TAGS = null;
var DEFAULT_DATA_URI_TAGS = addToSet({}, ['audio', 'video', 'img', 'source', 'image', 'track']);
/* Attributes safe for values like "javascript:" */
var URI_SAFE_ATTRIBUTES = null;
var DEFAULT_URI_SAFE_ATTRIBUTES = addToSet({}, ['alt', 'class', 'for', 'id', 'label', 'name', 'pattern', 'placeholder', 'role', 'summary', 'title', 'value', 'style', 'xmlns']);
var MATHML_NAMESPACE = 'http://www.w3.org/1998/Math/MathML';
var SVG_NAMESPACE = 'http://www.w3.org/2000/svg';
var HTML_NAMESPACE = 'http://www.w3.org/1999/xhtml';
/* Document namespace */
var NAMESPACE = HTML_NAMESPACE;
var IS_EMPTY_INPUT = false;
/* Parsing of strict XHTML documents */
var PARSER_MEDIA_TYPE = void 0;
var SUPPORTED_PARSER_MEDIA_TYPES = ['application/xhtml+xml', 'text/html'];
var DEFAULT_PARSER_MEDIA_TYPE = 'text/html';
var transformCaseFunc = void 0;
/* Keep a reference to config to pass to hooks */
var CONFIG = null;
/* Ideally, do not touch anything below this line */
/* ______________________________________________ */
var formElement = document.createElement('form');
/**
* _parseConfig
*
* @param {Object} cfg optional config literal
*/
// eslint-disable-next-line complexity
var _parseConfig = function _parseConfig(cfg) {
if (CONFIG && CONFIG === cfg) {
return;
}
/* Shield configuration object from tampering */
if (!cfg || (typeof cfg === 'undefined' ? 'undefined' : _typeof(cfg)) !== 'object') {
cfg = {};
}
/* Shield configuration object from prototype pollution */
cfg = clone(cfg);
/* Set configuration parameters */
ALLOWED_TAGS = 'ALLOWED_TAGS' in cfg ? addToSet({}, cfg.ALLOWED_TAGS) : DEFAULT_ALLOWED_TAGS;
ALLOWED_ATTR = 'ALLOWED_ATTR' in cfg ? addToSet({}, cfg.ALLOWED_ATTR) : DEFAULT_ALLOWED_ATTR;
URI_SAFE_ATTRIBUTES = 'ADD_URI_SAFE_ATTR' in cfg ? addToSet(clone(DEFAULT_URI_SAFE_ATTRIBUTES), cfg.ADD_URI_SAFE_ATTR) : DEFAULT_URI_SAFE_ATTRIBUTES;
DATA_URI_TAGS = 'ADD_DATA_URI_TAGS' in cfg ? addToSet(clone(DEFAULT_DATA_URI_TAGS), cfg.ADD_DATA_URI_TAGS) : DEFAULT_DATA_URI_TAGS;
FORBID_CONTENTS = 'FORBID_CONTENTS' in cfg ? addToSet({}, cfg.FORBID_CONTENTS) : DEFAULT_FORBID_CONTENTS;
FORBID_TAGS = 'FORBID_TAGS' in cfg ? addToSet({}, cfg.FORBID_TAGS) : {};
FORBID_ATTR = 'FORBID_ATTR' in cfg ? addToSet({}, cfg.FORBID_ATTR) : {};
USE_PROFILES = 'USE_PROFILES' in cfg ? cfg.USE_PROFILES : false;
ALLOW_ARIA_ATTR = cfg.ALLOW_ARIA_ATTR !== false; // Default true
ALLOW_DATA_ATTR = cfg.ALLOW_DATA_ATTR !== false; // Default true
ALLOW_UNKNOWN_PROTOCOLS = cfg.ALLOW_UNKNOWN_PROTOCOLS || false; // Default false
SAFE_FOR_TEMPLATES = cfg.SAFE_FOR_TEMPLATES || false; // Default false
WHOLE_DOCUMENT = cfg.WHOLE_DOCUMENT || false; // Default false
RETURN_DOM = cfg.RETURN_DOM || false; // Default false
RETURN_DOM_FRAGMENT = cfg.RETURN_DOM_FRAGMENT || false; // Default false
RETURN_DOM_IMPORT = cfg.RETURN_DOM_IMPORT !== false; // Default true
RETURN_TRUSTED_TYPE = cfg.RETURN_TRUSTED_TYPE || false; // Default false
FORCE_BODY = cfg.FORCE_BODY || false; // Default false
SANITIZE_DOM = cfg.SANITIZE_DOM !== false; // Default true
KEEP_CONTENT = cfg.KEEP_CONTENT !== false; // Default true
IN_PLACE = cfg.IN_PLACE || false; // Default false
IS_ALLOWED_URI$$1 = cfg.ALLOWED_URI_REGEXP || IS_ALLOWED_URI$$1;
NAMESPACE = cfg.NAMESPACE || HTML_NAMESPACE;
PARSER_MEDIA_TYPE =
// eslint-disable-next-line unicorn/prefer-includes
SUPPORTED_PARSER_MEDIA_TYPES.indexOf(cfg.PARSER_MEDIA_TYPE) === -1 ? PARSER_MEDIA_TYPE = DEFAULT_PARSER_MEDIA_TYPE : PARSER_MEDIA_TYPE = cfg.PARSER_MEDIA_TYPE;
// HTML tags and attributes are not case-sensitive, converting to lowercase. Keeping XHTML as is.
transformCaseFunc = PARSER_MEDIA_TYPE === 'application/xhtml+xml' ? function (x) {
return x;
} : stringToLowerCase;
if (SAFE_FOR_TEMPLATES) {
ALLOW_DATA_ATTR = false;
}
if (RETURN_DOM_FRAGMENT) {
RETURN_DOM = true;
}
/* Parse profile info */
if (USE_PROFILES) {
ALLOWED_TAGS = addToSet({}, [].concat(_toConsumableArray$1(text)));
ALLOWED_ATTR = [];
if (USE_PROFILES.html === true) {
addToSet(ALLOWED_TAGS, html);
addToSet(ALLOWED_ATTR, html$1);
}
if (USE_PROFILES.svg === true) {
addToSet(ALLOWED_TAGS, svg);
addToSet(ALLOWED_ATTR, svg$1);
addToSet(ALLOWED_ATTR, xml);
}
if (USE_PROFILES.svgFilters === true) {
addToSet(ALLOWED_TAGS, svgFilters);
addToSet(ALLOWED_ATTR, svg$1);
addToSet(ALLOWED_ATTR, xml);
}
if (USE_PROFILES.mathMl === true) {
addToSet(ALLOWED_TAGS, mathMl);
addToSet(ALLOWED_ATTR, mathMl$1);
addToSet(ALLOWED_ATTR, xml);
}
}
/* Merge configuration parameters */
if (cfg.ADD_TAGS) {
if (ALLOWED_TAGS === DEFAULT_ALLOWED_TAGS) {
ALLOWED_TAGS = clone(ALLOWED_TAGS);
}
addToSet(ALLOWED_TAGS, cfg.ADD_TAGS);
}
if (cfg.ADD_ATTR) {
if (ALLOWED_ATTR === DEFAULT_ALLOWED_ATTR) {
ALLOWED_ATTR = clone(ALLOWED_ATTR);
}
addToSet(ALLOWED_ATTR, cfg.ADD_ATTR);
}
if (cfg.ADD_URI_SAFE_ATTR) {
addToSet(URI_SAFE_ATTRIBUTES, cfg.ADD_URI_SAFE_ATTR);
}
if (cfg.FORBID_CONTENTS) {
if (FORBID_CONTENTS === DEFAULT_FORBID_CONTENTS) {
FORBID_CONTENTS = clone(FORBID_CONTENTS);
}
addToSet(FORBID_CONTENTS, cfg.FORBID_CONTENTS);
}
/* Add #text in case KEEP_CONTENT is set to true */
if (KEEP_CONTENT) {
ALLOWED_TAGS['#text'] = true;
}
/* Add html, head and body to ALLOWED_TAGS in case WHOLE_DOCUMENT is true */
if (WHOLE_DOCUMENT) {
addToSet(ALLOWED_TAGS, ['html', 'head', 'body']);
}
/* Add tbody to ALLOWED_TAGS in case tables are permitted, see #286, #365 */
if (ALLOWED_TAGS.table) {
addToSet(ALLOWED_TAGS, ['tbody']);
delete FORBID_TAGS.tbody;
}
// Prevent further manipulation of configuration.
// Not available in IE8, Safari 5, etc.
if (freeze) {
freeze(cfg);
}
CONFIG = cfg;
};
var MATHML_TEXT_INTEGRATION_POINTS = addToSet({}, ['mi', 'mo', 'mn', 'ms', 'mtext']);
var HTML_INTEGRATION_POINTS = addToSet({}, ['foreignobject', 'desc', 'title', 'annotation-xml']);
/* Keep track of all possible SVG and MathML tags
* so that we can perform the namespace checks
* correctly. */
var ALL_SVG_TAGS = addToSet({}, svg);
addToSet(ALL_SVG_TAGS, svgFilters);
addToSet(ALL_SVG_TAGS, svgDisallowed);
var ALL_MATHML_TAGS = addToSet({}, mathMl);
addToSet(ALL_MATHML_TAGS, mathMlDisallowed);
/**
*
*
* @param {Element} element a DOM element whose namespace is being checked
* @returns {boolean} Return false if the element has a
* namespace that a spec-compliant parser would never
* return. Return true otherwise.
*/
var _checkValidNamespace = function _checkValidNamespace(element) {
var parent = getParentNode(element);
// In JSDOM, if we're inside shadow DOM, then parentNode
// can be null. We just simulate parent in this case.
if (!parent || !parent.tagName) {
parent = {
namespaceURI: HTML_NAMESPACE,
tagName: 'template'
};
}
var tagName = stringToLowerCase(element.tagName);
var parentTagName = stringToLowerCase(parent.tagName);
if (element.namespaceURI === SVG_NAMESPACE) {
// The only way to switch from HTML namespace to SVG
// is via . If it happens via any other tag, then
// it should be killed.
if (parent.namespaceURI === HTML_NAMESPACE) {
return tagName === 'svg';
}
// The only way to switch from MathML to SVG is via
// svg if parent is either or MathML
// text integration points.
if (parent.namespaceURI === MATHML_NAMESPACE) {
return tagName === 'svg' && (parentTagName === 'annotation-xml' || MATHML_TEXT_INTEGRATION_POINTS[parentTagName]);
}
// We only allow elements that are defined in SVG
// spec. All others are disallowed in SVG namespace.
return Boolean(ALL_SVG_TAGS[tagName]);
}
if (element.namespaceURI === MATHML_NAMESPACE) {
// The only way to switch from HTML namespace to MathML
// is via . If it happens via any other tag, then
// it should be killed.
if (parent.namespaceURI === HTML_NAMESPACE) {
return tagName === 'math';
}
// The only way to switch from SVG to MathML is via
// and HTML integration points
if (parent.namespaceURI === SVG_NAMESPACE) {
return tagName === 'math' && HTML_INTEGRATION_POINTS[parentTagName];
}
// We only allow elements that are defined in MathML
// spec. All others are disallowed in MathML namespace.
return Boolean(ALL_MATHML_TAGS[tagName]);
}
if (element.namespaceURI === HTML_NAMESPACE) {
// The only way to switch from SVG to HTML is via
// HTML integration points, and from MathML to HTML
// is via MathML text integration points
if (parent.namespaceURI === SVG_NAMESPACE && !HTML_INTEGRATION_POINTS[parentTagName]) {
return false;
}
if (parent.namespaceURI === MATHML_NAMESPACE && !MATHML_TEXT_INTEGRATION_POINTS[parentTagName]) {
return false;
}
// Certain elements are allowed in both SVG and HTML
// namespace. We need to specify them explicitly
// so that they don't get erronously deleted from
// HTML namespace.
var commonSvgAndHTMLElements = addToSet({}, ['title', 'style', 'font', 'a', 'script']);
// We disallow tags that are specific for MathML
// or SVG and should never appear in HTML namespace
return !ALL_MATHML_TAGS[tagName] && (commonSvgAndHTMLElements[tagName] || !ALL_SVG_TAGS[tagName]);
}
// The code should never reach this place (this means
// that the element somehow got namespace that is not
// HTML, SVG or MathML). Return false just in case.
return false;
};
/**
* _forceRemove
*
* @param {Node} node a DOM node
*/
var _forceRemove = function _forceRemove(node) {
arrayPush(DOMPurify.removed, { element: node });
try {
// eslint-disable-next-line unicorn/prefer-dom-node-remove
node.parentNode.removeChild(node);
} catch (_) {
try {
node.outerHTML = emptyHTML;
} catch (_) {
node.remove();
}
}
};
/**
* _removeAttribute
*
* @param {String} name an Attribute name
* @param {Node} node a DOM node
*/
var _removeAttribute = function _removeAttribute(name, node) {
try {
arrayPush(DOMPurify.removed, {
attribute: node.getAttributeNode(name),
from: node
});
} catch (_) {
arrayPush(DOMPurify.removed, {
attribute: null,
from: node
});
}
node.removeAttribute(name);
// We void attribute values for unremovable "is"" attributes
if (name === 'is' && !ALLOWED_ATTR[name]) {
if (RETURN_DOM || RETURN_DOM_FRAGMENT) {
try {
_forceRemove(node);
} catch (_) {}
} else {
try {
node.setAttribute(name, '');
} catch (_) {}
}
}
};
/**
* _initDocument
*
* @param {String} dirty a string of dirty markup
* @return {Document} a DOM, filled with the dirty markup
*/
var _initDocument = function _initDocument(dirty) {
/* Create a HTML document */
var doc = void 0;
var leadingWhitespace = void 0;
if (FORCE_BODY) {
dirty = ' ' + dirty;
} else {
/* If FORCE_BODY isn't used, leading whitespace needs to be preserved manually */
var matches = stringMatch(dirty, /^[\r\n\t ]+/);
leadingWhitespace = matches && matches[0];
}
if (PARSER_MEDIA_TYPE === 'application/xhtml+xml') {
// Root of XHTML doc must contain xmlns declaration (see https://www.w3.org/TR/xhtml1/normative.html#strict)
dirty = '' + dirty + '';
}
var dirtyPayload = trustedTypesPolicy ? trustedTypesPolicy.createHTML(dirty) : dirty;
/*
* Use the DOMParser API by default, fallback later if needs be
* DOMParser not work for svg when has multiple root element.
*/
if (NAMESPACE === HTML_NAMESPACE) {
try {
doc = new DOMParser().parseFromString(dirtyPayload, PARSER_MEDIA_TYPE);
} catch (_) {}
}
/* Use createHTMLDocument in case DOMParser is not available */
if (!doc || !doc.documentElement) {
doc = implementation.createDocument(NAMESPACE, 'template', null);
try {
doc.documentElement.innerHTML = IS_EMPTY_INPUT ? '' : dirtyPayload;
} catch (_) {
// Syntax error if dirtyPayload is invalid xml
}
}
var body = doc.body || doc.documentElement;
if (dirty && leadingWhitespace) {
body.insertBefore(document.createTextNode(leadingWhitespace), body.childNodes[0] || null);
}
/* Work on whole document or just its body */
if (NAMESPACE === HTML_NAMESPACE) {
return getElementsByTagName.call(doc, WHOLE_DOCUMENT ? 'html' : 'body')[0];
}
return WHOLE_DOCUMENT ? doc.documentElement : body;
};
/**
* _createIterator
*
* @param {Document} root document/fragment to create iterator for
* @return {Iterator} iterator instance
*/
var _createIterator = function _createIterator(root) {
return createNodeIterator.call(root.ownerDocument || root, root, NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_COMMENT | NodeFilter.SHOW_TEXT, null, false);
};
/**
* _isClobbered
*
* @param {Node} elm element to check for clobbering attacks
* @return {Boolean} true if clobbered, false if safe
*/
var _isClobbered = function _isClobbered(elm) {
if (elm instanceof Text || elm instanceof Comment) {
return false;
}
if (typeof elm.nodeName !== 'string' || typeof elm.textContent !== 'string' || typeof elm.removeChild !== 'function' || !(elm.attributes instanceof NamedNodeMap) || typeof elm.removeAttribute !== 'function' || typeof elm.setAttribute !== 'function' || typeof elm.namespaceURI !== 'string' || typeof elm.insertBefore !== 'function') {
return true;
}
return false;
};
/**
* _isNode
*
* @param {Node} obj object to check whether it's a DOM node
* @return {Boolean} true is object is a DOM node
*/
var _isNode = function _isNode(object) {
return (typeof Node === 'undefined' ? 'undefined' : _typeof(Node)) === 'object' ? object instanceof Node : object && (typeof object === 'undefined' ? 'undefined' : _typeof(object)) === 'object' && typeof object.nodeType === 'number' && typeof object.nodeName === 'string';
};
/**
* _executeHook
* Execute user configurable hooks
*
* @param {String} entryPoint Name of the hook's entry point
* @param {Node} currentNode node to work on with the hook
* @param {Object} data additional hook parameters
*/
var _executeHook = function _executeHook(entryPoint, currentNode, data) {
if (!hooks[entryPoint]) {
return;
}
arrayForEach(hooks[entryPoint], function (hook) {
hook.call(DOMPurify, currentNode, data, CONFIG);
});
};
/**
* _sanitizeElements
*
* @protect nodeName
* @protect textContent
* @protect removeChild
*
* @param {Node} currentNode to check for permission to exist
* @return {Boolean} true if node was killed, false if left alive
*/
var _sanitizeElements = function _sanitizeElements(currentNode) {
var content = void 0;
/* Execute a hook if present */
_executeHook('beforeSanitizeElements', currentNode, null);
/* Check if element is clobbered or can clobber */
if (_isClobbered(currentNode)) {
_forceRemove(currentNode);
return true;
}
/* Check if tagname contains Unicode */
if (stringMatch(currentNode.nodeName, /[\u0080-\uFFFF]/)) {
_forceRemove(currentNode);
return true;
}
/* Now let's check the element's type and name */
var tagName = transformCaseFunc(currentNode.nodeName);
/* Execute a hook if present */
_executeHook('uponSanitizeElement', currentNode, {
tagName: tagName,
allowedTags: ALLOWED_TAGS
});
/* Detect mXSS attempts abusing namespace confusion */
if (!_isNode(currentNode.firstElementChild) && (!_isNode(currentNode.content) || !_isNode(currentNode.content.firstElementChild)) && regExpTest(/<[/\w]/g, currentNode.innerHTML) && regExpTest(/<[/\w]/g, currentNode.textContent)) {
_forceRemove(currentNode);
return true;
}
/* Mitigate a problem with templates inside select */
if (tagName === 'select' && regExpTest(/= 0; --i) {
parentNode.insertBefore(cloneNode(childNodes[i], true), getNextSibling(currentNode));
}
}
}
_forceRemove(currentNode);
return true;
}
/* Check whether element has a valid namespace */
if (currentNode instanceof Element && !_checkValidNamespace(currentNode)) {
_forceRemove(currentNode);
return true;
}
if ((tagName === 'noscript' || tagName === 'noembed') && regExpTest(/<\/no(script|embed)/i, currentNode.innerHTML)) {
_forceRemove(currentNode);
return true;
}
/* Sanitize element content to be template-safe */
if (SAFE_FOR_TEMPLATES && currentNode.nodeType === 3) {
/* Get the element's text content */
content = currentNode.textContent;
content = stringReplace(content, MUSTACHE_EXPR$$1, ' ');
content = stringReplace(content, ERB_EXPR$$1, ' ');
if (currentNode.textContent !== content) {
arrayPush(DOMPurify.removed, { element: currentNode.cloneNode() });
currentNode.textContent = content;
}
}
/* Execute a hook if present */
_executeHook('afterSanitizeElements', currentNode, null);
return false;
};
/**
* _isValidAttribute
*
* @param {string} lcTag Lowercase tag name of containing element.
* @param {string} lcName Lowercase attribute name.
* @param {string} value Attribute value.
* @return {Boolean} Returns true if `value` is valid, otherwise false.
*/
// eslint-disable-next-line complexity
var _isValidAttribute = function _isValidAttribute(lcTag, lcName, value) {
/* Make sure attribute cannot clobber */
if (SANITIZE_DOM && (lcName === 'id' || lcName === 'name') && (value in document || value in formElement)) {
return false;
}
/* Allow valid data-* attributes: At least one character after "-"
(https://html.spec.whatwg.org/multipage/dom.html#embedding-custom-non-visible-data-with-the-data-*-attributes)
XML-compatible (https://html.spec.whatwg.org/multipage/infrastructure.html#xml-compatible and http://www.w3.org/TR/xml/#d0e804)
We don't need to check the value; it's always URI safe. */
if (ALLOW_DATA_ATTR && !FORBID_ATTR[lcName] && regExpTest(DATA_ATTR$$1, lcName)) ; else if (ALLOW_ARIA_ATTR && regExpTest(ARIA_ATTR$$1, lcName)) ; else if (!ALLOWED_ATTR[lcName] || FORBID_ATTR[lcName]) {
return false;
/* Check value is safe. First, is attr inert? If so, is safe */
} else if (URI_SAFE_ATTRIBUTES[lcName]) ; else if (regExpTest(IS_ALLOWED_URI$$1, stringReplace(value, ATTR_WHITESPACE$$1, ''))) ; else if ((lcName === 'src' || lcName === 'xlink:href' || lcName === 'href') && lcTag !== 'script' && stringIndexOf(value, 'data:') === 0 && DATA_URI_TAGS[lcTag]) ; else if (ALLOW_UNKNOWN_PROTOCOLS && !regExpTest(IS_SCRIPT_OR_DATA$$1, stringReplace(value, ATTR_WHITESPACE$$1, ''))) ; else if (!value) ; else {
return false;
}
return true;
};
/**
* _sanitizeAttributes
*
* @protect attributes
* @protect nodeName
* @protect removeAttribute
* @protect setAttribute
*
* @param {Node} currentNode to sanitize
*/
var _sanitizeAttributes = function _sanitizeAttributes(currentNode) {
var attr = void 0;
var value = void 0;
var lcName = void 0;
var l = void 0;
/* Execute a hook if present */
_executeHook('beforeSanitizeAttributes', currentNode, null);
var attributes = currentNode.attributes;
/* Check if we have attributes; if not we might have a text node */
if (!attributes) {
return;
}
var hookEvent = {
attrName: '',
attrValue: '',
keepAttr: true,
allowedAttributes: ALLOWED_ATTR
};
l = attributes.length;
/* Go backwards over all attributes; safely remove bad ones */
while (l--) {
attr = attributes[l];
var _attr = attr,
name = _attr.name,
namespaceURI = _attr.namespaceURI;
value = stringTrim(attr.value);
lcName = transformCaseFunc(name);
/* Execute a hook if present */
hookEvent.attrName = lcName;
hookEvent.attrValue = value;
hookEvent.keepAttr = true;
hookEvent.forceKeepAttr = undefined; // Allows developers to see this is a property they can set
_executeHook('uponSanitizeAttribute', currentNode, hookEvent);
value = hookEvent.attrValue;
/* Did the hooks approve of the attribute? */
if (hookEvent.forceKeepAttr) {
continue;
}
/* Remove attribute */
_removeAttribute(name, currentNode);
/* Did the hooks approve of the attribute? */
if (!hookEvent.keepAttr) {
continue;
}
/* Work around a security issue in jQuery 3.0 */
if (regExpTest(/\/>/i, value)) {
_removeAttribute(name, currentNode);
continue;
}
/* Sanitize attribute content to be template-safe */
if (SAFE_FOR_TEMPLATES) {
value = stringReplace(value, MUSTACHE_EXPR$$1, ' ');
value = stringReplace(value, ERB_EXPR$$1, ' ');
}
/* Is `value` valid for this attribute? */
var lcTag = transformCaseFunc(currentNode.nodeName);
if (!_isValidAttribute(lcTag, lcName, value)) {
continue;
}
/* Handle invalid data-* attribute set by try-catching it */
try {
if (namespaceURI) {
currentNode.setAttributeNS(namespaceURI, name, value);
} else {
/* Fallback to setAttribute() for browser-unrecognized namespaces e.g. "x-schema". */
currentNode.setAttribute(name, value);
}
arrayPop(DOMPurify.removed);
} catch (_) {}
}
/* Execute a hook if present */
_executeHook('afterSanitizeAttributes', currentNode, null);
};
/**
* _sanitizeShadowDOM
*
* @param {DocumentFragment} fragment to iterate over recursively
*/
var _sanitizeShadowDOM = function _sanitizeShadowDOM(fragment) {
var shadowNode = void 0;
var shadowIterator = _createIterator(fragment);
/* Execute a hook if present */
_executeHook('beforeSanitizeShadowDOM', fragment, null);
while (shadowNode = shadowIterator.nextNode()) {
/* Execute a hook if present */
_executeHook('uponSanitizeShadowNode', shadowNode, null);
/* Sanitize tags and elements */
if (_sanitizeElements(shadowNode)) {
continue;
}
/* Deep shadow DOM detected */
if (shadowNode.content instanceof DocumentFragment) {
_sanitizeShadowDOM(shadowNode.content);
}
/* Check attributes, sanitize if necessary */
_sanitizeAttributes(shadowNode);
}
/* Execute a hook if present */
_executeHook('afterSanitizeShadowDOM', fragment, null);
};
/**
* Sanitize
* Public method providing core sanitation functionality
*
* @param {String|Node} dirty string or DOM node
* @param {Object} configuration object
*/
// eslint-disable-next-line complexity
DOMPurify.sanitize = function (dirty, cfg) {
var body = void 0;
var importedNode = void 0;
var currentNode = void 0;
var oldNode = void 0;
var returnNode = void 0;
/* Make sure we have a string to sanitize.
DO NOT return early, as this will return the wrong type if
the user has requested a DOM object rather than a string */
IS_EMPTY_INPUT = !dirty;
if (IS_EMPTY_INPUT) {
dirty = '';
}
/* Stringify, in case dirty is an object */
if (typeof dirty !== 'string' && !_isNode(dirty)) {
// eslint-disable-next-line no-negated-condition
if (typeof dirty.toString !== 'function') {
throw typeErrorCreate('toString is not a function');
} else {
dirty = dirty.toString();
if (typeof dirty !== 'string') {
throw typeErrorCreate('dirty is not a string, aborting');
}
}
}
/* Check we can run. Otherwise fall back or ignore */
if (!DOMPurify.isSupported) {
if (_typeof(window.toStaticHTML) === 'object' || typeof window.toStaticHTML === 'function') {
if (typeof dirty === 'string') {
return window.toStaticHTML(dirty);
}
if (_isNode(dirty)) {
return window.toStaticHTML(dirty.outerHTML);
}
}
return dirty;
}
/* Assign config vars */
if (!SET_CONFIG) {
_parseConfig(cfg);
}
/* Clean up removed elements */
DOMPurify.removed = [];
/* Check if dirty is correctly typed for IN_PLACE */
if (typeof dirty === 'string') {
IN_PLACE = false;
}
if (IN_PLACE) ; else if (dirty instanceof Node) {
/* If dirty is a DOM element, append to an empty document to avoid
elements being stripped by the parser */
body = _initDocument('');
importedNode = body.ownerDocument.importNode(dirty, true);
if (importedNode.nodeType === 1 && importedNode.nodeName === 'BODY') {
/* Node is already a body, use as is */
body = importedNode;
} else if (importedNode.nodeName === 'HTML') {
body = importedNode;
} else {
// eslint-disable-next-line unicorn/prefer-dom-node-append
body.appendChild(importedNode);
}
} else {
/* Exit directly if we have nothing to do */
if (!RETURN_DOM && !SAFE_FOR_TEMPLATES && !WHOLE_DOCUMENT &&
// eslint-disable-next-line unicorn/prefer-includes
dirty.indexOf('<') === -1) {
return trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML(dirty) : dirty;
}
/* Initialize the document to work on */
body = _initDocument(dirty);
/* Check we have a DOM node from the data */
if (!body) {
return RETURN_DOM ? null : emptyHTML;
}
}
/* Remove first element node (ours) if FORCE_BODY is set */
if (body && FORCE_BODY) {
_forceRemove(body.firstChild);
}
/* Get node iterator */
var nodeIterator = _createIterator(IN_PLACE ? dirty : body);
/* Now start iterating over the created document */
while (currentNode = nodeIterator.nextNode()) {
/* Fix IE's strange behavior with manipulated textNodes #89 */
if (currentNode.nodeType === 3 && currentNode === oldNode) {
continue;
}
/* Sanitize tags and elements */
if (_sanitizeElements(currentNode)) {
continue;
}
/* Shadow DOM detected, sanitize it */
if (currentNode.content instanceof DocumentFragment) {
_sanitizeShadowDOM(currentNode.content);
}
/* Check attributes, sanitize if necessary */
_sanitizeAttributes(currentNode);
oldNode = currentNode;
}
oldNode = null;
/* If we sanitized `dirty` in-place, return it. */
if (IN_PLACE) {
return dirty;
}
/* Return sanitized string or DOM */
if (RETURN_DOM) {
if (RETURN_DOM_FRAGMENT) {
returnNode = createDocumentFragment.call(body.ownerDocument);
while (body.firstChild) {
// eslint-disable-next-line unicorn/prefer-dom-node-append
returnNode.appendChild(body.firstChild);
}
} else {
returnNode = body;
}
if (RETURN_DOM_IMPORT) {
/*
AdoptNode() is not used because internal state is not reset
(e.g. the past names map of a HTMLFormElement), this is safe
in theory but we would rather not risk another attack vector.
The state that is cloned by importNode() is explicitly defined
by the specs.
*/
returnNode = importNode.call(originalDocument, returnNode, true);
}
return returnNode;
}
var serializedHTML = WHOLE_DOCUMENT ? body.outerHTML : body.innerHTML;
/* Sanitize final string template-safe */
if (SAFE_FOR_TEMPLATES) {
serializedHTML = stringReplace(serializedHTML, MUSTACHE_EXPR$$1, ' ');
serializedHTML = stringReplace(serializedHTML, ERB_EXPR$$1, ' ');
}
return trustedTypesPolicy && RETURN_TRUSTED_TYPE ? trustedTypesPolicy.createHTML(serializedHTML) : serializedHTML;
};
/**
* Public method to set the configuration once
* setConfig
*
* @param {Object} cfg configuration object
*/
DOMPurify.setConfig = function (cfg) {
_parseConfig(cfg);
SET_CONFIG = true;
};
/**
* Public method to remove the configuration
* clearConfig
*
*/
DOMPurify.clearConfig = function () {
CONFIG = null;
SET_CONFIG = false;
};
/**
* Public method to check if an attribute value is valid.
* Uses last set config, if any. Otherwise, uses config defaults.
* isValidAttribute
*
* @param {string} tag Tag name of containing element.
* @param {string} attr Attribute name.
* @param {string} value Attribute value.
* @return {Boolean} Returns true if `value` is valid. Otherwise, returns false.
*/
DOMPurify.isValidAttribute = function (tag, attr, value) {
/* Initialize shared config vars if necessary. */
if (!CONFIG) {
_parseConfig({});
}
var lcTag = transformCaseFunc(tag);
var lcName = transformCaseFunc(attr);
return _isValidAttribute(lcTag, lcName, value);
};
/**
* AddHook
* Public method to add DOMPurify hooks
*
* @param {String} entryPoint entry point for the hook to add
* @param {Function} hookFunction function to execute
*/
DOMPurify.addHook = function (entryPoint, hookFunction) {
if (typeof hookFunction !== 'function') {
return;
}
hooks[entryPoint] = hooks[entryPoint] || [];
arrayPush(hooks[entryPoint], hookFunction);
};
/**
* RemoveHook
* Public method to remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
*
* @param {String} entryPoint entry point for the hook to remove
*/
DOMPurify.removeHook = function (entryPoint) {
if (hooks[entryPoint]) {
arrayPop(hooks[entryPoint]);
}
};
/**
* RemoveHooks
* Public method to remove all DOMPurify hooks at a given entryPoint
*
* @param {String} entryPoint entry point for the hooks to remove
*/
DOMPurify.removeHooks = function (entryPoint) {
if (hooks[entryPoint]) {
hooks[entryPoint] = [];
}
};
/**
* RemoveAllHooks
* Public method to remove all DOMPurify hooks
*
*/
DOMPurify.removeAllHooks = function () {
hooks = {};
};
return DOMPurify;
}
var purify = createDOMPurify();
return purify;
}));
//# sourceMappingURL=purify.js.map
/***/ }),
/***/ 928:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/* eslint-disable complexity */
/**
* @fileoverview Returns the first index at which a given element can be found in the array.
* @author NHN FE Development Lab
*/
var isArray = __webpack_require__(322);
/**
* @module array
*/
/**
* Returns the first index at which a given element can be found in the array
* from start index(default 0), or -1 if it is not present.
* It compares searchElement to elements of the Array using strict equality
* (the same method used by the ===, or triple-equals, operator).
* @param {*} searchElement Element to locate in the array
* @param {Array} array Array that will be traversed.
* @param {number} startIndex Start index in array for searching (default 0)
* @returns {number} the First index at which a given element, or -1 if it is not present
* @memberof module:array
* @example
* // ES6
* import inArray from 'tui-code-snippet/array/inArray';
*
* // CommonJS
* const inArray = require('tui-code-snippet/array/inArray');
*
* const arr = ['one', 'two', 'three', 'four'];
* const idx1 = inArray('one', arr, 3); // -1
* const idx2 = inArray('one', arr); // 0
*/
function inArray(searchElement, array, startIndex) {
var i;
var length;
startIndex = startIndex || 0;
if (!isArray(array)) {
return -1;
}
if (Array.prototype.indexOf) {
return Array.prototype.indexOf.call(array, searchElement, startIndex);
}
length = array.length;
for (i = startIndex; startIndex >= 0 && i < length; i += 1) {
if (array[i] === searchElement) {
return i;
}
}
return -1;
}
module.exports = inArray;
/***/ }),
/***/ 690:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Execute the provided callback once for each property of object(or element of array) which actually exist.
* @author NHN FE Development Lab
*/
var isArray = __webpack_require__(322);
var forEachArray = __webpack_require__(893);
var forEachOwnProperties = __webpack_require__(956);
/**
* @module collection
*/
/**
* Execute the provided callback once for each property of object(or element of array) which actually exist.
* If the object is Array-like object(ex-arguments object), It needs to transform to Array.(see 'ex2' of example).
* If the callback function returns false, the loop will be stopped.
* Callback function(iteratee) is invoked with three arguments:
* 1) The value of the property(or The value of the element)
* 2) The name of the property(or The index of the element)
* 3) The object being traversed
* @param {Object} obj The object that will be traversed
* @param {function} iteratee Callback function
* @param {Object} [context] Context(this) of callback function
* @memberof module:collection
* @example
* // ES6
* import forEach from 'tui-code-snippet/collection/forEach';
*
* // CommonJS
* const forEach = require('tui-code-snippet/collection/forEach');
*
* let sum = 0;
*
* forEach([1,2,3], function(value){
* sum += value;
* });
* alert(sum); // 6
*
* // In case of Array-like object
* const array = Array.prototype.slice.call(arrayLike); // change to array
* forEach(array, function(value){
* sum += value;
* });
*/
function forEach(obj, iteratee, context) {
if (isArray(obj)) {
forEachArray(obj, iteratee, context);
} else {
forEachOwnProperties(obj, iteratee, context);
}
}
module.exports = forEach;
/***/ }),
/***/ 893:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Execute the provided callback once for each element present in the array(or Array-like object) in ascending order.
* @author NHN FE Development Lab
*/
/**
* Execute the provided callback once for each element present
* in the array(or Array-like object) in ascending order.
* If the callback function returns false, the loop will be stopped.
* Callback function(iteratee) is invoked with three arguments:
* 1) The value of the element
* 2) The index of the element
* 3) The array(or Array-like object) being traversed
* @param {Array|Arguments|NodeList} arr The array(or Array-like object) that will be traversed
* @param {function} iteratee Callback function
* @param {Object} [context] Context(this) of callback function
* @memberof module:collection
* @example
* // ES6
* import forEachArray from 'tui-code-snippet/collection/forEachArray';
*
* // CommonJS
* const forEachArray = require('tui-code-snippet/collection/forEachArray');
*
* let sum = 0;
*
* forEachArray([1,2,3], function(value){
* sum += value;
* });
* alert(sum); // 6
*/
function forEachArray(arr, iteratee, context) {
var index = 0;
var len = arr.length;
context = context || null;
for (; index < len; index += 1) {
if (iteratee.call(context, arr[index], index, arr) === false) {
break;
}
}
}
module.exports = forEachArray;
/***/ }),
/***/ 956:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Execute the provided callback once for each property of object which actually exist.
* @author NHN FE Development Lab
*/
/**
* Execute the provided callback once for each property of object which actually exist.
* If the callback function returns false, the loop will be stopped.
* Callback function(iteratee) is invoked with three arguments:
* 1) The value of the property
* 2) The name of the property
* 3) The object being traversed
* @param {Object} obj The object that will be traversed
* @param {function} iteratee Callback function
* @param {Object} [context] Context(this) of callback function
* @memberof module:collection
* @example
* // ES6
* import forEachOwnProperties from 'tui-code-snippet/collection/forEachOwnProperties';
*
* // CommonJS
* const forEachOwnProperties = require('tui-code-snippet/collection/forEachOwnProperties');
*
* let sum = 0;
*
* forEachOwnProperties({a:1,b:2,c:3}, function(value){
* sum += value;
* });
* alert(sum); // 6
*/
function forEachOwnProperties(obj, iteratee, context) {
var key;
context = context || null;
for (key in obj) {
if (obj.hasOwnProperty(key)) {
if (iteratee.call(context, obj[key], key, obj) === false) {
break;
}
}
}
}
module.exports = forEachOwnProperties;
/***/ }),
/***/ 990:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Transform the Array-like object to Array.
* @author NHN FE Development Lab
*/
var forEachArray = __webpack_require__(893);
/**
* Transform the Array-like object to Array.
* In low IE (below 8), Array.prototype.slice.call is not perfect. So, try-catch statement is used.
* @param {*} arrayLike Array-like object
* @returns {Array} Array
* @memberof module:collection
* @example
* // ES6
* import toArray from 'tui-code-snippet/collection/toArray';
*
* // CommonJS
* const toArray = require('tui-code-snippet/collection/toArray');
*
* const arrayLike = {
* 0: 'one',
* 1: 'two',
* 2: 'three',
* 3: 'four',
* length: 4
* };
* const result = toArray(arrayLike);
*
* alert(result instanceof Array); // true
* alert(result); // one,two,three,four
*/
function toArray(arrayLike) {
var arr;
try {
arr = Array.prototype.slice.call(arrayLike);
} catch (e) {
arr = [];
forEachArray(arrayLike, function(value) {
arr.push(value);
});
}
return arr;
}
module.exports = toArray;
/***/ }),
/***/ 755:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Get event collection for specific HTML element
* @author NHN FE Development Lab
*/
var EVENT_KEY = '_feEventKey';
/**
* Get event collection for specific HTML element
* @param {HTMLElement} element - HTML element
* @param {string} type - event type
* @returns {array}
* @private
*/
function safeEvent(element, type) {
var events = element[EVENT_KEY];
var handlers;
if (!events) {
events = element[EVENT_KEY] = {};
}
handlers = events[type];
if (!handlers) {
handlers = events[type] = [];
}
return handlers;
}
module.exports = safeEvent;
/***/ }),
/***/ 349:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Unbind DOM events
* @author NHN FE Development Lab
*/
var isString = __webpack_require__(758);
var forEach = __webpack_require__(690);
var safeEvent = __webpack_require__(755);
/**
* Unbind DOM events
* If a handler function is not passed, remove all events of that type.
* @param {HTMLElement} element - element to unbind events
* @param {(string|object)} types - Space splitted events names or eventName:handler object
* @param {function} [handler] - handler function
* @memberof module:domEvent
* @example
* // Following the example of domEvent#on
*
* // Unbind one event from an element.
* off(div, 'click', toggle);
*
* // Unbind multiple events with a same handler from multiple elements at once.
* // Use event names splitted by a space.
* off(element, 'mouseenter mouseleave', changeColor);
*
* // Unbind multiple events with different handlers from an element at once.
* // Use an object which of key is an event name and value is a handler function.
* off(div, {
* keydown: highlight,
* keyup: dehighlight
* });
*
* // Unbind events without handlers.
* off(div, 'drag');
*/
function off(element, types, handler) {
if (isString(types)) {
forEach(types.split(/\s+/g), function(type) {
unbindEvent(element, type, handler);
});
return;
}
forEach(types, function(func, type) {
unbindEvent(element, type, func);
});
}
/**
* Unbind DOM events
* If a handler function is not passed, remove all events of that type.
* @param {HTMLElement} element - element to unbind events
* @param {string} type - events name
* @param {function} [handler] - handler function
* @private
*/
function unbindEvent(element, type, handler) {
var events = safeEvent(element, type);
var index;
if (!handler) {
forEach(events, function(item) {
removeHandler(element, type, item.wrappedHandler);
});
events.splice(0, events.length);
} else {
forEach(events, function(item, idx) {
if (handler === item.handler) {
removeHandler(element, type, item.wrappedHandler);
index = idx;
return false;
}
return true;
});
events.splice(index, 1);
}
}
/**
* Remove an event handler
* @param {HTMLElement} element - An element to remove an event
* @param {string} type - event type
* @param {function} handler - event handler
* @private
*/
function removeHandler(element, type, handler) {
if ('removeEventListener' in element) {
element.removeEventListener(type, handler);
} else if ('detachEvent' in element) {
element.detachEvent('on' + type, handler);
}
}
module.exports = off;
/***/ }),
/***/ 348:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Bind DOM events
* @author NHN FE Development Lab
*/
var isString = __webpack_require__(758);
var forEach = __webpack_require__(690);
var safeEvent = __webpack_require__(755);
/**
* Bind DOM events.
* @param {HTMLElement} element - element to bind events
* @param {(string|object)} types - Space splitted events names or eventName:handler object
* @param {(function|object)} handler - handler function or context for handler method
* @param {object} [context] context - context for handler method.
* @memberof module:domEvent
* @example
* const div = document.querySelector('div');
*
* // Bind one event to an element.
* on(div, 'click', toggle);
*
* // Bind multiple events with a same handler to multiple elements at once.
* // Use event names splitted by a space.
* on(div, 'mouseenter mouseleave', changeColor);
*
* // Bind multiple events with different handlers to an element at once.
* // Use an object which of key is an event name and value is a handler function.
* on(div, {
* keydown: highlight,
* keyup: dehighlight
* });
*
* // Set a context for handler method.
* const name = 'global';
* const repository = {name: 'CodeSnippet'};
* on(div, 'drag', function() {
* console.log(this.name);
* }, repository);
* // Result when you drag a div: "CodeSnippet"
*/
function on(element, types, handler, context) {
if (isString(types)) {
forEach(types.split(/\s+/g), function(type) {
bindEvent(element, type, handler, context);
});
return;
}
forEach(types, function(func, type) {
bindEvent(element, type, func, handler);
});
}
/**
* Bind DOM events
* @param {HTMLElement} element - element to bind events
* @param {string} type - events name
* @param {function} handler - handler function or context for handler method
* @param {object} [context] context - context for handler method.
* @private
*/
function bindEvent(element, type, handler, context) {
/**
* Event handler
* @param {Event} e - event object
*/
function eventHandler(e) {
handler.call(context || element, e || window.event);
}
if ('addEventListener' in element) {
element.addEventListener(type, eventHandler);
} else if ('attachEvent' in element) {
element.attachEvent('on' + type, eventHandler);
}
memorizeHandler(element, type, handler, eventHandler);
}
/**
* Memorize DOM event handler for unbinding.
* @param {HTMLElement} element - element to bind events
* @param {string} type - events name
* @param {function} handler - handler function that user passed at on() use
* @param {function} wrappedHandler - handler function that wrapped by domevent for implementing some features
* @private
*/
function memorizeHandler(element, type, handler, wrappedHandler) {
var events = safeEvent(element, type);
var existInEvents = false;
forEach(events, function(obj) {
if (obj.handler === handler) {
existInEvents = true;
return false;
}
return true;
});
if (!existInEvents) {
events.push({
handler: handler,
wrappedHandler: wrappedHandler
});
}
}
module.exports = on;
/***/ }),
/***/ 24:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Set className value
* @author NHN FE Development Lab
*/
var isArray = __webpack_require__(322);
var isUndefined = __webpack_require__(929);
/**
* Set className value
* @param {(HTMLElement|SVGElement)} element - target element
* @param {(string|string[])} cssClass - class names
* @private
*/
function setClassName(element, cssClass) {
cssClass = isArray(cssClass) ? cssClass.join(' ') : cssClass;
cssClass = cssClass.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, '');
if (isUndefined(element.className.baseVal)) {
element.className = cssClass;
return;
}
element.className.baseVal = cssClass;
}
module.exports = setClassName;
/***/ }),
/***/ 204:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Add css class to element
* @author NHN FE Development Lab
*/
var forEach = __webpack_require__(690);
var inArray = __webpack_require__(928);
var getClass = __webpack_require__(902);
var setClassName = __webpack_require__(24);
/**
* domUtil module
* @module domUtil
*/
/**
* Add css class to element
* @param {(HTMLElement|SVGElement)} element - target element
* @param {...string} cssClass - css classes to add
* @memberof module:domUtil
*/
function addClass(element) {
var cssClass = Array.prototype.slice.call(arguments, 1);
var classList = element.classList;
var newClass = [];
var origin;
if (classList) {
forEach(cssClass, function(name) {
element.classList.add(name);
});
return;
}
origin = getClass(element);
if (origin) {
cssClass = [].concat(origin.split(/\s+/), cssClass);
}
forEach(cssClass, function(cls) {
if (inArray(cls, newClass) < 0) {
newClass.push(cls);
}
});
setClassName(element, newClass);
}
module.exports = addClass;
/***/ }),
/***/ 522:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Setting element style
* @author NHN FE Development Lab
*/
var isString = __webpack_require__(758);
var forEach = __webpack_require__(690);
/**
* Setting element style
* @param {(HTMLElement|SVGElement)} element - element to setting style
* @param {(string|object)} key - style prop name or {prop: value} pair object
* @param {string} [value] - style value
* @memberof module:domUtil
*/
function css(element, key, value) {
var style = element.style;
if (isString(key)) {
style[key] = value;
return;
}
forEach(key, function(v, k) {
style[k] = v;
});
}
module.exports = css;
/***/ }),
/***/ 902:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Get HTML element's design classes.
* @author NHN FE Development Lab
*/
var isUndefined = __webpack_require__(929);
/**
* Get HTML element's design classes.
* @param {(HTMLElement|SVGElement)} element target element
* @returns {string} element css class name
* @memberof module:domUtil
*/
function getClass(element) {
if (!element || !element.className) {
return '';
}
if (isUndefined(element.className.baseVal)) {
return element.className;
}
return element.className.baseVal;
}
module.exports = getClass;
/***/ }),
/***/ 714:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Check element has specific css class
* @author NHN FE Development Lab
*/
var inArray = __webpack_require__(928);
var getClass = __webpack_require__(902);
/**
* Check element has specific css class
* @param {(HTMLElement|SVGElement)} element - target element
* @param {string} cssClass - css class
* @returns {boolean}
* @memberof module:domUtil
*/
function hasClass(element, cssClass) {
var origin;
if (element.classList) {
return element.classList.contains(cssClass);
}
origin = getClass(element).split(/\s+/);
return inArray(cssClass, origin) > -1;
}
module.exports = hasClass;
/***/ }),
/***/ 471:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Check element match selector
* @author NHN FE Development Lab
*/
var inArray = __webpack_require__(928);
var toArray = __webpack_require__(990);
var elProto = Element.prototype;
var matchSelector = elProto.matches ||
elProto.webkitMatchesSelector ||
elProto.mozMatchesSelector ||
elProto.msMatchesSelector ||
function(selector) {
var doc = this.document || this.ownerDocument;
return inArray(this, toArray(doc.querySelectorAll(selector))) > -1;
};
/**
* Check element match selector
* @param {HTMLElement} element - element to check
* @param {string} selector - selector to check
* @returns {boolean} is selector matched to element?
* @memberof module:domUtil
*/
function matches(element, selector) {
return matchSelector.call(element, selector);
}
module.exports = matches;
/***/ }),
/***/ 462:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Remove css class from element
* @author NHN FE Development Lab
*/
var forEachArray = __webpack_require__(893);
var inArray = __webpack_require__(928);
var getClass = __webpack_require__(902);
var setClassName = __webpack_require__(24);
/**
* Remove css class from element
* @param {(HTMLElement|SVGElement)} element - target element
* @param {...string} cssClass - css classes to remove
* @memberof module:domUtil
*/
function removeClass(element) {
var cssClass = Array.prototype.slice.call(arguments, 1);
var classList = element.classList;
var origin, newClass;
if (classList) {
forEachArray(cssClass, function(name) {
classList.remove(name);
});
return;
}
origin = getClass(element).split(/\s+/);
newClass = [];
forEachArray(origin, function(name) {
if (inArray(name, cssClass) < 0) {
newClass.push(name);
}
});
setClassName(element, newClass);
}
module.exports = removeClass;
/***/ }),
/***/ 969:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Extend the target object from other objects.
* @author NHN FE Development Lab
*/
/**
* @module object
*/
/**
* Extend the target object from other objects.
* @param {object} target - Object that will be extended
* @param {...object} objects - Objects as sources
* @returns {object} Extended object
* @memberof module:object
*/
function extend(target, objects) { // eslint-disable-line no-unused-vars
var hasOwnProp = Object.prototype.hasOwnProperty;
var source, prop, i, len;
for (i = 1, len = arguments.length; i < len; i += 1) {
source = arguments[i];
for (prop in source) {
if (hasOwnProp.call(source, prop)) {
target[prop] = source[prop];
}
}
}
return target;
}
module.exports = extend;
/***/ }),
/***/ 254:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Request image ping.
* @author NHN FE Development Lab
*/
var forEachOwnProperties = __webpack_require__(956);
/**
* @module request
*/
/**
* Request image ping.
* @param {String} url url for ping request
* @param {Object} trackingInfo infos for make query string
* @returns {HTMLElement}
* @memberof module:request
* @example
* // ES6
* import imagePing from 'tui-code-snippet/request/imagePing';
*
* // CommonJS
* const imagePing = require('tui-code-snippet/request/imagePing');
*
* imagePing('https://www.google-analytics.com/collect', {
* v: 1,
* t: 'event',
* tid: 'trackingid',
* cid: 'cid',
* dp: 'dp',
* dh: 'dh'
* });
*/
function imagePing(url, trackingInfo) {
var trackingElement = document.createElement('img');
var queryString = '';
forEachOwnProperties(trackingInfo, function(value, key) {
queryString += '&' + key + '=' + value;
});
queryString = queryString.substring(1);
trackingElement.src = url + '?' + queryString;
trackingElement.style.display = 'none';
document.body.appendChild(trackingElement);
document.body.removeChild(trackingElement);
return trackingElement;
}
module.exports = imagePing;
/***/ }),
/***/ 391:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Send hostname on DOMContentLoaded.
* @author NHN FE Development Lab
*/
var isUndefined = __webpack_require__(929);
var imagePing = __webpack_require__(254);
var ms7days = 7 * 24 * 60 * 60 * 1000;
/**
* Check if the date has passed 7 days
* @param {number} date - milliseconds
* @returns {boolean}
* @private
*/
function isExpired(date) {
var now = new Date().getTime();
return now - date > ms7days;
}
/**
* Send hostname on DOMContentLoaded.
* To prevent hostname set tui.usageStatistics to false.
* @param {string} appName - application name
* @param {string} trackingId - GA tracking ID
* @ignore
*/
function sendHostname(appName, trackingId) {
var url = 'https://www.google-analytics.com/collect';
var hostname = location.hostname;
var hitType = 'event';
var eventCategory = 'use';
var applicationKeyForStorage = 'TOAST UI ' + appName + ' for ' + hostname + ': Statistics';
var date = window.localStorage.getItem(applicationKeyForStorage);
// skip if the flag is defined and is set to false explicitly
if (!isUndefined(window.tui) && window.tui.usageStatistics === false) {
return;
}
// skip if not pass seven days old
if (date && !isExpired(date)) {
return;
}
window.localStorage.setItem(applicationKeyForStorage, new Date().getTime());
setTimeout(function() {
if (document.readyState === 'interactive' || document.readyState === 'complete') {
imagePing(url, {
v: 1,
t: hitType,
tid: trackingId,
cid: hostname,
dp: hostname,
dh: appName,
el: appName,
ec: eventCategory
});
}
}, 1000);
}
module.exports = sendHostname;
/***/ }),
/***/ 516:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Creates a debounced function that delays invoking fn until after delay milliseconds has elapsed since the last time the debouced function was invoked.
* @author NHN FE Development Lab
*/
/**
* @module tricks
*/
/**
* Creates a debounced function that delays invoking fn until after delay milliseconds has elapsed
* since the last time the debouced function was invoked.
* @param {function} fn The function to debounce.
* @param {number} [delay=0] The number of milliseconds to delay
* @returns {function} debounced function.
* @memberof module:tricks
* @example
* // ES6
* import debounce from 'tui-code-snippet/tricks/debounce';
*
* // CommonJS
* const debounce = require('tui-code-snippet/tricks/debounce');
*
* function someMethodToInvokeDebounced() {}
*
* const debounced = debounce(someMethodToInvokeDebounced, 300);
*
* // invoke repeatedly
* debounced();
* debounced();
* debounced();
* debounced();
* debounced();
* debounced(); // last invoke of debounced()
*
* // invoke someMethodToInvokeDebounced() after 300 milliseconds.
*/
function debounce(fn, delay) {
var timer, args;
/* istanbul ignore next */
delay = delay || 0;
function debounced() { // eslint-disable-line require-jsdoc
args = Array.prototype.slice.call(arguments);
window.clearTimeout(timer);
timer = window.setTimeout(function() {
fn.apply(null, args);
}, delay);
}
return debounced;
}
module.exports = debounce;
/***/ }),
/***/ 423:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Creates a throttled function that only invokes fn at most once per every interval milliseconds.
* @author NHN FE Development Lab
*/
var debounce = __webpack_require__(516);
/**
* Creates a throttled function that only invokes fn at most once per every interval milliseconds.
* You can use this throttle short time repeatedly invoking functions. (e.g MouseMove, Resize ...)
* if you need reuse throttled method. you must remove slugs (e.g. flag variable) related with throttling.
* @param {function} fn function to throttle
* @param {number} [interval=0] the number of milliseconds to throttle invocations to.
* @returns {function} throttled function
* @memberof module:tricks
* @example
* // ES6
* import throttle from 'tui-code-snippet/tricks/throttle';
*
* // CommonJS
* const throttle = require('tui-code-snippet/tricks/throttle');
*
* function someMethodToInvokeThrottled() {}
*
* const throttled = throttle(someMethodToInvokeThrottled, 300);
*
* // invoke repeatedly
* throttled(); // invoke (leading)
* throttled();
* throttled(); // invoke (near 300 milliseconds)
* throttled();
* throttled();
* throttled(); // invoke (near 600 milliseconds)
* // ...
* // invoke (trailing)
*
* // if you need reuse throttled method. then invoke reset()
* throttled.reset();
*/
function throttle(fn, interval) {
var base;
var isLeading = true;
var tick = function(_args) {
fn.apply(null, _args);
base = null;
};
var debounced, stamp, args;
/* istanbul ignore next */
interval = interval || 0;
debounced = debounce(tick, interval);
function throttled() { // eslint-disable-line require-jsdoc
args = Array.prototype.slice.call(arguments);
if (isLeading) {
tick(args);
isLeading = false;
return;
}
stamp = Number(new Date());
base = base || stamp;
// pass array directly because `debounce()`, `tick()` are already use
// `apply()` method to invoke developer's `fn` handler.
//
// also, this `debounced` line invoked every time for implements
// `trailing` features.
debounced(args);
if ((stamp - base) >= interval) {
tick(args);
}
}
function reset() { // eslint-disable-line require-jsdoc
isLeading = true;
base = null;
}
throttled.reset = reset;
return throttled;
}
module.exports = throttle;
/***/ }),
/***/ 322:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is an instance of Array or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is an instance of Array or not.
* If the given variable is an instance of Array, return true.
* @param {*} obj - Target for checking
* @returns {boolean} Is array instance?
* @memberof module:type
*/
function isArray(obj) {
return obj instanceof Array;
}
module.exports = isArray;
/***/ }),
/***/ 326:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is a string or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is a boolean or not.
* If the given variable is a boolean, return true.
* @param {*} obj - Target for checking
* @returns {boolean} Is boolean?
* @memberof module:type
*/
function isBoolean(obj) {
return typeof obj === 'boolean' || obj instanceof Boolean;
}
module.exports = isBoolean;
/***/ }),
/***/ 65:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Check whether the given variable is existing or not.
* @author NHN FE Development Lab
*/
var isUndefined = __webpack_require__(929);
var isNull = __webpack_require__(934);
/**
* Check whether the given variable is existing or not.
* If the given variable is not null and not undefined, returns true.
* @param {*} param - Target for checking
* @returns {boolean} Is existy?
* @memberof module:type
* @example
* // ES6
* import isExisty from 'tui-code-snippet/type/isExisty');
*
* // CommonJS
* const isExisty = require('tui-code-snippet/type/isExisty');
*
* isExisty(''); //true
* isExisty(0); //true
* isExisty([]); //true
* isExisty({}); //true
* isExisty(null); //false
* isExisty(undefined); //false
*/
function isExisty(param) {
return !isUndefined(param) && !isNull(param);
}
module.exports = isExisty;
/***/ }),
/***/ 404:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Check whether the given variable is falsy or not.
* @author NHN FE Development Lab
*/
var isTruthy = __webpack_require__(790);
/**
* Check whether the given variable is falsy or not.
* If the given variable is null or undefined or false, returns true.
* @param {*} obj - Target for checking
* @returns {boolean} Is falsy?
* @memberof module:type
*/
function isFalsy(obj) {
return !isTruthy(obj);
}
module.exports = isFalsy;
/***/ }),
/***/ 294:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is a function or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is a function or not.
* If the given variable is a function, return true.
* @param {*} obj - Target for checking
* @returns {boolean} Is function?
* @memberof module:type
*/
function isFunction(obj) {
return obj instanceof Function;
}
module.exports = isFunction;
/***/ }),
/***/ 934:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is null or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is null or not.
* If the given variable(arguments[0]) is null, returns true.
* @param {*} obj - Target for checking
* @returns {boolean} Is null?
* @memberof module:type
*/
function isNull(obj) {
return obj === null;
}
module.exports = isNull;
/***/ }),
/***/ 321:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is a number or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is a number or not.
* If the given variable is a number, return true.
* @param {*} obj - Target for checking
* @returns {boolean} Is number?
* @memberof module:type
*/
function isNumber(obj) {
return typeof obj === 'number' || obj instanceof Number;
}
module.exports = isNumber;
/***/ }),
/***/ 73:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is an object or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is an object or not.
* If the given variable is an object, return true.
* @param {*} obj - Target for checking
* @returns {boolean} Is object?
* @memberof module:type
*/
function isObject(obj) {
return obj === Object(obj);
}
module.exports = isObject;
/***/ }),
/***/ 758:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is a string or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is a string or not.
* If the given variable is a string, return true.
* @param {*} obj - Target for checking
* @returns {boolean} Is string?
* @memberof module:type
*/
function isString(obj) {
return typeof obj === 'string' || obj instanceof String;
}
module.exports = isString;
/***/ }),
/***/ 790:
/***/ (function(module, __unused_webpack_exports, __webpack_require__) {
"use strict";
/**
* @fileoverview Check whether the given variable is truthy or not.
* @author NHN FE Development Lab
*/
var isExisty = __webpack_require__(65);
/**
* Check whether the given variable is truthy or not.
* If the given variable is not null or not undefined or not false, returns true.
* (It regards 0 as true)
* @param {*} obj - Target for checking
* @returns {boolean} Is truthy?
* @memberof module:type
*/
function isTruthy(obj) {
return isExisty(obj) && obj !== false;
}
module.exports = isTruthy;
/***/ }),
/***/ 929:
/***/ (function(module) {
"use strict";
/**
* @fileoverview Check whether the given variable is undefined or not.
* @author NHN FE Development Lab
*/
/**
* Check whether the given variable is undefined or not.
* If the given variable is undefined, returns true.
* @param {*} obj - Target for checking
* @returns {boolean} Is undefined?
* @memberof module:type
*/
function isUndefined(obj) {
return obj === undefined; // eslint-disable-line no-undefined
}
module.exports = isUndefined;
/***/ }),
/***/ 695:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__695__;
/***/ }),
/***/ 412:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__412__;
/***/ }),
/***/ 479:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__479__;
/***/ }),
/***/ 481:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__481__;
/***/ }),
/***/ 43:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__43__;
/***/ }),
/***/ 814:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__814__;
/***/ }),
/***/ 785:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__785__;
/***/ }),
/***/ 311:
/***/ (function(module) {
"use strict";
module.exports = __WEBPACK_EXTERNAL_MODULE__311__;
/***/ })
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ var cachedModule = __webpack_module_cache__[moduleId];
/******/ if (cachedModule !== undefined) {
/******/ return cachedModule.exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/compat get default export */
/******/ !function() {
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function() { return module['default']; } :
/******/ function() { return module; };
/******/ __webpack_require__.d(getter, { a: getter });
/******/ return getter;
/******/ };
/******/ }();
/******/
/******/ /* webpack/runtime/define property getters */
/******/ !function() {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = function(exports, definition) {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ }();
/******/
/******/ /* webpack/runtime/global */
/******/ !function() {
/******/ __webpack_require__.g = (function() {
/******/ if (typeof globalThis === 'object') return globalThis;
/******/ try {
/******/ return this || new Function('return this')();
/******/ } catch (e) {
/******/ if (typeof window === 'object') return window;
/******/ }
/******/ })();
/******/ }();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ !function() {
/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }
/******/ }();
/******/
/************************************************************************/
var __webpack_exports__ = {};
// This entry need to be wrapped in an IIFE because it need to be in strict mode.
!function() {
"use strict";
// EXPORTS
__webpack_require__.d(__webpack_exports__, {
"default": function() { return /* binding */ src; }
});
// UNUSED EXPORTS: Editor, EditorCore
;// CONCATENATED MODULE: ../../node_modules/tslib/tslib.es6.js
/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise */
var extendStatics = function(d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
return extendStatics(d, b);
};
function __extends(d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function() {
__assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
}
return t;
}
return __assign.apply(this, arguments);
}
function __rest(s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
}
function __decorate(decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
}
function __param(paramIndex, decorator) {
return function (target, key) { decorator(target, key, paramIndex); }
}
function __metadata(metadataKey, metadataValue) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
}
function __awaiter(thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
function __generator(thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
}
var __createBinding = Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
});
function __exportStar(m, o) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);
}
function __values(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
}
function __read(o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
}
/** @deprecated */
function __spread() {
for (var ar = [], i = 0; i < arguments.length; i++)
ar = ar.concat(__read(arguments[i]));
return ar;
}
/** @deprecated */
function __spreadArrays() {
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
for (var r = Array(s), k = 0, i = 0; i < il; i++)
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
r[k] = a[j];
return r;
}
function __spreadArray(to, from, pack) {
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
}
function __await(v) {
return this instanceof __await ? (this.v = v, this) : new __await(v);
}
function __asyncGenerator(thisArg, _arguments, generator) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var g = generator.apply(thisArg, _arguments || []), i, q = [];
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i;
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }
function fulfill(value) { resume("next", value); }
function reject(value) { resume("throw", value); }
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }
}
function __asyncDelegator(o) {
var i, p;
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i;
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; }
}
function __asyncValues(o) {
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
var m = o[Symbol.asyncIterator], i;
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
}
function __makeTemplateObject(cooked, raw) {
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; }
return cooked;
};
var __setModuleDefault = Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
};
function __importStar(mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
}
function __importDefault(mod) {
return (mod && mod.__esModule) ? mod : { default: mod };
}
function __classPrivateFieldGet(receiver, state, kind, f) {
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
}
function __classPrivateFieldSet(receiver, state, value, kind, f) {
if (kind === "m") throw new TypeError("Private method is not writable");
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
}
// EXTERNAL MODULE: external {"commonjs":"prosemirror-model","commonjs2":"prosemirror-model","amd":"prosemirror-model"}
var external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_ = __webpack_require__(43);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/collection/forEachOwnProperties.js
var forEachOwnProperties = __webpack_require__(956);
var forEachOwnProperties_default = /*#__PURE__*/__webpack_require__.n(forEachOwnProperties);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/object/extend.js
var extend = __webpack_require__(969);
var extend_default = /*#__PURE__*/__webpack_require__.n(extend);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domUtil/css.js
var css = __webpack_require__(522);
var css_default = /*#__PURE__*/__webpack_require__.n(css);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domUtil/addClass.js
var addClass = __webpack_require__(204);
var addClass_default = /*#__PURE__*/__webpack_require__.n(addClass);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domUtil/removeClass.js
var removeClass = __webpack_require__(462);
var removeClass_default = /*#__PURE__*/__webpack_require__.n(removeClass);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isString.js
var type_isString = __webpack_require__(758);
var isString_default = /*#__PURE__*/__webpack_require__.n(type_isString);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isNumber.js
var isNumber = __webpack_require__(321);
var isNumber_default = /*#__PURE__*/__webpack_require__.n(isNumber);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isUndefined.js
var isUndefined = __webpack_require__(929);
var isUndefined_default = /*#__PURE__*/__webpack_require__.n(isUndefined);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isNull.js
var isNull = __webpack_require__(934);
var isNull_default = /*#__PURE__*/__webpack_require__.n(isNull);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/request/sendHostname.js
var sendHostname = __webpack_require__(391);
var sendHostname_default = /*#__PURE__*/__webpack_require__.n(sendHostname);
;// CONCATENATED MODULE: ./src/utils/common.ts
var isMac = /Mac/.test(navigator.platform);
var reSpaceMoreThanOne = /[\u0020]+/g;
var reEscapeChars = /[>(){}[\]+-.!#|]/g;
var reEscapeHTML = /<([a-zA-Z_][a-zA-Z0-9\-._]*)(\s|[^\\>])*\/?>|<(\/)([a-zA-Z_][a-zA-Z0-9\-._]*)\s*\/?>||<([a-zA-Z_][a-zA-Z0-9\-.:/]*)>/g;
var reEscapeBackSlash = /\\[!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~\\]/g;
var reEscapePairedChars = /[*_~`]/g;
var reMdImageSyntax = /!\[.*\]\(.*\)/g;
var reEscapedCharInLinkSyntax = /[[\]]/g;
var reEscapeBackSlashInSentence = /(?:^|[^\\])\\(?!\\)/g;
var XMLSPECIAL = '[&<>"]';
var reXmlSpecial = new RegExp(XMLSPECIAL, 'g');
function replaceUnsafeChar(char) {
switch (char) {
case '&':
return '&';
case '<':
return '<';
case '>':
return '>';
case '"':
return '"';
default:
return char;
}
}
function escapeXml(text) {
if (reXmlSpecial.test(text)) {
return text.replace(reXmlSpecial, replaceUnsafeChar);
}
return text;
}
function sendHostName() {
sendHostname_default()('editor', 'UA-129966929-1');
}
function common_includes(arr, targetItem) {
return arr.indexOf(targetItem) !== -1;
}
var availableLinkAttributes = ['rel', 'target', 'hreflang', 'type'];
var reMarkdownTextToEscapeMap = {
codeblock: /(^ {4}[^\n]+\n*)+/,
thematicBreak: /^ *((\* *){3,}|(- *){3,} *|(_ *){3,}) */,
atxHeading: /^(#{1,6}) +[\s\S]+/,
seTextheading: /^([^\n]+)\n *(=|-){2,} */,
blockquote: /^( *>[^\n]+.*)+/,
list: /^ *(\*+|-+|\d+\.) [\s\S]+/,
def: /^ *\[([^\]]+)\]: *([^\s>]+)>?(?: +["(]([^\n]+)[")])? */,
link: /!?\[.*\]\(.*\)/,
reflink: /!?\[.*\]\s*\[([^\]]*)\]/,
verticalBar: /\u007C/,
fencedCodeblock: /^((`|~){3,})/,
};
function sanitizeLinkAttribute(attribute) {
if (!attribute) {
return null;
}
var linkAttributes = {};
availableLinkAttributes.forEach(function (key) {
if (!isUndefined_default()(attribute[key])) {
linkAttributes[key] = attribute[key];
}
});
return linkAttributes;
}
function repeat(text, count) {
var result = '';
for (var i = 0; i < count; i += 1) {
result += text;
}
return result;
}
function isNeedEscapeText(text) {
var needEscape = false;
forEachOwnProperties_default()(reMarkdownTextToEscapeMap, function (reMarkdownTextToEscape) {
if (reMarkdownTextToEscape.test(text)) {
needEscape = true;
}
return !needEscape;
});
return needEscape;
}
function escapeTextForLink(text) {
var imageSyntaxRanges = [];
var result = reMdImageSyntax.exec(text);
while (result) {
imageSyntaxRanges.push([result.index, result.index + result[0].length]);
result = reMdImageSyntax.exec(text);
}
return text.replace(reEscapedCharInLinkSyntax, function (matched, offset) {
var isDelimiter = imageSyntaxRanges.some(function (range) { return offset > range[0] && offset < range[1]; });
return isDelimiter ? matched : "\\" + matched;
});
}
function common_escape(text) {
var aheadReplacer = function (matched) { return "\\" + matched; };
var behindReplacer = function (matched) { return matched + "\\"; };
var escapedText = text.replace(reSpaceMoreThanOne, ' ');
if (reEscapeBackSlash.test(escapedText)) {
escapedText = escapedText.replace(reEscapeBackSlash, aheadReplacer);
}
if (reEscapeBackSlashInSentence.test(escapedText)) {
escapedText = escapedText.replace(reEscapeBackSlashInSentence, behindReplacer);
}
escapedText = escapedText.replace(reEscapePairedChars, aheadReplacer);
if (reEscapeHTML.test(escapedText)) {
escapedText = escapedText.replace(reEscapeHTML, aheadReplacer);
}
if (isNeedEscapeText(escapedText)) {
escapedText = escapedText.replace(reEscapeChars, aheadReplacer);
}
return escapedText;
}
function quote(text) {
var result;
if (text.indexOf('"') === -1) {
result = '""';
}
else {
result = text.indexOf("'") === -1 ? "''" : '()';
}
return result[0] + text + result[1];
}
function isNil(value) {
return isNull_default()(value) || isUndefined_default()(value);
}
function shallowEqual(o1, o2) {
if (o1 === null && o1 === o2) {
return true;
}
if (typeof o1 !== 'object' || typeof o2 !== 'object' || isNil(o1) || isNil(o2)) {
return o1 === o2;
}
for (var key in o1) {
if (o1[key] !== o2[key]) {
return false;
}
}
for (var key in o2) {
if (!(key in o1)) {
return false;
}
}
return true;
}
function last(arr) {
return arr[arr.length - 1];
}
function between(value, min, max) {
return value >= min && value <= max;
}
function isObject(obj) {
return typeof obj === 'object' && obj !== null;
}
function deepMergedCopy(targetObj, obj) {
var resultObj = __assign({}, targetObj);
if (targetObj && obj) {
Object.keys(obj).forEach(function (prop) {
if (isObject(resultObj[prop])) {
if (Array.isArray(obj[prop])) {
resultObj[prop] = deepCopyArray(obj[prop]);
}
else if (resultObj.hasOwnProperty(prop)) {
resultObj[prop] = deepMergedCopy(resultObj[prop], obj[prop]);
}
else {
resultObj[prop] = deepCopy(obj[prop]);
}
}
else {
resultObj[prop] = obj[prop];
}
});
}
return resultObj;
}
function deepCopyArray(items) {
return items.map(function (item) {
if (isObject(item)) {
return Array.isArray(item) ? deepCopyArray(item) : deepCopy(item);
}
return item;
});
}
function deepCopy(obj) {
var keys = Object.keys(obj);
if (!keys.length) {
return obj;
}
return keys.reduce(function (acc, prop) {
if (isObject(obj[prop])) {
acc[prop] = Array.isArray(obj[prop]) ? deepCopyArray(obj[prop]) : deepCopy(obj[prop]);
}
else {
acc[prop] = obj[prop];
}
return acc;
}, {});
}
function common_assign(targetObj, obj) {
if (obj === void 0) { obj = {}; }
Object.keys(obj).forEach(function (prop) {
if (targetObj.hasOwnProperty(prop) && typeof targetObj[prop] === 'object') {
if (Array.isArray(obj[prop])) {
targetObj[prop] = obj[prop];
}
else {
common_assign(targetObj[prop], obj[prop]);
}
}
else {
targetObj[prop] = obj[prop];
}
});
return targetObj;
}
function getSortedNumPair(valueA, valueB) {
return valueA > valueB ? [valueB, valueA] : [valueA, valueB];
}
function isStartWithSpace(text) {
var reStartWithSpace = /^\s(\S*)/g;
return reStartWithSpace.test(text);
}
function isEndWithSpace(text) {
var reEndWithSpace = /(\S*)\s$/g;
return reEndWithSpace.test(text);
}
// EXTERNAL MODULE: external {"commonjs":"prosemirror-view","commonjs2":"prosemirror-view","amd":"prosemirror-view"}
var external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_ = __webpack_require__(311);
// EXTERNAL MODULE: external {"commonjs":"prosemirror-transform","commonjs2":"prosemirror-transform","amd":"prosemirror-transform"}
var external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_ = __webpack_require__(785);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/collection/toArray.js
var collection_toArray = __webpack_require__(990);
var toArray_default = /*#__PURE__*/__webpack_require__.n(collection_toArray);
// EXTERNAL MODULE: external {"commonjs":"prosemirror-state","commonjs2":"prosemirror-state","amd":"prosemirror-state"}
var external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_ = __webpack_require__(814);
// EXTERNAL MODULE: external {"commonjs":"prosemirror-keymap","commonjs2":"prosemirror-keymap","amd":"prosemirror-keymap"}
var external_commonjs_prosemirror_keymap_commonjs2_prosemirror_keymap_amd_prosemirror_keymap_ = __webpack_require__(481);
// EXTERNAL MODULE: external {"commonjs":"prosemirror-commands","commonjs2":"prosemirror-commands","amd":"prosemirror-commands"}
var external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_ = __webpack_require__(695);
// EXTERNAL MODULE: external {"commonjs":"prosemirror-inputrules","commonjs2":"prosemirror-inputrules","amd":"prosemirror-inputrules"}
var external_commonjs_prosemirror_inputrules_commonjs2_prosemirror_inputrules_amd_prosemirror_inputrules_ = __webpack_require__(479);
// EXTERNAL MODULE: external {"commonjs":"prosemirror-history","commonjs2":"prosemirror-history","amd":"prosemirror-history"}
var external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_ = __webpack_require__(412);
;// CONCATENATED MODULE: ./src/helper/manipulation.ts
function createParagraph(schema, content) {
var paragraph = schema.nodes.paragraph;
if (!content) {
return paragraph.createAndFill();
}
return paragraph.create(null, isString_default()(content) ? schema.text(content) : content);
}
function createTextNode(schema, text, marks) {
return schema.text(text, marks);
}
function createTextSelection(tr, from, to) {
if (to === void 0) { to = from; }
var contentSize = tr.doc.content.size;
var size = contentSize > 0 ? contentSize - 1 : 1;
return external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.TextSelection.create(tr.doc, Math.min(from, size), Math.min(to, size));
}
function addParagraph(tr, _a, schema) {
var pos = _a.pos;
tr.replaceWith(pos, pos, createParagraph(schema));
return tr.setSelection(createTextSelection(tr, pos + 1));
}
function replaceTextNode(_a) {
var state = _a.state, from = _a.from, startIndex = _a.startIndex, endIndex = _a.endIndex, createText = _a.createText;
var tr = state.tr, doc = state.doc, schema = state.schema;
for (var i = startIndex; i <= endIndex; i += 1) {
var _b = doc.child(i), nodeSize = _b.nodeSize, textContent = _b.textContent, content = _b.content;
var text = createText(textContent);
var node = text ? createTextNode(schema, text) : external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty;
var mappedFrom = tr.mapping.map(from);
var mappedTo = mappedFrom + content.size;
tr.replaceWith(mappedFrom, mappedTo, node);
from += nodeSize;
}
return tr;
}
function splitAndExtendBlock(tr, pos, text, node) {
var textLen = text.length;
tr.split(pos)
.delete(pos - textLen, pos)
.insert(tr.mapping.map(pos), node)
.setSelection(createTextSelection(tr, tr.mapping.map(pos) - textLen));
}
;// CONCATENATED MODULE: ./src/utils/markdown.ts
function hasSpecificTypeAncestor(mdNode) {
var types = [];
for (var _i = 1; _i < arguments.length; _i++) {
types[_i - 1] = arguments[_i];
}
while (mdNode && mdNode.parent && mdNode.parent.type !== 'document') {
if (includes(types, mdNode.parent.type)) {
return true;
}
mdNode = mdNode.parent;
}
return false;
}
function getMdStartLine(mdNode) {
return mdNode.sourcepos[0][0];
}
function getMdEndLine(mdNode) {
return mdNode.sourcepos[1][0];
}
function getMdStartCh(mdNode) {
return mdNode.sourcepos[0][1];
}
function getMdEndCh(mdNode) {
return mdNode.sourcepos[1][1];
}
function isMultiLineNode(mdNode) {
var type = mdNode.type;
return type === 'codeBlock' || type === 'paragraph';
}
function isHTMLNode(mdNode) {
var type = mdNode.type;
return type === 'htmlBlock' || type === 'htmlInline';
}
function isStyledInlineNode(mdNode) {
var type = mdNode.type;
return (type === 'strike' ||
type === 'strong' ||
type === 'emph' ||
type === 'code' ||
type === 'link' ||
type === 'image');
}
function isCodeBlockNode(mdNode) {
return mdNode && mdNode.type === 'codeBlock';
}
function isCustomBlockNode(mdNode) {
return mdNode && mdNode.type === 'customBlock';
}
function isListNode(mdNode) {
return mdNode && (mdNode.type === 'item' || mdNode.type === 'list');
}
function isOrderedListNode(mdNode) {
return isListNode(mdNode) && mdNode.listData.type === 'ordered';
}
function isBulletListNode(mdNode) {
return isListNode(mdNode) && mdNode.listData.type !== 'ordered';
}
function isTableCellNode(mdNode) {
return mdNode && (mdNode.type === 'tableCell' || mdNode.type === 'tableDelimCell');
}
function isInlineNode(mdNode) {
switch (mdNode.type) {
case 'code':
case 'text':
case 'emph':
case 'strong':
case 'strike':
case 'link':
case 'image':
case 'htmlInline':
case 'linebreak':
case 'softbreak':
case 'customInline':
return true;
default:
return false;
}
}
function findClosestNode(mdNode, condition, includeSelf) {
if (includeSelf === void 0) { includeSelf = true; }
mdNode = includeSelf ? mdNode : mdNode.parent;
while (mdNode && mdNode.type !== 'document') {
if (condition(mdNode)) {
return mdNode;
}
mdNode = mdNode.parent;
}
return null;
}
function traverseParentNodes(mdNode, iteratee, includeSelf) {
if (includeSelf === void 0) { includeSelf = true; }
mdNode = includeSelf ? mdNode : mdNode.parent;
while (mdNode && mdNode.type !== 'document') {
iteratee(mdNode);
mdNode = mdNode.parent;
}
}
function addOffsetPos(originPos, offset) {
return [originPos[0], originPos[1] + offset];
}
function setOffsetPos(originPos, newOffset) {
return [originPos[0], newOffset];
}
function getInlineMarkdownText(mdNode) {
var text = mdNode.firstChild.literal;
switch (mdNode.type) {
case 'emph':
return "*" + text + "*";
case 'strong':
return "**" + text + "**";
case 'strike':
return "~~" + text + "~~";
case 'code':
return "`" + text + "`";
case 'link':
case 'image':
/* eslint-disable no-case-declarations */
var _a = mdNode, destination = _a.destination, title = _a.title;
var delim = mdNode.type === 'link' ? '' : '!';
return delim + "[" + text + "](" + destination + (title ? " \"" + title + "\"" : '') + ")";
default:
return null;
}
}
function isContainer(node) {
switch (node.type) {
case 'document':
case 'blockQuote':
case 'list':
case 'item':
case 'paragraph':
case 'heading':
case 'emph':
case 'strong':
case 'strike':
case 'link':
case 'image':
case 'table':
case 'tableHead':
case 'tableBody':
case 'tableRow':
case 'tableCell':
case 'tableDelimRow':
case 'customInline':
return true;
default:
return false;
}
}
function getChildrenText(node) {
var buffer = [];
var walker = node.walker();
var event = null;
while ((event = walker.next())) {
var childNode = event.node;
if (childNode.type === 'text') {
buffer.push(childNode.literal);
}
}
return buffer.join('');
}
;// CONCATENATED MODULE: ./src/widget/rules.ts
var widgetRules = [];
var widgetRuleMap = {};
var reWidgetPrefix = /\$\$widget\d+\s/;
function unwrapWidgetSyntax(text) {
var index = text.search(reWidgetPrefix);
if (index !== -1) {
var rest = text.substring(index);
var replaced = rest.replace(reWidgetPrefix, '').replace('$$', '');
text = text.substring(0, index);
text += unwrapWidgetSyntax(replaced);
}
return text;
}
function createWidgetContent(info, text) {
return "$$" + info + " " + text + "$$";
}
function widgetToDOM(info, text) {
var _a = widgetRuleMap[info], rule = _a.rule, toDOM = _a.toDOM;
var matches = unwrapWidgetSyntax(text).match(rule);
if (matches) {
text = matches[0];
}
return toDOM(text);
}
function getWidgetRules() {
return widgetRules;
}
function setWidgetRules(rules) {
widgetRules = rules;
widgetRules.forEach(function (rule, index) {
widgetRuleMap["widget" + index] = rule;
});
}
function mergeNodes(nodes, text, schema, ruleIndex) {
return nodes.concat(createNodesWithWidget(text, schema, ruleIndex));
}
/**
* create nodes with plain text and replace text matched to the widget rules with the widget node
* For example, in case the text and widget rules as below
*
* text: $test plain text #test
* widget rules: [{ rule: /$.+/ }, { rule: /#.+/ }]
*
* The creating node process is recursive and is as follows.
*
* in first widget rule(/$.+/)
* $test -> widget node
* plain text -> match with next widget rule
* #test -> match with next widget rule
*
* in second widget rule(/#.+/)
* plain text -> text node(no rule for matching)
* #test -> widget node
*/
function createNodesWithWidget(text, schema, ruleIndex) {
if (ruleIndex === void 0) { ruleIndex = 0; }
var nodes = [];
var rule = (widgetRules[ruleIndex] || {}).rule;
var nextRuleIndex = ruleIndex + 1;
text = unwrapWidgetSyntax(text);
if (rule && rule.test(text)) {
var index = void 0;
while ((index = text.search(rule)) !== -1) {
var prev = text.substring(0, index);
// get widget node on first splitted text using next widget rule
if (prev) {
nodes = mergeNodes(nodes, prev, schema, nextRuleIndex);
}
// build widget node using current widget rule
text = text.substring(index);
var literal = text.match(rule)[0];
var info = "widget" + ruleIndex;
nodes.push(schema.nodes.widget.create({ info: info }, schema.text(createWidgetContent(info, literal))));
text = text.substring(literal.length);
}
// get widget node on last splitted text using next widget rule
if (text) {
nodes = mergeNodes(nodes, text, schema, nextRuleIndex);
}
}
else if (text) {
nodes =
ruleIndex < widgetRules.length - 1
? mergeNodes(nodes, text, schema, nextRuleIndex)
: [schema.text(text)];
}
return nodes;
}
function getWidgetContent(widgetNode) {
var event;
var text = '';
var walker = widgetNode.walker();
while ((event = walker.next())) {
var node = event.node, entering = event.entering;
if (entering) {
if (node !== widgetNode && node.type !== 'text') {
text += getInlineMarkdownText(node);
// skip the children
walker.resumeAt(widgetNode, false);
walker.next();
}
else if (node.type === 'text') {
text += node.literal;
}
}
}
return text;
}
;// CONCATENATED MODULE: ./src/commands/defaultCommands.ts
function getDefaultCommands() {
return {
deleteSelection: function () { return external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.deleteSelection; },
selectAll: function () { return external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.selectAll; },
undo: function () { return external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.undo; },
redo: function () { return external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.redo; },
};
}
;// CONCATENATED MODULE: ./src/plugins/placeholder.ts
function placeholder(options) {
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
props: {
decorations: function (state) {
var doc = state.doc;
if (options.text &&
doc.childCount === 1 &&
doc.firstChild.isTextblock &&
doc.firstChild.content.size === 0) {
var placeHolder = document.createElement('span');
addClass_default()(placeHolder, 'placeholder');
if (options.className) {
addClass_default()(placeHolder, options.className);
}
placeHolder.textContent = options.text;
return external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.DecorationSet.create(doc, [external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.Decoration.widget(1, placeHolder)]);
}
return null;
},
},
});
}
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isArray.js
var isArray = __webpack_require__(322);
var isArray_default = /*#__PURE__*/__webpack_require__.n(isArray);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domUtil/hasClass.js
var hasClass = __webpack_require__(714);
var hasClass_default = /*#__PURE__*/__webpack_require__.n(hasClass);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domUtil/matches.js
var matches = __webpack_require__(471);
var matches_default = /*#__PURE__*/__webpack_require__.n(matches);
;// CONCATENATED MODULE: ./src/utils/constants.ts
var TAG_NAME = '[A-Za-z][A-Za-z0-9-]*';
var ATTRIBUTE_NAME = '[a-zA-Z_:][a-zA-Z0-9:._-]*';
var UNQUOTED_VALUE = '[^"\'=<>`\\x00-\\x20]+';
var SINGLE_QUOTED_VALUE = "'[^']*'";
var DOUBLE_QUOTED_VALUE = '"[^"]*"';
var ATTRIBUTE_VALUE = "(?:" + UNQUOTED_VALUE + "|" + SINGLE_QUOTED_VALUE + "|" + DOUBLE_QUOTED_VALUE + ")";
var ATTRIBUTE_VALUE_SPEC = "" + '(?:\\s*=\\s*' + ATTRIBUTE_VALUE + ")";
var ATTRIBUTE = "" + '(?:\\s+' + ATTRIBUTE_NAME + ATTRIBUTE_VALUE_SPEC + "?)";
var OPEN_TAG = "<(" + TAG_NAME + ")(" + ATTRIBUTE + ")*\\s*/?>";
var CLOSE_TAG = "(" + TAG_NAME + ")\\s*[>]";
var HTML_TAG = "(?:" + OPEN_TAG + "|" + CLOSE_TAG + ")";
var reHTMLTag = new RegExp("^" + HTML_TAG, 'i');
var reBR = / /i;
var reHTMLComment = /|/;
var ALTERNATIVE_TAG_FOR_BR = '';
var DEFAULT_TEXT_NOT_START_OR_END_WITH_SPACE = 'a';
;// CONCATENATED MODULE: ./src/utils/dom.ts
function isPositionInBox(style, offsetX, offsetY) {
var left = parseInt(style.left, 10);
var top = parseInt(style.top, 10);
var width = parseInt(style.width, 10) + parseInt(style.paddingLeft, 10) + parseInt(style.paddingRight, 10);
var height = parseInt(style.height, 10) + parseInt(style.paddingTop, 10) + parseInt(style.paddingBottom, 10);
return offsetX >= left && offsetX <= left + width && offsetY >= top && offsetY <= top + height;
}
var CLS_PREFIX = 'toastui-editor-';
function cls() {
var names = [];
for (var _i = 0; _i < arguments.length; _i++) {
names[_i] = arguments[_i];
}
var result = [];
for (var _a = 0, names_1 = names; _a < names_1.length; _a++) {
var name = names_1[_a];
var className = void 0;
if (Array.isArray(name)) {
className = name[0] ? name[1] : null;
}
else {
className = name;
}
if (className) {
result.push("" + CLS_PREFIX + className);
}
}
return result.join(' ');
}
function clsWithMdPrefix() {
var names = [];
for (var _i = 0; _i < arguments.length; _i++) {
names[_i] = arguments[_i];
}
return names.map(function (className) { return CLS_PREFIX + "md-" + className; }).join(' ');
}
function isTextNode(node) {
return (node === null || node === void 0 ? void 0 : node.nodeType) === Node.TEXT_NODE;
}
function isElemNode(node) {
return node && node.nodeType === Node.ELEMENT_NODE;
}
function findNodes(element, selector) {
var nodeList = toArray_default()(element.querySelectorAll(selector));
if (nodeList.length) {
return nodeList;
}
return [];
}
function appendNodes(node, nodesToAppend) {
nodesToAppend = isArray_default()(nodesToAppend) ? toArray_default()(nodesToAppend) : [nodesToAppend];
nodesToAppend.forEach(function (nodeToAppend) {
node.appendChild(nodeToAppend);
});
}
function insertBeforeNode(insertedNode, node) {
if (node.parentNode) {
node.parentNode.insertBefore(insertedNode, node);
}
}
function removeNode(node) {
if (node.parentNode) {
node.parentNode.removeChild(node);
}
}
function unwrapNode(node) {
var result = [];
while (node.firstChild) {
result.push(node.firstChild);
if (node.parentNode) {
node.parentNode.insertBefore(node.firstChild, node);
}
}
removeNode(node);
return result;
}
function toggleClass(element, className, state) {
if (isUndefined_default()(state)) {
state = !hasClass_default()(element, className);
}
var toggleFn = state ? (addClass_default()) : (removeClass_default());
toggleFn(element, className);
}
function createElementWith(contents, target) {
var container = document.createElement('div');
if (isString_default()(contents)) {
container.innerHTML = contents;
}
else {
container.appendChild(contents);
}
var firstChild = container.firstChild;
if (target) {
target.appendChild(firstChild);
}
return firstChild;
}
function getOuterWidth(el) {
var computed = window.getComputedStyle(el);
return (['margin-left', 'margin-right'].reduce(function (acc, type) { return acc + parseInt(computed.getPropertyValue(type), 10); }, 0) + el.offsetWidth);
}
function closest(node, found) {
var condition;
if (isString_default()(found)) {
condition = function (target) { return matches_default()(target, found); };
}
else {
condition = function (target) { return target === found; };
}
while (node && node !== document) {
if (isElemNode(node) && condition(node)) {
return node;
}
node = node.parentNode;
}
return null;
}
function getTotalOffset(el, root) {
var offsetTop = 0;
var offsetLeft = 0;
while (el && el !== root) {
var top = el.offsetTop, left = el.offsetLeft, offsetParent = el.offsetParent;
offsetTop += top;
offsetLeft += left;
if (offsetParent === root.offsetParent) {
break;
}
el = el.offsetParent;
}
return { offsetTop: offsetTop, offsetLeft: offsetLeft };
}
function finalizeHtml(html, needHtmlText) {
var result;
if (needHtmlText) {
result = html.innerHTML;
}
else {
var frag = document.createDocumentFragment();
var childNodes = toArray(html.childNodes);
var length = childNodes.length;
for (var i = 0; i < length; i += 1) {
frag.appendChild(childNodes[i]);
}
result = frag;
}
return result;
}
function empty(node) {
while (node.firstChild) {
node.removeChild(node.firstChild);
}
}
function appendNode(node, appended) {
if (isString(appended)) {
node.insertAdjacentHTML('beforeend', appended);
}
else {
var nodes = appended.length
? toArray(appended)
: [appended];
for (var i = 0, len = nodes.length; i < len; i += 1) {
node.appendChild(nodes[i]);
}
}
}
function prependNode(node, appended) {
if (isString(appended)) {
node.insertAdjacentHTML('afterbegin', appended);
}
else {
var nodes = appended.length
? toArray(appended)
: [appended];
for (var i = nodes.length - 1, len = 0; i >= len; i -= 1) {
node.insertBefore(nodes[i], node.firstChild);
}
}
}
function setAttributes(attributes, element) {
Object.keys(attributes).forEach(function (attrName) {
if (isNil(attributes[attrName])) {
element.removeAttribute(attrName);
}
else {
element.setAttribute(attrName, attributes[attrName]);
}
});
}
function replaceBRWithEmptyBlock(html) {
// remove br in paragraph to compatible with markdown
var replacedHTML = html.replace(/
<\/p>/gi, '
');
var reHTMLTag = new RegExp(HTML_TAG, 'ig');
var htmlTagMatched = replacedHTML.match(reHTMLTag);
htmlTagMatched === null || htmlTagMatched === void 0 ? void 0 : htmlTagMatched.forEach(function (htmlTag, index) {
if (reBR.test(htmlTag)) {
var alternativeTag = ALTERNATIVE_TAG_FOR_BR;
if (index) {
var prevTag = htmlTagMatched[index - 1];
var openTagMatched = prevTag.match(OPEN_TAG);
if (openTagMatched && !/br/i.test(openTagMatched[1])) {
var tagName = openTagMatched[1];
alternativeTag = "" + tagName + "><" + tagName + ">";
}
}
replacedHTML = replacedHTML.replace(reBR, alternativeTag);
}
});
return replacedHTML;
}
function removeProseMirrorHackNodes(html) {
var reProseMirrorImage = / /g;
var reProseMirrorTrailingBreak = / class="ProseMirror-trailingBreak"/g;
var resultHTML = html;
resultHTML = resultHTML.replace(reProseMirrorImage, '');
resultHTML = resultHTML.replace(reProseMirrorTrailingBreak, '');
return resultHTML;
}
;// CONCATENATED MODULE: ./src/plugins/popupWidget.ts
var pluginKey = new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.PluginKey('widget');
var MARGIN = 5;
var PopupWidget = /** @class */ (function () {
function PopupWidget(view, eventEmitter) {
var _this = this;
this.popup = null;
this.removeWidget = function () {
if (_this.popup) {
_this.rootEl.removeChild(_this.popup);
_this.popup = null;
}
};
this.rootEl = view.dom.parentElement;
this.eventEmitter = eventEmitter;
this.eventEmitter.listen('blur', this.removeWidget);
this.eventEmitter.listen('loadUI', function () {
_this.rootEl = closest(view.dom.parentElement, "." + cls('defaultUI'));
});
this.eventEmitter.listen('removePopupWidget', this.removeWidget);
}
PopupWidget.prototype.update = function (view) {
var widget = pluginKey.getState(view.state);
this.removeWidget();
if (widget) {
var node = widget.node, style = widget.style;
var _a = view.coordsAtPos(widget.pos), top = _a.top, left = _a.left, bottom = _a.bottom;
var height = bottom - top;
var rect = this.rootEl.getBoundingClientRect();
var relTopPos = top - rect.top;
css_default()(node, { opacity: '0' });
this.rootEl.appendChild(node);
css_default()(node, {
position: 'absolute',
left: left - rect.left + MARGIN + "px",
top: (style === 'bottom' ? relTopPos + height - MARGIN : relTopPos - height) + "px",
opacity: '1',
});
this.popup = node;
view.focus();
}
};
PopupWidget.prototype.destroy = function () {
this.eventEmitter.removeEventHandler('blur', this.removeWidget);
};
return PopupWidget;
}());
function addWidget(eventEmitter) {
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
key: pluginKey,
state: {
init: function () {
return null;
},
apply: function (tr) {
return tr.getMeta('widget');
},
},
view: function (editorView) {
return new PopupWidget(editorView, eventEmitter);
},
});
}
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/collection/forEachArray.js
var forEachArray = __webpack_require__(893);
var forEachArray_default = /*#__PURE__*/__webpack_require__.n(forEachArray);
;// CONCATENATED MODULE: ./src/helper/image.ts
function addDefaultImageBlobHook(eventEmitter) {
eventEmitter.listen('addImageBlobHook', function (blob, callback) {
var reader = new FileReader();
reader.onload = function (_a) {
var target = _a.target;
return callback(target.result);
};
reader.readAsDataURL(blob);
});
}
function emitImageBlobHook(eventEmitter, blob, type) {
var hook = function (imageUrl, altText) {
eventEmitter.emit('command', 'addImage', {
imageUrl: imageUrl,
altText: altText || blob.name || 'image',
});
};
eventEmitter.emit('addImageBlobHook', blob, hook, type);
}
function pasteImageOnly(items) {
var images = toArray_default()(items).filter(function (_a) {
var type = _a.type;
return type.indexOf('image') !== -1;
});
if (images.length === 1) {
var item = images[0];
if (item) {
return item.getAsFile();
}
}
return null;
}
;// CONCATENATED MODULE: ./src/plugins/dropImage.ts
function dropImage(_a) {
var eventEmitter = _a.eventEmitter;
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
props: {
handleDOMEvents: {
drop: function (_, ev) {
var _a;
var items = (_a = ev.dataTransfer) === null || _a === void 0 ? void 0 : _a.files;
if (items) {
forEachArray_default()(items, function (item) {
if (item.type.indexOf('image') !== -1) {
ev.preventDefault();
ev.stopPropagation();
emitImageBlobHook(eventEmitter, item, ev.type);
return false;
}
return true;
});
}
return true;
},
},
},
});
}
;// CONCATENATED MODULE: ./src/spec/node.ts
var node_Node = /** @class */ (function () {
function Node() {
}
Object.defineProperty(Node.prototype, "type", {
get: function () {
return 'node';
},
enumerable: false,
configurable: true
});
Node.prototype.setContext = function (context) {
this.context = context;
};
return Node;
}());
/* harmony default export */ var node = (node_Node);
;// CONCATENATED MODULE: ./src/widget/widgetNode.ts
function widgetNodeView(pmNode) {
var dom = document.createElement('span');
var node = widgetToDOM(pmNode.attrs.info, pmNode.textContent);
dom.className = 'tui-widget';
dom.appendChild(node);
return { dom: dom };
}
function isWidgetNode(pmNode) {
return pmNode.type.name === 'widget';
}
var Widget = /** @class */ (function (_super) {
__extends(Widget, _super);
function Widget() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Widget.prototype, "name", {
get: function () {
return 'widget';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Widget.prototype, "schema", {
get: function () {
return {
attrs: {
info: { default: null },
},
group: 'inline',
inline: true,
content: 'text*',
selectable: false,
atom: true,
toDOM: function () {
return ['span', { class: 'tui-widget' }, 0];
},
parseDOM: [
{
tag: 'span.tui-widget',
getAttrs: function (dom) {
var text = dom.textContent;
var _a = text.match(/\$\$(widget\d+)/), info = _a[1];
return { info: info };
},
},
],
};
},
enumerable: false,
configurable: true
});
return Widget;
}(node));
;// CONCATENATED MODULE: ./src/base.ts
var EditorBase = /** @class */ (function () {
function EditorBase(eventEmitter) {
this.timer = null;
this.el = document.createElement('div');
this.el.className = 'toastui-editor';
this.eventEmitter = eventEmitter;
this.placeholder = { text: '' };
}
EditorBase.prototype.createState = function () {
return external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.EditorState.create({
schema: this.schema,
plugins: this.createPlugins(),
});
};
EditorBase.prototype.initEvent = function () {
var _a = this, eventEmitter = _a.eventEmitter, view = _a.view, editorType = _a.editorType;
view.dom.addEventListener('focus', function () { return eventEmitter.emit('focus', editorType); });
view.dom.addEventListener('blur', function () { return eventEmitter.emit('blur', editorType); });
};
EditorBase.prototype.emitChangeEvent = function (tr) {
this.eventEmitter.emit('caretChange', this.editorType);
if (tr.docChanged) {
this.eventEmitter.emit('change', this.editorType);
}
};
Object.defineProperty(EditorBase.prototype, "defaultPlugins", {
get: function () {
var rules = this.createInputRules();
var plugins = __spreadArray(__spreadArray([], this.keymaps), [
(0,external_commonjs_prosemirror_keymap_commonjs2_prosemirror_keymap_amd_prosemirror_keymap_.keymap)(__assign({ 'Shift-Enter': external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.baseKeymap.Enter }, external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.baseKeymap)),
(0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.history)(),
placeholder(this.placeholder),
addWidget(this.eventEmitter),
dropImage(this.context),
]);
return rules ? plugins.concat(rules) : plugins;
},
enumerable: false,
configurable: true
});
EditorBase.prototype.createInputRules = function () {
var widgetRules = getWidgetRules();
var rules = widgetRules.map(function (_a) {
var rule = _a.rule;
return new external_commonjs_prosemirror_inputrules_commonjs2_prosemirror_inputrules_amd_prosemirror_inputrules_.InputRule(rule, function (state, match, start, end) {
var schema = state.schema, tr = state.tr, doc = state.doc;
var allMatched = match.input.match(new RegExp(rule, 'g'));
var pos = doc.resolve(start);
var parent = pos.parent;
var count = 0;
if (isWidgetNode(parent)) {
parent = pos.node(pos.depth - 1);
}
parent.forEach(function (child) { return isWidgetNode(child) && (count += 1); });
// replace the content only if the count of matched rules in whole text is greater than current widget node count
if (allMatched.length > count) {
var content = last(allMatched);
var nodes = createNodesWithWidget(content, schema);
// adjust start position based on widget content
return tr.replaceWith(end - content.length + 1, end, nodes);
}
return null;
});
});
return rules.length ? (0,external_commonjs_prosemirror_inputrules_commonjs2_prosemirror_inputrules_amd_prosemirror_inputrules_.inputRules)({ rules: rules }) : null;
};
EditorBase.prototype.clearTimer = function () {
if (this.timer) {
clearTimeout(this.timer);
this.timer = null;
}
};
EditorBase.prototype.createSchema = function () {
return new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Schema({
nodes: this.specs.nodes,
marks: this.specs.marks,
});
};
EditorBase.prototype.createKeymaps = function (useCommandShortcut) {
var _a = getDefaultCommands(), undo = _a.undo, redo = _a.redo;
var allKeymaps = this.specs.keymaps(useCommandShortcut);
var historyKeymap = {
'Mod-z': undo(),
'Shift-Mod-z': redo(),
};
return useCommandShortcut ? allKeymaps.concat((0,external_commonjs_prosemirror_keymap_commonjs2_prosemirror_keymap_amd_prosemirror_keymap_.keymap)(historyKeymap)) : allKeymaps;
};
EditorBase.prototype.createCommands = function () {
return this.specs.commands(this.view);
};
EditorBase.prototype.createPluginProps = function () {
var _this = this;
return this.extraPlugins.map(function (plugin) { return plugin(_this.eventEmitter); });
};
EditorBase.prototype.focus = function () {
var _this = this;
this.clearTimer();
// prevent the error for IE11
this.timer = setTimeout(function () {
_this.view.focus();
_this.view.dispatch(_this.view.state.tr.scrollIntoView());
});
};
EditorBase.prototype.blur = function () {
this.view.dom.blur();
};
EditorBase.prototype.destroy = function () {
var _this = this;
this.clearTimer();
this.view.destroy();
Object.keys(this).forEach(function (prop) {
delete _this[prop];
});
};
EditorBase.prototype.moveCursorToStart = function (focus) {
var tr = this.view.state.tr;
this.view.dispatch(tr.setSelection(createTextSelection(tr, 1)).scrollIntoView());
if (focus) {
this.focus();
}
};
EditorBase.prototype.moveCursorToEnd = function (focus) {
var tr = this.view.state.tr;
this.view.dispatch(tr.setSelection(createTextSelection(tr, tr.doc.content.size - 1)).scrollIntoView());
if (focus) {
this.focus();
}
};
EditorBase.prototype.setScrollTop = function (top) {
this.view.dom.scrollTop = top;
};
EditorBase.prototype.getScrollTop = function () {
return this.view.dom.scrollTop;
};
EditorBase.prototype.setPlaceholder = function (text) {
this.placeholder.text = text;
this.view.dispatch(this.view.state.tr.scrollIntoView());
};
EditorBase.prototype.setHeight = function (height) {
css_default()(this.el, { height: height + "px" });
};
EditorBase.prototype.setMinHeight = function (minHeight) {
css_default()(this.el, { minHeight: minHeight + "px" });
};
EditorBase.prototype.getElement = function () {
return this.el;
};
return EditorBase;
}());
/* harmony default export */ var base = (EditorBase);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isFunction.js
var isFunction = __webpack_require__(294);
var isFunction_default = /*#__PURE__*/__webpack_require__.n(isFunction);
;// CONCATENATED MODULE: ./src/spec/specManager.ts
var defaultCommandShortcuts = [
'Enter',
'Shift-Enter',
'Mod-Enter',
'Tab',
'Shift-Tab',
'Delete',
'Backspace',
'Mod-Delete',
'Mod-Backspace',
'ArrowUp',
'ArrowDown',
'ArrowLeft',
'ArrowRight',
'Mod-d',
'Mod-D',
'Alt-ArrowUp',
'Alt-ArrowDown',
];
function execCommand(view, command, payload) {
view.focus();
return command(payload)(view.state, view.dispatch, view);
}
var SpecManager = /** @class */ (function () {
function SpecManager(specs) {
this.specs = specs;
}
Object.defineProperty(SpecManager.prototype, "nodes", {
get: function () {
return this.specs
.filter(function (spec) { return spec.type === 'node'; })
.reduce(function (nodes, _a) {
var _b;
var name = _a.name, schema = _a.schema;
return __assign(__assign({}, nodes), (_b = {}, _b[name] = schema, _b));
}, {});
},
enumerable: false,
configurable: true
});
Object.defineProperty(SpecManager.prototype, "marks", {
get: function () {
return this.specs
.filter(function (spec) { return spec.type === 'mark'; })
.reduce(function (marks, _a) {
var _b;
var name = _a.name, schema = _a.schema;
return __assign(__assign({}, marks), (_b = {}, _b[name] = schema, _b));
}, {});
},
enumerable: false,
configurable: true
});
SpecManager.prototype.commands = function (view, addedCommands) {
var specCommands = this.specs
.filter(function (_a) {
var commands = _a.commands;
return commands;
})
.reduce(function (allCommands, spec) {
var commands = {};
var specCommand = spec.commands();
if (isFunction_default()(specCommand)) {
commands[spec.name] = function (payload) { return execCommand(view, specCommand, payload); };
}
else {
Object.keys(specCommand).forEach(function (name) {
commands[name] = function (payload) { return execCommand(view, specCommand[name], payload); };
});
}
return __assign(__assign({}, allCommands), commands);
}, {});
var defaultCommands = getDefaultCommands();
Object.keys(defaultCommands).forEach(function (name) {
specCommands[name] = function (payload) { return execCommand(view, defaultCommands[name], payload); };
});
if (addedCommands) {
Object.keys(addedCommands).forEach(function (name) {
specCommands[name] = function (payload) { return execCommand(view, addedCommands[name], payload); };
});
}
return specCommands;
};
SpecManager.prototype.keymaps = function (useCommandShortcut) {
var specKeymaps = this.specs.filter(function (spec) { return spec.keymaps; }).map(function (spec) { return spec.keymaps(); });
return specKeymaps.map(function (keys) {
if (!useCommandShortcut) {
Object.keys(keys).forEach(function (key) {
if (!common_includes(defaultCommandShortcuts, key)) {
delete keys[key];
}
});
}
return (0,external_commonjs_prosemirror_keymap_commonjs2_prosemirror_keymap_amd_prosemirror_keymap_.keymap)(keys);
});
};
SpecManager.prototype.setContext = function (context) {
this.specs.forEach(function (spec) {
spec.setContext(context);
});
};
return SpecManager;
}());
/* harmony default export */ var specManager = (SpecManager);
;// CONCATENATED MODULE: ./src/markdown/helper/pos.ts
function resolveSelectionPos(selection) {
var from = selection.from, to = selection.to;
if (selection instanceof external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.AllSelection) {
return [from + 1, to - 1];
}
return [from, to];
}
function getMdLine(resolvedPos) {
return resolvedPos.index(0) + 1;
}
function getWidgetNodePos(node, chPos, direction) {
if (direction === void 0) { direction = 1; }
var additionalPos = 0;
node.forEach(function (child, pos) {
// add or subtract widget node tag
if (isWidgetNode(child) && pos + 2 < chPos) {
additionalPos += 2 * direction;
}
});
return additionalPos;
}
function getEditorToMdPos(doc, from, to) {
if (to === void 0) { to = from; }
var collapsed = from === to;
var startResolvedPos = doc.resolve(from);
var startLine = getMdLine(startResolvedPos);
var endLine = startLine;
var startOffset = startResolvedPos.start(1);
var endOffset = startOffset;
if (!collapsed) {
// prevent the end offset from pointing to the root document position
var endResolvedPos = doc.resolve(to === doc.content.size ? to - 1 : to);
endOffset = endResolvedPos.start(1);
endLine = getMdLine(endResolvedPos);
// To resolve the end offset excluding document tag size
if (endResolvedPos.pos === doc.content.size) {
to = doc.content.size - 2;
}
}
var startCh = Math.max(from - startOffset + 1, 1);
var endCh = Math.max(to - endOffset + 1, 1);
return [
[startLine, startCh + getWidgetNodePos(doc.child(startLine - 1), startCh, -1)],
[endLine, endCh + getWidgetNodePos(doc.child(endLine - 1), endCh, -1)],
];
}
function getStartPosListPerLine(doc, endIndex) {
var startPosListPerLine = [];
for (var i = 0, pos = 0; i < endIndex; i += 1) {
var child = doc.child(i);
startPosListPerLine[i] = pos;
pos += child.nodeSize;
}
return startPosListPerLine;
}
function getMdToEditorPos(doc, startPos, endPos) {
var startPosListPerLine = getStartPosListPerLine(doc, endPos[0]);
var startIndex = startPos[0] - 1;
var endIndex = endPos[0] - 1;
var startNode = doc.child(startIndex);
var endNode = doc.child(endIndex);
// calculate the position corresponding to the line
var from = startPosListPerLine[startIndex];
var to = startPosListPerLine[endIndex];
// calculate the position corresponding to the character offset of the line
from += startPos[1] + getWidgetNodePos(startNode, startPos[1] - 1);
to += endPos[1] + getWidgetNodePos(endNode, endPos[1] - 1);
return [from, Math.min(to, doc.content.size)];
}
function getRangeInfo(selection) {
var $from = selection.$from, $to = selection.$to;
var from = selection.from, to = selection.to;
var doc = $from.doc;
if (selection instanceof external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.AllSelection) {
$from = doc.resolve(from + 1);
$to = doc.resolve(to - 1);
}
if ($from.depth === 0) {
$from = doc.resolve(from - 1);
$to = $from;
}
return {
startFromOffset: $from.start(1),
endFromOffset: $to.start(1),
startToOffset: $from.end(1),
endToOffset: $to.end(1),
startIndex: $from.index(0),
endIndex: $to.index(0),
from: $from.pos,
to: $to.pos,
};
}
function getNodeContentOffsetRange(doc, targetIndex) {
var startOffset = 1;
var endOffset = 1;
for (var i = 0, offset = 0; i < doc.childCount; i += 1) {
var nodeSize = doc.child(i).nodeSize;
// calculate content start, end offset(not node offset)
startOffset = offset + 1;
endOffset = offset + nodeSize - 1;
if (i === targetIndex) {
break;
}
offset += nodeSize;
}
return { startOffset: startOffset, endOffset: endOffset };
}
;// CONCATENATED MODULE: ./src/markdown/plugins/helper/markInfo.ts
var HEADING = 'heading';
var BLOCK_QUOTE = 'blockQuote';
var LIST_ITEM = 'listItem';
var TABLE = 'table';
var TABLE_CELL = 'tableCell';
var CODE_BLOCK = 'codeBlock';
var THEMATIC_BREAK = 'thematicBreak';
var LINK = 'link';
var CODE = 'code';
var META = 'meta';
var DELIM = 'delimiter';
var TASK_DELIM = 'taskDelimiter';
var TEXT = 'markedText';
var HTML = 'html';
var CUSTOM_BLOCK = 'customBlock';
var delimSize = {
strong: 2,
emph: 1,
strike: 2,
};
function markInfo(start, end, type, attrs) {
return { start: start, end: end, spec: { type: type, attrs: attrs } };
}
function heading(_a, start, end) {
var level = _a.level, headingType = _a.headingType;
var marks = [markInfo(start, end, HEADING, { level: level })];
if (headingType === 'atx') {
marks.push(markInfo(start, addOffsetPos(start, level), DELIM));
}
else {
marks.push(markInfo(setOffsetPos(end, 0), end, HEADING, { seText: true }));
}
return marks;
}
function emphasisAndStrikethrough(_a, start, end) {
var type = _a.type;
var startDelimPos = addOffsetPos(start, delimSize[type]);
var endDelimPos = addOffsetPos(end, -delimSize[type]);
return [
markInfo(startDelimPos, endDelimPos, type),
markInfo(start, startDelimPos, DELIM),
markInfo(endDelimPos, end, DELIM),
];
}
function markLink(start, end, linkTextStart, lastChildCh) {
return [
markInfo(start, end, LINK),
markInfo(setOffsetPos(start, linkTextStart[1] + 1), setOffsetPos(end, lastChildCh), LINK, {
desc: true,
}),
markInfo(setOffsetPos(end, lastChildCh + 2), addOffsetPos(end, -1), LINK, { url: true }),
];
}
function markInfo_image(_a, start, end) {
var lastChild = _a.lastChild;
var lastChildCh = lastChild ? getMdEndCh(lastChild) + 1 : 3; // 3: length of '![]'
var linkTextEnd = addOffsetPos(start, 1);
return __spreadArray([markInfo(start, linkTextEnd, META)], markLink(start, end, linkTextEnd, lastChildCh));
}
function markInfo_link(_a, start, end) {
var lastChild = _a.lastChild, extendedAutolink = _a.extendedAutolink;
var lastChildCh = lastChild ? getMdEndCh(lastChild) + 1 : 2; // 2: length of '[]'
return extendedAutolink
? [markInfo(start, end, LINK, { desc: true })]
: markLink(start, end, start, lastChildCh);
}
function code(_a, start, end) {
var tickCount = _a.tickCount;
var openDelimEnd = addOffsetPos(start, tickCount);
var closeDelimStart = addOffsetPos(end, -tickCount);
return [
markInfo(start, end, CODE),
markInfo(start, openDelimEnd, CODE, { start: true }),
markInfo(openDelimEnd, closeDelimStart, CODE, { marked: true }),
markInfo(closeDelimStart, end, CODE, { end: true }),
];
}
function lineBackground(parent, start, end, prefix) {
var defaultBackground = {
start: start,
end: end,
spec: {
attrs: { className: prefix + "-line-background", codeStart: start[0], codeEnd: end[0] },
},
lineBackground: true,
};
return parent.type !== 'item' && parent.type !== 'blockQuote'
? [
__assign(__assign({}, defaultBackground), { end: start, spec: { attrs: { className: prefix + "-line-background start" } } }),
__assign(__assign({}, defaultBackground), { start: [Math.min(start[0] + 1, end[0]), start[1]] }),
]
: null;
}
function codeBlock(node, start, end, endLine) {
var fenceOffset = node.fenceOffset, fenceLength = node.fenceLength, fenceChar = node.fenceChar, info = node.info, infoPadding = node.infoPadding, parent = node.parent;
var fenceEnd = fenceOffset + fenceLength;
var marks = [markInfo(setOffsetPos(start, 1), end, CODE_BLOCK)];
if (fenceChar) {
marks.push(markInfo(start, addOffsetPos(start, fenceEnd), DELIM));
}
if (info) {
marks.push(markInfo(addOffsetPos(start, fenceLength), addOffsetPos(start, fenceLength + infoPadding + info.length), META));
}
var codeBlockEnd = "^(\\s{0,4})(" + fenceChar + "{" + fenceLength + ",})";
var reCodeBlockEnd = new RegExp(codeBlockEnd);
if (reCodeBlockEnd.test(endLine)) {
marks.push(markInfo(setOffsetPos(end, 1), end, DELIM));
}
var lineBackgroundMarkInfo = lineBackground(parent, start, end, 'code-block');
return lineBackgroundMarkInfo ? marks.concat(lineBackgroundMarkInfo) : marks;
}
function customBlock(node, start, end) {
var _a = node, offset = _a.offset, syntaxLength = _a.syntaxLength, info = _a.info, parent = _a.parent;
var syntaxEnd = offset + syntaxLength;
var marks = [markInfo(setOffsetPos(start, 1), end, CUSTOM_BLOCK)];
marks.push(markInfo(start, addOffsetPos(start, syntaxEnd), DELIM));
if (info) {
marks.push(markInfo(addOffsetPos(start, syntaxEnd), addOffsetPos(start, syntaxLength + info.length), META));
}
marks.push(markInfo(setOffsetPos(end, 1), end, DELIM));
var lineBackgroundMarkInfo = lineBackground(parent, start, end, 'custom-block');
return lineBackgroundMarkInfo ? marks.concat(lineBackgroundMarkInfo) : marks;
}
function markListItemChildren(node, markType) {
var marks = [];
while (node) {
var type = node.type;
if (type === 'paragraph' || type === 'codeBlock') {
marks.push(markInfo([getMdStartLine(node), getMdStartCh(node) - 1], [getMdEndLine(node), getMdEndCh(node) + 1], markType));
}
node = node.next;
}
return marks;
}
function markParagraphInBlockQuote(node) {
var marks = [];
while (node) {
marks.push(markInfo([getMdStartLine(node), getMdStartCh(node)], [getMdEndLine(node), getMdEndCh(node) + 1], TEXT));
node = node.next;
}
return marks;
}
function blockQuote(node, start, end) {
var marks = node.parent && node.parent.type !== 'blockQuote' ? [markInfo(start, end, BLOCK_QUOTE)] : [];
if (node.firstChild) {
var childMarks = [];
if (node.firstChild.type === 'paragraph') {
childMarks = markParagraphInBlockQuote(node.firstChild.firstChild);
}
else if (node.firstChild.type === 'list') {
childMarks = markListItemChildren(node.firstChild, TEXT);
}
marks = __spreadArray(__spreadArray([], marks), childMarks);
}
return marks;
}
function getSpecOfListItemStyle(node) {
var depth = 0;
while (node.parent.parent && node.parent.parent.type === 'item') {
node = node.parent.parent;
depth += 1;
}
var attrs = [{ odd: true }, { even: true }][depth % 2];
return [LIST_ITEM, __assign(__assign({}, attrs), { listStyle: true })];
}
function item(node, start) {
var _a = node.listData, padding = _a.padding, task = _a.task;
var spec = getSpecOfListItemStyle(node);
var marks = [markInfo.apply(void 0, __spreadArray([start, addOffsetPos(start, padding)], spec))];
if (task) {
marks.push(markInfo(addOffsetPos(start, padding), addOffsetPos(start, padding + 3), TASK_DELIM));
marks.push(markInfo(addOffsetPos(start, padding + 1), addOffsetPos(start, padding + 2), META));
}
return marks.concat(markListItemChildren(node.firstChild, TEXT));
}
var markNodeFuncMap = {
heading: heading,
strong: emphasisAndStrikethrough,
emph: emphasisAndStrikethrough,
strike: emphasisAndStrikethrough,
link: markInfo_link,
image: markInfo_image,
code: code,
codeBlock: codeBlock,
blockQuote: blockQuote,
item: item,
customBlock: customBlock,
};
var simpleMarkClassNameMap = {
thematicBreak: THEMATIC_BREAK,
table: TABLE,
tableCell: TABLE_CELL,
htmlInline: HTML,
};
function getMarkInfo(node, start, end, endLine) {
var type = node.type;
if (isFunction_default()(markNodeFuncMap[type])) {
// @ts-ignore
return markNodeFuncMap[type](node, start, end, endLine);
}
if (simpleMarkClassNameMap[type]) {
return [markInfo(start, end, simpleMarkClassNameMap[type])];
}
return null;
}
;// CONCATENATED MODULE: ./src/markdown/plugins/syntaxHighlight.ts
var removingBackgroundIndexMap = {};
function syntaxHighlight(_a) {
var schema = _a.schema, toastMark = _a.toastMark;
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
appendTransaction: function (transactions, _, newState) {
var tr = transactions[0];
var newTr = newState.tr;
if (tr.docChanged) {
var markInfo_1 = [];
var editResult = tr.getMeta('editResult');
editResult.forEach(function (result) {
var nodes = result.nodes, removedNodeRange = result.removedNodeRange;
if (nodes.length) {
markInfo_1 = markInfo_1.concat(getMarkForRemoving(newTr, nodes));
for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {
var parent = nodes_1[_i];
var walker = parent.walker();
var event = walker.next();
while (event) {
var node = event.node, entering = event.entering;
if (entering) {
markInfo_1 = markInfo_1.concat(getMarkForAdding(node, toastMark));
}
event = walker.next();
}
}
}
else if (removedNodeRange) {
var maxIndex = newTr.doc.childCount - 1;
var _a = removedNodeRange.line, startLine = _a[0], endLine = _a[1];
var startIndex = Math.min(startLine, maxIndex);
var endIndex = Math.min(endLine, maxIndex);
// cache the index to remove code block, custom block background when there are no adding nodes
for (var i = startIndex; i <= endIndex; i += 1) {
removingBackgroundIndexMap[i] = true;
}
}
});
appendMarkTr(newTr, schema, markInfo_1);
}
return newTr.setMeta('widget', tr.getMeta('widget'));
},
});
}
function isDifferentBlock(doc, index, attrs) {
return Object.keys(attrs).some(function (name) { return attrs[name] !== doc.child(index).attrs[name]; });
}
function addLineBackground(tr, doc, paragraph, blockPosInfo, attrs) {
if (attrs === void 0) { attrs = {}; }
var startIndex = blockPosInfo.startIndex, endIndex = blockPosInfo.endIndex, from = blockPosInfo.from, to = blockPosInfo.to;
var shouldChangeBlockType = false;
for (var i = startIndex; i <= endIndex; i += 1) {
// prevent to remove background of the node that need to have background
delete removingBackgroundIndexMap[i];
shouldChangeBlockType = isDifferentBlock(doc, i, attrs);
}
if (shouldChangeBlockType) {
tr.setBlockType(from, to, paragraph, attrs);
}
}
function appendMarkTr(tr, schema, marks) {
var doc = tr.doc;
var paragraph = schema.nodes.paragraph;
// get start position per line for lazy calculation
var startPosListPerLine = getStartPosListPerLine(doc, doc.childCount);
marks.forEach(function (_a) {
var start = _a.start, end = _a.end, spec = _a.spec, lineBackground = _a.lineBackground;
var startIndex = Math.min(start[0], doc.childCount) - 1;
var endIndex = Math.min(end[0], doc.childCount) - 1;
var startNode = doc.child(startIndex);
var endNode = doc.child(endIndex);
// calculate the position corresponding to the line
var from = startPosListPerLine[startIndex];
var to = startPosListPerLine[endIndex];
// calculate the position corresponding to the character offset of the line
from += start[1] + getWidgetNodePos(startNode, start[1] - 1);
to += end[1] + getWidgetNodePos(endNode, end[1] - 1);
if (spec) {
if (lineBackground) {
var posInfo = { from: from, to: to, startIndex: startIndex, endIndex: endIndex };
addLineBackground(tr, doc, paragraph, posInfo, spec.attrs);
}
else {
tr.addMark(from, to, schema.mark(spec.type, spec.attrs));
}
}
else {
tr.removeMark(from, to);
}
});
removeBlockBackground(tr, startPosListPerLine, paragraph);
}
function removeBlockBackground(tr, startPosListPerLine, paragraph) {
Object.keys(removingBackgroundIndexMap).forEach(function (index) {
var startIndex = Number(index);
// get the end position of the current line with the next node start position.
var endIndex = Math.min(Number(index) + 1, tr.doc.childCount - 1);
var from = startPosListPerLine[startIndex];
// subtract '1' for getting end position of the line
var to = startPosListPerLine[endIndex] - 1;
if (startIndex === endIndex) {
to += 2;
}
tr.setBlockType(from, to, paragraph);
});
}
function cacheIndexToRemoveBackground(doc, start, end) {
var skipLines = [];
removingBackgroundIndexMap = {};
for (var i = start[0] - 1; i < end[0]; i += 1) {
var node = doc.child(i);
var codeEnd = node.attrs.codeEnd;
var codeStart = node.attrs.codeStart;
if (codeStart && codeEnd && !common_includes(skipLines, codeStart)) {
skipLines.push(codeStart);
codeEnd = Math.min(codeEnd, doc.childCount);
// should subtract '1' to markdown line position
// because markdown parser has '1'(not zero) as the start number
var startIndex = codeStart - 1;
var endIndex = end[0];
for (var index = startIndex; index < endIndex; index += 1) {
removingBackgroundIndexMap[index] = true;
}
}
}
}
function getMarkForRemoving(_a, nodes) {
var doc = _a.doc;
var start = nodes[0].sourcepos[0];
var _b = last(nodes).sourcepos, end = _b[1];
var startPos = [start[0], start[1]];
var endPos = [end[0], end[1] + 1];
var marks = [];
cacheIndexToRemoveBackground(doc, start, end);
marks.push({ start: startPos, end: endPos });
return marks;
}
function getMarkForAdding(node, toastMark) {
var lineTexts = toastMark.getLineTexts();
var startPos = [getMdStartLine(node), getMdStartCh(node)];
var endPos = [getMdEndLine(node), getMdEndCh(node) + 1];
var markInfo = getMarkInfo(node, startPos, endPos, lineTexts[endPos[0] - 1]);
return markInfo !== null && markInfo !== void 0 ? markInfo : [];
}
;// CONCATENATED MODULE: ./src/markdown/plugins/previewHighlight.ts
var defaultToolbarStateKeys = [
'taskList',
'orderedList',
'bulletList',
'table',
'strong',
'emph',
'strike',
'heading',
'thematicBreak',
'blockQuote',
'code',
'codeBlock',
'indent',
'outdent',
];
function getToolbarStateType(mdNode) {
var type = mdNode.type;
if (isListNode(mdNode)) {
if (mdNode.listData.task) {
return 'taskList';
}
return mdNode.listData.type === 'ordered' ? 'orderedList' : 'bulletList';
}
if (type.indexOf('table') !== -1) {
return 'table';
}
if (!common_includes(defaultToolbarStateKeys, type)) {
return null;
}
return type;
}
function getToolbarState(targetNode) {
var toolbarState = {
indent: { active: false, disabled: true },
outdent: { active: false, disabled: true },
};
var listEnabled = true;
traverseParentNodes(targetNode, function (mdNode) {
var type = getToolbarStateType(mdNode);
if (!type) {
return;
}
if (type === 'bulletList' || type === 'orderedList') {
// to apply the nearlist list state in the nested list
if (listEnabled) {
toolbarState[type] = { active: true };
toolbarState.indent.disabled = false;
toolbarState.outdent.disabled = false;
listEnabled = false;
}
}
else {
toolbarState[type] = { active: true };
}
});
return toolbarState;
}
function previewHighlight(_a) {
var toastMark = _a.toastMark, eventEmitter = _a.eventEmitter;
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
view: function () {
return {
update: function (view, prevState) {
var state = view.state;
var doc = state.doc, selection = state.selection;
if (prevState && prevState.doc.eq(doc) && prevState.selection.eq(selection)) {
return;
}
var from = selection.from;
var startChOffset = state.doc.resolve(from).start();
var line = state.doc.content.findIndex(from).index + 1;
var ch = from - startChOffset;
if (from === startChOffset) {
ch += 1;
}
var cursorPos = [line, ch];
var mdNode = toastMark.findNodeAtPosition(cursorPos);
var toolbarState = getToolbarState(mdNode);
eventEmitter.emit('changeToolbarState', {
cursorPos: cursorPos,
mdNode: mdNode,
toolbarState: toolbarState,
});
eventEmitter.emit('setFocusedNode', mdNode);
},
};
},
});
}
;// CONCATENATED MODULE: ./src/markdown/nodes/doc.ts
var Doc = /** @class */ (function (_super) {
__extends(Doc, _super);
function Doc() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Doc.prototype, "name", {
get: function () {
return 'doc';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Doc.prototype, "schema", {
get: function () {
return {
content: 'block+',
};
},
enumerable: false,
configurable: true
});
return Doc;
}(node));
;// CONCATENATED MODULE: ./src/spec/mark.ts
var Mark = /** @class */ (function () {
function Mark() {
}
Object.defineProperty(Mark.prototype, "type", {
get: function () {
return 'mark';
},
enumerable: false,
configurable: true
});
Mark.prototype.setContext = function (context) {
this.context = context;
};
return Mark;
}());
/* harmony default export */ var mark = (Mark);
;// CONCATENATED MODULE: ./src/markdown/helper/query.ts
function getTextByMdLine(doc, mdLine) {
return getTextContent(doc, mdLine - 1);
}
function getTextContent(doc, index) {
return doc.child(index).textContent;
}
;// CONCATENATED MODULE: ./src/markdown/marks/blockQuote.ts
var reBlockQuote = /^\s*> ?/;
var BlockQuote = /** @class */ (function (_super) {
__extends(BlockQuote, _super);
function BlockQuote() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(BlockQuote.prototype, "name", {
get: function () {
return 'blockQuote';
},
enumerable: false,
configurable: true
});
Object.defineProperty(BlockQuote.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('block-quote') }, 0];
},
};
},
enumerable: false,
configurable: true
});
BlockQuote.prototype.createBlockQuoteText = function (text, isBlockQuote) {
return isBlockQuote ? text.replace(reBlockQuote, '').trim() : "> " + text.trim();
};
BlockQuote.prototype.extendBlockQuote = function () {
var _this = this;
return function (_a, dispatch) {
var selection = _a.selection, doc = _a.doc, tr = _a.tr, schema = _a.schema;
var _b = getRangeInfo(selection), endFromOffset = _b.endFromOffset, endToOffset = _b.endToOffset, endIndex = _b.endIndex, to = _b.to;
var textContent = getTextContent(doc, endIndex);
var isBlockQuote = reBlockQuote.test(textContent);
if (isBlockQuote && to > endFromOffset && selection.empty) {
var isEmpty = !textContent.replace(reBlockQuote, '').trim();
if (isEmpty) {
tr.deleteRange(endFromOffset, endToOffset).split(tr.mapping.map(endToOffset));
}
else {
var slicedText = textContent.slice(to - endFromOffset).trim();
var node = createTextNode(schema, _this.createBlockQuoteText(slicedText));
splitAndExtendBlock(tr, endToOffset, slicedText, node);
}
dispatch(tr);
return true;
}
return false;
};
};
BlockQuote.prototype.commands = function () {
var _this = this;
return function () { return function (state, dispatch) {
var selection = state.selection, doc = state.doc;
var _a = getRangeInfo(selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset, startIndex = _a.startIndex, endIndex = _a.endIndex;
var isBlockQuote = reBlockQuote.test(getTextContent(doc, startIndex));
var tr = replaceTextNode({
state: state,
startIndex: startIndex,
endIndex: endIndex,
from: startFromOffset,
createText: function (textContent) { return _this.createBlockQuoteText(textContent, isBlockQuote); },
});
dispatch(tr.setSelection(createTextSelection(tr, tr.mapping.map(endToOffset))));
return true;
}; };
};
BlockQuote.prototype.keymaps = function () {
var blockQuoteCommand = this.commands()();
return {
'alt-q': blockQuoteCommand,
'alt-Q': blockQuoteCommand,
Enter: this.extendBlockQuote(),
};
};
return BlockQuote;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/helper/list.ts
var reList = /(^\s*)([-*+] |[\d]+\. )/;
var reOrderedList = /(^\s*)([\d])+\.( \[[ xX]])? /;
var reOrderedListGroup = /^(\s*)((\d+)([.)]\s(?:\[(?:x|\s)\]\s)?))(.*)/;
var reCanBeTaskList = /(^\s*)([-*+]|[\d]+\.)( \[[ xX]])? /;
var reBulletListGroup = /^(\s*)([-*+]+(\s(?:\[(?:x|\s)\]\s)?))(.*)/;
var reTaskList = /(^\s*)([-*+] |[\d]+\. )(\[[ xX]] )/;
var reBulletTaskList = /(^\s*)([-*+])( \[[ xX]]) /;
function getListType(text) {
return reOrderedList.test(text) ? 'ordered' : 'bullet';
}
function getListDepth(mdNode) {
var depth = 0;
while (mdNode && mdNode.type !== 'document') {
if (mdNode.type === 'list') {
depth += 1;
}
mdNode = mdNode.parent;
}
return depth;
}
function findSameDepthList(toastMark, currentLine, depth, backward) {
var lineTexts = toastMark.getLineTexts();
var lineLen = lineTexts.length;
var result = [];
var line = currentLine;
while (backward ? line < lineLen : line > 1) {
line = backward ? line + 1 : line - 1;
var mdNode = toastMark.findFirstNodeAtLine(line);
var currentListDepth = getListDepth(mdNode);
if (currentListDepth === depth) {
result.push({ line: line, depth: depth, mdNode: mdNode });
}
else if (currentListDepth < depth) {
break;
}
}
return result;
}
function getSameDepthItems(_a) {
var toastMark = _a.toastMark, mdNode = _a.mdNode, line = _a.line;
var depth = getListDepth(mdNode);
var forwardList = findSameDepthList(toastMark, line, depth, false).reverse();
var backwardList = findSameDepthList(toastMark, line, depth, true);
return forwardList.concat([{ line: line, depth: depth, mdNode: mdNode }]).concat(backwardList);
}
function textToBullet(text) {
if (!reList.test(text)) {
return "* " + text;
}
var type = getListType(text);
if (type === 'bullet' && reCanBeTaskList.test(text)) {
text = text.replace(reBulletTaskList, '$1$2 ');
}
else if (type === 'ordered') {
text = text.replace(reOrderedList, '$1* ');
}
return text;
}
function textToOrdered(text, ordinalNum) {
if (!reList.test(text)) {
return ordinalNum + ". " + text;
}
var type = getListType(text);
if (type === 'bullet' || (type === 'ordered' && reCanBeTaskList.test(text))) {
text = text.replace(reCanBeTaskList, "$1" + ordinalNum + ". ");
}
else if (type === 'ordered') {
// eslint-disable-next-line prefer-destructuring
var start = reOrderedListGroup.exec(text)[3];
if (Number(start) !== ordinalNum) {
text = text.replace(reOrderedList, "$1" + ordinalNum + ". ");
}
}
return text;
}
function getChangedInfo(doc, sameDepthItems, type, start) {
if (start === void 0) { start = 0; }
var firstIndex = Number.MAX_VALUE;
var lastIndex = 0;
var changedResults = sameDepthItems.map(function (_a, index) {
var line = _a.line;
firstIndex = Math.min(line - 1, firstIndex);
lastIndex = Math.max(line - 1, lastIndex);
var text = getTextByMdLine(doc, line);
text = type === 'bullet' ? textToBullet(text) : textToOrdered(text, index + 1 + start);
return { text: text, line: line };
});
return { changedResults: changedResults, firstIndex: firstIndex, lastIndex: lastIndex };
}
function getBulletOrOrdered(type, context) {
var sameDepthListInfo = getSameDepthItems(context);
return getChangedInfo(context.doc, sameDepthListInfo, type);
}
var otherListToList = {
bullet: function (context) {
return getBulletOrOrdered('bullet', context);
},
ordered: function (context) {
return getBulletOrOrdered('ordered', context);
},
task: function (_a) {
var mdNode = _a.mdNode, doc = _a.doc, line = _a.line;
var text = getTextByMdLine(doc, line);
if (mdNode.listData.task) {
text = text.replace(reTaskList, '$1$2');
}
else if (isListNode(mdNode)) {
text = text.replace(reList, '$1$2[ ] ');
}
return { changedResults: [{ text: text, line: line }] };
},
};
var otherNodeToList = {
bullet: function (_a) {
var doc = _a.doc, line = _a.line;
var lineText = getTextByMdLine(doc, line);
var changedResults = [{ text: "* " + lineText, line: line }];
return { changedResults: changedResults };
},
ordered: function (_a) {
var toastMark = _a.toastMark, doc = _a.doc, line = _a.line, startLine = _a.startLine;
var lineText = getTextByMdLine(doc, line);
var firstOrderedListNum = 1;
var firstOrderedListLine = startLine;
var skipped = 0;
for (var i = startLine - 1; i > 0; i -= 1) {
var mdNode = toastMark.findFirstNodeAtLine(i);
var text = getTextByMdLine(doc, i);
var canBeListNode = text && !!findClosestNode(mdNode, function (targetNode) { return isListNode(targetNode); });
var searchResult = reOrderedListGroup.exec(getTextByMdLine(doc, i));
if (!searchResult && !canBeListNode) {
break;
}
if (!searchResult && canBeListNode) {
skipped += 1;
continue;
}
var _b = searchResult, indent = _b[1], start = _b[3];
// basis on one depth list
if (!indent) {
firstOrderedListNum = Number(start);
firstOrderedListLine = i;
break;
}
}
var ordinalNum = firstOrderedListNum + line - firstOrderedListLine - skipped;
var changedResults = [{ text: ordinalNum + ". " + lineText, line: line }];
return { changedResults: changedResults };
},
task: function (_a) {
var doc = _a.doc, line = _a.line;
var lineText = getTextByMdLine(doc, line);
var changedResults = [{ text: "* [ ] " + lineText, line: line }];
return { changedResults: changedResults };
},
};
var extendList = {
bullet: function (_a) {
var line = _a.line, doc = _a.doc;
var lineText = getTextByMdLine(doc, line);
var _b = reBulletListGroup.exec(lineText), indent = _b[1], delimiter = _b[2];
return { listSyntax: "" + indent + delimiter };
},
ordered: function (_a) {
var toastMark = _a.toastMark, line = _a.line, mdNode = _a.mdNode, doc = _a.doc;
var depth = getListDepth(mdNode);
var lineText = getTextByMdLine(doc, line);
var _b = reOrderedListGroup.exec(lineText), indent = _b[1], start = _b[3], delimiter = _b[4];
var ordinalNum = Number(start) + 1;
var listSyntax = "" + indent + ordinalNum + delimiter;
var backwardList = findSameDepthList(toastMark, line, depth, true);
var filteredList = backwardList.filter(function (info) {
var searchResult = reOrderedListGroup.exec(getTextByMdLine(doc, info.line));
return (searchResult &&
searchResult[1].length === indent.length &&
!!findClosestNode(info.mdNode, function (targetNode) { return isOrderedListNode(targetNode); }));
});
return __assign({ listSyntax: listSyntax }, getChangedInfo(doc, filteredList, 'ordered', ordinalNum));
},
};
function getReorderedListInfo(doc, schema, line, ordinalNum, prevIndentLength) {
var nodes = [];
var lineText = getTextByMdLine(doc, line);
var searchResult = reOrderedListGroup.exec(lineText);
while (searchResult) {
var indent = searchResult[1], delimiter = searchResult[4], text = searchResult[5];
var indentLength = indent.length;
if (indentLength === prevIndentLength) {
nodes.push(createTextNode(schema, "" + indent + ordinalNum + delimiter + text));
ordinalNum += 1;
line += 1;
}
else if (indentLength > prevIndentLength) {
var nestedListInfo = getReorderedListInfo(doc, schema, line, 1, indentLength);
line = nestedListInfo.line;
nodes = nodes.concat(nestedListInfo.nodes);
}
if (indentLength < prevIndentLength || line > doc.childCount) {
break;
}
lineText = getTextByMdLine(doc, line);
searchResult = reOrderedListGroup.exec(lineText);
}
return { nodes: nodes, line: line };
}
;// CONCATENATED MODULE: ./src/markdown/nodes/paragraph.ts
var reStartSpace = /(^\s{1,4})(.*)/;
function isBlockUnit(from, to, text) {
return from < to || reList.test(text) || reBlockQuote.test(text);
}
function isInTableCellNode(doc, schema, selection) {
var $pos = selection.$from;
if ($pos.depth === 0) {
$pos = doc.resolve($pos.pos - 1);
}
var node = $pos.node(1);
var startOffset = $pos.start(1);
var contentSize = node.content.size;
return (node.rangeHasMark(0, contentSize, schema.marks.table) &&
$pos.pos - startOffset !== contentSize &&
$pos.pos !== startOffset);
}
function createSelection(tr, posInfo) {
var from = posInfo.from, to = posInfo.to;
if (posInfo.type === 'indent') {
var softTabLen = 4;
from += softTabLen;
to += (posInfo.lineLen + 1) * softTabLen;
}
else {
var spaceLenList = posInfo.spaceLenList;
from -= spaceLenList[0];
for (var i = 0; i < spaceLenList.length; i += 1) {
to -= spaceLenList[i];
}
}
return createTextSelection(tr, from, to);
}
var Paragraph = /** @class */ (function (_super) {
__extends(Paragraph, _super);
function Paragraph() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Paragraph.prototype, "name", {
get: function () {
return 'paragraph';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Paragraph.prototype, "schema", {
get: function () {
return {
content: 'inline*',
attrs: {
className: { default: null },
codeStart: { default: null },
codeEnd: { default: null },
},
selectable: false,
group: 'block',
parseDOM: [{ tag: 'div' }],
toDOM: function (_a) {
var attrs = _a.attrs;
return attrs.className
? ['div', { class: clsWithMdPrefix(attrs.className) }, 0]
: ['div', 0];
},
};
},
enumerable: false,
configurable: true
});
Paragraph.prototype.reorderList = function (startLine, endLine) {
var _a = this.context, view = _a.view, toastMark = _a.toastMark, schema = _a.schema;
var _b = view.state, tr = _b.tr, selection = _b.selection, doc = _b.doc;
var mdNode = toastMark.findFirstNodeAtLine(startLine);
var topListNode = mdNode;
while (mdNode && !isBulletListNode(mdNode) && mdNode.parent.type !== 'document') {
mdNode = mdNode.parent;
if (isOrderedListNode(mdNode)) {
topListNode = mdNode;
break;
}
}
if (topListNode) {
startLine = topListNode.sourcepos[0][0];
}
var _c = reOrderedListGroup.exec(getTextByMdLine(doc, startLine)), indent = _c[1], start = _c[3];
var indentLen = indent.length;
var _d = getReorderedListInfo(doc, schema, startLine, Number(start), indentLen), line = _d.line, nodes = _d.nodes;
endLine = Math.max(endLine, line - 1);
var startOffset = getNodeContentOffsetRange(doc, startLine - 1).startOffset;
for (var i = startLine - 1; i <= endLine - 1; i += 1) {
var _e = doc.child(i), nodeSize = _e.nodeSize, content = _e.content;
var mappedFrom = tr.mapping.map(startOffset);
var mappedTo = mappedFrom + content.size;
tr.replaceWith(mappedFrom, mappedTo, nodes[i - startLine + 1]);
startOffset += nodeSize;
}
var newSelection = createTextSelection(tr, selection.from, selection.to);
view.dispatch(tr.setSelection(newSelection));
};
Paragraph.prototype.indent = function (tabKey) {
var _this = this;
if (tabKey === void 0) { tabKey = false; }
return function () { return function (state, dispatch) {
var schema = state.schema, selection = state.selection, doc = state.doc;
var _a = getRangeInfo(selection), from = _a.from, to = _a.to, startFromOffset = _a.startFromOffset, startIndex = _a.startIndex, endIndex = _a.endIndex;
if (tabKey && isInTableCellNode(doc, schema, selection)) {
return false;
}
var startLineText = getTextContent(doc, startIndex);
if ((tabKey && isBlockUnit(from, to, startLineText)) ||
(!tabKey && reList.test(startLineText))) {
var tr = replaceTextNode({
state: state,
from: startFromOffset,
startIndex: startIndex,
endIndex: endIndex,
createText: function (textContent) { return " " + textContent; },
});
var posInfo = {
type: 'indent',
from: from,
to: to,
lineLen: endIndex - startIndex,
};
dispatch(tr.setSelection(createSelection(tr, posInfo)));
if (reOrderedListGroup.test(startLineText)) {
_this.reorderList(startIndex + 1, endIndex + 1);
}
}
else if (tabKey) {
dispatch(state.tr.insert(to, createTextNode(schema, ' ')));
}
return true;
}; };
};
Paragraph.prototype.outdent = function (tabKey) {
var _this = this;
if (tabKey === void 0) { tabKey = false; }
return function () { return function (state, dispatch) {
var selection = state.selection, doc = state.doc, schema = state.schema;
var _a = getRangeInfo(selection), from = _a.from, to = _a.to, startFromOffset = _a.startFromOffset, startIndex = _a.startIndex, endIndex = _a.endIndex;
if (tabKey && isInTableCellNode(doc, schema, selection)) {
return false;
}
var startLineText = getTextContent(doc, startIndex);
if ((tabKey && isBlockUnit(from, to, startLineText)) ||
(!tabKey && reList.test(startLineText))) {
var spaceLenList_1 = [];
var tr = replaceTextNode({
state: state,
from: startFromOffset,
startIndex: startIndex,
endIndex: endIndex,
createText: function (textContent) {
var searchResult = reStartSpace.exec(textContent);
spaceLenList_1.push(searchResult ? searchResult[1].length : 0);
return textContent.replace(reStartSpace, '$2');
},
});
var posInfo = { type: 'outdent', from: from, to: to, spaceLenList: spaceLenList_1 };
dispatch(tr.setSelection(createSelection(tr, posInfo)));
if (reOrderedListGroup.test(startLineText)) {
_this.reorderList(startIndex + 1, endIndex + 1);
}
}
else if (tabKey) {
var startText = startLineText.slice(0, to - startFromOffset);
var startTextWithoutSpace = startText.replace(/\s{1,4}$/, '');
var deletStart = to - (startText.length - startTextWithoutSpace.length);
dispatch(state.tr.delete(deletStart, to));
}
return true;
}; };
};
Paragraph.prototype.deleteLines = function () {
var _this = this;
return function (state, dispatch) {
var view = _this.context.view;
var _a = getRangeInfo(state.selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset;
var deleteRange = function () {
dispatch(state.tr.deleteRange(startFromOffset, endToOffset));
return true;
};
return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.chainCommands)(deleteRange, external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.joinForward)(state, dispatch, view);
};
};
Paragraph.prototype.moveDown = function () {
return function (state, dispatch) {
var doc = state.doc, tr = state.tr, selection = state.selection, schema = state.schema;
var _a = getRangeInfo(selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset, endIndex = _a.endIndex;
if (endIndex < doc.content.childCount - 1) {
var _b = doc.child(endIndex + 1), nodeSize = _b.nodeSize, textContent = _b.textContent;
tr.delete(endToOffset, endToOffset + nodeSize)
.split(startFromOffset)
// subtract 2(start, end tag length) to insert prev line
.insert(tr.mapping.map(startFromOffset) - 2, createTextNode(schema, textContent));
dispatch(tr);
return true;
}
return false;
};
};
Paragraph.prototype.moveUp = function () {
return function (state, dispatch) {
var tr = state.tr, doc = state.doc, selection = state.selection, schema = state.schema;
var _a = getRangeInfo(selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset, startIndex = _a.startIndex;
if (startIndex > 0) {
var _b = doc.child(startIndex - 1), nodeSize = _b.nodeSize, textContent = _b.textContent;
tr.delete(startFromOffset - nodeSize, startFromOffset)
.split(tr.mapping.map(endToOffset))
.insert(tr.mapping.map(endToOffset), createTextNode(schema, textContent));
dispatch(tr);
return true;
}
return false;
};
};
Paragraph.prototype.commands = function () {
return {
indent: this.indent(),
outdent: this.outdent(),
};
};
Paragraph.prototype.keymaps = function () {
return {
Tab: this.indent(true)(),
'Shift-Tab': this.outdent(true)(),
'Mod-d': this.deleteLines(),
'Mod-D': this.deleteLines(),
'Alt-ArrowUp': this.moveUp(),
'Alt-ArrowDown': this.moveDown(),
};
};
return Paragraph;
}(node));
;// CONCATENATED MODULE: ./src/markdown/nodes/text.ts
var Text = /** @class */ (function (_super) {
__extends(Text, _super);
function Text() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Text.prototype, "name", {
get: function () {
return 'text';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Text.prototype, "schema", {
get: function () {
return {
group: 'inline',
};
},
enumerable: false,
configurable: true
});
return Text;
}(node));
;// CONCATENATED MODULE: ./src/markdown/marks/heading.ts
var reHeading = /^#{1,6}\s/;
var Heading = /** @class */ (function (_super) {
__extends(Heading, _super);
function Heading() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Heading.prototype, "name", {
get: function () {
return 'heading';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Heading.prototype, "schema", {
get: function () {
return {
attrs: {
level: { default: 1 },
seText: { default: false },
},
toDOM: function (_a) {
var attrs = _a.attrs;
var level = attrs.level, seText = attrs.seText;
var classNames = "heading|heading" + level;
if (seText) {
classNames += '|delimiter|setext';
}
return ['span', { class: clsWithMdPrefix.apply(void 0, classNames.split('|')) }, 0];
},
};
},
enumerable: false,
configurable: true
});
Heading.prototype.createHeadingText = function (level, text, curHeadingSyntax) {
var textContent = text.replace(curHeadingSyntax, '').trim();
var headingText = '';
while (level > 0) {
headingText += '#';
level -= 1;
}
return headingText + " " + textContent;
};
Heading.prototype.commands = function () {
var _this = this;
return function (payload) { return function (state, dispatch) {
var level = payload.level;
var _a = getRangeInfo(state.selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset, startIndex = _a.startIndex, endIndex = _a.endIndex;
var tr = replaceTextNode({
state: state,
from: startFromOffset,
startIndex: startIndex,
endIndex: endIndex,
createText: function (textContent) {
var matchedHeading = textContent.match(reHeading);
var curHeadingSyntax = matchedHeading ? matchedHeading[0] : '';
return _this.createHeadingText(level, textContent, curHeadingSyntax);
},
});
dispatch(tr.setSelection(createTextSelection(tr, tr.mapping.map(endToOffset))));
return true;
}; };
};
return Heading;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/codeBlock.ts
var fencedCodeBlockSyntax = '```';
var CodeBlock = /** @class */ (function (_super) {
__extends(CodeBlock, _super);
function CodeBlock() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(CodeBlock.prototype, "name", {
get: function () {
return 'codeBlock';
},
enumerable: false,
configurable: true
});
Object.defineProperty(CodeBlock.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('code-block') }, 0];
},
};
},
enumerable: false,
configurable: true
});
CodeBlock.prototype.commands = function () {
return function () { return function (state, dispatch) {
var selection = state.selection, schema = state.schema, tr = state.tr;
var _a = getRangeInfo(selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset;
var fencedNode = createTextNode(schema, fencedCodeBlockSyntax);
// add fenced start block
tr.insert(startFromOffset, fencedNode).split(startFromOffset + fencedCodeBlockSyntax.length);
// add fenced end block
tr.split(tr.mapping.map(endToOffset)).insert(tr.mapping.map(endToOffset), fencedNode);
dispatch(tr.setSelection(
// subtract fenced syntax length and open, close tag(2)
createTextSelection(tr, tr.mapping.map(endToOffset) - (fencedCodeBlockSyntax.length + 2))));
return true;
}; };
};
CodeBlock.prototype.keepIndentation = function () {
var _this = this;
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr, doc = _a.doc, schema = _a.schema;
var toastMark = _this.context.toastMark;
var _b = getRangeInfo(selection), startFromOffset = _b.startFromOffset, endToOffset = _b.endToOffset, endIndex = _b.endIndex, from = _b.from, to = _b.to;
var textContent = getTextContent(doc, endIndex);
if (from === to && textContent.trim()) {
var matched = textContent.match(/^\s+/);
var mdNode = toastMark.findFirstNodeAtLine(endIndex + 1);
if (isCodeBlockNode(mdNode) && matched) {
var spaces = matched[0];
var slicedText = textContent.slice(to - startFromOffset);
var node = createTextNode(schema, spaces + slicedText);
splitAndExtendBlock(tr, endToOffset, slicedText, node);
dispatch(tr);
return true;
}
}
return false;
};
};
CodeBlock.prototype.keymaps = function () {
var codeBlockCommand = this.commands()();
return {
'Shift-Mod-p': codeBlockCommand,
'Shift-Mod-P': codeBlockCommand,
Enter: this.keepIndentation(),
};
};
return CodeBlock;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/table.ts
var reEmptyTable = /\||\s/g;
function createTableHeader(columnCount) {
return [createTableRow(columnCount), createTableRow(columnCount, true)];
}
function createTableBody(columnCount, rowCount) {
var bodyRows = [];
for (var i = 0; i < rowCount; i += 1) {
bodyRows.push(createTableRow(columnCount));
}
return bodyRows;
}
function createTableRow(columnCount, delim) {
var row = '|';
for (var i = 0; i < columnCount; i += 1) {
row += delim ? ' --- |' : ' |';
}
return row;
}
function createTargetTypes(moveNext) {
return moveNext
? { type: 'next', parentType: 'tableHead', childType: 'firstChild' }
: { type: 'prev', parentType: 'tableBody', childType: 'lastChild' };
}
var Table = /** @class */ (function (_super) {
__extends(Table, _super);
function Table() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Table.prototype, "name", {
get: function () {
return 'table';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Table.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('table') }, 0];
},
};
},
enumerable: false,
configurable: true
});
Table.prototype.extendTable = function () {
var _this = this;
return function (_a, dispatch) {
var selection = _a.selection, doc = _a.doc, tr = _a.tr, schema = _a.schema;
if (!selection.empty) {
return false;
}
var _b = getRangeInfo(selection), endFromOffset = _b.endFromOffset, endToOffset = _b.endToOffset, endIndex = _b.endIndex, to = _b.to;
var textContent = getTextContent(doc, endIndex);
// should add `1` to line for the markdown parser
// because markdown parser has `1`(not zero) as the start number
var mdPos = [endIndex + 1, to - endFromOffset + 1];
var mdNode = _this.context.toastMark.findNodeAtPosition(mdPos);
var cellNode = findClosestNode(mdNode, function (node) {
return isTableCellNode(node) &&
(node.parent.type === 'tableDelimRow' || node.parent.parent.type === 'tableBody');
});
if (cellNode) {
var isEmpty = !textContent.replace(reEmptyTable, '').trim();
var parent = cellNode.parent;
var columnCount = parent.parent.parent.columns.length;
var row = createTableRow(columnCount);
if (isEmpty) {
tr.deleteRange(endFromOffset, endToOffset).split(tr.mapping.map(endToOffset));
}
else {
tr
.split(endToOffset)
.insert(tr.mapping.map(endToOffset), createTextNode(schema, row))
// should subtract `2` to selection end position considering ` |` text
.setSelection(createTextSelection(tr, tr.mapping.map(endToOffset) - 2));
}
dispatch(tr);
return true;
}
return false;
};
};
Table.prototype.moveTableCell = function (moveNext) {
var _this = this;
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr;
var _b = getRangeInfo(selection), endFromOffset = _b.endFromOffset, endIndex = _b.endIndex, to = _b.to;
var mdPos = [endIndex + 1, to - endFromOffset];
var mdNode = _this.context.toastMark.findNodeAtPosition(mdPos);
var cellNode = findClosestNode(mdNode, function (node) { return isTableCellNode(node); });
if (cellNode) {
var parent = cellNode.parent;
var _c = createTargetTypes(moveNext), type = _c.type, parentType = _c.parentType, childType = _c.childType;
var chOffset = getMdEndCh(cellNode);
if (cellNode[type]) {
chOffset = getMdEndCh(cellNode[type]) - 1;
}
else {
var row = !parent[type] && parent.parent.type === parentType
? parent.parent[type][childType]
: parent[type];
if (type === 'next') {
// if there is next row, the base offset would be end position of the next row's first child.
// Otherwise, the base offset is zero.
var baseOffset = row ? getMdEndCh(row[childType]) : 0;
// calculate tag(open, close) position('2') for selection
chOffset += baseOffset + 2;
}
else if (type === 'prev') {
// if there is prev row, the target position would be '-4' for calculating ' |' characters and tag(open, close)
// Otherwise, the target position is zero.
chOffset = row ? -4 : 0;
}
}
dispatch(tr.setSelection(createTextSelection(tr, endFromOffset + chOffset)));
return true;
}
return false;
};
};
Table.prototype.addTable = function () {
return function (payload) { return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr, schema = _a.schema;
var _b = payload, columnCount = _b.columnCount, rowCount = _b.rowCount;
var endToOffset = getRangeInfo(selection).endToOffset;
var headerRows = createTableHeader(columnCount);
var bodyRows = createTableBody(columnCount, rowCount - 1);
var rows = __spreadArray(__spreadArray([], headerRows), bodyRows);
rows.forEach(function (row) {
tr.split(tr.mapping.map(endToOffset)).insert(tr.mapping.map(endToOffset), createTextNode(schema, row));
});
// should add `4` to selection position considering `| ` text and start block tag length
dispatch(tr.setSelection(createTextSelection(tr, endToOffset + 4)));
return true;
}; };
};
Table.prototype.commands = function () {
return { addTable: this.addTable() };
};
Table.prototype.keymaps = function () {
return {
Enter: this.extendTable(),
Tab: this.moveTableCell(true),
'Shift-Tab': this.moveTableCell(false),
};
};
return Table;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/thematicBreak.ts
var thematicBreakSyntax = '***';
var ThematicBreak = /** @class */ (function (_super) {
__extends(ThematicBreak, _super);
function ThematicBreak() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(ThematicBreak.prototype, "name", {
get: function () {
return 'thematicBreak';
},
enumerable: false,
configurable: true
});
Object.defineProperty(ThematicBreak.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('thematic-break') }, 0];
},
};
},
enumerable: false,
configurable: true
});
ThematicBreak.prototype.hr = function () {
return function () { return function (state, dispatch) {
var selection = state.selection, schema = state.schema, tr = state.tr;
var _a = getRangeInfo(selection), from = _a.from, to = _a.to, endToOffset = _a.endToOffset;
var node = createTextNode(schema, thematicBreakSyntax);
tr
.split(from)
.replaceWith(tr.mapping.map(from), tr.mapping.map(to), node)
.split(tr.mapping.map(to)).setSelection(createTextSelection(tr, tr.mapping.map(endToOffset)));
dispatch(tr);
return true;
}; };
};
ThematicBreak.prototype.commands = function () {
return { hr: this.hr() };
};
ThematicBreak.prototype.keymaps = function () {
var lineCommand = this.hr()();
return { 'Mod-l': lineCommand, 'Mod-L': lineCommand };
};
return ThematicBreak;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/listItem.ts
function cannotBeListNode(_a, line) {
var type = _a.type, sourcepos = _a.sourcepos;
// eslint-disable-next-line prefer-destructuring
var startLine = sourcepos[0][0];
return line <= startLine && (type === 'codeBlock' || type === 'heading' || type.match('table'));
}
var ListItem = /** @class */ (function (_super) {
__extends(ListItem, _super);
function ListItem() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(ListItem.prototype, "name", {
get: function () {
return 'listItem';
},
enumerable: false,
configurable: true
});
Object.defineProperty(ListItem.prototype, "schema", {
get: function () {
return {
attrs: {
odd: { default: false },
even: { default: false },
listStyle: { default: false },
},
toDOM: function (_a) {
var attrs = _a.attrs;
var odd = attrs.odd, even = attrs.even, listStyle = attrs.listStyle;
var classNames = 'list-item';
if (listStyle) {
classNames += '|list-item-style';
}
if (odd) {
classNames += '|list-item-odd';
}
if (even) {
classNames += '|list-item-even';
}
return ['span', { class: clsWithMdPrefix.apply(void 0, classNames.split('|')) }, 0];
},
};
},
enumerable: false,
configurable: true
});
ListItem.prototype.extendList = function () {
var _this = this;
return function (_a, dispatch) {
var selection = _a.selection, doc = _a.doc, schema = _a.schema, tr = _a.tr;
var toastMark = _this.context.toastMark;
var _b = getRangeInfo(selection), to = _b.to, startFromOffset = _b.startFromOffset, endFromOffset = _b.endFromOffset, endIndex = _b.endIndex, endToOffset = _b.endToOffset;
var textContent = getTextContent(doc, endIndex);
var isList = reList.test(textContent);
if (!isList || selection.from === startFromOffset || !selection.empty) {
return false;
}
var isEmpty = !textContent.replace(reCanBeTaskList, '').trim();
if (isEmpty) {
tr.deleteRange(endFromOffset, endToOffset).split(tr.mapping.map(endToOffset));
}
else {
var commandType = getListType(textContent);
// should add `1` to line for the markdown parser
// because markdown parser has `1`(not zero) as the start number
var mdNode = toastMark.findFirstNodeAtLine(endIndex + 1);
var slicedText = textContent.slice(to - endFromOffset);
var context = { toastMark: toastMark, mdNode: mdNode, doc: doc, line: endIndex + 1 };
var _c = extendList[commandType](context), listSyntax = _c.listSyntax, changedResults = _c.changedResults;
// change ordinal number of backward ordered list
if (changedResults === null || changedResults === void 0 ? void 0 : changedResults.length) {
// split the block
tr.split(to);
// set first ordered list info
changedResults.unshift({ text: listSyntax + slicedText, line: endIndex + 1 });
_this.changeToListPerLine(tr, changedResults, {
from: to,
// don't subtract 1 because the line has increased through 'split' command.
startLine: changedResults[0].line,
endLine: last(changedResults).line,
});
var pos = tr.mapping.map(endToOffset) - slicedText.length;
tr.setSelection(createTextSelection(tr, pos));
}
else {
var node = createTextNode(schema, listSyntax + slicedText);
splitAndExtendBlock(tr, endToOffset, slicedText, node);
}
}
dispatch(tr);
return true;
};
};
ListItem.prototype.toList = function (commandType) {
var _this = this;
return function () { return function (_a, dispatch) {
var doc = _a.doc, tr = _a.tr, selection = _a.selection;
var toastMark = _this.context.toastMark;
var rangeInfo = getRangeInfo(selection);
// should add `1` to line for the markdown parser
// because markdown parser has `1`(not zero) as the start number
var startLine = rangeInfo.startIndex + 1;
var endLine = rangeInfo.endIndex + 1;
var endToOffset = rangeInfo.endToOffset;
var skipLines = [];
for (var line = startLine; line <= endLine; line += 1) {
var mdNode = toastMark.findFirstNodeAtLine(line);
if (mdNode && cannotBeListNode(mdNode, line)) {
break;
}
// to skip unnecessary processing
if (skipLines.indexOf(line) !== -1) {
continue;
}
var context = { toastMark: toastMark, mdNode: mdNode, doc: doc, line: line, startLine: startLine };
var changedResults = (isListNode(mdNode)
? otherListToList[commandType](context)
: otherNodeToList[commandType](context)).changedResults;
var endOffset = _this.changeToListPerLine(tr, changedResults, {
from: getNodeContentOffsetRange(doc, changedResults[0].line - 1).startOffset,
startLine: changedResults[0].line,
endLine: last(changedResults).line,
indexDiff: 1,
});
endToOffset = Math.max(endOffset, endToOffset);
if (changedResults) {
skipLines = skipLines.concat(changedResults.map(function (info) { return info.line; }));
}
}
dispatch(tr.setSelection(createTextSelection(tr, tr.mapping.map(endToOffset))));
return true;
}; };
};
ListItem.prototype.changeToListPerLine = function (tr, changedResults, _a) {
var from = _a.from, startLine = _a.startLine, endLine = _a.endLine, _b = _a.indexDiff, indexDiff = _b === void 0 ? 0 : _b;
var maxEndOffset = 0;
var _loop_1 = function (i) {
var _c = tr.doc.child(i), nodeSize = _c.nodeSize, content = _c.content;
var mappedFrom = tr.mapping.map(from);
var mappedTo = mappedFrom + content.size;
var changedResult = changedResults.filter(function (result) { return result.line - indexDiff === i; })[0];
if (changedResult) {
tr.replaceWith(mappedFrom, mappedTo, createTextNode(this_1.context.schema, changedResult.text));
maxEndOffset = Math.max(maxEndOffset, from + content.size);
}
from += nodeSize;
};
var this_1 = this;
for (var i = startLine - indexDiff; i <= endLine - indexDiff; i += 1) {
_loop_1(i);
}
return maxEndOffset;
};
ListItem.prototype.toggleTask = function () {
var _this = this;
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr, doc = _a.doc, schema = _a.schema;
var toastMark = _this.context.toastMark;
var _b = getRangeInfo(selection), startIndex = _b.startIndex, endIndex = _b.endIndex;
var newTr = null;
for (var i = startIndex; i <= endIndex; i += 1) {
var mdNode = toastMark.findFirstNodeAtLine(i + 1);
if (isListNode(mdNode) && mdNode.listData.task) {
var _c = mdNode.listData, checked = _c.checked, padding = _c.padding;
var stateChar = checked ? ' ' : 'x';
var mdPos = mdNode.sourcepos[0];
var startOffset = getNodeContentOffsetRange(doc, mdPos[0] - 1).startOffset;
startOffset += mdPos[1] + padding;
newTr = tr.replaceWith(startOffset, startOffset + 1, schema.text(stateChar));
}
}
if (newTr) {
dispatch(newTr);
return true;
}
return false;
};
};
ListItem.prototype.commands = function () {
return {
bulletList: this.toList('bullet'),
orderedList: this.toList('ordered'),
taskList: this.toList('task'),
};
};
ListItem.prototype.keymaps = function () {
var bulletCommand = this.toList('bullet')();
var orderedCommand = this.toList('ordered')();
var taskCommand = this.toList('task')();
var togleTaskCommand = this.toggleTask();
return {
'Mod-u': bulletCommand,
'Mod-U': bulletCommand,
'Mod-o': orderedCommand,
'Mod-O': orderedCommand,
'alt-t': taskCommand,
'alt-T': taskCommand,
'Shift-Ctrl-x': togleTaskCommand,
'Shift-Ctrl-X': togleTaskCommand,
Enter: this.extendList(),
};
};
return ListItem;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/helper/mdCommand.ts
function toggleMark(condition, syntax) {
return function () { return function (_a, dispatch) {
var tr = _a.tr, selection = _a.selection;
var conditionFn = !isFunction_default()(condition)
? function (text) { return condition.test(text); }
: condition;
var syntaxLen = syntax.length;
var doc = tr.doc;
var _b = resolveSelectionPos(selection), from = _b[0], to = _b[1];
var prevPos = Math.max(from - syntaxLen, 1);
var nextPos = Math.min(to + syntaxLen, doc.content.size - 1);
var slice = selection.content();
var textContent = slice.content.textBetween(0, slice.content.size, '\n');
var prevText = doc.textBetween(prevPos, from, '\n');
var nextText = doc.textBetween(to, nextPos, '\n');
textContent = "" + prevText + textContent + nextText;
if (prevText && nextText && conditionFn(textContent)) {
tr.delete(nextPos - syntaxLen, nextPos).delete(prevPos, prevPos + syntaxLen);
}
else {
tr.insertText(syntax, to).insertText(syntax, from);
var newSelection = selection.empty
? createTextSelection(tr, from + syntaxLen)
: createTextSelection(tr, from + syntaxLen, to + syntaxLen);
tr.setSelection(newSelection);
}
dispatch(tr);
return true;
}; };
}
;// CONCATENATED MODULE: ./src/markdown/marks/strong.ts
var reStrong = /^(\*{2}|_{2}).*([\s\S]*)\1$/m;
var strongSyntax = '**';
var Strong = /** @class */ (function (_super) {
__extends(Strong, _super);
function Strong() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Strong.prototype, "name", {
get: function () {
return 'strong';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Strong.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('strong') }, 0];
},
};
},
enumerable: false,
configurable: true
});
Strong.prototype.bold = function () {
return toggleMark(reStrong, strongSyntax);
};
Strong.prototype.commands = function () {
return { bold: this.bold() };
};
Strong.prototype.keymaps = function () {
var boldCommand = this.bold()();
return { 'Mod-b': boldCommand, 'Mod-B': boldCommand };
};
return Strong;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/strike.ts
var reStrike = /^(~{2}).*([\s\S]*)\1$/m;
var strikeSyntax = '~~';
var Strike = /** @class */ (function (_super) {
__extends(Strike, _super);
function Strike() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Strike.prototype, "name", {
get: function () {
return 'strike';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Strike.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('strike') }, 0];
},
};
},
enumerable: false,
configurable: true
});
Strike.prototype.commands = function () {
return toggleMark(reStrike, strikeSyntax);
};
Strike.prototype.keymaps = function () {
var strikeCommand = this.commands()();
return { 'Mod-s': strikeCommand, 'Mod-S': strikeCommand };
};
return Strike;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/emph.ts
var reEmph = /^(\*|_).*([\s\S]*)\1$/m;
var emphSyntax = '*';
var Emph = /** @class */ (function (_super) {
__extends(Emph, _super);
function Emph() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Emph.prototype, "name", {
get: function () {
return 'emph';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Emph.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('emph') }, 0];
},
};
},
enumerable: false,
configurable: true
});
Emph.prototype.italic = function () {
return toggleMark(reEmph, emphSyntax);
};
Emph.prototype.commands = function () {
return { italic: this.italic() };
};
Emph.prototype.keymaps = function () {
var italicCommand = this.italic()();
return { 'Mod-i': italicCommand, 'Mod-I': italicCommand };
};
return Emph;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/code.ts
var reCode = /^(`).*([\s\S]*)\1$/m;
var codeSyntax = '`';
var Code = /** @class */ (function (_super) {
__extends(Code, _super);
function Code() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Code.prototype, "name", {
get: function () {
return 'code';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Code.prototype, "schema", {
get: function () {
return {
attrs: {
start: { default: false },
end: { default: false },
marked: { default: false },
},
toDOM: function (mark) {
var _a = mark.attrs, start = _a.start, end = _a.end, marked = _a.marked;
var classNames = 'code';
if (start) {
classNames += '|delimiter|start';
}
if (end) {
classNames += '|delimiter|end';
}
if (marked) {
classNames += '|marked-text';
}
return ['span', { class: clsWithMdPrefix.apply(void 0, classNames.split('|')) }, 0];
},
};
},
enumerable: false,
configurable: true
});
Code.prototype.commands = function () {
return toggleMark(reCode, codeSyntax);
};
Code.prototype.keymaps = function () {
var codeCommand = this.commands()();
return { 'Shift-Mod-c': codeCommand, 'Shift-Mod-C': codeCommand };
};
return Code;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/link.ts
var Link = /** @class */ (function (_super) {
__extends(Link, _super);
function Link() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Link.prototype, "name", {
get: function () {
return 'link';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Link.prototype, "schema", {
get: function () {
return {
attrs: {
url: { default: false },
desc: { default: false },
},
toDOM: function (_a) {
var attrs = _a.attrs;
var url = attrs.url, desc = attrs.desc;
var classNames = 'link';
if (url) {
classNames += '|link-url|marked-text';
}
if (desc) {
classNames += '|link-desc|marked-text';
}
return ['span', { class: clsWithMdPrefix.apply(void 0, classNames.split('|')) }, 0];
},
};
},
enumerable: false,
configurable: true
});
Link.prototype.addLinkOrImage = function (commandType) {
return function (payload) { return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr, schema = _a.schema;
var _b = resolveSelectionPos(selection), from = _b[0], to = _b[1];
var _c = payload, linkText = _c.linkText, altText = _c.altText, linkUrl = _c.linkUrl, imageUrl = _c.imageUrl;
var text = linkText;
var url = linkUrl;
var syntax = '';
if (commandType === 'image') {
text = altText;
url = imageUrl;
syntax = '!';
}
text = escapeTextForLink(text);
syntax += "[" + text + "](" + url + ")";
dispatch(tr.replaceWith(from, to, createTextNode(schema, syntax)));
return true;
}; };
};
Link.prototype.commands = function () {
return {
addImage: this.addLinkOrImage('image'),
addLink: this.addLinkOrImage('link'),
};
};
return Link;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/simpleMark.ts
var TaskDelimiter = /** @class */ (function (_super) {
__extends(TaskDelimiter, _super);
function TaskDelimiter() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TaskDelimiter.prototype, "name", {
get: function () {
return 'taskDelimiter';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TaskDelimiter.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('delimiter', 'list-item') }, 0];
},
};
},
enumerable: false,
configurable: true
});
return TaskDelimiter;
}(mark));
var Delimiter = /** @class */ (function (_super) {
__extends(Delimiter, _super);
function Delimiter() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Delimiter.prototype, "name", {
get: function () {
return 'delimiter';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Delimiter.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('delimiter') }, 0];
},
};
},
enumerable: false,
configurable: true
});
return Delimiter;
}(mark));
var Meta = /** @class */ (function (_super) {
__extends(Meta, _super);
function Meta() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Meta.prototype, "name", {
get: function () {
return 'meta';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Meta.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('meta') }, 0];
},
};
},
enumerable: false,
configurable: true
});
return Meta;
}(mark));
var MarkedText = /** @class */ (function (_super) {
__extends(MarkedText, _super);
function MarkedText() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(MarkedText.prototype, "name", {
get: function () {
return 'markedText';
},
enumerable: false,
configurable: true
});
Object.defineProperty(MarkedText.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('marked-text') }, 0];
},
};
},
enumerable: false,
configurable: true
});
return MarkedText;
}(mark));
var TableCell = /** @class */ (function (_super) {
__extends(TableCell, _super);
function TableCell() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TableCell.prototype, "name", {
get: function () {
return 'tableCell';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableCell.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('table-cell') }, 0];
},
};
},
enumerable: false,
configurable: true
});
return TableCell;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/html.ts
var Html = /** @class */ (function (_super) {
__extends(Html, _super);
function Html() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Html.prototype, "name", {
get: function () {
return 'html';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Html.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('html') }, 0];
},
};
},
enumerable: false,
configurable: true
});
return Html;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/marks/customBlock.ts
var customBlockSyntax = '$$';
var CustomBlock = /** @class */ (function (_super) {
__extends(CustomBlock, _super);
function CustomBlock() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(CustomBlock.prototype, "name", {
get: function () {
return 'customBlock';
},
enumerable: false,
configurable: true
});
Object.defineProperty(CustomBlock.prototype, "schema", {
get: function () {
return {
toDOM: function () {
return ['span', { class: clsWithMdPrefix('custom-block') }, 0];
},
};
},
enumerable: false,
configurable: true
});
CustomBlock.prototype.commands = function () {
return function (payload) { return function (state, dispatch) {
var selection = state.selection, schema = state.schema, tr = state.tr;
var _a = getRangeInfo(selection), startFromOffset = _a.startFromOffset, endToOffset = _a.endToOffset;
if (!(payload === null || payload === void 0 ? void 0 : payload.info)) {
return false;
}
var customBlock = "" + customBlockSyntax + payload.info;
var startNode = createTextNode(schema, customBlock);
var endNode = createTextNode(schema, customBlockSyntax);
tr.insert(startFromOffset, startNode).split(startFromOffset + customBlock.length);
tr.split(tr.mapping.map(endToOffset)).insert(tr.mapping.map(endToOffset), endNode);
dispatch(tr.setSelection(createTextSelection(tr, tr.mapping.map(endToOffset) - (customBlockSyntax.length + 2))));
return true;
}; };
};
return CustomBlock;
}(mark));
;// CONCATENATED MODULE: ./src/markdown/plugins/smartTask.ts
var reTaskMarkerKey = /x|backspace/i;
var reTaskMarker = /^\[(\s*)(x?)(\s*)\](?:\s+)/i;
function smartTask(_a) {
var schema = _a.schema, toastMark = _a.toastMark;
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
props: {
handleDOMEvents: {
keyup: function (view, ev) {
var _a;
var _b = view.state, doc = _b.doc, tr = _b.tr, selection = _b.selection;
if (selection.empty && reTaskMarkerKey.test(ev.key)) {
var _c = getRangeInfo(selection), startIndex = _c.startIndex, startFromOffset = _c.startFromOffset, from = _c.from;
// should add `1` to line for the markdown parser
// because markdown parser has `1`(not zero) as the start number
var mdPos = [startIndex + 1, from - startFromOffset + 1];
var mdNode = toastMark.findNodeAtPosition(mdPos);
var paraNode = findClosestNode(mdNode, function (node) { var _a; return node.type === 'paragraph' && ((_a = node.parent) === null || _a === void 0 ? void 0 : _a.type) === 'item'; });
if ((_a = paraNode === null || paraNode === void 0 ? void 0 : paraNode.firstChild) === null || _a === void 0 ? void 0 : _a.literal) {
var firstChild = paraNode.firstChild;
var matched = firstChild.literal.match(reTaskMarker);
if (matched) {
var startMdPos = firstChild.sourcepos[0];
var startSpaces = matched[1], stateChar = matched[2], lastSpaces = matched[3];
var spaces = startSpaces.length + lastSpaces.length;
var startOffset = getNodeContentOffsetRange(doc, startMdPos[0] - 1).startOffset;
var startPos = startMdPos[1] + startOffset;
if (stateChar) {
var addedPos = spaces ? spaces + 1 : 0;
tr.replaceWith(startPos, addedPos + startPos, schema.text(stateChar));
view.dispatch(tr);
}
else if (!spaces) {
tr.insertText(' ', startPos);
view.dispatch(tr);
}
}
}
}
return false;
},
},
},
});
}
;// CONCATENATED MODULE: ./src/markdown/mdEditor.ts
var EVENT_TYPE = 'cut';
var reLineEnding = /\r\n|\n|\r/;
var MdEditor = /** @class */ (function (_super) {
__extends(MdEditor, _super);
function MdEditor(eventEmitter, options) {
var _this = _super.call(this, eventEmitter) || this;
var toastMark = options.toastMark, _a = options.useCommandShortcut, useCommandShortcut = _a === void 0 ? true : _a, _b = options.mdPlugins, mdPlugins = _b === void 0 ? [] : _b;
_this.editorType = 'markdown';
_this.el.classList.add('md-mode');
_this.toastMark = toastMark;
_this.extraPlugins = mdPlugins;
_this.specs = _this.createSpecs();
_this.schema = _this.createSchema();
_this.context = _this.createContext();
_this.keymaps = _this.createKeymaps(useCommandShortcut);
_this.view = _this.createView();
_this.commands = _this.createCommands();
_this.specs.setContext(__assign(__assign({}, _this.context), { view: _this.view }));
_this.createClipboard();
// To prevent unnecessary focus setting during initial rendering
_this.eventEmitter.listen('changePreviewTabWrite', function (isMarkdownTabMounted) {
return _this.toggleActive(true, isMarkdownTabMounted);
});
_this.eventEmitter.listen('changePreviewTabPreview', function () { return _this.toggleActive(false); });
_this.initEvent();
return _this;
}
MdEditor.prototype.toggleActive = function (active, isMarkdownTabMounted) {
toggleClass(this.el, 'active', active);
if (active) {
if (!isMarkdownTabMounted) {
this.focus();
}
}
else {
this.blur();
}
};
MdEditor.prototype.createClipboard = function () {
var _this = this;
this.clipboard = document.createElement('textarea');
this.clipboard.className = cls('pseudo-clipboard');
this.clipboard.addEventListener('paste', function (ev) {
var clipboardData = ev.clipboardData || window.clipboardData;
var items = clipboardData && clipboardData.items;
if (items) {
var containRtfItem = toArray_default()(items).some(function (item) { return item.kind === 'string' && item.type === 'text/rtf'; });
// if it contains rtf, it's most likely copy paste from office -> no image
if (!containRtfItem) {
var imageBlob = pasteImageOnly(items);
if (imageBlob) {
ev.preventDefault();
emitImageBlobHook(_this.eventEmitter, imageBlob, ev.type);
}
}
}
});
// process the pasted data in input event for IE11
this.clipboard.addEventListener('input', function (ev) {
var text = ev.target.value;
_this.replaceSelection(text);
ev.preventDefault();
ev.target.value = '';
});
this.el.insertBefore(this.clipboard, this.view.dom);
};
MdEditor.prototype.createContext = function () {
return {
toastMark: this.toastMark,
schema: this.schema,
eventEmitter: this.eventEmitter,
};
};
MdEditor.prototype.createSpecs = function () {
return new specManager([
new Doc(),
new Paragraph(),
new Widget(),
new Text(),
new Heading(),
new BlockQuote(),
new CodeBlock(),
new CustomBlock(),
new Table(),
new TableCell(),
new ThematicBreak(),
new ListItem(),
new Strong(),
new Strike(),
new Emph(),
new Code(),
new Link(),
new Delimiter(),
new TaskDelimiter(),
new MarkedText(),
new Meta(),
new Html(),
]);
};
MdEditor.prototype.createPlugins = function () {
return __spreadArray([
syntaxHighlight(this.context),
previewHighlight(this.context),
smartTask(this.context)
], this.createPluginProps()).concat(this.defaultPlugins);
};
MdEditor.prototype.createView = function () {
var _this = this;
return new external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.EditorView(this.el, {
state: this.createState(),
dispatchTransaction: function (tr) {
_this.updateMarkdown(tr);
var state = _this.view.state.applyTransaction(tr).state;
_this.view.updateState(state);
_this.emitChangeEvent(tr);
},
handleKeyDown: function (_, ev) {
if ((ev.metaKey || ev.ctrlKey) && ev.key.toUpperCase() === 'V') {
_this.clipboard.focus();
}
_this.eventEmitter.emit('keydown', _this.editorType, ev);
return false;
},
handleDOMEvents: {
copy: function (_, ev) { return _this.captureCopy(ev); },
cut: function (_, ev) { return _this.captureCopy(ev, EVENT_TYPE); },
scroll: function () {
_this.eventEmitter.emit('scroll', 'editor');
return true;
},
keyup: function (_, ev) {
_this.eventEmitter.emit('keyup', _this.editorType, ev);
return false;
},
},
nodeViews: {
widget: widgetNodeView,
},
});
};
MdEditor.prototype.createCommands = function () {
return this.specs.commands(this.view);
};
MdEditor.prototype.captureCopy = function (ev, type) {
ev.preventDefault();
var _a = this.view.state, selection = _a.selection, tr = _a.tr;
if (selection.empty) {
return true;
}
var text = this.getChanged(selection.content());
if (ev.clipboardData) {
ev.clipboardData.setData('text/plain', text);
}
else {
window.clipboardData.setData('Text', text);
}
if (type === EVENT_TYPE) {
this.view.dispatch(tr.deleteSelection().scrollIntoView().setMeta('uiEvent', EVENT_TYPE));
}
return true;
};
MdEditor.prototype.updateMarkdown = function (tr) {
var _this = this;
if (tr.docChanged) {
tr.steps.forEach(function (step, index) {
if (step.slice && !(step instanceof external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.ReplaceAroundStep)) {
var doc = tr.docs[index];
var _a = [step.from, step.to], from = _a[0], to = _a[1];
var _b = getEditorToMdPos(doc, from, to), startPos = _b[0], endPos = _b[1];
var changed = _this.getChanged(step.slice);
if (startPos[0] === endPos[0] && startPos[1] === endPos[1] && changed === '') {
changed = '\n';
}
var editResult = _this.toastMark.editMarkdown(startPos, endPos, changed);
_this.eventEmitter.emit('updatePreview', editResult);
tr.setMeta('editResult', editResult).scrollIntoView();
}
});
}
};
MdEditor.prototype.getChanged = function (slice) {
var changed = '';
var from = 0;
var to = slice.content.size;
slice.content.nodesBetween(from, to, function (node, pos) {
if (node.isText) {
changed += node.text.slice(Math.max(from, pos) - pos, to - pos);
}
else if (node.isBlock && pos > 0) {
changed += '\n';
}
});
return changed;
};
MdEditor.prototype.setSelection = function (start, end) {
if (end === void 0) { end = start; }
var tr = this.view.state.tr;
var _a = getMdToEditorPos(tr.doc, start, end), from = _a[0], to = _a[1];
this.view.dispatch(tr.setSelection(createTextSelection(tr, from, to)).scrollIntoView());
};
MdEditor.prototype.replaceSelection = function (text, start, end) {
var newTr;
var _a = this.view.state, tr = _a.tr, schema = _a.schema, doc = _a.doc;
var lineTexts = text.split(reLineEnding);
var nodes = lineTexts.map(function (lineText) {
return createParagraph(schema, createNodesWithWidget(lineText, schema));
});
var slice = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(nodes), 1, 1);
this.focus();
if (start && end) {
var _b = getMdToEditorPos(doc, start, end), from = _b[0], to = _b[1];
newTr = tr.replaceRange(from, to, slice);
}
else {
newTr = tr.replaceSelection(slice);
}
this.view.dispatch(newTr.scrollIntoView());
};
MdEditor.prototype.deleteSelection = function (start, end) {
var newTr;
var _a = this.view.state, tr = _a.tr, doc = _a.doc;
if (start && end) {
var _b = getMdToEditorPos(doc, start, end), from = _b[0], to = _b[1];
newTr = tr.deleteRange(from, to);
}
else {
newTr = tr.deleteSelection();
}
this.view.dispatch(newTr.scrollIntoView());
};
MdEditor.prototype.getSelectedText = function (start, end) {
var _a = this.view.state, doc = _a.doc, selection = _a.selection;
var from = selection.from, to = selection.to;
if (start && end) {
var pos = getMdToEditorPos(doc, start, end);
from = pos[0];
to = pos[1];
}
return doc.textBetween(from, to, '\n');
};
MdEditor.prototype.getSelection = function () {
var _a = this.view.state.selection, from = _a.from, to = _a.to;
return getEditorToMdPos(this.view.state.tr.doc, from, to);
};
MdEditor.prototype.setMarkdown = function (markdown, cursorToEnd) {
if (cursorToEnd === void 0) { cursorToEnd = true; }
var lineTexts = markdown.split(reLineEnding);
var _a = this.view.state, tr = _a.tr, doc = _a.doc, schema = _a.schema;
var nodes = lineTexts.map(function (lineText) {
return createParagraph(schema, createNodesWithWidget(lineText, schema));
});
this.view.dispatch(tr.replaceWith(0, doc.content.size, nodes));
if (cursorToEnd) {
this.moveCursorToEnd(true);
}
};
MdEditor.prototype.addWidget = function (node, style, mdPos) {
var _a = this.view.state, tr = _a.tr, doc = _a.doc, selection = _a.selection;
var pos = mdPos ? getMdToEditorPos(doc, mdPos, mdPos)[0] : selection.to;
this.view.dispatch(tr.setMeta('widget', { pos: pos, node: node, style: style }));
};
MdEditor.prototype.replaceWithWidget = function (start, end, text) {
var _a = this.view.state, tr = _a.tr, schema = _a.schema, doc = _a.doc;
var pos = getMdToEditorPos(doc, start, end);
var nodes = createNodesWithWidget(text, schema);
this.view.dispatch(tr.replaceWith(pos[0], pos[1], nodes));
};
MdEditor.prototype.getRangeInfoOfNode = function (pos) {
var _a = this.view.state, doc = _a.doc, selection = _a.selection;
var mdPos = pos || getEditorToMdPos(doc, selection.from)[0];
var mdNode = this.toastMark.findNodeAtPosition(mdPos);
if (mdNode.type === 'text' && mdNode.parent.type !== 'paragraph') {
mdNode = mdNode.parent;
}
// add 1 sync for prosemirror position
mdNode.sourcepos[1][1] += 1;
return { range: mdNode.sourcepos, type: mdNode.type };
};
MdEditor.prototype.getMarkdown = function () {
return this.toastMark
.getLineTexts()
.map(function (lineText) { return unwrapWidgetSyntax(lineText); })
.join('\n');
};
MdEditor.prototype.getToastMark = function () {
return this.toastMark;
};
return MdEditor;
}(base));
/* harmony default export */ var mdEditor = (MdEditor);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domEvent/off.js
var off = __webpack_require__(349);
var off_default = /*#__PURE__*/__webpack_require__.n(off);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/domEvent/on.js
var on = __webpack_require__(348);
var on_default = /*#__PURE__*/__webpack_require__.n(on);
;// CONCATENATED MODULE: ../../libs/toastmark/dist/esm/index.js
/*! *****************************************************************************
Copyright (c) Microsoft Corporation.
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
PERFORMANCE OF THIS SOFTWARE.
***************************************************************************** */
/* global Reflect, Promise */
var esm_extendStatics = function (d, b) {
esm_extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b)
if (Object.prototype.hasOwnProperty.call(b, p))
d[p] = b[p]; };
return esm_extendStatics(d, b);
};
function esm_extends(d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
esm_extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var esm_assign = function () {
esm_assign = Object.assign || function __assign(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s)
if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return esm_assign.apply(this, arguments);
};
function esm_spreadArray(to, from, pack) {
if (pack || arguments.length === 2)
for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar)
ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
}
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof __webpack_require__.g !== 'undefined' ? __webpack_require__.g : typeof self !== 'undefined' ? self : {};
var encodeCache = {};
// Create a lookup array where anything but characters in `chars` string
// and alphanumeric chars is percent-encoded.
//
function getEncodeCache(exclude) {
var i, ch, cache = encodeCache[exclude];
if (cache) {
return cache;
}
cache = encodeCache[exclude] = [];
for (i = 0; i < 128; i++) {
ch = String.fromCharCode(i);
if (/^[0-9a-z]$/i.test(ch)) {
// always allow unencoded alphanumeric characters
cache.push(ch);
}
else {
cache.push('%' + ('0' + i.toString(16).toUpperCase()).slice(-2));
}
}
for (i = 0; i < exclude.length; i++) {
cache[exclude.charCodeAt(i)] = exclude[i];
}
return cache;
}
// Encode unsafe characters with percent-encoding, skipping already
// encoded sequences.
//
// - string - string to encode
// - exclude - list of characters to ignore (in addition to a-zA-Z0-9)
// - keepEscaped - don't encode '%' in a correct escape sequence (default: true)
//
function encode$1(string, exclude, keepEscaped) {
var i, l, code, nextCode, cache, result = '';
if (typeof exclude !== 'string') {
// encode(string, keepEscaped)
keepEscaped = exclude;
exclude = encode$1.defaultChars;
}
if (typeof keepEscaped === 'undefined') {
keepEscaped = true;
}
cache = getEncodeCache(exclude);
for (i = 0, l = string.length; i < l; i++) {
code = string.charCodeAt(i);
if (keepEscaped && code === 0x25 /* % */ && i + 2 < l) {
if (/^[0-9a-f]{2}$/i.test(string.slice(i + 1, i + 3))) {
result += string.slice(i, i + 3);
i += 2;
continue;
}
}
if (code < 128) {
result += cache[code];
continue;
}
if (code >= 0xD800 && code <= 0xDFFF) {
if (code >= 0xD800 && code <= 0xDBFF && i + 1 < l) {
nextCode = string.charCodeAt(i + 1);
if (nextCode >= 0xDC00 && nextCode <= 0xDFFF) {
result += encodeURIComponent(string[i] + string[i + 1]);
i++;
continue;
}
}
result += '%EF%BF%BD';
continue;
}
result += encodeURIComponent(string[i]);
}
return result;
}
encode$1.defaultChars = ";/?:@&=+$,-_.!~*'()#";
encode$1.componentChars = "-_.!~*'()";
var encode_1 = encode$1;
var lib = {};
var decode = {};
var Aacute$1 = "Á";
var aacute$1 = "á";
var Abreve = "Ă";
var abreve = "ă";
var ac = "∾";
var acd = "∿";
var acE = "∾̳";
var Acirc$1 = "Â";
var acirc$1 = "â";
var acute$1 = "´";
var Acy = "А";
var acy = "а";
var AElig$1 = "Æ";
var aelig$1 = "æ";
var af = "";
var Afr = "𝔄";
var afr = "𝔞";
var Agrave$1 = "À";
var agrave$1 = "à";
var alefsym = "ℵ";
var aleph = "ℵ";
var Alpha = "Α";
var alpha = "α";
var Amacr = "Ā";
var amacr = "ā";
var amalg = "⨿";
var amp$2 = "&";
var AMP$1 = "&";
var andand = "⩕";
var And = "⩓";
var and = "∧";
var andd = "⩜";
var andslope = "⩘";
var andv = "⩚";
var ang = "∠";
var ange = "⦤";
var angle = "∠";
var angmsdaa = "⦨";
var angmsdab = "⦩";
var angmsdac = "⦪";
var angmsdad = "⦫";
var angmsdae = "⦬";
var angmsdaf = "⦭";
var angmsdag = "⦮";
var angmsdah = "⦯";
var angmsd = "∡";
var angrt = "∟";
var angrtvb = "⊾";
var angrtvbd = "⦝";
var angsph = "∢";
var angst = "Å";
var angzarr = "⍼";
var Aogon = "Ą";
var aogon = "ą";
var Aopf = "𝔸";
var aopf = "𝕒";
var apacir = "⩯";
var ap = "≈";
var apE = "⩰";
var ape = "≊";
var apid = "≋";
var apos$1 = "'";
var ApplyFunction = "";
var approx = "≈";
var approxeq = "≊";
var Aring$1 = "Å";
var aring$1 = "å";
var Ascr = "𝒜";
var ascr = "𝒶";
var Assign = "≔";
var ast = "*";
var asymp = "≈";
var asympeq = "≍";
var Atilde$1 = "Ã";
var atilde$1 = "ã";
var Auml$1 = "Ä";
var auml$1 = "ä";
var awconint = "∳";
var awint = "⨑";
var backcong = "≌";
var backepsilon = "϶";
var backprime = "‵";
var backsim = "∽";
var backsimeq = "⋍";
var Backslash = "∖";
var Barv = "⫧";
var barvee = "⊽";
var barwed = "⌅";
var Barwed = "⌆";
var barwedge = "⌅";
var bbrk = "⎵";
var bbrktbrk = "⎶";
var bcong = "≌";
var Bcy = "Б";
var bcy = "б";
var bdquo = "„";
var becaus = "∵";
var because = "∵";
var Because = "∵";
var bemptyv = "⦰";
var bepsi = "϶";
var bernou = "ℬ";
var Bernoullis = "ℬ";
var Beta = "Β";
var beta = "β";
var beth = "ℶ";
var esm_between = "≬";
var Bfr = "𝔅";
var bfr = "𝔟";
var bigcap = "⋂";
var bigcirc = "◯";
var bigcup = "⋃";
var bigodot = "⨀";
var bigoplus = "⨁";
var bigotimes = "⨂";
var bigsqcup = "⨆";
var bigstar = "★";
var bigtriangledown = "▽";
var bigtriangleup = "△";
var biguplus = "⨄";
var bigvee = "⋁";
var bigwedge = "⋀";
var bkarow = "⤍";
var blacklozenge = "⧫";
var blacksquare = "▪";
var blacktriangle = "▴";
var blacktriangledown = "▾";
var blacktriangleleft = "◂";
var blacktriangleright = "▸";
var blank = "␣";
var blk12 = "▒";
var blk14 = "░";
var blk34 = "▓";
var block = "█";
var bne = "=⃥";
var bnequiv = "≡⃥";
var bNot = "⫭";
var bnot = "⌐";
var Bopf = "𝔹";
var bopf = "𝕓";
var bot = "⊥";
var bottom = "⊥";
var bowtie = "⋈";
var boxbox = "⧉";
var boxdl = "┐";
var boxdL = "╕";
var boxDl = "╖";
var boxDL = "╗";
var boxdr = "┌";
var boxdR = "╒";
var boxDr = "╓";
var boxDR = "╔";
var boxh = "─";
var boxH = "═";
var boxhd = "┬";
var boxHd = "╤";
var boxhD = "╥";
var boxHD = "╦";
var boxhu = "┴";
var boxHu = "╧";
var boxhU = "╨";
var boxHU = "╩";
var boxminus = "⊟";
var boxplus = "⊞";
var boxtimes = "⊠";
var boxul = "┘";
var boxuL = "╛";
var boxUl = "╜";
var boxUL = "╝";
var boxur = "└";
var boxuR = "╘";
var boxUr = "╙";
var boxUR = "╚";
var boxv = "│";
var boxV = "║";
var boxvh = "┼";
var boxvH = "╪";
var boxVh = "╫";
var boxVH = "╬";
var boxvl = "┤";
var boxvL = "╡";
var boxVl = "╢";
var boxVL = "╣";
var boxvr = "├";
var boxvR = "╞";
var boxVr = "╟";
var boxVR = "╠";
var bprime = "‵";
var breve = "˘";
var Breve = "˘";
var brvbar$1 = "¦";
var bscr = "𝒷";
var Bscr = "ℬ";
var bsemi = "⁏";
var bsim = "∽";
var bsime = "⋍";
var bsolb = "⧅";
var bsol = "\\";
var bsolhsub = "⟈";
var bull = "•";
var bullet = "•";
var bump = "≎";
var bumpE = "⪮";
var bumpe = "≏";
var Bumpeq = "≎";
var bumpeq = "≏";
var Cacute = "Ć";
var cacute = "ć";
var capand = "⩄";
var capbrcup = "⩉";
var capcap = "⩋";
var cap = "∩";
var Cap = "⋒";
var capcup = "⩇";
var capdot = "⩀";
var CapitalDifferentialD = "ⅅ";
var caps = "∩︀";
var caret = "⁁";
var caron = "ˇ";
var Cayleys = "ℭ";
var ccaps = "⩍";
var Ccaron = "Č";
var ccaron = "č";
var Ccedil$1 = "Ç";
var ccedil$1 = "ç";
var Ccirc = "Ĉ";
var ccirc = "ĉ";
var Cconint = "∰";
var ccups = "⩌";
var ccupssm = "⩐";
var Cdot = "Ċ";
var cdot = "ċ";
var cedil$1 = "¸";
var Cedilla = "¸";
var cemptyv = "⦲";
var cent$1 = "¢";
var centerdot = "·";
var CenterDot = "·";
var cfr = "𝔠";
var Cfr = "ℭ";
var CHcy = "Ч";
var chcy = "ч";
var check = "✓";
var checkmark = "✓";
var Chi = "Χ";
var chi = "χ";
var circ = "ˆ";
var circeq = "≗";
var circlearrowleft = "↺";
var circlearrowright = "↻";
var circledast = "⊛";
var circledcirc = "⊚";
var circleddash = "⊝";
var CircleDot = "⊙";
var circledR = "®";
var circledS = "Ⓢ";
var CircleMinus = "⊖";
var CirclePlus = "⊕";
var CircleTimes = "⊗";
var cir = "○";
var cirE = "⧃";
var cire = "≗";
var cirfnint = "⨐";
var cirmid = "⫯";
var cirscir = "⧂";
var ClockwiseContourIntegral = "∲";
var CloseCurlyDoubleQuote = "”";
var CloseCurlyQuote = "’";
var clubs = "♣";
var clubsuit = "♣";
var colon = ":";
var Colon = "∷";
var Colone = "⩴";
var colone = "≔";
var coloneq = "≔";
var comma = ",";
var commat = "@";
var comp = "∁";
var compfn = "∘";
var complement = "∁";
var complexes = "ℂ";
var cong = "≅";
var congdot = "⩭";
var Congruent = "≡";
var conint = "∮";
var Conint = "∯";
var ContourIntegral = "∮";
var copf = "𝕔";
var Copf = "ℂ";
var coprod = "∐";
var Coproduct = "∐";
var copy$1 = "©";
var COPY$1 = "©";
var copysr = "℗";
var CounterClockwiseContourIntegral = "∳";
var crarr = "↵";
var cross = "✗";
var Cross = "⨯";
var Cscr = "𝒞";
var cscr = "𝒸";
var csub = "⫏";
var csube = "⫑";
var csup = "⫐";
var csupe = "⫒";
var ctdot = "⋯";
var cudarrl = "⤸";
var cudarrr = "⤵";
var cuepr = "⋞";
var cuesc = "⋟";
var cularr = "↶";
var cularrp = "⤽";
var cupbrcap = "⩈";
var cupcap = "⩆";
var CupCap = "≍";
var cup = "∪";
var Cup = "⋓";
var cupcup = "⩊";
var cupdot = "⊍";
var cupor = "⩅";
var cups = "∪︀";
var curarr = "↷";
var curarrm = "⤼";
var curlyeqprec = "⋞";
var curlyeqsucc = "⋟";
var curlyvee = "⋎";
var curlywedge = "⋏";
var curren$1 = "¤";
var curvearrowleft = "↶";
var curvearrowright = "↷";
var cuvee = "⋎";
var cuwed = "⋏";
var cwconint = "∲";
var cwint = "∱";
var cylcty = "⌭";
var dagger = "†";
var Dagger = "‡";
var daleth = "ℸ";
var darr = "↓";
var Darr = "↡";
var dArr = "⇓";
var dash = "‐";
var Dashv = "⫤";
var dashv = "⊣";
var dbkarow = "⤏";
var dblac = "˝";
var Dcaron = "Ď";
var dcaron = "ď";
var Dcy = "Д";
var dcy = "д";
var ddagger = "‡";
var ddarr = "⇊";
var DD = "ⅅ";
var dd = "ⅆ";
var DDotrahd = "⤑";
var ddotseq = "⩷";
var deg$1 = "°";
var Del = "∇";
var Delta = "Δ";
var delta = "δ";
var demptyv = "⦱";
var dfisht = "⥿";
var Dfr = "𝔇";
var dfr = "𝔡";
var dHar = "⥥";
var dharl = "⇃";
var dharr = "⇂";
var DiacriticalAcute = "´";
var DiacriticalDot = "˙";
var DiacriticalDoubleAcute = "˝";
var DiacriticalGrave = "`";
var DiacriticalTilde = "˜";
var diam = "⋄";
var diamond = "⋄";
var Diamond = "⋄";
var diamondsuit = "♦";
var diams = "♦";
var die = "¨";
var DifferentialD = "ⅆ";
var digamma = "ϝ";
var disin = "⋲";
var div = "÷";
var divide$1 = "÷";
var divideontimes = "⋇";
var divonx = "⋇";
var DJcy = "Ђ";
var djcy = "ђ";
var dlcorn = "⌞";
var dlcrop = "⌍";
var dollar = "$";
var Dopf = "𝔻";
var dopf = "𝕕";
var Dot = "¨";
var dot = "˙";
var DotDot = "⃜";
var doteq = "≐";
var doteqdot = "≑";
var DotEqual = "≐";
var dotminus = "∸";
var dotplus = "∔";
var dotsquare = "⊡";
var doublebarwedge = "⌆";
var DoubleContourIntegral = "∯";
var DoubleDot = "¨";
var DoubleDownArrow = "⇓";
var DoubleLeftArrow = "⇐";
var DoubleLeftRightArrow = "⇔";
var DoubleLeftTee = "⫤";
var DoubleLongLeftArrow = "⟸";
var DoubleLongLeftRightArrow = "⟺";
var DoubleLongRightArrow = "⟹";
var DoubleRightArrow = "⇒";
var DoubleRightTee = "⊨";
var DoubleUpArrow = "⇑";
var DoubleUpDownArrow = "⇕";
var DoubleVerticalBar = "∥";
var DownArrowBar = "⤓";
var downarrow = "↓";
var DownArrow = "↓";
var Downarrow = "⇓";
var DownArrowUpArrow = "⇵";
var DownBreve = "̑";
var downdownarrows = "⇊";
var downharpoonleft = "⇃";
var downharpoonright = "⇂";
var DownLeftRightVector = "⥐";
var DownLeftTeeVector = "⥞";
var DownLeftVectorBar = "⥖";
var DownLeftVector = "↽";
var DownRightTeeVector = "⥟";
var DownRightVectorBar = "⥗";
var DownRightVector = "⇁";
var DownTeeArrow = "↧";
var DownTee = "⊤";
var drbkarow = "⤐";
var drcorn = "⌟";
var drcrop = "⌌";
var Dscr = "𝒟";
var dscr = "𝒹";
var DScy = "Ѕ";
var dscy = "ѕ";
var dsol = "⧶";
var Dstrok = "Đ";
var dstrok = "đ";
var dtdot = "⋱";
var dtri = "▿";
var dtrif = "▾";
var duarr = "⇵";
var duhar = "⥯";
var dwangle = "⦦";
var DZcy = "Џ";
var dzcy = "џ";
var dzigrarr = "⟿";
var Eacute$1 = "É";
var eacute$1 = "é";
var easter = "⩮";
var Ecaron = "Ě";
var ecaron = "ě";
var Ecirc$1 = "Ê";
var ecirc$1 = "ê";
var ecir = "≖";
var ecolon = "≕";
var Ecy = "Э";
var ecy = "э";
var eDDot = "⩷";
var Edot = "Ė";
var edot = "ė";
var eDot = "≑";
var ee = "ⅇ";
var efDot = "≒";
var Efr = "𝔈";
var efr = "𝔢";
var eg = "⪚";
var Egrave$1 = "È";
var egrave$1 = "è";
var egs = "⪖";
var egsdot = "⪘";
var el = "⪙";
var esm_Element = "∈";
var elinters = "⏧";
var ell = "ℓ";
var els = "⪕";
var elsdot = "⪗";
var Emacr = "Ē";
var emacr = "ē";
var esm_empty = "∅";
var emptyset = "∅";
var EmptySmallSquare = "◻";
var emptyv = "∅";
var EmptyVerySmallSquare = "▫";
var emsp13 = " ";
var emsp14 = " ";
var emsp = " ";
var ENG = "Ŋ";
var eng = "ŋ";
var ensp = " ";
var Eogon = "Ę";
var eogon = "ę";
var Eopf = "𝔼";
var eopf = "𝕖";
var epar = "⋕";
var eparsl = "⧣";
var eplus = "⩱";
var epsi = "ε";
var Epsilon = "Ε";
var epsilon = "ε";
var epsiv = "ϵ";
var eqcirc = "≖";
var eqcolon = "≕";
var eqsim = "≂";
var eqslantgtr = "⪖";
var eqslantless = "⪕";
var Equal = "⩵";
var equals = "=";
var EqualTilde = "≂";
var equest = "≟";
var Equilibrium = "⇌";
var equiv = "≡";
var equivDD = "⩸";
var eqvparsl = "⧥";
var erarr = "⥱";
var erDot = "≓";
var escr = "ℯ";
var Escr = "ℰ";
var esdot = "≐";
var Esim = "⩳";
var esim = "≂";
var Eta = "Η";
var eta = "η";
var ETH$1 = "Ð";
var eth$1 = "ð";
var Euml$1 = "Ë";
var euml$1 = "ë";
var euro = "€";
var excl = "!";
var exist = "∃";
var Exists = "∃";
var expectation = "ℰ";
var exponentiale = "ⅇ";
var ExponentialE = "ⅇ";
var fallingdotseq = "≒";
var Fcy = "Ф";
var fcy = "ф";
var female = "♀";
var ffilig = "ffi";
var fflig = "ff";
var ffllig = "ffl";
var Ffr = "𝔉";
var ffr = "𝔣";
var filig = "fi";
var FilledSmallSquare = "◼";
var FilledVerySmallSquare = "▪";
var fjlig = "fj";
var flat = "♭";
var fllig = "fl";
var fltns = "▱";
var fnof = "ƒ";
var Fopf = "𝔽";
var fopf = "𝕗";
var forall = "∀";
var ForAll = "∀";
var fork = "⋔";
var forkv = "⫙";
var Fouriertrf = "ℱ";
var fpartint = "⨍";
var frac12$1 = "½";
var frac13 = "⅓";
var frac14$1 = "¼";
var frac15 = "⅕";
var frac16 = "⅙";
var frac18 = "⅛";
var frac23 = "⅔";
var frac25 = "⅖";
var frac34$1 = "¾";
var frac35 = "⅗";
var frac38 = "⅜";
var frac45 = "⅘";
var frac56 = "⅚";
var frac58 = "⅝";
var frac78 = "⅞";
var frasl = "⁄";
var frown = "⌢";
var fscr = "𝒻";
var Fscr = "ℱ";
var gacute = "ǵ";
var Gamma = "Γ";
var gamma = "γ";
var Gammad = "Ϝ";
var gammad = "ϝ";
var gap = "⪆";
var Gbreve = "Ğ";
var gbreve = "ğ";
var Gcedil = "Ģ";
var Gcirc = "Ĝ";
var gcirc = "ĝ";
var Gcy = "Г";
var gcy = "г";
var Gdot = "Ġ";
var gdot = "ġ";
var ge = "≥";
var gE = "≧";
var gEl = "⪌";
var gel = "⋛";
var geq = "≥";
var geqq = "≧";
var geqslant = "⩾";
var gescc = "⪩";
var ges = "⩾";
var gesdot = "⪀";
var gesdoto = "⪂";
var gesdotol = "⪄";
var gesl = "⋛︀";
var gesles = "⪔";
var Gfr = "𝔊";
var gfr = "𝔤";
var gg = "≫";
var Gg = "⋙";
var ggg = "⋙";
var gimel = "ℷ";
var GJcy = "Ѓ";
var gjcy = "ѓ";
var gla = "⪥";
var gl = "≷";
var glE = "⪒";
var glj = "⪤";
var gnap = "⪊";
var gnapprox = "⪊";
var gne = "⪈";
var gnE = "≩";
var gneq = "⪈";
var gneqq = "≩";
var gnsim = "⋧";
var Gopf = "𝔾";
var gopf = "𝕘";
var grave = "`";
var GreaterEqual = "≥";
var GreaterEqualLess = "⋛";
var GreaterFullEqual = "≧";
var GreaterGreater = "⪢";
var GreaterLess = "≷";
var GreaterSlantEqual = "⩾";
var GreaterTilde = "≳";
var Gscr = "𝒢";
var gscr = "ℊ";
var gsim = "≳";
var gsime = "⪎";
var gsiml = "⪐";
var gtcc = "⪧";
var gtcir = "⩺";
var gt$2 = ">";
var GT$1 = ">";
var Gt = "≫";
var gtdot = "⋗";
var gtlPar = "⦕";
var gtquest = "⩼";
var gtrapprox = "⪆";
var gtrarr = "⥸";
var gtrdot = "⋗";
var gtreqless = "⋛";
var gtreqqless = "⪌";
var gtrless = "≷";
var gtrsim = "≳";
var gvertneqq = "≩︀";
var gvnE = "≩︀";
var Hacek = "ˇ";
var hairsp = " ";
var half = "½";
var hamilt = "ℋ";
var HARDcy = "Ъ";
var hardcy = "ъ";
var harrcir = "⥈";
var harr = "↔";
var hArr = "⇔";
var harrw = "↭";
var Hat = "^";
var hbar = "ℏ";
var Hcirc = "Ĥ";
var hcirc = "ĥ";
var hearts = "♥";
var heartsuit = "♥";
var hellip = "…";
var hercon = "⊹";
var hfr = "𝔥";
var Hfr = "ℌ";
var HilbertSpace = "ℋ";
var hksearow = "⤥";
var hkswarow = "⤦";
var hoarr = "⇿";
var homtht = "∻";
var hookleftarrow = "↩";
var hookrightarrow = "↪";
var hopf = "𝕙";
var Hopf = "ℍ";
var horbar = "―";
var HorizontalLine = "─";
var hscr = "𝒽";
var Hscr = "ℋ";
var hslash = "ℏ";
var Hstrok = "Ħ";
var hstrok = "ħ";
var HumpDownHump = "≎";
var HumpEqual = "≏";
var hybull = "⁃";
var hyphen = "‐";
var Iacute$1 = "Í";
var iacute$1 = "í";
var ic = "";
var Icirc$1 = "Î";
var icirc$1 = "î";
var Icy = "И";
var icy = "и";
var Idot = "İ";
var IEcy = "Е";
var iecy = "е";
var iexcl$1 = "¡";
var iff = "⇔";
var ifr = "𝔦";
var Ifr = "ℑ";
var Igrave$1 = "Ì";
var igrave$1 = "ì";
var ii = "ⅈ";
var iiiint = "⨌";
var iiint = "∭";
var iinfin = "⧜";
var iiota = "℩";
var IJlig = "IJ";
var ijlig = "ij";
var Imacr = "Ī";
var imacr = "ī";
var esm_image = "ℑ";
var ImaginaryI = "ⅈ";
var imagline = "ℐ";
var imagpart = "ℑ";
var imath = "ı";
var Im = "ℑ";
var imof = "⊷";
var imped = "Ƶ";
var Implies = "⇒";
var incare = "℅";
var infin = "∞";
var infintie = "⧝";
var inodot = "ı";
var intcal = "⊺";
var esm_int = "∫";
var Int = "∬";
var integers = "ℤ";
var Integral = "∫";
var intercal = "⊺";
var Intersection = "⋂";
var intlarhk = "⨗";
var intprod = "⨼";
var InvisibleComma = "";
var InvisibleTimes = "";
var IOcy = "Ё";
var iocy = "ё";
var Iogon = "Į";
var iogon = "į";
var Iopf = "𝕀";
var iopf = "𝕚";
var Iota = "Ι";
var iota = "ι";
var iprod = "⨼";
var iquest$1 = "¿";
var iscr = "𝒾";
var Iscr = "ℐ";
var isin = "∈";
var isindot = "⋵";
var isinE = "⋹";
var isins = "⋴";
var isinsv = "⋳";
var isinv = "∈";
var it = "";
var Itilde = "Ĩ";
var itilde = "ĩ";
var Iukcy = "І";
var iukcy = "і";
var Iuml$1 = "Ï";
var iuml$1 = "ï";
var Jcirc = "Ĵ";
var jcirc = "ĵ";
var Jcy = "Й";
var jcy = "й";
var Jfr = "𝔍";
var jfr = "𝔧";
var jmath = "ȷ";
var Jopf = "𝕁";
var jopf = "𝕛";
var Jscr = "𝒥";
var jscr = "𝒿";
var Jsercy = "Ј";
var jsercy = "ј";
var Jukcy = "Є";
var jukcy = "є";
var Kappa = "Κ";
var kappa = "κ";
var kappav = "ϰ";
var Kcedil = "Ķ";
var kcedil = "ķ";
var Kcy = "К";
var kcy = "к";
var Kfr = "𝔎";
var kfr = "𝔨";
var kgreen = "ĸ";
var KHcy = "Х";
var khcy = "х";
var KJcy = "Ќ";
var kjcy = "ќ";
var Kopf = "𝕂";
var kopf = "𝕜";
var Kscr = "𝒦";
var kscr = "𝓀";
var lAarr = "⇚";
var Lacute = "Ĺ";
var lacute = "ĺ";
var laemptyv = "⦴";
var lagran = "ℒ";
var Lambda = "Λ";
var lambda = "λ";
var lang = "⟨";
var Lang = "⟪";
var langd = "⦑";
var langle = "⟨";
var lap = "⪅";
var Laplacetrf = "ℒ";
var laquo$1 = "«";
var larrb = "⇤";
var larrbfs = "⤟";
var larr = "←";
var Larr = "↞";
var lArr = "⇐";
var larrfs = "⤝";
var larrhk = "↩";
var larrlp = "↫";
var larrpl = "⤹";
var larrsim = "⥳";
var larrtl = "↢";
var latail = "⤙";
var lAtail = "⤛";
var lat = "⪫";
var late = "⪭";
var lates = "⪭︀";
var lbarr = "⤌";
var lBarr = "⤎";
var lbbrk = "❲";
var lbrace = "{";
var lbrack = "[";
var lbrke = "⦋";
var lbrksld = "⦏";
var lbrkslu = "⦍";
var Lcaron = "Ľ";
var lcaron = "ľ";
var Lcedil = "Ļ";
var lcedil = "ļ";
var lceil = "⌈";
var lcub = "{";
var Lcy = "Л";
var lcy = "л";
var ldca = "⤶";
var ldquo = "“";
var ldquor = "„";
var ldrdhar = "⥧";
var ldrushar = "⥋";
var ldsh = "↲";
var le = "≤";
var lE = "≦";
var LeftAngleBracket = "⟨";
var LeftArrowBar = "⇤";
var leftarrow = "←";
var LeftArrow = "←";
var Leftarrow = "⇐";
var LeftArrowRightArrow = "⇆";
var leftarrowtail = "↢";
var LeftCeiling = "⌈";
var LeftDoubleBracket = "⟦";
var LeftDownTeeVector = "⥡";
var LeftDownVectorBar = "⥙";
var LeftDownVector = "⇃";
var LeftFloor = "⌊";
var leftharpoondown = "↽";
var leftharpoonup = "↼";
var leftleftarrows = "⇇";
var leftrightarrow = "↔";
var LeftRightArrow = "↔";
var Leftrightarrow = "⇔";
var leftrightarrows = "⇆";
var leftrightharpoons = "⇋";
var leftrightsquigarrow = "↭";
var LeftRightVector = "⥎";
var LeftTeeArrow = "↤";
var LeftTee = "⊣";
var LeftTeeVector = "⥚";
var leftthreetimes = "⋋";
var LeftTriangleBar = "⧏";
var LeftTriangle = "⊲";
var LeftTriangleEqual = "⊴";
var LeftUpDownVector = "⥑";
var LeftUpTeeVector = "⥠";
var LeftUpVectorBar = "⥘";
var LeftUpVector = "↿";
var LeftVectorBar = "⥒";
var LeftVector = "↼";
var lEg = "⪋";
var leg = "⋚";
var leq = "≤";
var leqq = "≦";
var leqslant = "⩽";
var lescc = "⪨";
var les = "⩽";
var lesdot = "⩿";
var lesdoto = "⪁";
var lesdotor = "⪃";
var lesg = "⋚︀";
var lesges = "⪓";
var lessapprox = "⪅";
var lessdot = "⋖";
var lesseqgtr = "⋚";
var lesseqqgtr = "⪋";
var LessEqualGreater = "⋚";
var LessFullEqual = "≦";
var LessGreater = "≶";
var lessgtr = "≶";
var LessLess = "⪡";
var lesssim = "≲";
var LessSlantEqual = "⩽";
var LessTilde = "≲";
var lfisht = "⥼";
var lfloor = "⌊";
var Lfr = "𝔏";
var lfr = "𝔩";
var lg = "≶";
var lgE = "⪑";
var lHar = "⥢";
var lhard = "↽";
var lharu = "↼";
var lharul = "⥪";
var lhblk = "▄";
var LJcy = "Љ";
var ljcy = "љ";
var llarr = "⇇";
var ll = "≪";
var Ll = "⋘";
var llcorner = "⌞";
var Lleftarrow = "⇚";
var llhard = "⥫";
var lltri = "◺";
var Lmidot = "Ŀ";
var lmidot = "ŀ";
var lmoustache = "⎰";
var lmoust = "⎰";
var lnap = "⪉";
var lnapprox = "⪉";
var lne = "⪇";
var lnE = "≨";
var lneq = "⪇";
var lneqq = "≨";
var lnsim = "⋦";
var loang = "⟬";
var loarr = "⇽";
var lobrk = "⟦";
var longleftarrow = "⟵";
var LongLeftArrow = "⟵";
var Longleftarrow = "⟸";
var longleftrightarrow = "⟷";
var LongLeftRightArrow = "⟷";
var Longleftrightarrow = "⟺";
var longmapsto = "⟼";
var longrightarrow = "⟶";
var LongRightArrow = "⟶";
var Longrightarrow = "⟹";
var looparrowleft = "↫";
var looparrowright = "↬";
var lopar = "⦅";
var Lopf = "𝕃";
var lopf = "𝕝";
var loplus = "⨭";
var lotimes = "⨴";
var lowast = "∗";
var lowbar = "_";
var LowerLeftArrow = "↙";
var LowerRightArrow = "↘";
var loz = "◊";
var lozenge = "◊";
var lozf = "⧫";
var lpar = "(";
var lparlt = "⦓";
var lrarr = "⇆";
var lrcorner = "⌟";
var lrhar = "⇋";
var lrhard = "⥭";
var lrm = "";
var lrtri = "⊿";
var lsaquo = "‹";
var lscr = "𝓁";
var Lscr = "ℒ";
var lsh = "↰";
var Lsh = "↰";
var lsim = "≲";
var lsime = "⪍";
var lsimg = "⪏";
var lsqb = "[";
var lsquo = "‘";
var lsquor = "‚";
var Lstrok = "Ł";
var lstrok = "ł";
var ltcc = "⪦";
var ltcir = "⩹";
var lt$2 = "<";
var LT$1 = "<";
var Lt = "≪";
var ltdot = "⋖";
var lthree = "⋋";
var ltimes = "⋉";
var ltlarr = "⥶";
var ltquest = "⩻";
var ltri = "◃";
var ltrie = "⊴";
var ltrif = "◂";
var ltrPar = "⦖";
var lurdshar = "⥊";
var luruhar = "⥦";
var lvertneqq = "≨︀";
var lvnE = "≨︀";
var macr$1 = "¯";
var male = "♂";
var malt = "✠";
var maltese = "✠";
var map = "↦";
var mapsto = "↦";
var mapstodown = "↧";
var mapstoleft = "↤";
var mapstoup = "↥";
var marker = "▮";
var mcomma = "⨩";
var Mcy = "М";
var mcy = "м";
var mdash = "—";
var mDDot = "∺";
var measuredangle = "∡";
var MediumSpace = " ";
var Mellintrf = "ℳ";
var Mfr = "𝔐";
var mfr = "𝔪";
var mho = "℧";
var micro$1 = "µ";
var midast = "*";
var midcir = "⫰";
var mid = "∣";
var middot$1 = "·";
var minusb = "⊟";
var minus = "−";
var minusd = "∸";
var minusdu = "⨪";
var MinusPlus = "∓";
var mlcp = "⫛";
var mldr = "…";
var mnplus = "∓";
var models = "⊧";
var Mopf = "𝕄";
var mopf = "𝕞";
var mp = "∓";
var mscr = "𝓂";
var Mscr = "ℳ";
var mstpos = "∾";
var Mu = "Μ";
var mu = "μ";
var multimap = "⊸";
var mumap = "⊸";
var nabla = "∇";
var Nacute = "Ń";
var nacute = "ń";
var nang = "∠⃒";
var nap = "≉";
var napE = "⩰̸";
var napid = "≋̸";
var napos = "ʼn";
var napprox = "≉";
var natural = "♮";
var naturals = "ℕ";
var natur = "♮";
var nbsp$1 = " ";
var nbump = "≎̸";
var nbumpe = "≏̸";
var ncap = "⩃";
var Ncaron = "Ň";
var ncaron = "ň";
var Ncedil = "Ņ";
var ncedil = "ņ";
var ncong = "≇";
var ncongdot = "⩭̸";
var ncup = "⩂";
var Ncy = "Н";
var ncy = "н";
var ndash = "–";
var nearhk = "⤤";
var nearr = "↗";
var neArr = "⇗";
var nearrow = "↗";
var ne = "≠";
var nedot = "≐̸";
var NegativeMediumSpace = "";
var NegativeThickSpace = "";
var NegativeThinSpace = "";
var NegativeVeryThinSpace = "";
var nequiv = "≢";
var nesear = "⤨";
var nesim = "≂̸";
var NestedGreaterGreater = "≫";
var NestedLessLess = "≪";
var NewLine = "\n";
var nexist = "∄";
var nexists = "∄";
var Nfr = "𝔑";
var nfr = "𝔫";
var ngE = "≧̸";
var nge = "≱";
var ngeq = "≱";
var ngeqq = "≧̸";
var ngeqslant = "⩾̸";
var nges = "⩾̸";
var nGg = "⋙̸";
var ngsim = "≵";
var nGt = "≫⃒";
var ngt = "≯";
var ngtr = "≯";
var nGtv = "≫̸";
var nharr = "↮";
var nhArr = "⇎";
var nhpar = "⫲";
var ni = "∋";
var nis = "⋼";
var nisd = "⋺";
var niv = "∋";
var NJcy = "Њ";
var njcy = "њ";
var nlarr = "↚";
var nlArr = "⇍";
var nldr = "‥";
var nlE = "≦̸";
var nle = "≰";
var nleftarrow = "↚";
var nLeftarrow = "⇍";
var nleftrightarrow = "↮";
var nLeftrightarrow = "⇎";
var nleq = "≰";
var nleqq = "≦̸";
var nleqslant = "⩽̸";
var nles = "⩽̸";
var nless = "≮";
var nLl = "⋘̸";
var nlsim = "≴";
var nLt = "≪⃒";
var nlt = "≮";
var nltri = "⋪";
var nltrie = "⋬";
var nLtv = "≪̸";
var nmid = "∤";
var NoBreak = "";
var NonBreakingSpace = " ";
var nopf = "𝕟";
var Nopf = "ℕ";
var Not = "⫬";
var not$1 = "¬";
var NotCongruent = "≢";
var NotCupCap = "≭";
var NotDoubleVerticalBar = "∦";
var NotElement = "∉";
var NotEqual = "≠";
var NotEqualTilde = "≂̸";
var NotExists = "∄";
var NotGreater = "≯";
var NotGreaterEqual = "≱";
var NotGreaterFullEqual = "≧̸";
var NotGreaterGreater = "≫̸";
var NotGreaterLess = "≹";
var NotGreaterSlantEqual = "⩾̸";
var NotGreaterTilde = "≵";
var NotHumpDownHump = "≎̸";
var NotHumpEqual = "≏̸";
var notin = "∉";
var notindot = "⋵̸";
var notinE = "⋹̸";
var notinva = "∉";
var notinvb = "⋷";
var notinvc = "⋶";
var NotLeftTriangleBar = "⧏̸";
var NotLeftTriangle = "⋪";
var NotLeftTriangleEqual = "⋬";
var NotLess = "≮";
var NotLessEqual = "≰";
var NotLessGreater = "≸";
var NotLessLess = "≪̸";
var NotLessSlantEqual = "⩽̸";
var NotLessTilde = "≴";
var NotNestedGreaterGreater = "⪢̸";
var NotNestedLessLess = "⪡̸";
var notni = "∌";
var notniva = "∌";
var notnivb = "⋾";
var notnivc = "⋽";
var NotPrecedes = "⊀";
var NotPrecedesEqual = "⪯̸";
var NotPrecedesSlantEqual = "⋠";
var NotReverseElement = "∌";
var NotRightTriangleBar = "⧐̸";
var NotRightTriangle = "⋫";
var NotRightTriangleEqual = "⋭";
var NotSquareSubset = "⊏̸";
var NotSquareSubsetEqual = "⋢";
var NotSquareSuperset = "⊐̸";
var NotSquareSupersetEqual = "⋣";
var NotSubset = "⊂⃒";
var NotSubsetEqual = "⊈";
var NotSucceeds = "⊁";
var NotSucceedsEqual = "⪰̸";
var NotSucceedsSlantEqual = "⋡";
var NotSucceedsTilde = "≿̸";
var NotSuperset = "⊃⃒";
var NotSupersetEqual = "⊉";
var NotTilde = "≁";
var NotTildeEqual = "≄";
var NotTildeFullEqual = "≇";
var NotTildeTilde = "≉";
var NotVerticalBar = "∤";
var nparallel = "∦";
var npar = "∦";
var nparsl = "⫽⃥";
var npart = "∂̸";
var npolint = "⨔";
var npr = "⊀";
var nprcue = "⋠";
var nprec = "⊀";
var npreceq = "⪯̸";
var npre = "⪯̸";
var nrarrc = "⤳̸";
var nrarr = "↛";
var nrArr = "⇏";
var nrarrw = "↝̸";
var nrightarrow = "↛";
var nRightarrow = "⇏";
var nrtri = "⋫";
var nrtrie = "⋭";
var nsc = "⊁";
var nsccue = "⋡";
var nsce = "⪰̸";
var Nscr = "𝒩";
var nscr = "𝓃";
var nshortmid = "∤";
var nshortparallel = "∦";
var nsim = "≁";
var nsime = "≄";
var nsimeq = "≄";
var nsmid = "∤";
var nspar = "∦";
var nsqsube = "⋢";
var nsqsupe = "⋣";
var nsub = "⊄";
var nsubE = "⫅̸";
var nsube = "⊈";
var nsubset = "⊂⃒";
var nsubseteq = "⊈";
var nsubseteqq = "⫅̸";
var nsucc = "⊁";
var nsucceq = "⪰̸";
var nsup = "⊅";
var nsupE = "⫆̸";
var nsupe = "⊉";
var nsupset = "⊃⃒";
var nsupseteq = "⊉";
var nsupseteqq = "⫆̸";
var ntgl = "≹";
var Ntilde$1 = "Ñ";
var ntilde$1 = "ñ";
var ntlg = "≸";
var ntriangleleft = "⋪";
var ntrianglelefteq = "⋬";
var ntriangleright = "⋫";
var ntrianglerighteq = "⋭";
var Nu = "Ν";
var nu = "ν";
var num = "#";
var numero = "№";
var numsp = " ";
var nvap = "≍⃒";
var nvdash = "⊬";
var nvDash = "⊭";
var nVdash = "⊮";
var nVDash = "⊯";
var nvge = "≥⃒";
var nvgt = ">⃒";
var nvHarr = "⤄";
var nvinfin = "⧞";
var nvlArr = "⤂";
var nvle = "≤⃒";
var nvlt = "<⃒";
var nvltrie = "⊴⃒";
var nvrArr = "⤃";
var nvrtrie = "⊵⃒";
var nvsim = "∼⃒";
var nwarhk = "⤣";
var nwarr = "↖";
var nwArr = "⇖";
var nwarrow = "↖";
var nwnear = "⤧";
var Oacute$1 = "Ó";
var oacute$1 = "ó";
var oast = "⊛";
var Ocirc$1 = "Ô";
var ocirc$1 = "ô";
var ocir = "⊚";
var Ocy = "О";
var ocy = "о";
var odash = "⊝";
var Odblac = "Ő";
var odblac = "ő";
var odiv = "⨸";
var odot = "⊙";
var odsold = "⦼";
var OElig = "Œ";
var oelig = "œ";
var ofcir = "⦿";
var Ofr = "𝔒";
var ofr = "𝔬";
var ogon = "˛";
var Ograve$1 = "Ò";
var ograve$1 = "ò";
var ogt = "⧁";
var ohbar = "⦵";
var ohm = "Ω";
var oint = "∮";
var olarr = "↺";
var olcir = "⦾";
var olcross = "⦻";
var oline = "‾";
var olt = "⧀";
var Omacr = "Ō";
var omacr = "ō";
var Omega = "Ω";
var omega = "ω";
var Omicron = "Ο";
var omicron = "ο";
var omid = "⦶";
var ominus = "⊖";
var Oopf = "𝕆";
var oopf = "𝕠";
var opar = "⦷";
var OpenCurlyDoubleQuote = "“";
var OpenCurlyQuote = "‘";
var operp = "⦹";
var oplus = "⊕";
var orarr = "↻";
var Or = "⩔";
var or = "∨";
var ord = "⩝";
var order = "ℴ";
var orderof = "ℴ";
var ordf$1 = "ª";
var ordm$1 = "º";
var origof = "⊶";
var oror = "⩖";
var orslope = "⩗";
var orv = "⩛";
var oS = "Ⓢ";
var Oscr = "𝒪";
var oscr = "ℴ";
var Oslash$1 = "Ø";
var oslash$1 = "ø";
var osol = "⊘";
var Otilde$1 = "Õ";
var otilde$1 = "õ";
var otimesas = "⨶";
var Otimes = "⨷";
var otimes = "⊗";
var Ouml$1 = "Ö";
var ouml$1 = "ö";
var ovbar = "⌽";
var OverBar = "‾";
var OverBrace = "⏞";
var OverBracket = "⎴";
var OverParenthesis = "⏜";
var para$1 = "¶";
var parallel = "∥";
var par = "∥";
var parsim = "⫳";
var parsl = "⫽";
var part = "∂";
var PartialD = "∂";
var Pcy = "П";
var pcy = "п";
var percnt = "%";
var period = ".";
var permil = "‰";
var perp = "⊥";
var pertenk = "‱";
var Pfr = "𝔓";
var pfr = "𝔭";
var Phi = "Φ";
var phi = "φ";
var phiv = "ϕ";
var phmmat = "ℳ";
var phone = "☎";
var Pi = "Π";
var pi = "π";
var pitchfork = "⋔";
var piv = "ϖ";
var planck = "ℏ";
var planckh = "ℎ";
var plankv = "ℏ";
var plusacir = "⨣";
var plusb = "⊞";
var pluscir = "⨢";
var plus = "+";
var plusdo = "∔";
var plusdu = "⨥";
var pluse = "⩲";
var PlusMinus = "±";
var plusmn$1 = "±";
var plussim = "⨦";
var plustwo = "⨧";
var pm = "±";
var Poincareplane = "ℌ";
var pointint = "⨕";
var popf = "𝕡";
var Popf = "ℙ";
var pound$1 = "£";
var prap = "⪷";
var Pr = "⪻";
var pr = "≺";
var prcue = "≼";
var precapprox = "⪷";
var prec = "≺";
var preccurlyeq = "≼";
var Precedes = "≺";
var PrecedesEqual = "⪯";
var PrecedesSlantEqual = "≼";
var PrecedesTilde = "≾";
var preceq = "⪯";
var precnapprox = "⪹";
var precneqq = "⪵";
var precnsim = "⋨";
var pre = "⪯";
var prE = "⪳";
var precsim = "≾";
var prime = "′";
var Prime = "″";
var primes = "ℙ";
var prnap = "⪹";
var prnE = "⪵";
var prnsim = "⋨";
var prod = "∏";
var Product = "∏";
var profalar = "⌮";
var profline = "⌒";
var profsurf = "⌓";
var prop = "∝";
var Proportional = "∝";
var Proportion = "∷";
var propto = "∝";
var prsim = "≾";
var prurel = "⊰";
var Pscr = "𝒫";
var pscr = "𝓅";
var Psi = "Ψ";
var psi = "ψ";
var puncsp = " ";
var Qfr = "𝔔";
var qfr = "𝔮";
var qint = "⨌";
var qopf = "𝕢";
var Qopf = "ℚ";
var qprime = "⁗";
var Qscr = "𝒬";
var qscr = "𝓆";
var quaternions = "ℍ";
var quatint = "⨖";
var quest = "?";
var questeq = "≟";
var quot$2 = "\"";
var QUOT$1 = "\"";
var rAarr = "⇛";
var race = "∽̱";
var Racute = "Ŕ";
var racute = "ŕ";
var radic = "√";
var raemptyv = "⦳";
var rang = "⟩";
var Rang = "⟫";
var rangd = "⦒";
var range = "⦥";
var rangle = "⟩";
var raquo$1 = "»";
var rarrap = "⥵";
var rarrb = "⇥";
var rarrbfs = "⤠";
var rarrc = "⤳";
var rarr = "→";
var Rarr = "↠";
var rArr = "⇒";
var rarrfs = "⤞";
var rarrhk = "↪";
var rarrlp = "↬";
var rarrpl = "⥅";
var rarrsim = "⥴";
var Rarrtl = "⤖";
var rarrtl = "↣";
var rarrw = "↝";
var ratail = "⤚";
var rAtail = "⤜";
var ratio = "∶";
var rationals = "ℚ";
var rbarr = "⤍";
var rBarr = "⤏";
var RBarr = "⤐";
var rbbrk = "❳";
var rbrace = "}";
var rbrack = "]";
var rbrke = "⦌";
var rbrksld = "⦎";
var rbrkslu = "⦐";
var Rcaron = "Ř";
var rcaron = "ř";
var Rcedil = "Ŗ";
var rcedil = "ŗ";
var rceil = "⌉";
var rcub = "}";
var Rcy = "Р";
var rcy = "р";
var rdca = "⤷";
var rdldhar = "⥩";
var rdquo = "”";
var rdquor = "”";
var rdsh = "↳";
var real = "ℜ";
var realine = "ℛ";
var realpart = "ℜ";
var reals = "ℝ";
var Re = "ℜ";
var rect = "▭";
var reg$1 = "®";
var REG$1 = "®";
var ReverseElement = "∋";
var ReverseEquilibrium = "⇋";
var ReverseUpEquilibrium = "⥯";
var rfisht = "⥽";
var rfloor = "⌋";
var rfr = "𝔯";
var Rfr = "ℜ";
var rHar = "⥤";
var rhard = "⇁";
var rharu = "⇀";
var rharul = "⥬";
var Rho = "Ρ";
var rho = "ρ";
var rhov = "ϱ";
var RightAngleBracket = "⟩";
var RightArrowBar = "⇥";
var rightarrow = "→";
var RightArrow = "→";
var Rightarrow = "⇒";
var RightArrowLeftArrow = "⇄";
var rightarrowtail = "↣";
var RightCeiling = "⌉";
var RightDoubleBracket = "⟧";
var RightDownTeeVector = "⥝";
var RightDownVectorBar = "⥕";
var RightDownVector = "⇂";
var RightFloor = "⌋";
var rightharpoondown = "⇁";
var rightharpoonup = "⇀";
var rightleftarrows = "⇄";
var rightleftharpoons = "⇌";
var rightrightarrows = "⇉";
var rightsquigarrow = "↝";
var RightTeeArrow = "↦";
var RightTee = "⊢";
var RightTeeVector = "⥛";
var rightthreetimes = "⋌";
var RightTriangleBar = "⧐";
var RightTriangle = "⊳";
var RightTriangleEqual = "⊵";
var RightUpDownVector = "⥏";
var RightUpTeeVector = "⥜";
var RightUpVectorBar = "⥔";
var RightUpVector = "↾";
var RightVectorBar = "⥓";
var RightVector = "⇀";
var ring = "˚";
var risingdotseq = "≓";
var rlarr = "⇄";
var rlhar = "⇌";
var rlm = "";
var rmoustache = "⎱";
var rmoust = "⎱";
var rnmid = "⫮";
var roang = "⟭";
var roarr = "⇾";
var robrk = "⟧";
var ropar = "⦆";
var ropf = "𝕣";
var Ropf = "ℝ";
var roplus = "⨮";
var rotimes = "⨵";
var RoundImplies = "⥰";
var rpar = ")";
var rpargt = "⦔";
var rppolint = "⨒";
var rrarr = "⇉";
var Rrightarrow = "⇛";
var rsaquo = "›";
var rscr = "𝓇";
var Rscr = "ℛ";
var rsh = "↱";
var Rsh = "↱";
var rsqb = "]";
var rsquo = "’";
var rsquor = "’";
var rthree = "⋌";
var rtimes = "⋊";
var rtri = "▹";
var rtrie = "⊵";
var rtrif = "▸";
var rtriltri = "⧎";
var RuleDelayed = "⧴";
var ruluhar = "⥨";
var rx = "℞";
var Sacute = "Ś";
var sacute = "ś";
var sbquo = "‚";
var scap = "⪸";
var Scaron = "Š";
var scaron = "š";
var Sc = "⪼";
var sc = "≻";
var sccue = "≽";
var sce = "⪰";
var scE = "⪴";
var Scedil = "Ş";
var scedil = "ş";
var Scirc = "Ŝ";
var scirc = "ŝ";
var scnap = "⪺";
var scnE = "⪶";
var scnsim = "⋩";
var scpolint = "⨓";
var scsim = "≿";
var Scy = "С";
var scy = "с";
var sdotb = "⊡";
var sdot = "⋅";
var sdote = "⩦";
var searhk = "⤥";
var searr = "↘";
var seArr = "⇘";
var searrow = "↘";
var sect$1 = "§";
var semi = ";";
var seswar = "⤩";
var setminus = "∖";
var setmn = "∖";
var sext = "✶";
var Sfr = "𝔖";
var sfr = "𝔰";
var sfrown = "⌢";
var sharp = "♯";
var SHCHcy = "Щ";
var shchcy = "щ";
var SHcy = "Ш";
var shcy = "ш";
var ShortDownArrow = "↓";
var ShortLeftArrow = "←";
var shortmid = "∣";
var shortparallel = "∥";
var ShortRightArrow = "→";
var ShortUpArrow = "↑";
var shy$1 = "";
var Sigma = "Σ";
var sigma = "σ";
var sigmaf = "ς";
var sigmav = "ς";
var sim = "∼";
var simdot = "⩪";
var sime = "≃";
var simeq = "≃";
var simg = "⪞";
var simgE = "⪠";
var siml = "⪝";
var simlE = "⪟";
var simne = "≆";
var simplus = "⨤";
var simrarr = "⥲";
var slarr = "←";
var SmallCircle = "∘";
var smallsetminus = "∖";
var smashp = "⨳";
var smeparsl = "⧤";
var smid = "∣";
var smile = "⌣";
var smt = "⪪";
var smte = "⪬";
var smtes = "⪬︀";
var SOFTcy = "Ь";
var softcy = "ь";
var solbar = "⌿";
var solb = "⧄";
var sol = "/";
var Sopf = "𝕊";
var sopf = "𝕤";
var spades = "♠";
var spadesuit = "♠";
var spar = "∥";
var sqcap = "⊓";
var sqcaps = "⊓︀";
var sqcup = "⊔";
var sqcups = "⊔︀";
var Sqrt = "√";
var sqsub = "⊏";
var sqsube = "⊑";
var sqsubset = "⊏";
var sqsubseteq = "⊑";
var sqsup = "⊐";
var sqsupe = "⊒";
var sqsupset = "⊐";
var sqsupseteq = "⊒";
var square = "□";
var Square = "□";
var SquareIntersection = "⊓";
var SquareSubset = "⊏";
var SquareSubsetEqual = "⊑";
var SquareSuperset = "⊐";
var SquareSupersetEqual = "⊒";
var SquareUnion = "⊔";
var squarf = "▪";
var squ = "□";
var squf = "▪";
var srarr = "→";
var Sscr = "𝒮";
var sscr = "𝓈";
var ssetmn = "∖";
var ssmile = "⌣";
var sstarf = "⋆";
var Star = "⋆";
var star = "☆";
var starf = "★";
var straightepsilon = "ϵ";
var straightphi = "ϕ";
var strns = "¯";
var sub = "⊂";
var Sub = "⋐";
var subdot = "⪽";
var subE = "⫅";
var sube = "⊆";
var subedot = "⫃";
var submult = "⫁";
var subnE = "⫋";
var subne = "⊊";
var subplus = "⪿";
var subrarr = "⥹";
var subset = "⊂";
var Subset = "⋐";
var subseteq = "⊆";
var subseteqq = "⫅";
var SubsetEqual = "⊆";
var subsetneq = "⊊";
var subsetneqq = "⫋";
var subsim = "⫇";
var subsub = "⫕";
var subsup = "⫓";
var succapprox = "⪸";
var succ = "≻";
var succcurlyeq = "≽";
var Succeeds = "≻";
var SucceedsEqual = "⪰";
var SucceedsSlantEqual = "≽";
var SucceedsTilde = "≿";
var succeq = "⪰";
var succnapprox = "⪺";
var succneqq = "⪶";
var succnsim = "⋩";
var succsim = "≿";
var SuchThat = "∋";
var sum = "∑";
var Sum = "∑";
var sung = "♪";
var sup1$1 = "¹";
var sup2$1 = "²";
var sup3$1 = "³";
var sup = "⊃";
var Sup = "⋑";
var supdot = "⪾";
var supdsub = "⫘";
var supE = "⫆";
var supe = "⊇";
var supedot = "⫄";
var Superset = "⊃";
var SupersetEqual = "⊇";
var suphsol = "⟉";
var suphsub = "⫗";
var suplarr = "⥻";
var supmult = "⫂";
var supnE = "⫌";
var supne = "⊋";
var supplus = "⫀";
var supset = "⊃";
var Supset = "⋑";
var supseteq = "⊇";
var supseteqq = "⫆";
var supsetneq = "⊋";
var supsetneqq = "⫌";
var supsim = "⫈";
var supsub = "⫔";
var supsup = "⫖";
var swarhk = "⤦";
var swarr = "↙";
var swArr = "⇙";
var swarrow = "↙";
var swnwar = "⤪";
var szlig$1 = "ß";
var Tab = "\t";
var target = "⌖";
var Tau = "Τ";
var tau = "τ";
var tbrk = "⎴";
var Tcaron = "Ť";
var tcaron = "ť";
var Tcedil = "Ţ";
var tcedil = "ţ";
var Tcy = "Т";
var tcy = "т";
var tdot = "⃛";
var telrec = "⌕";
var Tfr = "𝔗";
var tfr = "𝔱";
var there4 = "∴";
var therefore = "∴";
var Therefore = "∴";
var Theta = "Θ";
var theta = "θ";
var thetasym = "ϑ";
var thetav = "ϑ";
var thickapprox = "≈";
var thicksim = "∼";
var ThickSpace = " ";
var ThinSpace = " ";
var thinsp = " ";
var thkap = "≈";
var thksim = "∼";
var THORN$1 = "Þ";
var thorn$1 = "þ";
var tilde = "˜";
var Tilde = "∼";
var TildeEqual = "≃";
var TildeFullEqual = "≅";
var TildeTilde = "≈";
var timesbar = "⨱";
var timesb = "⊠";
var times$1 = "×";
var timesd = "⨰";
var tint = "∭";
var toea = "⤨";
var topbot = "⌶";
var topcir = "⫱";
var esm_top = "⊤";
var Topf = "𝕋";
var topf = "𝕥";
var topfork = "⫚";
var tosa = "⤩";
var tprime = "‴";
var trade = "™";
var TRADE = "™";
var triangle = "▵";
var triangledown = "▿";
var triangleleft = "◃";
var trianglelefteq = "⊴";
var triangleq = "≜";
var triangleright = "▹";
var trianglerighteq = "⊵";
var tridot = "◬";
var trie = "≜";
var triminus = "⨺";
var TripleDot = "⃛";
var triplus = "⨹";
var trisb = "⧍";
var tritime = "⨻";
var trpezium = "⏢";
var Tscr = "𝒯";
var tscr = "𝓉";
var TScy = "Ц";
var tscy = "ц";
var TSHcy = "Ћ";
var tshcy = "ћ";
var Tstrok = "Ŧ";
var tstrok = "ŧ";
var twixt = "≬";
var twoheadleftarrow = "↞";
var twoheadrightarrow = "↠";
var Uacute$1 = "Ú";
var uacute$1 = "ú";
var uarr = "↑";
var Uarr = "↟";
var uArr = "⇑";
var Uarrocir = "⥉";
var Ubrcy = "Ў";
var ubrcy = "ў";
var Ubreve = "Ŭ";
var ubreve = "ŭ";
var Ucirc$1 = "Û";
var ucirc$1 = "û";
var Ucy = "У";
var ucy = "у";
var udarr = "⇅";
var Udblac = "Ű";
var udblac = "ű";
var udhar = "⥮";
var ufisht = "⥾";
var Ufr = "𝔘";
var ufr = "𝔲";
var Ugrave$1 = "Ù";
var ugrave$1 = "ù";
var uHar = "⥣";
var uharl = "↿";
var uharr = "↾";
var uhblk = "▀";
var ulcorn = "⌜";
var ulcorner = "⌜";
var ulcrop = "⌏";
var ultri = "◸";
var Umacr = "Ū";
var umacr = "ū";
var uml$1 = "¨";
var UnderBar = "_";
var UnderBrace = "⏟";
var UnderBracket = "⎵";
var UnderParenthesis = "⏝";
var Union = "⋃";
var UnionPlus = "⊎";
var Uogon = "Ų";
var uogon = "ų";
var Uopf = "𝕌";
var uopf = "𝕦";
var UpArrowBar = "⤒";
var uparrow = "↑";
var UpArrow = "↑";
var Uparrow = "⇑";
var UpArrowDownArrow = "⇅";
var updownarrow = "↕";
var UpDownArrow = "↕";
var Updownarrow = "⇕";
var UpEquilibrium = "⥮";
var upharpoonleft = "↿";
var upharpoonright = "↾";
var uplus = "⊎";
var UpperLeftArrow = "↖";
var UpperRightArrow = "↗";
var upsi = "υ";
var Upsi = "ϒ";
var upsih = "ϒ";
var Upsilon = "Υ";
var upsilon = "υ";
var UpTeeArrow = "↥";
var UpTee = "⊥";
var upuparrows = "⇈";
var urcorn = "⌝";
var urcorner = "⌝";
var urcrop = "⌎";
var Uring = "Ů";
var uring = "ů";
var urtri = "◹";
var Uscr = "𝒰";
var uscr = "𝓊";
var utdot = "⋰";
var Utilde = "Ũ";
var utilde = "ũ";
var utri = "▵";
var utrif = "▴";
var uuarr = "⇈";
var Uuml$1 = "Ü";
var uuml$1 = "ü";
var uwangle = "⦧";
var vangrt = "⦜";
var varepsilon = "ϵ";
var varkappa = "ϰ";
var varnothing = "∅";
var varphi = "ϕ";
var varpi = "ϖ";
var varpropto = "∝";
var varr = "↕";
var vArr = "⇕";
var varrho = "ϱ";
var varsigma = "ς";
var varsubsetneq = "⊊︀";
var varsubsetneqq = "⫋︀";
var varsupsetneq = "⊋︀";
var varsupsetneqq = "⫌︀";
var vartheta = "ϑ";
var vartriangleleft = "⊲";
var vartriangleright = "⊳";
var vBar = "⫨";
var Vbar = "⫫";
var vBarv = "⫩";
var Vcy = "В";
var vcy = "в";
var vdash = "⊢";
var vDash = "⊨";
var Vdash = "⊩";
var VDash = "⊫";
var Vdashl = "⫦";
var veebar = "⊻";
var vee = "∨";
var Vee = "⋁";
var veeeq = "≚";
var vellip = "⋮";
var verbar = "|";
var Verbar = "‖";
var vert = "|";
var Vert = "‖";
var VerticalBar = "∣";
var VerticalLine = "|";
var VerticalSeparator = "❘";
var VerticalTilde = "≀";
var VeryThinSpace = " ";
var Vfr = "𝔙";
var vfr = "𝔳";
var vltri = "⊲";
var vnsub = "⊂⃒";
var vnsup = "⊃⃒";
var Vopf = "𝕍";
var vopf = "𝕧";
var vprop = "∝";
var vrtri = "⊳";
var Vscr = "𝒱";
var vscr = "𝓋";
var vsubnE = "⫋︀";
var vsubne = "⊊︀";
var vsupnE = "⫌︀";
var vsupne = "⊋︀";
var Vvdash = "⊪";
var vzigzag = "⦚";
var Wcirc = "Ŵ";
var wcirc = "ŵ";
var wedbar = "⩟";
var wedge = "∧";
var Wedge = "⋀";
var wedgeq = "≙";
var weierp = "℘";
var Wfr = "𝔚";
var wfr = "𝔴";
var Wopf = "𝕎";
var wopf = "𝕨";
var wp = "℘";
var wr = "≀";
var wreath = "≀";
var Wscr = "𝒲";
var wscr = "𝓌";
var xcap = "⋂";
var xcirc = "◯";
var xcup = "⋃";
var xdtri = "▽";
var Xfr = "𝔛";
var xfr = "𝔵";
var xharr = "⟷";
var xhArr = "⟺";
var Xi = "Ξ";
var xi = "ξ";
var xlarr = "⟵";
var xlArr = "⟸";
var xmap = "⟼";
var xnis = "⋻";
var xodot = "⨀";
var Xopf = "𝕏";
var xopf = "𝕩";
var xoplus = "⨁";
var xotime = "⨂";
var xrarr = "⟶";
var xrArr = "⟹";
var Xscr = "𝒳";
var xscr = "𝓍";
var xsqcup = "⨆";
var xuplus = "⨄";
var xutri = "△";
var xvee = "⋁";
var xwedge = "⋀";
var Yacute$1 = "Ý";
var yacute$1 = "ý";
var YAcy = "Я";
var yacy = "я";
var Ycirc = "Ŷ";
var ycirc = "ŷ";
var Ycy = "Ы";
var ycy = "ы";
var yen$1 = "¥";
var Yfr = "𝔜";
var yfr = "𝔶";
var YIcy = "Ї";
var yicy = "ї";
var Yopf = "𝕐";
var yopf = "𝕪";
var Yscr = "𝒴";
var yscr = "𝓎";
var YUcy = "Ю";
var yucy = "ю";
var yuml$1 = "ÿ";
var Yuml = "Ÿ";
var Zacute = "Ź";
var zacute = "ź";
var Zcaron = "Ž";
var zcaron = "ž";
var Zcy = "З";
var zcy = "з";
var Zdot = "Ż";
var zdot = "ż";
var zeetrf = "ℨ";
var ZeroWidthSpace = "";
var Zeta = "Ζ";
var zeta = "ζ";
var zfr = "𝔷";
var Zfr = "ℨ";
var ZHcy = "Ж";
var zhcy = "ж";
var zigrarr = "⇝";
var zopf = "𝕫";
var Zopf = "ℤ";
var Zscr = "𝒵";
var zscr = "𝓏";
var zwj = "";
var zwnj = "";
var require$$1$1 = {
Aacute: Aacute$1,
aacute: aacute$1,
Abreve: Abreve,
abreve: abreve,
ac: ac,
acd: acd,
acE: acE,
Acirc: Acirc$1,
acirc: acirc$1,
acute: acute$1,
Acy: Acy,
acy: acy,
AElig: AElig$1,
aelig: aelig$1,
af: af,
Afr: Afr,
afr: afr,
Agrave: Agrave$1,
agrave: agrave$1,
alefsym: alefsym,
aleph: aleph,
Alpha: Alpha,
alpha: alpha,
Amacr: Amacr,
amacr: amacr,
amalg: amalg,
amp: amp$2,
AMP: AMP$1,
andand: andand,
And: And,
and: and,
andd: andd,
andslope: andslope,
andv: andv,
ang: ang,
ange: ange,
angle: angle,
angmsdaa: angmsdaa,
angmsdab: angmsdab,
angmsdac: angmsdac,
angmsdad: angmsdad,
angmsdae: angmsdae,
angmsdaf: angmsdaf,
angmsdag: angmsdag,
angmsdah: angmsdah,
angmsd: angmsd,
angrt: angrt,
angrtvb: angrtvb,
angrtvbd: angrtvbd,
angsph: angsph,
angst: angst,
angzarr: angzarr,
Aogon: Aogon,
aogon: aogon,
Aopf: Aopf,
aopf: aopf,
apacir: apacir,
ap: ap,
apE: apE,
ape: ape,
apid: apid,
apos: apos$1,
ApplyFunction: ApplyFunction,
approx: approx,
approxeq: approxeq,
Aring: Aring$1,
aring: aring$1,
Ascr: Ascr,
ascr: ascr,
Assign: Assign,
ast: ast,
asymp: asymp,
asympeq: asympeq,
Atilde: Atilde$1,
atilde: atilde$1,
Auml: Auml$1,
auml: auml$1,
awconint: awconint,
awint: awint,
backcong: backcong,
backepsilon: backepsilon,
backprime: backprime,
backsim: backsim,
backsimeq: backsimeq,
Backslash: Backslash,
Barv: Barv,
barvee: barvee,
barwed: barwed,
Barwed: Barwed,
barwedge: barwedge,
bbrk: bbrk,
bbrktbrk: bbrktbrk,
bcong: bcong,
Bcy: Bcy,
bcy: bcy,
bdquo: bdquo,
becaus: becaus,
because: because,
Because: Because,
bemptyv: bemptyv,
bepsi: bepsi,
bernou: bernou,
Bernoullis: Bernoullis,
Beta: Beta,
beta: beta,
beth: beth,
between: esm_between,
Bfr: Bfr,
bfr: bfr,
bigcap: bigcap,
bigcirc: bigcirc,
bigcup: bigcup,
bigodot: bigodot,
bigoplus: bigoplus,
bigotimes: bigotimes,
bigsqcup: bigsqcup,
bigstar: bigstar,
bigtriangledown: bigtriangledown,
bigtriangleup: bigtriangleup,
biguplus: biguplus,
bigvee: bigvee,
bigwedge: bigwedge,
bkarow: bkarow,
blacklozenge: blacklozenge,
blacksquare: blacksquare,
blacktriangle: blacktriangle,
blacktriangledown: blacktriangledown,
blacktriangleleft: blacktriangleleft,
blacktriangleright: blacktriangleright,
blank: blank,
blk12: blk12,
blk14: blk14,
blk34: blk34,
block: block,
bne: bne,
bnequiv: bnequiv,
bNot: bNot,
bnot: bnot,
Bopf: Bopf,
bopf: bopf,
bot: bot,
bottom: bottom,
bowtie: bowtie,
boxbox: boxbox,
boxdl: boxdl,
boxdL: boxdL,
boxDl: boxDl,
boxDL: boxDL,
boxdr: boxdr,
boxdR: boxdR,
boxDr: boxDr,
boxDR: boxDR,
boxh: boxh,
boxH: boxH,
boxhd: boxhd,
boxHd: boxHd,
boxhD: boxhD,
boxHD: boxHD,
boxhu: boxhu,
boxHu: boxHu,
boxhU: boxhU,
boxHU: boxHU,
boxminus: boxminus,
boxplus: boxplus,
boxtimes: boxtimes,
boxul: boxul,
boxuL: boxuL,
boxUl: boxUl,
boxUL: boxUL,
boxur: boxur,
boxuR: boxuR,
boxUr: boxUr,
boxUR: boxUR,
boxv: boxv,
boxV: boxV,
boxvh: boxvh,
boxvH: boxvH,
boxVh: boxVh,
boxVH: boxVH,
boxvl: boxvl,
boxvL: boxvL,
boxVl: boxVl,
boxVL: boxVL,
boxvr: boxvr,
boxvR: boxvR,
boxVr: boxVr,
boxVR: boxVR,
bprime: bprime,
breve: breve,
Breve: Breve,
brvbar: brvbar$1,
bscr: bscr,
Bscr: Bscr,
bsemi: bsemi,
bsim: bsim,
bsime: bsime,
bsolb: bsolb,
bsol: bsol,
bsolhsub: bsolhsub,
bull: bull,
bullet: bullet,
bump: bump,
bumpE: bumpE,
bumpe: bumpe,
Bumpeq: Bumpeq,
bumpeq: bumpeq,
Cacute: Cacute,
cacute: cacute,
capand: capand,
capbrcup: capbrcup,
capcap: capcap,
cap: cap,
Cap: Cap,
capcup: capcup,
capdot: capdot,
CapitalDifferentialD: CapitalDifferentialD,
caps: caps,
caret: caret,
caron: caron,
Cayleys: Cayleys,
ccaps: ccaps,
Ccaron: Ccaron,
ccaron: ccaron,
Ccedil: Ccedil$1,
ccedil: ccedil$1,
Ccirc: Ccirc,
ccirc: ccirc,
Cconint: Cconint,
ccups: ccups,
ccupssm: ccupssm,
Cdot: Cdot,
cdot: cdot,
cedil: cedil$1,
Cedilla: Cedilla,
cemptyv: cemptyv,
cent: cent$1,
centerdot: centerdot,
CenterDot: CenterDot,
cfr: cfr,
Cfr: Cfr,
CHcy: CHcy,
chcy: chcy,
check: check,
checkmark: checkmark,
Chi: Chi,
chi: chi,
circ: circ,
circeq: circeq,
circlearrowleft: circlearrowleft,
circlearrowright: circlearrowright,
circledast: circledast,
circledcirc: circledcirc,
circleddash: circleddash,
CircleDot: CircleDot,
circledR: circledR,
circledS: circledS,
CircleMinus: CircleMinus,
CirclePlus: CirclePlus,
CircleTimes: CircleTimes,
cir: cir,
cirE: cirE,
cire: cire,
cirfnint: cirfnint,
cirmid: cirmid,
cirscir: cirscir,
ClockwiseContourIntegral: ClockwiseContourIntegral,
CloseCurlyDoubleQuote: CloseCurlyDoubleQuote,
CloseCurlyQuote: CloseCurlyQuote,
clubs: clubs,
clubsuit: clubsuit,
colon: colon,
Colon: Colon,
Colone: Colone,
colone: colone,
coloneq: coloneq,
comma: comma,
commat: commat,
comp: comp,
compfn: compfn,
complement: complement,
complexes: complexes,
cong: cong,
congdot: congdot,
Congruent: Congruent,
conint: conint,
Conint: Conint,
ContourIntegral: ContourIntegral,
copf: copf,
Copf: Copf,
coprod: coprod,
Coproduct: Coproduct,
copy: copy$1,
COPY: COPY$1,
copysr: copysr,
CounterClockwiseContourIntegral: CounterClockwiseContourIntegral,
crarr: crarr,
cross: cross,
Cross: Cross,
Cscr: Cscr,
cscr: cscr,
csub: csub,
csube: csube,
csup: csup,
csupe: csupe,
ctdot: ctdot,
cudarrl: cudarrl,
cudarrr: cudarrr,
cuepr: cuepr,
cuesc: cuesc,
cularr: cularr,
cularrp: cularrp,
cupbrcap: cupbrcap,
cupcap: cupcap,
CupCap: CupCap,
cup: cup,
Cup: Cup,
cupcup: cupcup,
cupdot: cupdot,
cupor: cupor,
cups: cups,
curarr: curarr,
curarrm: curarrm,
curlyeqprec: curlyeqprec,
curlyeqsucc: curlyeqsucc,
curlyvee: curlyvee,
curlywedge: curlywedge,
curren: curren$1,
curvearrowleft: curvearrowleft,
curvearrowright: curvearrowright,
cuvee: cuvee,
cuwed: cuwed,
cwconint: cwconint,
cwint: cwint,
cylcty: cylcty,
dagger: dagger,
Dagger: Dagger,
daleth: daleth,
darr: darr,
Darr: Darr,
dArr: dArr,
dash: dash,
Dashv: Dashv,
dashv: dashv,
dbkarow: dbkarow,
dblac: dblac,
Dcaron: Dcaron,
dcaron: dcaron,
Dcy: Dcy,
dcy: dcy,
ddagger: ddagger,
ddarr: ddarr,
DD: DD,
dd: dd,
DDotrahd: DDotrahd,
ddotseq: ddotseq,
deg: deg$1,
Del: Del,
Delta: Delta,
delta: delta,
demptyv: demptyv,
dfisht: dfisht,
Dfr: Dfr,
dfr: dfr,
dHar: dHar,
dharl: dharl,
dharr: dharr,
DiacriticalAcute: DiacriticalAcute,
DiacriticalDot: DiacriticalDot,
DiacriticalDoubleAcute: DiacriticalDoubleAcute,
DiacriticalGrave: DiacriticalGrave,
DiacriticalTilde: DiacriticalTilde,
diam: diam,
diamond: diamond,
Diamond: Diamond,
diamondsuit: diamondsuit,
diams: diams,
die: die,
DifferentialD: DifferentialD,
digamma: digamma,
disin: disin,
div: div,
divide: divide$1,
divideontimes: divideontimes,
divonx: divonx,
DJcy: DJcy,
djcy: djcy,
dlcorn: dlcorn,
dlcrop: dlcrop,
dollar: dollar,
Dopf: Dopf,
dopf: dopf,
Dot: Dot,
dot: dot,
DotDot: DotDot,
doteq: doteq,
doteqdot: doteqdot,
DotEqual: DotEqual,
dotminus: dotminus,
dotplus: dotplus,
dotsquare: dotsquare,
doublebarwedge: doublebarwedge,
DoubleContourIntegral: DoubleContourIntegral,
DoubleDot: DoubleDot,
DoubleDownArrow: DoubleDownArrow,
DoubleLeftArrow: DoubleLeftArrow,
DoubleLeftRightArrow: DoubleLeftRightArrow,
DoubleLeftTee: DoubleLeftTee,
DoubleLongLeftArrow: DoubleLongLeftArrow,
DoubleLongLeftRightArrow: DoubleLongLeftRightArrow,
DoubleLongRightArrow: DoubleLongRightArrow,
DoubleRightArrow: DoubleRightArrow,
DoubleRightTee: DoubleRightTee,
DoubleUpArrow: DoubleUpArrow,
DoubleUpDownArrow: DoubleUpDownArrow,
DoubleVerticalBar: DoubleVerticalBar,
DownArrowBar: DownArrowBar,
downarrow: downarrow,
DownArrow: DownArrow,
Downarrow: Downarrow,
DownArrowUpArrow: DownArrowUpArrow,
DownBreve: DownBreve,
downdownarrows: downdownarrows,
downharpoonleft: downharpoonleft,
downharpoonright: downharpoonright,
DownLeftRightVector: DownLeftRightVector,
DownLeftTeeVector: DownLeftTeeVector,
DownLeftVectorBar: DownLeftVectorBar,
DownLeftVector: DownLeftVector,
DownRightTeeVector: DownRightTeeVector,
DownRightVectorBar: DownRightVectorBar,
DownRightVector: DownRightVector,
DownTeeArrow: DownTeeArrow,
DownTee: DownTee,
drbkarow: drbkarow,
drcorn: drcorn,
drcrop: drcrop,
Dscr: Dscr,
dscr: dscr,
DScy: DScy,
dscy: dscy,
dsol: dsol,
Dstrok: Dstrok,
dstrok: dstrok,
dtdot: dtdot,
dtri: dtri,
dtrif: dtrif,
duarr: duarr,
duhar: duhar,
dwangle: dwangle,
DZcy: DZcy,
dzcy: dzcy,
dzigrarr: dzigrarr,
Eacute: Eacute$1,
eacute: eacute$1,
easter: easter,
Ecaron: Ecaron,
ecaron: ecaron,
Ecirc: Ecirc$1,
ecirc: ecirc$1,
ecir: ecir,
ecolon: ecolon,
Ecy: Ecy,
ecy: ecy,
eDDot: eDDot,
Edot: Edot,
edot: edot,
eDot: eDot,
ee: ee,
efDot: efDot,
Efr: Efr,
efr: efr,
eg: eg,
Egrave: Egrave$1,
egrave: egrave$1,
egs: egs,
egsdot: egsdot,
el: el,
Element: esm_Element,
elinters: elinters,
ell: ell,
els: els,
elsdot: elsdot,
Emacr: Emacr,
emacr: emacr,
empty: esm_empty,
emptyset: emptyset,
EmptySmallSquare: EmptySmallSquare,
emptyv: emptyv,
EmptyVerySmallSquare: EmptyVerySmallSquare,
emsp13: emsp13,
emsp14: emsp14,
emsp: emsp,
ENG: ENG,
eng: eng,
ensp: ensp,
Eogon: Eogon,
eogon: eogon,
Eopf: Eopf,
eopf: eopf,
epar: epar,
eparsl: eparsl,
eplus: eplus,
epsi: epsi,
Epsilon: Epsilon,
epsilon: epsilon,
epsiv: epsiv,
eqcirc: eqcirc,
eqcolon: eqcolon,
eqsim: eqsim,
eqslantgtr: eqslantgtr,
eqslantless: eqslantless,
Equal: Equal,
equals: equals,
EqualTilde: EqualTilde,
equest: equest,
Equilibrium: Equilibrium,
equiv: equiv,
equivDD: equivDD,
eqvparsl: eqvparsl,
erarr: erarr,
erDot: erDot,
escr: escr,
Escr: Escr,
esdot: esdot,
Esim: Esim,
esim: esim,
Eta: Eta,
eta: eta,
ETH: ETH$1,
eth: eth$1,
Euml: Euml$1,
euml: euml$1,
euro: euro,
excl: excl,
exist: exist,
Exists: Exists,
expectation: expectation,
exponentiale: exponentiale,
ExponentialE: ExponentialE,
fallingdotseq: fallingdotseq,
Fcy: Fcy,
fcy: fcy,
female: female,
ffilig: ffilig,
fflig: fflig,
ffllig: ffllig,
Ffr: Ffr,
ffr: ffr,
filig: filig,
FilledSmallSquare: FilledSmallSquare,
FilledVerySmallSquare: FilledVerySmallSquare,
fjlig: fjlig,
flat: flat,
fllig: fllig,
fltns: fltns,
fnof: fnof,
Fopf: Fopf,
fopf: fopf,
forall: forall,
ForAll: ForAll,
fork: fork,
forkv: forkv,
Fouriertrf: Fouriertrf,
fpartint: fpartint,
frac12: frac12$1,
frac13: frac13,
frac14: frac14$1,
frac15: frac15,
frac16: frac16,
frac18: frac18,
frac23: frac23,
frac25: frac25,
frac34: frac34$1,
frac35: frac35,
frac38: frac38,
frac45: frac45,
frac56: frac56,
frac58: frac58,
frac78: frac78,
frasl: frasl,
frown: frown,
fscr: fscr,
Fscr: Fscr,
gacute: gacute,
Gamma: Gamma,
gamma: gamma,
Gammad: Gammad,
gammad: gammad,
gap: gap,
Gbreve: Gbreve,
gbreve: gbreve,
Gcedil: Gcedil,
Gcirc: Gcirc,
gcirc: gcirc,
Gcy: Gcy,
gcy: gcy,
Gdot: Gdot,
gdot: gdot,
ge: ge,
gE: gE,
gEl: gEl,
gel: gel,
geq: geq,
geqq: geqq,
geqslant: geqslant,
gescc: gescc,
ges: ges,
gesdot: gesdot,
gesdoto: gesdoto,
gesdotol: gesdotol,
gesl: gesl,
gesles: gesles,
Gfr: Gfr,
gfr: gfr,
gg: gg,
Gg: Gg,
ggg: ggg,
gimel: gimel,
GJcy: GJcy,
gjcy: gjcy,
gla: gla,
gl: gl,
glE: glE,
glj: glj,
gnap: gnap,
gnapprox: gnapprox,
gne: gne,
gnE: gnE,
gneq: gneq,
gneqq: gneqq,
gnsim: gnsim,
Gopf: Gopf,
gopf: gopf,
grave: grave,
GreaterEqual: GreaterEqual,
GreaterEqualLess: GreaterEqualLess,
GreaterFullEqual: GreaterFullEqual,
GreaterGreater: GreaterGreater,
GreaterLess: GreaterLess,
GreaterSlantEqual: GreaterSlantEqual,
GreaterTilde: GreaterTilde,
Gscr: Gscr,
gscr: gscr,
gsim: gsim,
gsime: gsime,
gsiml: gsiml,
gtcc: gtcc,
gtcir: gtcir,
gt: gt$2,
GT: GT$1,
Gt: Gt,
gtdot: gtdot,
gtlPar: gtlPar,
gtquest: gtquest,
gtrapprox: gtrapprox,
gtrarr: gtrarr,
gtrdot: gtrdot,
gtreqless: gtreqless,
gtreqqless: gtreqqless,
gtrless: gtrless,
gtrsim: gtrsim,
gvertneqq: gvertneqq,
gvnE: gvnE,
Hacek: Hacek,
hairsp: hairsp,
half: half,
hamilt: hamilt,
HARDcy: HARDcy,
hardcy: hardcy,
harrcir: harrcir,
harr: harr,
hArr: hArr,
harrw: harrw,
Hat: Hat,
hbar: hbar,
Hcirc: Hcirc,
hcirc: hcirc,
hearts: hearts,
heartsuit: heartsuit,
hellip: hellip,
hercon: hercon,
hfr: hfr,
Hfr: Hfr,
HilbertSpace: HilbertSpace,
hksearow: hksearow,
hkswarow: hkswarow,
hoarr: hoarr,
homtht: homtht,
hookleftarrow: hookleftarrow,
hookrightarrow: hookrightarrow,
hopf: hopf,
Hopf: Hopf,
horbar: horbar,
HorizontalLine: HorizontalLine,
hscr: hscr,
Hscr: Hscr,
hslash: hslash,
Hstrok: Hstrok,
hstrok: hstrok,
HumpDownHump: HumpDownHump,
HumpEqual: HumpEqual,
hybull: hybull,
hyphen: hyphen,
Iacute: Iacute$1,
iacute: iacute$1,
ic: ic,
Icirc: Icirc$1,
icirc: icirc$1,
Icy: Icy,
icy: icy,
Idot: Idot,
IEcy: IEcy,
iecy: iecy,
iexcl: iexcl$1,
iff: iff,
ifr: ifr,
Ifr: Ifr,
Igrave: Igrave$1,
igrave: igrave$1,
ii: ii,
iiiint: iiiint,
iiint: iiint,
iinfin: iinfin,
iiota: iiota,
IJlig: IJlig,
ijlig: ijlig,
Imacr: Imacr,
imacr: imacr,
image: esm_image,
ImaginaryI: ImaginaryI,
imagline: imagline,
imagpart: imagpart,
imath: imath,
Im: Im,
imof: imof,
imped: imped,
Implies: Implies,
incare: incare,
"in": "∈",
infin: infin,
infintie: infintie,
inodot: inodot,
intcal: intcal,
int: esm_int,
Int: Int,
integers: integers,
Integral: Integral,
intercal: intercal,
Intersection: Intersection,
intlarhk: intlarhk,
intprod: intprod,
InvisibleComma: InvisibleComma,
InvisibleTimes: InvisibleTimes,
IOcy: IOcy,
iocy: iocy,
Iogon: Iogon,
iogon: iogon,
Iopf: Iopf,
iopf: iopf,
Iota: Iota,
iota: iota,
iprod: iprod,
iquest: iquest$1,
iscr: iscr,
Iscr: Iscr,
isin: isin,
isindot: isindot,
isinE: isinE,
isins: isins,
isinsv: isinsv,
isinv: isinv,
it: it,
Itilde: Itilde,
itilde: itilde,
Iukcy: Iukcy,
iukcy: iukcy,
Iuml: Iuml$1,
iuml: iuml$1,
Jcirc: Jcirc,
jcirc: jcirc,
Jcy: Jcy,
jcy: jcy,
Jfr: Jfr,
jfr: jfr,
jmath: jmath,
Jopf: Jopf,
jopf: jopf,
Jscr: Jscr,
jscr: jscr,
Jsercy: Jsercy,
jsercy: jsercy,
Jukcy: Jukcy,
jukcy: jukcy,
Kappa: Kappa,
kappa: kappa,
kappav: kappav,
Kcedil: Kcedil,
kcedil: kcedil,
Kcy: Kcy,
kcy: kcy,
Kfr: Kfr,
kfr: kfr,
kgreen: kgreen,
KHcy: KHcy,
khcy: khcy,
KJcy: KJcy,
kjcy: kjcy,
Kopf: Kopf,
kopf: kopf,
Kscr: Kscr,
kscr: kscr,
lAarr: lAarr,
Lacute: Lacute,
lacute: lacute,
laemptyv: laemptyv,
lagran: lagran,
Lambda: Lambda,
lambda: lambda,
lang: lang,
Lang: Lang,
langd: langd,
langle: langle,
lap: lap,
Laplacetrf: Laplacetrf,
laquo: laquo$1,
larrb: larrb,
larrbfs: larrbfs,
larr: larr,
Larr: Larr,
lArr: lArr,
larrfs: larrfs,
larrhk: larrhk,
larrlp: larrlp,
larrpl: larrpl,
larrsim: larrsim,
larrtl: larrtl,
latail: latail,
lAtail: lAtail,
lat: lat,
late: late,
lates: lates,
lbarr: lbarr,
lBarr: lBarr,
lbbrk: lbbrk,
lbrace: lbrace,
lbrack: lbrack,
lbrke: lbrke,
lbrksld: lbrksld,
lbrkslu: lbrkslu,
Lcaron: Lcaron,
lcaron: lcaron,
Lcedil: Lcedil,
lcedil: lcedil,
lceil: lceil,
lcub: lcub,
Lcy: Lcy,
lcy: lcy,
ldca: ldca,
ldquo: ldquo,
ldquor: ldquor,
ldrdhar: ldrdhar,
ldrushar: ldrushar,
ldsh: ldsh,
le: le,
lE: lE,
LeftAngleBracket: LeftAngleBracket,
LeftArrowBar: LeftArrowBar,
leftarrow: leftarrow,
LeftArrow: LeftArrow,
Leftarrow: Leftarrow,
LeftArrowRightArrow: LeftArrowRightArrow,
leftarrowtail: leftarrowtail,
LeftCeiling: LeftCeiling,
LeftDoubleBracket: LeftDoubleBracket,
LeftDownTeeVector: LeftDownTeeVector,
LeftDownVectorBar: LeftDownVectorBar,
LeftDownVector: LeftDownVector,
LeftFloor: LeftFloor,
leftharpoondown: leftharpoondown,
leftharpoonup: leftharpoonup,
leftleftarrows: leftleftarrows,
leftrightarrow: leftrightarrow,
LeftRightArrow: LeftRightArrow,
Leftrightarrow: Leftrightarrow,
leftrightarrows: leftrightarrows,
leftrightharpoons: leftrightharpoons,
leftrightsquigarrow: leftrightsquigarrow,
LeftRightVector: LeftRightVector,
LeftTeeArrow: LeftTeeArrow,
LeftTee: LeftTee,
LeftTeeVector: LeftTeeVector,
leftthreetimes: leftthreetimes,
LeftTriangleBar: LeftTriangleBar,
LeftTriangle: LeftTriangle,
LeftTriangleEqual: LeftTriangleEqual,
LeftUpDownVector: LeftUpDownVector,
LeftUpTeeVector: LeftUpTeeVector,
LeftUpVectorBar: LeftUpVectorBar,
LeftUpVector: LeftUpVector,
LeftVectorBar: LeftVectorBar,
LeftVector: LeftVector,
lEg: lEg,
leg: leg,
leq: leq,
leqq: leqq,
leqslant: leqslant,
lescc: lescc,
les: les,
lesdot: lesdot,
lesdoto: lesdoto,
lesdotor: lesdotor,
lesg: lesg,
lesges: lesges,
lessapprox: lessapprox,
lessdot: lessdot,
lesseqgtr: lesseqgtr,
lesseqqgtr: lesseqqgtr,
LessEqualGreater: LessEqualGreater,
LessFullEqual: LessFullEqual,
LessGreater: LessGreater,
lessgtr: lessgtr,
LessLess: LessLess,
lesssim: lesssim,
LessSlantEqual: LessSlantEqual,
LessTilde: LessTilde,
lfisht: lfisht,
lfloor: lfloor,
Lfr: Lfr,
lfr: lfr,
lg: lg,
lgE: lgE,
lHar: lHar,
lhard: lhard,
lharu: lharu,
lharul: lharul,
lhblk: lhblk,
LJcy: LJcy,
ljcy: ljcy,
llarr: llarr,
ll: ll,
Ll: Ll,
llcorner: llcorner,
Lleftarrow: Lleftarrow,
llhard: llhard,
lltri: lltri,
Lmidot: Lmidot,
lmidot: lmidot,
lmoustache: lmoustache,
lmoust: lmoust,
lnap: lnap,
lnapprox: lnapprox,
lne: lne,
lnE: lnE,
lneq: lneq,
lneqq: lneqq,
lnsim: lnsim,
loang: loang,
loarr: loarr,
lobrk: lobrk,
longleftarrow: longleftarrow,
LongLeftArrow: LongLeftArrow,
Longleftarrow: Longleftarrow,
longleftrightarrow: longleftrightarrow,
LongLeftRightArrow: LongLeftRightArrow,
Longleftrightarrow: Longleftrightarrow,
longmapsto: longmapsto,
longrightarrow: longrightarrow,
LongRightArrow: LongRightArrow,
Longrightarrow: Longrightarrow,
looparrowleft: looparrowleft,
looparrowright: looparrowright,
lopar: lopar,
Lopf: Lopf,
lopf: lopf,
loplus: loplus,
lotimes: lotimes,
lowast: lowast,
lowbar: lowbar,
LowerLeftArrow: LowerLeftArrow,
LowerRightArrow: LowerRightArrow,
loz: loz,
lozenge: lozenge,
lozf: lozf,
lpar: lpar,
lparlt: lparlt,
lrarr: lrarr,
lrcorner: lrcorner,
lrhar: lrhar,
lrhard: lrhard,
lrm: lrm,
lrtri: lrtri,
lsaquo: lsaquo,
lscr: lscr,
Lscr: Lscr,
lsh: lsh,
Lsh: Lsh,
lsim: lsim,
lsime: lsime,
lsimg: lsimg,
lsqb: lsqb,
lsquo: lsquo,
lsquor: lsquor,
Lstrok: Lstrok,
lstrok: lstrok,
ltcc: ltcc,
ltcir: ltcir,
lt: lt$2,
LT: LT$1,
Lt: Lt,
ltdot: ltdot,
lthree: lthree,
ltimes: ltimes,
ltlarr: ltlarr,
ltquest: ltquest,
ltri: ltri,
ltrie: ltrie,
ltrif: ltrif,
ltrPar: ltrPar,
lurdshar: lurdshar,
luruhar: luruhar,
lvertneqq: lvertneqq,
lvnE: lvnE,
macr: macr$1,
male: male,
malt: malt,
maltese: maltese,
"Map": "⤅",
map: map,
mapsto: mapsto,
mapstodown: mapstodown,
mapstoleft: mapstoleft,
mapstoup: mapstoup,
marker: marker,
mcomma: mcomma,
Mcy: Mcy,
mcy: mcy,
mdash: mdash,
mDDot: mDDot,
measuredangle: measuredangle,
MediumSpace: MediumSpace,
Mellintrf: Mellintrf,
Mfr: Mfr,
mfr: mfr,
mho: mho,
micro: micro$1,
midast: midast,
midcir: midcir,
mid: mid,
middot: middot$1,
minusb: minusb,
minus: minus,
minusd: minusd,
minusdu: minusdu,
MinusPlus: MinusPlus,
mlcp: mlcp,
mldr: mldr,
mnplus: mnplus,
models: models,
Mopf: Mopf,
mopf: mopf,
mp: mp,
mscr: mscr,
Mscr: Mscr,
mstpos: mstpos,
Mu: Mu,
mu: mu,
multimap: multimap,
mumap: mumap,
nabla: nabla,
Nacute: Nacute,
nacute: nacute,
nang: nang,
nap: nap,
napE: napE,
napid: napid,
napos: napos,
napprox: napprox,
natural: natural,
naturals: naturals,
natur: natur,
nbsp: nbsp$1,
nbump: nbump,
nbumpe: nbumpe,
ncap: ncap,
Ncaron: Ncaron,
ncaron: ncaron,
Ncedil: Ncedil,
ncedil: ncedil,
ncong: ncong,
ncongdot: ncongdot,
ncup: ncup,
Ncy: Ncy,
ncy: ncy,
ndash: ndash,
nearhk: nearhk,
nearr: nearr,
neArr: neArr,
nearrow: nearrow,
ne: ne,
nedot: nedot,
NegativeMediumSpace: NegativeMediumSpace,
NegativeThickSpace: NegativeThickSpace,
NegativeThinSpace: NegativeThinSpace,
NegativeVeryThinSpace: NegativeVeryThinSpace,
nequiv: nequiv,
nesear: nesear,
nesim: nesim,
NestedGreaterGreater: NestedGreaterGreater,
NestedLessLess: NestedLessLess,
NewLine: NewLine,
nexist: nexist,
nexists: nexists,
Nfr: Nfr,
nfr: nfr,
ngE: ngE,
nge: nge,
ngeq: ngeq,
ngeqq: ngeqq,
ngeqslant: ngeqslant,
nges: nges,
nGg: nGg,
ngsim: ngsim,
nGt: nGt,
ngt: ngt,
ngtr: ngtr,
nGtv: nGtv,
nharr: nharr,
nhArr: nhArr,
nhpar: nhpar,
ni: ni,
nis: nis,
nisd: nisd,
niv: niv,
NJcy: NJcy,
njcy: njcy,
nlarr: nlarr,
nlArr: nlArr,
nldr: nldr,
nlE: nlE,
nle: nle,
nleftarrow: nleftarrow,
nLeftarrow: nLeftarrow,
nleftrightarrow: nleftrightarrow,
nLeftrightarrow: nLeftrightarrow,
nleq: nleq,
nleqq: nleqq,
nleqslant: nleqslant,
nles: nles,
nless: nless,
nLl: nLl,
nlsim: nlsim,
nLt: nLt,
nlt: nlt,
nltri: nltri,
nltrie: nltrie,
nLtv: nLtv,
nmid: nmid,
NoBreak: NoBreak,
NonBreakingSpace: NonBreakingSpace,
nopf: nopf,
Nopf: Nopf,
Not: Not,
not: not$1,
NotCongruent: NotCongruent,
NotCupCap: NotCupCap,
NotDoubleVerticalBar: NotDoubleVerticalBar,
NotElement: NotElement,
NotEqual: NotEqual,
NotEqualTilde: NotEqualTilde,
NotExists: NotExists,
NotGreater: NotGreater,
NotGreaterEqual: NotGreaterEqual,
NotGreaterFullEqual: NotGreaterFullEqual,
NotGreaterGreater: NotGreaterGreater,
NotGreaterLess: NotGreaterLess,
NotGreaterSlantEqual: NotGreaterSlantEqual,
NotGreaterTilde: NotGreaterTilde,
NotHumpDownHump: NotHumpDownHump,
NotHumpEqual: NotHumpEqual,
notin: notin,
notindot: notindot,
notinE: notinE,
notinva: notinva,
notinvb: notinvb,
notinvc: notinvc,
NotLeftTriangleBar: NotLeftTriangleBar,
NotLeftTriangle: NotLeftTriangle,
NotLeftTriangleEqual: NotLeftTriangleEqual,
NotLess: NotLess,
NotLessEqual: NotLessEqual,
NotLessGreater: NotLessGreater,
NotLessLess: NotLessLess,
NotLessSlantEqual: NotLessSlantEqual,
NotLessTilde: NotLessTilde,
NotNestedGreaterGreater: NotNestedGreaterGreater,
NotNestedLessLess: NotNestedLessLess,
notni: notni,
notniva: notniva,
notnivb: notnivb,
notnivc: notnivc,
NotPrecedes: NotPrecedes,
NotPrecedesEqual: NotPrecedesEqual,
NotPrecedesSlantEqual: NotPrecedesSlantEqual,
NotReverseElement: NotReverseElement,
NotRightTriangleBar: NotRightTriangleBar,
NotRightTriangle: NotRightTriangle,
NotRightTriangleEqual: NotRightTriangleEqual,
NotSquareSubset: NotSquareSubset,
NotSquareSubsetEqual: NotSquareSubsetEqual,
NotSquareSuperset: NotSquareSuperset,
NotSquareSupersetEqual: NotSquareSupersetEqual,
NotSubset: NotSubset,
NotSubsetEqual: NotSubsetEqual,
NotSucceeds: NotSucceeds,
NotSucceedsEqual: NotSucceedsEqual,
NotSucceedsSlantEqual: NotSucceedsSlantEqual,
NotSucceedsTilde: NotSucceedsTilde,
NotSuperset: NotSuperset,
NotSupersetEqual: NotSupersetEqual,
NotTilde: NotTilde,
NotTildeEqual: NotTildeEqual,
NotTildeFullEqual: NotTildeFullEqual,
NotTildeTilde: NotTildeTilde,
NotVerticalBar: NotVerticalBar,
nparallel: nparallel,
npar: npar,
nparsl: nparsl,
npart: npart,
npolint: npolint,
npr: npr,
nprcue: nprcue,
nprec: nprec,
npreceq: npreceq,
npre: npre,
nrarrc: nrarrc,
nrarr: nrarr,
nrArr: nrArr,
nrarrw: nrarrw,
nrightarrow: nrightarrow,
nRightarrow: nRightarrow,
nrtri: nrtri,
nrtrie: nrtrie,
nsc: nsc,
nsccue: nsccue,
nsce: nsce,
Nscr: Nscr,
nscr: nscr,
nshortmid: nshortmid,
nshortparallel: nshortparallel,
nsim: nsim,
nsime: nsime,
nsimeq: nsimeq,
nsmid: nsmid,
nspar: nspar,
nsqsube: nsqsube,
nsqsupe: nsqsupe,
nsub: nsub,
nsubE: nsubE,
nsube: nsube,
nsubset: nsubset,
nsubseteq: nsubseteq,
nsubseteqq: nsubseteqq,
nsucc: nsucc,
nsucceq: nsucceq,
nsup: nsup,
nsupE: nsupE,
nsupe: nsupe,
nsupset: nsupset,
nsupseteq: nsupseteq,
nsupseteqq: nsupseteqq,
ntgl: ntgl,
Ntilde: Ntilde$1,
ntilde: ntilde$1,
ntlg: ntlg,
ntriangleleft: ntriangleleft,
ntrianglelefteq: ntrianglelefteq,
ntriangleright: ntriangleright,
ntrianglerighteq: ntrianglerighteq,
Nu: Nu,
nu: nu,
num: num,
numero: numero,
numsp: numsp,
nvap: nvap,
nvdash: nvdash,
nvDash: nvDash,
nVdash: nVdash,
nVDash: nVDash,
nvge: nvge,
nvgt: nvgt,
nvHarr: nvHarr,
nvinfin: nvinfin,
nvlArr: nvlArr,
nvle: nvle,
nvlt: nvlt,
nvltrie: nvltrie,
nvrArr: nvrArr,
nvrtrie: nvrtrie,
nvsim: nvsim,
nwarhk: nwarhk,
nwarr: nwarr,
nwArr: nwArr,
nwarrow: nwarrow,
nwnear: nwnear,
Oacute: Oacute$1,
oacute: oacute$1,
oast: oast,
Ocirc: Ocirc$1,
ocirc: ocirc$1,
ocir: ocir,
Ocy: Ocy,
ocy: ocy,
odash: odash,
Odblac: Odblac,
odblac: odblac,
odiv: odiv,
odot: odot,
odsold: odsold,
OElig: OElig,
oelig: oelig,
ofcir: ofcir,
Ofr: Ofr,
ofr: ofr,
ogon: ogon,
Ograve: Ograve$1,
ograve: ograve$1,
ogt: ogt,
ohbar: ohbar,
ohm: ohm,
oint: oint,
olarr: olarr,
olcir: olcir,
olcross: olcross,
oline: oline,
olt: olt,
Omacr: Omacr,
omacr: omacr,
Omega: Omega,
omega: omega,
Omicron: Omicron,
omicron: omicron,
omid: omid,
ominus: ominus,
Oopf: Oopf,
oopf: oopf,
opar: opar,
OpenCurlyDoubleQuote: OpenCurlyDoubleQuote,
OpenCurlyQuote: OpenCurlyQuote,
operp: operp,
oplus: oplus,
orarr: orarr,
Or: Or,
or: or,
ord: ord,
order: order,
orderof: orderof,
ordf: ordf$1,
ordm: ordm$1,
origof: origof,
oror: oror,
orslope: orslope,
orv: orv,
oS: oS,
Oscr: Oscr,
oscr: oscr,
Oslash: Oslash$1,
oslash: oslash$1,
osol: osol,
Otilde: Otilde$1,
otilde: otilde$1,
otimesas: otimesas,
Otimes: Otimes,
otimes: otimes,
Ouml: Ouml$1,
ouml: ouml$1,
ovbar: ovbar,
OverBar: OverBar,
OverBrace: OverBrace,
OverBracket: OverBracket,
OverParenthesis: OverParenthesis,
para: para$1,
parallel: parallel,
par: par,
parsim: parsim,
parsl: parsl,
part: part,
PartialD: PartialD,
Pcy: Pcy,
pcy: pcy,
percnt: percnt,
period: period,
permil: permil,
perp: perp,
pertenk: pertenk,
Pfr: Pfr,
pfr: pfr,
Phi: Phi,
phi: phi,
phiv: phiv,
phmmat: phmmat,
phone: phone,
Pi: Pi,
pi: pi,
pitchfork: pitchfork,
piv: piv,
planck: planck,
planckh: planckh,
plankv: plankv,
plusacir: plusacir,
plusb: plusb,
pluscir: pluscir,
plus: plus,
plusdo: plusdo,
plusdu: plusdu,
pluse: pluse,
PlusMinus: PlusMinus,
plusmn: plusmn$1,
plussim: plussim,
plustwo: plustwo,
pm: pm,
Poincareplane: Poincareplane,
pointint: pointint,
popf: popf,
Popf: Popf,
pound: pound$1,
prap: prap,
Pr: Pr,
pr: pr,
prcue: prcue,
precapprox: precapprox,
prec: prec,
preccurlyeq: preccurlyeq,
Precedes: Precedes,
PrecedesEqual: PrecedesEqual,
PrecedesSlantEqual: PrecedesSlantEqual,
PrecedesTilde: PrecedesTilde,
preceq: preceq,
precnapprox: precnapprox,
precneqq: precneqq,
precnsim: precnsim,
pre: pre,
prE: prE,
precsim: precsim,
prime: prime,
Prime: Prime,
primes: primes,
prnap: prnap,
prnE: prnE,
prnsim: prnsim,
prod: prod,
Product: Product,
profalar: profalar,
profline: profline,
profsurf: profsurf,
prop: prop,
Proportional: Proportional,
Proportion: Proportion,
propto: propto,
prsim: prsim,
prurel: prurel,
Pscr: Pscr,
pscr: pscr,
Psi: Psi,
psi: psi,
puncsp: puncsp,
Qfr: Qfr,
qfr: qfr,
qint: qint,
qopf: qopf,
Qopf: Qopf,
qprime: qprime,
Qscr: Qscr,
qscr: qscr,
quaternions: quaternions,
quatint: quatint,
quest: quest,
questeq: questeq,
quot: quot$2,
QUOT: QUOT$1,
rAarr: rAarr,
race: race,
Racute: Racute,
racute: racute,
radic: radic,
raemptyv: raemptyv,
rang: rang,
Rang: Rang,
rangd: rangd,
range: range,
rangle: rangle,
raquo: raquo$1,
rarrap: rarrap,
rarrb: rarrb,
rarrbfs: rarrbfs,
rarrc: rarrc,
rarr: rarr,
Rarr: Rarr,
rArr: rArr,
rarrfs: rarrfs,
rarrhk: rarrhk,
rarrlp: rarrlp,
rarrpl: rarrpl,
rarrsim: rarrsim,
Rarrtl: Rarrtl,
rarrtl: rarrtl,
rarrw: rarrw,
ratail: ratail,
rAtail: rAtail,
ratio: ratio,
rationals: rationals,
rbarr: rbarr,
rBarr: rBarr,
RBarr: RBarr,
rbbrk: rbbrk,
rbrace: rbrace,
rbrack: rbrack,
rbrke: rbrke,
rbrksld: rbrksld,
rbrkslu: rbrkslu,
Rcaron: Rcaron,
rcaron: rcaron,
Rcedil: Rcedil,
rcedil: rcedil,
rceil: rceil,
rcub: rcub,
Rcy: Rcy,
rcy: rcy,
rdca: rdca,
rdldhar: rdldhar,
rdquo: rdquo,
rdquor: rdquor,
rdsh: rdsh,
real: real,
realine: realine,
realpart: realpart,
reals: reals,
Re: Re,
rect: rect,
reg: reg$1,
REG: REG$1,
ReverseElement: ReverseElement,
ReverseEquilibrium: ReverseEquilibrium,
ReverseUpEquilibrium: ReverseUpEquilibrium,
rfisht: rfisht,
rfloor: rfloor,
rfr: rfr,
Rfr: Rfr,
rHar: rHar,
rhard: rhard,
rharu: rharu,
rharul: rharul,
Rho: Rho,
rho: rho,
rhov: rhov,
RightAngleBracket: RightAngleBracket,
RightArrowBar: RightArrowBar,
rightarrow: rightarrow,
RightArrow: RightArrow,
Rightarrow: Rightarrow,
RightArrowLeftArrow: RightArrowLeftArrow,
rightarrowtail: rightarrowtail,
RightCeiling: RightCeiling,
RightDoubleBracket: RightDoubleBracket,
RightDownTeeVector: RightDownTeeVector,
RightDownVectorBar: RightDownVectorBar,
RightDownVector: RightDownVector,
RightFloor: RightFloor,
rightharpoondown: rightharpoondown,
rightharpoonup: rightharpoonup,
rightleftarrows: rightleftarrows,
rightleftharpoons: rightleftharpoons,
rightrightarrows: rightrightarrows,
rightsquigarrow: rightsquigarrow,
RightTeeArrow: RightTeeArrow,
RightTee: RightTee,
RightTeeVector: RightTeeVector,
rightthreetimes: rightthreetimes,
RightTriangleBar: RightTriangleBar,
RightTriangle: RightTriangle,
RightTriangleEqual: RightTriangleEqual,
RightUpDownVector: RightUpDownVector,
RightUpTeeVector: RightUpTeeVector,
RightUpVectorBar: RightUpVectorBar,
RightUpVector: RightUpVector,
RightVectorBar: RightVectorBar,
RightVector: RightVector,
ring: ring,
risingdotseq: risingdotseq,
rlarr: rlarr,
rlhar: rlhar,
rlm: rlm,
rmoustache: rmoustache,
rmoust: rmoust,
rnmid: rnmid,
roang: roang,
roarr: roarr,
robrk: robrk,
ropar: ropar,
ropf: ropf,
Ropf: Ropf,
roplus: roplus,
rotimes: rotimes,
RoundImplies: RoundImplies,
rpar: rpar,
rpargt: rpargt,
rppolint: rppolint,
rrarr: rrarr,
Rrightarrow: Rrightarrow,
rsaquo: rsaquo,
rscr: rscr,
Rscr: Rscr,
rsh: rsh,
Rsh: Rsh,
rsqb: rsqb,
rsquo: rsquo,
rsquor: rsquor,
rthree: rthree,
rtimes: rtimes,
rtri: rtri,
rtrie: rtrie,
rtrif: rtrif,
rtriltri: rtriltri,
RuleDelayed: RuleDelayed,
ruluhar: ruluhar,
rx: rx,
Sacute: Sacute,
sacute: sacute,
sbquo: sbquo,
scap: scap,
Scaron: Scaron,
scaron: scaron,
Sc: Sc,
sc: sc,
sccue: sccue,
sce: sce,
scE: scE,
Scedil: Scedil,
scedil: scedil,
Scirc: Scirc,
scirc: scirc,
scnap: scnap,
scnE: scnE,
scnsim: scnsim,
scpolint: scpolint,
scsim: scsim,
Scy: Scy,
scy: scy,
sdotb: sdotb,
sdot: sdot,
sdote: sdote,
searhk: searhk,
searr: searr,
seArr: seArr,
searrow: searrow,
sect: sect$1,
semi: semi,
seswar: seswar,
setminus: setminus,
setmn: setmn,
sext: sext,
Sfr: Sfr,
sfr: sfr,
sfrown: sfrown,
sharp: sharp,
SHCHcy: SHCHcy,
shchcy: shchcy,
SHcy: SHcy,
shcy: shcy,
ShortDownArrow: ShortDownArrow,
ShortLeftArrow: ShortLeftArrow,
shortmid: shortmid,
shortparallel: shortparallel,
ShortRightArrow: ShortRightArrow,
ShortUpArrow: ShortUpArrow,
shy: shy$1,
Sigma: Sigma,
sigma: sigma,
sigmaf: sigmaf,
sigmav: sigmav,
sim: sim,
simdot: simdot,
sime: sime,
simeq: simeq,
simg: simg,
simgE: simgE,
siml: siml,
simlE: simlE,
simne: simne,
simplus: simplus,
simrarr: simrarr,
slarr: slarr,
SmallCircle: SmallCircle,
smallsetminus: smallsetminus,
smashp: smashp,
smeparsl: smeparsl,
smid: smid,
smile: smile,
smt: smt,
smte: smte,
smtes: smtes,
SOFTcy: SOFTcy,
softcy: softcy,
solbar: solbar,
solb: solb,
sol: sol,
Sopf: Sopf,
sopf: sopf,
spades: spades,
spadesuit: spadesuit,
spar: spar,
sqcap: sqcap,
sqcaps: sqcaps,
sqcup: sqcup,
sqcups: sqcups,
Sqrt: Sqrt,
sqsub: sqsub,
sqsube: sqsube,
sqsubset: sqsubset,
sqsubseteq: sqsubseteq,
sqsup: sqsup,
sqsupe: sqsupe,
sqsupset: sqsupset,
sqsupseteq: sqsupseteq,
square: square,
Square: Square,
SquareIntersection: SquareIntersection,
SquareSubset: SquareSubset,
SquareSubsetEqual: SquareSubsetEqual,
SquareSuperset: SquareSuperset,
SquareSupersetEqual: SquareSupersetEqual,
SquareUnion: SquareUnion,
squarf: squarf,
squ: squ,
squf: squf,
srarr: srarr,
Sscr: Sscr,
sscr: sscr,
ssetmn: ssetmn,
ssmile: ssmile,
sstarf: sstarf,
Star: Star,
star: star,
starf: starf,
straightepsilon: straightepsilon,
straightphi: straightphi,
strns: strns,
sub: sub,
Sub: Sub,
subdot: subdot,
subE: subE,
sube: sube,
subedot: subedot,
submult: submult,
subnE: subnE,
subne: subne,
subplus: subplus,
subrarr: subrarr,
subset: subset,
Subset: Subset,
subseteq: subseteq,
subseteqq: subseteqq,
SubsetEqual: SubsetEqual,
subsetneq: subsetneq,
subsetneqq: subsetneqq,
subsim: subsim,
subsub: subsub,
subsup: subsup,
succapprox: succapprox,
succ: succ,
succcurlyeq: succcurlyeq,
Succeeds: Succeeds,
SucceedsEqual: SucceedsEqual,
SucceedsSlantEqual: SucceedsSlantEqual,
SucceedsTilde: SucceedsTilde,
succeq: succeq,
succnapprox: succnapprox,
succneqq: succneqq,
succnsim: succnsim,
succsim: succsim,
SuchThat: SuchThat,
sum: sum,
Sum: Sum,
sung: sung,
sup1: sup1$1,
sup2: sup2$1,
sup3: sup3$1,
sup: sup,
Sup: Sup,
supdot: supdot,
supdsub: supdsub,
supE: supE,
supe: supe,
supedot: supedot,
Superset: Superset,
SupersetEqual: SupersetEqual,
suphsol: suphsol,
suphsub: suphsub,
suplarr: suplarr,
supmult: supmult,
supnE: supnE,
supne: supne,
supplus: supplus,
supset: supset,
Supset: Supset,
supseteq: supseteq,
supseteqq: supseteqq,
supsetneq: supsetneq,
supsetneqq: supsetneqq,
supsim: supsim,
supsub: supsub,
supsup: supsup,
swarhk: swarhk,
swarr: swarr,
swArr: swArr,
swarrow: swarrow,
swnwar: swnwar,
szlig: szlig$1,
Tab: Tab,
target: target,
Tau: Tau,
tau: tau,
tbrk: tbrk,
Tcaron: Tcaron,
tcaron: tcaron,
Tcedil: Tcedil,
tcedil: tcedil,
Tcy: Tcy,
tcy: tcy,
tdot: tdot,
telrec: telrec,
Tfr: Tfr,
tfr: tfr,
there4: there4,
therefore: therefore,
Therefore: Therefore,
Theta: Theta,
theta: theta,
thetasym: thetasym,
thetav: thetav,
thickapprox: thickapprox,
thicksim: thicksim,
ThickSpace: ThickSpace,
ThinSpace: ThinSpace,
thinsp: thinsp,
thkap: thkap,
thksim: thksim,
THORN: THORN$1,
thorn: thorn$1,
tilde: tilde,
Tilde: Tilde,
TildeEqual: TildeEqual,
TildeFullEqual: TildeFullEqual,
TildeTilde: TildeTilde,
timesbar: timesbar,
timesb: timesb,
times: times$1,
timesd: timesd,
tint: tint,
toea: toea,
topbot: topbot,
topcir: topcir,
top: esm_top,
Topf: Topf,
topf: topf,
topfork: topfork,
tosa: tosa,
tprime: tprime,
trade: trade,
TRADE: TRADE,
triangle: triangle,
triangledown: triangledown,
triangleleft: triangleleft,
trianglelefteq: trianglelefteq,
triangleq: triangleq,
triangleright: triangleright,
trianglerighteq: trianglerighteq,
tridot: tridot,
trie: trie,
triminus: triminus,
TripleDot: TripleDot,
triplus: triplus,
trisb: trisb,
tritime: tritime,
trpezium: trpezium,
Tscr: Tscr,
tscr: tscr,
TScy: TScy,
tscy: tscy,
TSHcy: TSHcy,
tshcy: tshcy,
Tstrok: Tstrok,
tstrok: tstrok,
twixt: twixt,
twoheadleftarrow: twoheadleftarrow,
twoheadrightarrow: twoheadrightarrow,
Uacute: Uacute$1,
uacute: uacute$1,
uarr: uarr,
Uarr: Uarr,
uArr: uArr,
Uarrocir: Uarrocir,
Ubrcy: Ubrcy,
ubrcy: ubrcy,
Ubreve: Ubreve,
ubreve: ubreve,
Ucirc: Ucirc$1,
ucirc: ucirc$1,
Ucy: Ucy,
ucy: ucy,
udarr: udarr,
Udblac: Udblac,
udblac: udblac,
udhar: udhar,
ufisht: ufisht,
Ufr: Ufr,
ufr: ufr,
Ugrave: Ugrave$1,
ugrave: ugrave$1,
uHar: uHar,
uharl: uharl,
uharr: uharr,
uhblk: uhblk,
ulcorn: ulcorn,
ulcorner: ulcorner,
ulcrop: ulcrop,
ultri: ultri,
Umacr: Umacr,
umacr: umacr,
uml: uml$1,
UnderBar: UnderBar,
UnderBrace: UnderBrace,
UnderBracket: UnderBracket,
UnderParenthesis: UnderParenthesis,
Union: Union,
UnionPlus: UnionPlus,
Uogon: Uogon,
uogon: uogon,
Uopf: Uopf,
uopf: uopf,
UpArrowBar: UpArrowBar,
uparrow: uparrow,
UpArrow: UpArrow,
Uparrow: Uparrow,
UpArrowDownArrow: UpArrowDownArrow,
updownarrow: updownarrow,
UpDownArrow: UpDownArrow,
Updownarrow: Updownarrow,
UpEquilibrium: UpEquilibrium,
upharpoonleft: upharpoonleft,
upharpoonright: upharpoonright,
uplus: uplus,
UpperLeftArrow: UpperLeftArrow,
UpperRightArrow: UpperRightArrow,
upsi: upsi,
Upsi: Upsi,
upsih: upsih,
Upsilon: Upsilon,
upsilon: upsilon,
UpTeeArrow: UpTeeArrow,
UpTee: UpTee,
upuparrows: upuparrows,
urcorn: urcorn,
urcorner: urcorner,
urcrop: urcrop,
Uring: Uring,
uring: uring,
urtri: urtri,
Uscr: Uscr,
uscr: uscr,
utdot: utdot,
Utilde: Utilde,
utilde: utilde,
utri: utri,
utrif: utrif,
uuarr: uuarr,
Uuml: Uuml$1,
uuml: uuml$1,
uwangle: uwangle,
vangrt: vangrt,
varepsilon: varepsilon,
varkappa: varkappa,
varnothing: varnothing,
varphi: varphi,
varpi: varpi,
varpropto: varpropto,
varr: varr,
vArr: vArr,
varrho: varrho,
varsigma: varsigma,
varsubsetneq: varsubsetneq,
varsubsetneqq: varsubsetneqq,
varsupsetneq: varsupsetneq,
varsupsetneqq: varsupsetneqq,
vartheta: vartheta,
vartriangleleft: vartriangleleft,
vartriangleright: vartriangleright,
vBar: vBar,
Vbar: Vbar,
vBarv: vBarv,
Vcy: Vcy,
vcy: vcy,
vdash: vdash,
vDash: vDash,
Vdash: Vdash,
VDash: VDash,
Vdashl: Vdashl,
veebar: veebar,
vee: vee,
Vee: Vee,
veeeq: veeeq,
vellip: vellip,
verbar: verbar,
Verbar: Verbar,
vert: vert,
Vert: Vert,
VerticalBar: VerticalBar,
VerticalLine: VerticalLine,
VerticalSeparator: VerticalSeparator,
VerticalTilde: VerticalTilde,
VeryThinSpace: VeryThinSpace,
Vfr: Vfr,
vfr: vfr,
vltri: vltri,
vnsub: vnsub,
vnsup: vnsup,
Vopf: Vopf,
vopf: vopf,
vprop: vprop,
vrtri: vrtri,
Vscr: Vscr,
vscr: vscr,
vsubnE: vsubnE,
vsubne: vsubne,
vsupnE: vsupnE,
vsupne: vsupne,
Vvdash: Vvdash,
vzigzag: vzigzag,
Wcirc: Wcirc,
wcirc: wcirc,
wedbar: wedbar,
wedge: wedge,
Wedge: Wedge,
wedgeq: wedgeq,
weierp: weierp,
Wfr: Wfr,
wfr: wfr,
Wopf: Wopf,
wopf: wopf,
wp: wp,
wr: wr,
wreath: wreath,
Wscr: Wscr,
wscr: wscr,
xcap: xcap,
xcirc: xcirc,
xcup: xcup,
xdtri: xdtri,
Xfr: Xfr,
xfr: xfr,
xharr: xharr,
xhArr: xhArr,
Xi: Xi,
xi: xi,
xlarr: xlarr,
xlArr: xlArr,
xmap: xmap,
xnis: xnis,
xodot: xodot,
Xopf: Xopf,
xopf: xopf,
xoplus: xoplus,
xotime: xotime,
xrarr: xrarr,
xrArr: xrArr,
Xscr: Xscr,
xscr: xscr,
xsqcup: xsqcup,
xuplus: xuplus,
xutri: xutri,
xvee: xvee,
xwedge: xwedge,
Yacute: Yacute$1,
yacute: yacute$1,
YAcy: YAcy,
yacy: yacy,
Ycirc: Ycirc,
ycirc: ycirc,
Ycy: Ycy,
ycy: ycy,
yen: yen$1,
Yfr: Yfr,
yfr: yfr,
YIcy: YIcy,
yicy: yicy,
Yopf: Yopf,
yopf: yopf,
Yscr: Yscr,
yscr: yscr,
YUcy: YUcy,
yucy: yucy,
yuml: yuml$1,
Yuml: Yuml,
Zacute: Zacute,
zacute: zacute,
Zcaron: Zcaron,
zcaron: zcaron,
Zcy: Zcy,
zcy: zcy,
Zdot: Zdot,
zdot: zdot,
zeetrf: zeetrf,
ZeroWidthSpace: ZeroWidthSpace,
Zeta: Zeta,
zeta: zeta,
zfr: zfr,
Zfr: Zfr,
ZHcy: ZHcy,
zhcy: zhcy,
zigrarr: zigrarr,
zopf: zopf,
Zopf: Zopf,
Zscr: Zscr,
zscr: zscr,
zwj: zwj,
zwnj: zwnj
};
var Aacute = "Á";
var aacute = "á";
var Acirc = "Â";
var acirc = "â";
var acute = "´";
var AElig = "Æ";
var aelig = "æ";
var Agrave = "À";
var agrave = "à";
var amp$1 = "&";
var AMP = "&";
var Aring = "Å";
var aring = "å";
var Atilde = "Ã";
var atilde = "ã";
var Auml = "Ä";
var auml = "ä";
var brvbar = "¦";
var Ccedil = "Ç";
var ccedil = "ç";
var cedil = "¸";
var cent = "¢";
var copy = "©";
var COPY = "©";
var curren = "¤";
var deg = "°";
var divide = "÷";
var Eacute = "É";
var eacute = "é";
var Ecirc = "Ê";
var ecirc = "ê";
var Egrave = "È";
var egrave = "è";
var ETH = "Ð";
var eth = "ð";
var Euml = "Ë";
var euml = "ë";
var frac12 = "½";
var frac14 = "¼";
var frac34 = "¾";
var gt$1 = ">";
var GT = ">";
var Iacute = "Í";
var iacute = "í";
var Icirc = "Î";
var icirc = "î";
var iexcl = "¡";
var Igrave = "Ì";
var igrave = "ì";
var iquest = "¿";
var Iuml = "Ï";
var iuml = "ï";
var laquo = "«";
var lt$1 = "<";
var LT = "<";
var macr = "¯";
var micro = "µ";
var middot = "·";
var nbsp = " ";
var not = "¬";
var Ntilde = "Ñ";
var ntilde = "ñ";
var Oacute = "Ó";
var oacute = "ó";
var Ocirc = "Ô";
var ocirc = "ô";
var Ograve = "Ò";
var ograve = "ò";
var ordf = "ª";
var ordm = "º";
var Oslash = "Ø";
var oslash = "ø";
var Otilde = "Õ";
var otilde = "õ";
var Ouml = "Ö";
var ouml = "ö";
var para = "¶";
var plusmn = "±";
var pound = "£";
var quot$1 = "\"";
var QUOT = "\"";
var raquo = "»";
var reg = "®";
var REG = "®";
var sect = "§";
var shy = "";
var sup1 = "¹";
var sup2 = "²";
var sup3 = "³";
var szlig = "ß";
var THORN = "Þ";
var thorn = "þ";
var times = "×";
var Uacute = "Ú";
var uacute = "ú";
var Ucirc = "Û";
var ucirc = "û";
var Ugrave = "Ù";
var ugrave = "ù";
var uml = "¨";
var Uuml = "Ü";
var uuml = "ü";
var Yacute = "Ý";
var yacute = "ý";
var yen = "¥";
var yuml = "ÿ";
var require$$1 = {
Aacute: Aacute,
aacute: aacute,
Acirc: Acirc,
acirc: acirc,
acute: acute,
AElig: AElig,
aelig: aelig,
Agrave: Agrave,
agrave: agrave,
amp: amp$1,
AMP: AMP,
Aring: Aring,
aring: aring,
Atilde: Atilde,
atilde: atilde,
Auml: Auml,
auml: auml,
brvbar: brvbar,
Ccedil: Ccedil,
ccedil: ccedil,
cedil: cedil,
cent: cent,
copy: copy,
COPY: COPY,
curren: curren,
deg: deg,
divide: divide,
Eacute: Eacute,
eacute: eacute,
Ecirc: Ecirc,
ecirc: ecirc,
Egrave: Egrave,
egrave: egrave,
ETH: ETH,
eth: eth,
Euml: Euml,
euml: euml,
frac12: frac12,
frac14: frac14,
frac34: frac34,
gt: gt$1,
GT: GT,
Iacute: Iacute,
iacute: iacute,
Icirc: Icirc,
icirc: icirc,
iexcl: iexcl,
Igrave: Igrave,
igrave: igrave,
iquest: iquest,
Iuml: Iuml,
iuml: iuml,
laquo: laquo,
lt: lt$1,
LT: LT,
macr: macr,
micro: micro,
middot: middot,
nbsp: nbsp,
not: not,
Ntilde: Ntilde,
ntilde: ntilde,
Oacute: Oacute,
oacute: oacute,
Ocirc: Ocirc,
ocirc: ocirc,
Ograve: Ograve,
ograve: ograve,
ordf: ordf,
ordm: ordm,
Oslash: Oslash,
oslash: oslash,
Otilde: Otilde,
otilde: otilde,
Ouml: Ouml,
ouml: ouml,
para: para,
plusmn: plusmn,
pound: pound,
quot: quot$1,
QUOT: QUOT,
raquo: raquo,
reg: reg,
REG: REG,
sect: sect,
shy: shy,
sup1: sup1,
sup2: sup2,
sup3: sup3,
szlig: szlig,
THORN: THORN,
thorn: thorn,
times: times,
Uacute: Uacute,
uacute: uacute,
Ucirc: Ucirc,
ucirc: ucirc,
Ugrave: Ugrave,
ugrave: ugrave,
uml: uml,
Uuml: Uuml,
uuml: uuml,
Yacute: Yacute,
yacute: yacute,
yen: yen,
yuml: yuml
};
var amp = "&";
var apos = "'";
var gt = ">";
var lt = "<";
var quot = "\"";
var require$$0$1 = {
amp: amp,
apos: apos,
gt: gt,
lt: lt,
quot: quot
};
var decode_codepoint = {};
var require$$0 = {
"0": 65533,
"128": 8364,
"130": 8218,
"131": 402,
"132": 8222,
"133": 8230,
"134": 8224,
"135": 8225,
"136": 710,
"137": 8240,
"138": 352,
"139": 8249,
"140": 338,
"142": 381,
"145": 8216,
"146": 8217,
"147": 8220,
"148": 8221,
"149": 8226,
"150": 8211,
"151": 8212,
"152": 732,
"153": 8482,
"154": 353,
"155": 8250,
"156": 339,
"158": 382,
"159": 376
};
var __importDefault$2 = (commonjsGlobal && commonjsGlobal.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(decode_codepoint, "__esModule", { value: true });
var decode_json_1 = __importDefault$2(require$$0);
// Adapted from https://github.com/mathiasbynens/he/blob/master/src/he.js#L94-L119
var fromCodePoint$2 =
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
String.fromCodePoint ||
function (codePoint) {
var output = "";
if (codePoint > 0xffff) {
codePoint -= 0x10000;
output += String.fromCharCode(((codePoint >>> 10) & 0x3ff) | 0xd800);
codePoint = 0xdc00 | (codePoint & 0x3ff);
}
output += String.fromCharCode(codePoint);
return output;
};
function decodeCodePoint(codePoint) {
if ((codePoint >= 0xd800 && codePoint <= 0xdfff) || codePoint > 0x10ffff) {
return "\uFFFD";
}
if (codePoint in decode_json_1.default) {
codePoint = decode_json_1.default[codePoint];
}
return fromCodePoint$2(codePoint);
}
decode_codepoint.default = decodeCodePoint;
var __importDefault$1 = (commonjsGlobal && commonjsGlobal.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(decode, "__esModule", { value: true });
decode.decodeHTML = decode.decodeHTMLStrict = decode.decodeXML = void 0;
var entities_json_1$1 = __importDefault$1(require$$1$1);
var legacy_json_1 = __importDefault$1(require$$1);
var xml_json_1$1 = __importDefault$1(require$$0$1);
var decode_codepoint_1 = __importDefault$1(decode_codepoint);
var strictEntityRe = /&(?:[a-zA-Z0-9]+|#[xX][\da-fA-F]+|#\d+);/g;
decode.decodeXML = getStrictDecoder(xml_json_1$1.default);
decode.decodeHTMLStrict = getStrictDecoder(entities_json_1$1.default);
function getStrictDecoder(map) {
var replace = getReplacer(map);
return function (str) { return String(str).replace(strictEntityRe, replace); };
}
var sorter = function (a, b) { return (a < b ? 1 : -1); };
decode.decodeHTML = (function () {
var legacy = Object.keys(legacy_json_1.default).sort(sorter);
var keys = Object.keys(entities_json_1$1.default).sort(sorter);
for (var i = 0, j = 0; i < keys.length; i++) {
if (legacy[j] === keys[i]) {
keys[i] += ";?";
j++;
}
else {
keys[i] += ";";
}
}
var re = new RegExp("&(?:" + keys.join("|") + "|#[xX][\\da-fA-F]+;?|#\\d+;?)", "g");
var replace = getReplacer(entities_json_1$1.default);
function replacer(str) {
if (str.substr(-1) !== ";")
str += ";";
return replace(str);
}
// TODO consider creating a merged map
return function (str) { return String(str).replace(re, replacer); };
})();
function getReplacer(map) {
return function replace(str) {
if (str.charAt(1) === "#") {
var secondChar = str.charAt(2);
if (secondChar === "X" || secondChar === "x") {
return decode_codepoint_1.default(parseInt(str.substr(3), 16));
}
return decode_codepoint_1.default(parseInt(str.substr(2), 10));
}
// eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
return map[str.slice(1, -1)] || str;
};
}
var encode = {};
var esm_importDefault = (commonjsGlobal && commonjsGlobal.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(encode, "__esModule", { value: true });
encode.escapeUTF8 = encode.escape = encode.encodeNonAsciiHTML = encode.encodeHTML = encode.encodeXML = void 0;
var xml_json_1 = esm_importDefault(require$$0$1);
var inverseXML = getInverseObj(xml_json_1.default);
var xmlReplacer = getInverseReplacer(inverseXML);
/**
* Encodes all non-ASCII characters, as well as characters not valid in XML
* documents using XML entities.
*
* If a character has no equivalent entity, a
* numeric hexadecimal reference (eg. `ü`) will be used.
*/
encode.encodeXML = getASCIIEncoder(inverseXML);
var entities_json_1 = esm_importDefault(require$$1$1);
var inverseHTML = getInverseObj(entities_json_1.default);
var htmlReplacer = getInverseReplacer(inverseHTML);
/**
* Encodes all entities and non-ASCII characters in the input.
*
* This includes characters that are valid ASCII characters in HTML documents.
* For example `#` will be encoded as `#`. To get a more compact output,
* consider using the `encodeNonAsciiHTML` function.
*
* If a character has no equivalent entity, a
* numeric hexadecimal reference (eg. `ü`) will be used.
*/
encode.encodeHTML = getInverse(inverseHTML, htmlReplacer);
/**
* Encodes all non-ASCII characters, as well as characters not valid in HTML
* documents using HTML entities.
*
* If a character has no equivalent entity, a
* numeric hexadecimal reference (eg. `ü`) will be used.
*/
encode.encodeNonAsciiHTML = getASCIIEncoder(inverseHTML);
function getInverseObj(obj) {
return Object.keys(obj)
.sort()
.reduce(function (inverse, name) {
inverse[obj[name]] = "&" + name + ";";
return inverse;
}, {});
}
function getInverseReplacer(inverse) {
var single = [];
var multiple = [];
for (var _i = 0, _a = Object.keys(inverse); _i < _a.length; _i++) {
var k = _a[_i];
if (k.length === 1) {
// Add value to single array
single.push("\\" + k);
}
else {
// Add value to multiple array
multiple.push(k);
}
}
// Add ranges to single characters.
single.sort();
for (var start = 0; start < single.length - 1; start++) {
// Find the end of a run of characters
var end = start;
while (end < single.length - 1 &&
single[end].charCodeAt(1) + 1 === single[end + 1].charCodeAt(1)) {
end += 1;
}
var count = 1 + end - start;
// We want to replace at least three characters
if (count < 3)
continue;
single.splice(start, count, single[start] + "-" + single[end]);
}
multiple.unshift("[" + single.join("") + "]");
return new RegExp(multiple.join("|"), "g");
}
// /[^\0-\x7F]/gu
var reNonASCII = /(?:[\x80-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])/g;
var getCodePoint =
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
String.prototype.codePointAt != null
? // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
function (str) { return str.codePointAt(0); }
: // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae
function (c) {
return (c.charCodeAt(0) - 0xd800) * 0x400 +
c.charCodeAt(1) -
0xdc00 +
0x10000;
};
function singleCharReplacer(c) {
return "" + (c.length > 1 ? getCodePoint(c) : c.charCodeAt(0))
.toString(16)
.toUpperCase() + ";";
}
function getInverse(inverse, re) {
return function (data) {
return data
.replace(re, function (name) { return inverse[name]; })
.replace(reNonASCII, singleCharReplacer);
};
}
var esm_reEscapeChars = new RegExp(xmlReplacer.source + "|" + reNonASCII.source, "g");
/**
* Encodes all non-ASCII characters, as well as characters not valid in XML
* documents using numeric hexadecimal reference (eg. `ü`).
*
* Have a look at `escapeUTF8` if you want a more concise output at the expense
* of reduced transportability.
*
* @param data String to escape.
*/
function esm_escape(data) {
return data.replace(esm_reEscapeChars, singleCharReplacer);
}
encode.escape = esm_escape;
/**
* Encodes all characters not valid in XML documents using numeric hexadecimal
* reference (eg. `ü`).
*
* Note that the output will be character-set dependent.
*
* @param data String to escape.
*/
function escapeUTF8(data) {
return data.replace(xmlReplacer, singleCharReplacer);
}
encode.escapeUTF8 = escapeUTF8;
function getASCIIEncoder(obj) {
return function (data) {
return data.replace(esm_reEscapeChars, function (c) { return obj[c] || singleCharReplacer(c); });
};
}
(function (exports) {
Object.defineProperty(exports, "__esModule", { value: true });
exports.decodeXMLStrict = exports.decodeHTML5Strict = exports.decodeHTML4Strict = exports.decodeHTML5 = exports.decodeHTML4 = exports.decodeHTMLStrict = exports.decodeHTML = exports.decodeXML = exports.encodeHTML5 = exports.encodeHTML4 = exports.escapeUTF8 = exports.escape = exports.encodeNonAsciiHTML = exports.encodeHTML = exports.encodeXML = exports.encode = exports.decodeStrict = exports.decode = void 0;
var decode_1 = decode;
var encode_1 = encode;
/**
* Decodes a string with entities.
*
* @param data String to decode.
* @param level Optional level to decode at. 0 = XML, 1 = HTML. Default is 0.
* @deprecated Use `decodeXML` or `decodeHTML` directly.
*/
function decode$1(data, level) {
return (!level || level <= 0 ? decode_1.decodeXML : decode_1.decodeHTML)(data);
}
exports.decode = decode$1;
/**
* Decodes a string with entities. Does not allow missing trailing semicolons for entities.
*
* @param data String to decode.
* @param level Optional level to decode at. 0 = XML, 1 = HTML. Default is 0.
* @deprecated Use `decodeHTMLStrict` or `decodeXML` directly.
*/
function decodeStrict(data, level) {
return (!level || level <= 0 ? decode_1.decodeXML : decode_1.decodeHTMLStrict)(data);
}
exports.decodeStrict = decodeStrict;
/**
* Encodes a string with entities.
*
* @param data String to encode.
* @param level Optional level to encode at. 0 = XML, 1 = HTML. Default is 0.
* @deprecated Use `encodeHTML`, `encodeXML` or `encodeNonAsciiHTML` directly.
*/
function encode$1(data, level) {
return (!level || level <= 0 ? encode_1.encodeXML : encode_1.encodeHTML)(data);
}
exports.encode = encode$1;
var encode_2 = encode;
Object.defineProperty(exports, "encodeXML", { enumerable: true, get: function () { return encode_2.encodeXML; } });
Object.defineProperty(exports, "encodeHTML", { enumerable: true, get: function () { return encode_2.encodeHTML; } });
Object.defineProperty(exports, "encodeNonAsciiHTML", { enumerable: true, get: function () { return encode_2.encodeNonAsciiHTML; } });
Object.defineProperty(exports, "escape", { enumerable: true, get: function () { return encode_2.escape; } });
Object.defineProperty(exports, "escapeUTF8", { enumerable: true, get: function () { return encode_2.escapeUTF8; } });
// Legacy aliases (deprecated)
Object.defineProperty(exports, "encodeHTML4", { enumerable: true, get: function () { return encode_2.encodeHTML; } });
Object.defineProperty(exports, "encodeHTML5", { enumerable: true, get: function () { return encode_2.encodeHTML; } });
var decode_2 = decode;
Object.defineProperty(exports, "decodeXML", { enumerable: true, get: function () { return decode_2.decodeXML; } });
Object.defineProperty(exports, "decodeHTML", { enumerable: true, get: function () { return decode_2.decodeHTML; } });
Object.defineProperty(exports, "decodeHTMLStrict", { enumerable: true, get: function () { return decode_2.decodeHTMLStrict; } });
// Legacy aliases (deprecated)
Object.defineProperty(exports, "decodeHTML4", { enumerable: true, get: function () { return decode_2.decodeHTML; } });
Object.defineProperty(exports, "decodeHTML5", { enumerable: true, get: function () { return decode_2.decodeHTML; } });
Object.defineProperty(exports, "decodeHTML4Strict", { enumerable: true, get: function () { return decode_2.decodeHTMLStrict; } });
Object.defineProperty(exports, "decodeHTML5Strict", { enumerable: true, get: function () { return decode_2.decodeHTMLStrict; } });
Object.defineProperty(exports, "decodeXMLStrict", { enumerable: true, get: function () { return decode_2.decodeXML; } });
}(lib));
var ENTITY = '&(?:#x[a-f0-9]{1,6}|#[0-9]{1,7}|[a-z][a-z0-9]{1,31});';
var C_BACKSLASH$1 = 92;
var reBackslashOrAmp = /[\\&]/;
var ESCAPABLE = '[!"#$%&\'()*+,./:;<=>?@[\\\\\\]^_`{|}~-]';
var reEntityOrEscapedChar = new RegExp("\\\\" + ESCAPABLE + "|" + ENTITY, 'gi');
var esm_XMLSPECIAL = '[&<>"]';
var esm_reXmlSpecial = new RegExp(esm_XMLSPECIAL, 'g');
var unescapeChar = function (s) {
if (s.charCodeAt(0) === C_BACKSLASH$1) {
return s.charAt(1);
}
return lib.decodeHTML(s);
};
// Replace entities and backslash escapes with literal characters.
function unescapeString(s) {
if (reBackslashOrAmp.test(s)) {
return s.replace(reEntityOrEscapedChar, unescapeChar);
}
return s;
}
function normalizeURI(uri) {
try {
return encode_1(uri);
}
catch (err) {
return uri;
}
}
function esm_replaceUnsafeChar(s) {
switch (s) {
case '&':
return '&';
case '<':
return '<';
case '>':
return '>';
case '"':
return '"';
default:
return s;
}
}
function esm_escapeXml(s) {
if (esm_reXmlSpecial.test(s)) {
return s.replace(esm_reXmlSpecial, esm_replaceUnsafeChar);
}
return s;
}
function esm_repeat(str, count) {
var arr = [];
for (var i = 0; i < count; i++) {
arr.push(str);
}
return arr.join('');
}
function isEmpty(str) {
if (!str) {
return true;
}
return !/[^ \t]+/.test(str);
}
var NodeWalker = /** @class */ (function () {
function NodeWalker(root) {
this.current = root;
this.root = root;
this.entering = true;
}
NodeWalker.prototype.next = function () {
var cur = this.current;
var entering = this.entering;
if (cur === null) {
return null;
}
var container = esm_isContainer(cur);
if (entering && container) {
if (cur.firstChild) {
this.current = cur.firstChild;
this.entering = true;
}
else {
// stay on node but exit
this.entering = false;
}
}
else if (cur === this.root) {
this.current = null;
}
else if (cur.next === null) {
this.current = cur.parent;
this.entering = false;
}
else {
this.current = cur.next;
this.entering = true;
}
return { entering: entering, node: cur };
};
NodeWalker.prototype.resumeAt = function (node, entering) {
this.current = node;
this.entering = entering === true;
};
return NodeWalker;
}());
function esm_isContainer(node) {
switch (node.type) {
case 'document':
case 'blockQuote':
case 'list':
case 'item':
case 'paragraph':
case 'heading':
case 'emph':
case 'strong':
case 'strike':
case 'link':
case 'image':
case 'table':
case 'tableHead':
case 'tableBody':
case 'tableRow':
case 'tableCell':
case 'tableDelimRow':
case 'customInline':
return true;
default:
return false;
}
}
var lastNodeId = 1;
var nodeMap = {};
function getNodeById(id) {
return nodeMap[id];
}
function removeNodeById(id) {
delete nodeMap[id];
}
function removeAllNode() {
nodeMap = {};
}
var esm_Node = /** @class */ (function () {
function Node(nodeType, sourcepos) {
this.parent = null;
this.prev = null;
this.next = null;
// only for container node
this.firstChild = null;
this.lastChild = null;
// only for leaf node
this.literal = null;
if (nodeType === 'document') {
this.id = -1;
}
else {
this.id = lastNodeId++;
}
this.type = nodeType;
this.sourcepos = sourcepos;
nodeMap[this.id] = this;
}
Node.prototype.isContainer = function () {
return esm_isContainer(this);
};
Node.prototype.unlink = function () {
if (this.prev) {
this.prev.next = this.next;
}
else if (this.parent) {
this.parent.firstChild = this.next;
}
if (this.next) {
this.next.prev = this.prev;
}
else if (this.parent) {
this.parent.lastChild = this.prev;
}
this.parent = null;
this.next = null;
this.prev = null;
};
Node.prototype.replaceWith = function (node) {
this.insertBefore(node);
this.unlink();
};
Node.prototype.insertAfter = function (sibling) {
sibling.unlink();
sibling.next = this.next;
if (sibling.next) {
sibling.next.prev = sibling;
}
sibling.prev = this;
this.next = sibling;
if (this.parent) {
sibling.parent = this.parent;
if (!sibling.next) {
sibling.parent.lastChild = sibling;
}
}
};
Node.prototype.insertBefore = function (sibling) {
sibling.unlink();
sibling.prev = this.prev;
if (sibling.prev) {
sibling.prev.next = sibling;
}
sibling.next = this;
this.prev = sibling;
sibling.parent = this.parent;
if (!sibling.prev) {
sibling.parent.firstChild = sibling;
}
};
Node.prototype.appendChild = function (child) {
child.unlink();
child.parent = this;
if (this.lastChild) {
this.lastChild.next = child;
child.prev = this.lastChild;
this.lastChild = child;
}
else {
this.firstChild = child;
this.lastChild = child;
}
};
Node.prototype.prependChild = function (child) {
child.unlink();
child.parent = this;
if (this.firstChild) {
this.firstChild.prev = child;
child.next = this.firstChild;
this.firstChild = child;
}
else {
this.firstChild = child;
this.lastChild = child;
}
};
Node.prototype.walker = function () {
return new NodeWalker(this);
};
return Node;
}());
var BlockNode = /** @class */ (function (_super) {
esm_extends(BlockNode, _super);
function BlockNode(nodeType, sourcepos) {
var _this = _super.call(this, nodeType, sourcepos) || this;
// temporal data (for parsing)
_this.open = true;
_this.lineOffsets = null;
_this.stringContent = null;
_this.lastLineBlank = false;
_this.lastLineChecked = false;
_this.type = nodeType;
return _this;
}
return BlockNode;
}(esm_Node));
var ListNode = /** @class */ (function (_super) {
esm_extends(ListNode, _super);
function ListNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.listData = null;
return _this;
}
return ListNode;
}(BlockNode));
var HeadingNode = /** @class */ (function (_super) {
esm_extends(HeadingNode, _super);
function HeadingNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.level = 0;
_this.headingType = 'atx';
return _this;
}
return HeadingNode;
}(BlockNode));
var CodeBlockNode = /** @class */ (function (_super) {
esm_extends(CodeBlockNode, _super);
function CodeBlockNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.isFenced = false;
_this.fenceChar = null;
_this.fenceLength = 0;
_this.fenceOffset = -1;
_this.info = null;
_this.infoPadding = 0;
return _this;
}
return CodeBlockNode;
}(BlockNode));
var TableNode = /** @class */ (function (_super) {
esm_extends(TableNode, _super);
function TableNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.columns = [];
return _this;
}
return TableNode;
}(BlockNode));
var TableCellNode = /** @class */ (function (_super) {
esm_extends(TableCellNode, _super);
function TableCellNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.startIdx = 0;
_this.endIdx = 0;
_this.paddingLeft = 0;
_this.paddingRight = 0;
_this.ignored = false;
return _this;
}
return TableCellNode;
}(BlockNode));
var RefDefNode = /** @class */ (function (_super) {
esm_extends(RefDefNode, _super);
function RefDefNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.title = '';
_this.dest = '';
_this.label = '';
return _this;
}
return RefDefNode;
}(BlockNode));
var CustomBlockNode = /** @class */ (function (_super) {
esm_extends(CustomBlockNode, _super);
function CustomBlockNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.syntaxLength = 0;
_this.offset = -1;
_this.info = '';
return _this;
}
return CustomBlockNode;
}(BlockNode));
var HtmlBlockNode = /** @class */ (function (_super) {
esm_extends(HtmlBlockNode, _super);
function HtmlBlockNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.htmlBlockType = -1;
return _this;
}
return HtmlBlockNode;
}(BlockNode));
var LinkNode = /** @class */ (function (_super) {
esm_extends(LinkNode, _super);
function LinkNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.destination = null;
_this.title = null;
_this.extendedAutolink = false;
return _this;
}
return LinkNode;
}(esm_Node));
var CodeNode = /** @class */ (function (_super) {
esm_extends(CodeNode, _super);
function CodeNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.tickCount = 0;
return _this;
}
return CodeNode;
}(esm_Node));
var CustomInlineNode = /** @class */ (function (_super) {
esm_extends(CustomInlineNode, _super);
function CustomInlineNode() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.info = '';
return _this;
}
return CustomInlineNode;
}(esm_Node));
function createNode(type, sourcepos) {
switch (type) {
case 'heading':
return new HeadingNode(type, sourcepos);
case 'list':
case 'item':
return new ListNode(type, sourcepos);
case 'link':
case 'image':
return new LinkNode(type, sourcepos);
case 'codeBlock':
return new CodeBlockNode(type, sourcepos);
case 'htmlBlock':
return new HtmlBlockNode(type, sourcepos);
case 'table':
return new TableNode(type, sourcepos);
case 'tableCell':
return new TableCellNode(type, sourcepos);
case 'document':
case 'paragraph':
case 'blockQuote':
case 'thematicBreak':
case 'tableRow':
case 'tableBody':
case 'tableHead':
case 'frontMatter':
return new BlockNode(type, sourcepos);
case 'code':
return new CodeNode(type, sourcepos);
case 'refDef':
return new RefDefNode(type, sourcepos);
case 'customBlock':
return new CustomBlockNode(type, sourcepos);
case 'customInline':
return new CustomInlineNode(type, sourcepos);
default:
return new esm_Node(type, sourcepos);
}
}
function isCodeBlock(node) {
return node.type === 'codeBlock';
}
function isHtmlBlock(node) {
return node.type === 'htmlBlock';
}
function isHeading(node) {
return node.type === 'heading';
}
function isList(node) {
return node.type === 'list';
}
function isTable(node) {
return node.type === 'table';
}
function isRefDef(node) {
return node.type === 'refDef';
}
function isCustomBlock(node) {
return node.type === 'customBlock';
}
function isCustomInline(node) {
return node.type === 'customInline';
}
function esm_text(s, sourcepos) {
var node = createNode('text', sourcepos);
node.literal = s;
return node;
}
var TAGNAME = '[A-Za-z][A-Za-z0-9-]*';
var ATTRIBUTENAME = '[a-zA-Z_:][a-zA-Z0-9:._-]*';
var UNQUOTEDVALUE = '[^"\'=<>`\\x00-\\x20]+';
var SINGLEQUOTEDVALUE = "'[^']*'";
var DOUBLEQUOTEDVALUE = '"[^"]*"';
var ATTRIBUTEVALUE = "(?:" + UNQUOTEDVALUE + "|" + SINGLEQUOTEDVALUE + "|" + DOUBLEQUOTEDVALUE + ")";
var ATTRIBUTEVALUESPEC = "" + '(?:\\s*=\\s*' + ATTRIBUTEVALUE + ")";
var esm_ATTRIBUTE = "" + '(?:\\s+' + ATTRIBUTENAME + ATTRIBUTEVALUESPEC + "?)";
var OPENTAG = "<" + TAGNAME + esm_ATTRIBUTE + "*\\s*/?>";
var CLOSETAG = "" + TAGNAME + "\\s*[>]";
var HTMLCOMMENT = '|';
var PROCESSINGINSTRUCTION = '[<][?].*?[?][>]';
var DECLARATION = ']*>';
var CDATA = '';
var HTMLTAG = "(?:" + OPENTAG + "|" + CLOSETAG + "|" + HTMLCOMMENT + "|" + PROCESSINGINSTRUCTION + "|" + DECLARATION + "|" + CDATA + ")";
var reHtmlTag = new RegExp("^" + HTMLTAG, 'i');
// derived from https://github.com/mathiasbynens/String.fromCodePoint
/*! http://mths.be/fromcodepoint v0.2.1 by @mathias */
var fromCodePoint;
if (String.fromCodePoint) {
fromCodePoint = function (_) {
try {
return String.fromCodePoint(_);
}
catch (e) {
if (e instanceof RangeError) {
return String.fromCharCode(0xfffd);
}
throw e;
}
};
}
else {
var stringFromCharCode_1 = String.fromCharCode;
var floor_1 = Math.floor;
fromCodePoint = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
var MAX_SIZE = 0x4000;
var codeUnits = [];
var highSurrogate;
var lowSurrogate;
var index = -1;
var length = args.length;
if (!length) {
return '';
}
var result = '';
while (++index < length) {
var codePoint = Number(args[index]);
if (!isFinite(codePoint) || // `NaN`, `+Infinity`, or `-Infinity`
codePoint < 0 || // not a valid Unicode code point
codePoint > 0x10ffff || // not a valid Unicode code point
floor_1(codePoint) !== codePoint // not an integer
) {
return String.fromCharCode(0xfffd);
}
if (codePoint <= 0xffff) {
// BMP code point
codeUnits.push(codePoint);
}
else {
// Astral code point; split in surrogate halves
// http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae
codePoint -= 0x10000;
highSurrogate = (codePoint >> 10) + 0xd800;
lowSurrogate = (codePoint % 0x400) + 0xdc00;
codeUnits.push(highSurrogate, lowSurrogate);
}
if (index + 1 === length || codeUnits.length > MAX_SIZE) {
result += stringFromCharCode_1.apply(void 0, codeUnits);
codeUnits.length = 0;
}
}
return result;
};
}
var fromCodePoint$1 = fromCodePoint;
var DOMAIN = '(?:[w-]+.)*[A-Za-z0-9-]+.[A-Za-z0-9-]+';
var PATH = '[^<\\s]*[^!.,:*_?~\\s]';
var EMAIL = '[\\w.+-]+@(?:[\\w-]+\\.)+[\\w-]+';
function trimUnmatchedTrailingParens(source) {
var trailingParen = /\)+$/.exec(source);
if (trailingParen) {
var count = 0;
for (var _i = 0, source_1 = source; _i < source_1.length; _i++) {
var ch = source_1[_i];
if (ch === '(') {
if (count < 0) {
count = 1;
}
else {
count += 1;
}
}
else if (ch === ')') {
count -= 1;
}
}
if (count < 0) {
var trimCount = Math.min(-count, trailingParen[0].length);
return source.substring(0, source.length - trimCount);
}
}
return source;
}
function trimTrailingEntity(source) {
return source.replace(/&[A-Za-z0-9]+;$/, '');
}
function parseEmailLink(source) {
var reEmailLink = new RegExp(EMAIL, 'g');
var result = [];
var m;
while ((m = reEmailLink.exec(source))) {
var text_1 = m[0];
if (!/[_-]+$/.test(text_1)) {
result.push({
text: text_1,
range: [m.index, m.index + text_1.length - 1],
url: "mailto:" + text_1,
});
}
}
return result;
}
function parseUrlLink(source) {
var reWwwAutolink = new RegExp("(www|https?://)." + DOMAIN + PATH, 'g');
var result = [];
var m;
while ((m = reWwwAutolink.exec(source))) {
var text_2 = trimTrailingEntity(trimUnmatchedTrailingParens(m[0]));
var scheme = m[1] === 'www' ? 'http://' : '';
result.push({
text: text_2,
range: [m.index, m.index + text_2.length - 1],
url: "" + scheme + text_2,
});
}
return result;
}
function baseAutolinkParser(source) {
return esm_spreadArray(esm_spreadArray([], parseUrlLink(source)), parseEmailLink(source)).sort(function (a, b) { return a.range[0] - b.range[0]; });
}
function convertExtAutoLinks(walker, autolinkParser) {
if (typeof autolinkParser === 'boolean') {
autolinkParser = baseAutolinkParser;
}
var event;
var _loop_1 = function () {
var entering = event.entering, node = event.node;
if (entering && node.type === 'text' && node.parent.type !== 'link') {
var literal = node.literal;
var linkInfos = autolinkParser(literal);
if (!linkInfos || !linkInfos.length) {
return "continue";
}
var lastIdx = 0;
var _a = node.sourcepos[0], lineNum_1 = _a[0], chPos_1 = _a[1];
var sourcepos = function (startIdx, endIdx) {
return [
[lineNum_1, chPos_1 + startIdx],
[lineNum_1, chPos_1 + endIdx],
];
};
var newNodes = [];
for (var _i = 0, linkInfos_1 = linkInfos; _i < linkInfos_1.length; _i++) {
var _b = linkInfos_1[_i], range = _b.range, url = _b.url, linkText = _b.text;
if (range[0] > lastIdx) {
newNodes.push(esm_text(literal.substring(lastIdx, range[0]), sourcepos(lastIdx, range[0] - 1)));
}
var linkNode = createNode('link', sourcepos.apply(void 0, range));
linkNode.appendChild(esm_text(linkText, sourcepos.apply(void 0, range)));
linkNode.destination = url;
linkNode.extendedAutolink = true;
newNodes.push(linkNode);
lastIdx = range[1] + 1;
}
if (lastIdx < literal.length) {
newNodes.push(esm_text(literal.substring(lastIdx), sourcepos(lastIdx, literal.length - 1)));
}
for (var _c = 0, newNodes_1 = newNodes; _c < newNodes_1.length; _c++) {
var newNode = newNodes_1[_c];
node.insertBefore(newNode);
}
node.unlink();
}
};
while ((event = walker.next())) {
_loop_1();
}
}
function esm_last(arr) {
return arr[arr.length - 1];
}
// normalize a reference in reference link (remove []s, trim,
// collapse internal space, unicode case fold.
// See commonmark/commonmark.js#168.
function normalizeReference(str) {
return str
.slice(1, str.length - 1)
.trim()
.replace(/[ \t\r\n]+/, ' ')
.toLowerCase()
.toUpperCase();
}
function iterateObject(obj, iteratee) {
Object.keys(obj).forEach(function (key) {
iteratee(key, obj[key]);
});
}
function omit(obj) {
var propNames = [];
for (var _i = 1; _i < arguments.length; _i++) {
propNames[_i - 1] = arguments[_i];
}
var resultMap = esm_assign({}, obj);
propNames.forEach(function (key) {
delete resultMap[key];
});
return resultMap;
}
function isEmptyObj(obj) {
return !Object.keys(obj).length;
}
function clearObj(obj) {
Object.keys(obj).forEach(function (key) {
delete obj[key];
});
}
var C_NEWLINE = 10;
var C_ASTERISK = 42;
var C_UNDERSCORE = 95;
var C_BACKTICK = 96;
var C_OPEN_BRACKET$1 = 91;
var C_CLOSE_BRACKET = 93;
var C_TILDE = 126;
var C_LESSTHAN$1 = 60;
var C_BANG = 33;
var C_BACKSLASH = 92;
var C_AMPERSAND = 38;
var C_OPEN_PAREN = 40;
var C_CLOSE_PAREN = 41;
var C_COLON = 58;
var C_SINGLEQUOTE = 39;
var C_DOUBLEQUOTE = 34;
var C_DOLLAR = 36;
// Some regexps used in inline parser:
var ESCAPED_CHAR = "\\\\" + ESCAPABLE;
var rePunctuation = new RegExp(/[!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~\xA1\xA7\xAB\xB6\xB7\xBB\xBF\u037E\u0387\u055A-\u055F\u0589\u058A\u05BE\u05C0\u05C3\u05C6\u05F3\u05F4\u0609\u060A\u060C\u060D\u061B\u061E\u061F\u066A-\u066D\u06D4\u0700-\u070D\u07F7-\u07F9\u0830-\u083E\u085E\u0964\u0965\u0970\u0AF0\u0DF4\u0E4F\u0E5A\u0E5B\u0F04-\u0F12\u0F14\u0F3A-\u0F3D\u0F85\u0FD0-\u0FD4\u0FD9\u0FDA\u104A-\u104F\u10FB\u1360-\u1368\u1400\u166D\u166E\u169B\u169C\u16EB-\u16ED\u1735\u1736\u17D4-\u17D6\u17D8-\u17DA\u1800-\u180A\u1944\u1945\u1A1E\u1A1F\u1AA0-\u1AA6\u1AA8-\u1AAD\u1B5A-\u1B60\u1BFC-\u1BFF\u1C3B-\u1C3F\u1C7E\u1C7F\u1CC0-\u1CC7\u1CD3\u2010-\u2027\u2030-\u2043\u2045-\u2051\u2053-\u205E\u207D\u207E\u208D\u208E\u2308-\u230B\u2329\u232A\u2768-\u2775\u27C5\u27C6\u27E6-\u27EF\u2983-\u2998\u29D8-\u29DB\u29FC\u29FD\u2CF9-\u2CFC\u2CFE\u2CFF\u2D70\u2E00-\u2E2E\u2E30-\u2E42\u3001-\u3003\u3008-\u3011\u3014-\u301F\u3030\u303D\u30A0\u30FB\uA4FE\uA4FF\uA60D-\uA60F\uA673\uA67E\uA6F2-\uA6F7\uA874-\uA877\uA8CE\uA8CF\uA8F8-\uA8FA\uA8FC\uA92E\uA92F\uA95F\uA9C1-\uA9CD\uA9DE\uA9DF\uAA5C-\uAA5F\uAADE\uAADF\uAAF0\uAAF1\uABEB\uFD3E\uFD3F\uFE10-\uFE19\uFE30-\uFE52\uFE54-\uFE61\uFE63\uFE68\uFE6A\uFE6B\uFF01-\uFF03\uFF05-\uFF0A\uFF0C-\uFF0F\uFF1A\uFF1B\uFF1F\uFF20\uFF3B-\uFF3D\uFF3F\uFF5B\uFF5D\uFF5F-\uFF65]|\uD800[\uDD00-\uDD02\uDF9F\uDFD0]|\uD801\uDD6F|\uD802[\uDC57\uDD1F\uDD3F\uDE50-\uDE58\uDE7F\uDEF0-\uDEF6\uDF39-\uDF3F\uDF99-\uDF9C]|\uD804[\uDC47-\uDC4D\uDCBB\uDCBC\uDCBE-\uDCC1\uDD40-\uDD43\uDD74\uDD75\uDDC5-\uDDC9\uDDCD\uDDDB\uDDDD-\uDDDF\uDE38-\uDE3D\uDEA9]|\uD805[\uDCC6\uDDC1-\uDDD7\uDE41-\uDE43\uDF3C-\uDF3E]|\uD809[\uDC70-\uDC74]|\uD81A[\uDE6E\uDE6F\uDEF5\uDF37-\uDF3B\uDF44]|\uD82F\uDC9F|\uD836[\uDE87-\uDE8B]/);
var reLinkTitle = new RegExp("^(?:\"(" + ESCAPED_CHAR + "|[^\"\\x00])*\"" +
"|" +
("'(" + ESCAPED_CHAR + "|[^'\\x00])*'") +
"|" +
("\\((" + ESCAPED_CHAR + "|[^()\\x00])*\\))"));
var reLinkDestinationBraces = /^(?:<(?:[^<>\n\\\x00]|\\.)*>)/;
var reEscapable = new RegExp("^" + ESCAPABLE);
var reEntityHere = new RegExp("^" + ENTITY, 'i');
var reTicks = /`+/;
var reTicksHere = /^`+/;
var reEllipses = /\.\.\./g;
var reDash = /--+/g;
var reEmailAutolink = /^<([a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*)>/;
var reAutolink = /^<[A-Za-z][A-Za-z0-9.+-]{1,31}:[^<>\x00-\x20]*>/i;
var reSpnl = /^ *(?:\n *)?/;
var reWhitespaceChar = /^[ \t\n\x0b\x0c\x0d]/;
var reUnicodeWhitespaceChar = /^\s/;
var reFinalSpace = / *$/;
var reInitialSpace = /^ */;
var reSpaceAtEndOfLine = /^ *(?:\n|$)/;
var reLinkLabel = /^\[(?:[^\\\[\]]|\\.){0,1000}\]/;
// Matches a string of non-special characters.
var reMain = /^[^\n`\[\]\\!<&*_'"~$]+/m;
var InlineParser = /** @class */ (function () {
function InlineParser(options) {
// An InlineParser keeps track of a subject (a string to be parsed)
// and a position in that subject.
this.subject = '';
this.delimiters = null; // used by handleDelim method
this.brackets = null;
this.pos = 0;
this.lineStartNum = 0;
this.lineIdx = 0;
this.lineOffsets = [0];
this.linePosOffset = 0;
this.refMap = {};
this.refLinkCandidateMap = {};
this.refDefCandidateMap = {};
this.options = options;
}
InlineParser.prototype.sourcepos = function (start, end) {
var linePosOffset = this.linePosOffset + this.lineOffsets[this.lineIdx];
var lineNum = this.lineStartNum + this.lineIdx;
var startpos = [lineNum, start + linePosOffset];
if (typeof end === 'number') {
return [startpos, [lineNum, end + linePosOffset]];
}
return startpos;
};
InlineParser.prototype.nextLine = function () {
this.lineIdx += 1;
this.linePosOffset = -this.pos;
};
// If re matches at current position in the subject, advance
// position in subject and return the match; otherwise return null.
InlineParser.prototype.match = function (re) {
var m = re.exec(this.subject.slice(this.pos));
if (m === null) {
return null;
}
this.pos += m.index + m[0].length;
return m[0];
};
// Returns the code for the character at the current subject position, or -1
// there are no more characters.
InlineParser.prototype.peek = function () {
if (this.pos < this.subject.length) {
return this.subject.charCodeAt(this.pos);
}
return -1;
};
// Parse zero or more space characters, including at most one newline
InlineParser.prototype.spnl = function () {
this.match(reSpnl);
return true;
};
// All of the parsers below try to match something at the current position
// in the subject. If they succeed in matching anything, they
// return the inline matched, advancing the subject.
// Attempt to parse backticks, adding either a backtick code span or a
// literal sequence of backticks.
InlineParser.prototype.parseBackticks = function (block) {
var startpos = this.pos + 1;
var ticks = this.match(reTicksHere);
if (ticks === null) {
return false;
}
var afterOpenTicks = this.pos;
var matched;
while ((matched = this.match(reTicks)) !== null) {
if (matched === ticks) {
var contents = this.subject.slice(afterOpenTicks, this.pos - ticks.length);
var sourcepos = this.sourcepos(startpos, this.pos);
var lines = contents.split('\n');
if (lines.length > 1) {
var lastLine = esm_last(lines);
this.lineIdx += lines.length - 1;
this.linePosOffset = -(this.pos - lastLine.length - ticks.length);
sourcepos[1] = this.sourcepos(this.pos);
contents = lines.join(' ');
}
var node = createNode('code', sourcepos);
if (contents.length > 0 &&
contents.match(/[^ ]/) !== null &&
contents[0] == ' ' &&
contents[contents.length - 1] == ' ') {
node.literal = contents.slice(1, contents.length - 1);
}
else {
node.literal = contents;
}
node.tickCount = ticks.length;
block.appendChild(node);
return true;
}
}
// If we got here, we didn't match a closing backtick sequence.
this.pos = afterOpenTicks;
block.appendChild(esm_text(ticks, this.sourcepos(startpos, this.pos - 1)));
return true;
};
// Parse a backslash-escaped special character, adding either the escaped
// character, a hard line break (if the backslash is followed by a newline),
// or a literal backslash to the block's children. Assumes current character
// is a backslash.
InlineParser.prototype.parseBackslash = function (block) {
var subj = this.subject;
var node;
this.pos += 1;
var startpos = this.pos;
if (this.peek() === C_NEWLINE) {
this.pos += 1;
node = createNode('linebreak', this.sourcepos(this.pos - 1, this.pos));
block.appendChild(node);
this.nextLine();
}
else if (reEscapable.test(subj.charAt(this.pos))) {
block.appendChild(esm_text(subj.charAt(this.pos), this.sourcepos(startpos, this.pos)));
this.pos += 1;
}
else {
block.appendChild(esm_text('\\', this.sourcepos(startpos, startpos)));
}
return true;
};
// Attempt to parse an autolink (URL or email in pointy brackets).
InlineParser.prototype.parseAutolink = function (block) {
var m;
var dest;
var node;
var startpos = this.pos + 1;
if ((m = this.match(reEmailAutolink))) {
dest = m.slice(1, m.length - 1);
node = createNode('link', this.sourcepos(startpos, this.pos));
node.destination = normalizeURI("mailto:" + dest);
node.title = '';
node.appendChild(esm_text(dest, this.sourcepos(startpos + 1, this.pos - 1)));
block.appendChild(node);
return true;
}
if ((m = this.match(reAutolink))) {
dest = m.slice(1, m.length - 1);
node = createNode('link', this.sourcepos(startpos, this.pos));
node.destination = normalizeURI(dest);
node.title = '';
node.appendChild(esm_text(dest, this.sourcepos(startpos + 1, this.pos - 1)));
block.appendChild(node);
return true;
}
return false;
};
// Attempt to parse a raw HTML tag.
InlineParser.prototype.parseHtmlTag = function (block) {
var startpos = this.pos + 1;
var m = this.match(reHtmlTag);
if (m === null) {
return false;
}
var node = createNode('htmlInline', this.sourcepos(startpos, this.pos));
node.literal = m;
block.appendChild(node);
return true;
};
// Scan a sequence of characters with code cc, and return information about
// the number of delimiters and whether they are positioned such that
// they can open and/or close emphasis or strong emphasis. A utility
// function for strong/emph parsing.
InlineParser.prototype.scanDelims = function (cc) {
var numdelims = 0;
var startpos = this.pos;
if (cc === C_SINGLEQUOTE || cc === C_DOUBLEQUOTE) {
numdelims++;
this.pos++;
}
else {
while (this.peek() === cc) {
numdelims++;
this.pos++;
}
}
if (numdelims === 0 || (numdelims < 2 && (cc === C_TILDE || cc === C_DOLLAR))) {
this.pos = startpos;
return null;
}
var charBefore = startpos === 0 ? '\n' : this.subject.charAt(startpos - 1);
var ccAfter = this.peek();
var charAfter;
if (ccAfter === -1) {
charAfter = '\n';
}
else {
charAfter = fromCodePoint$1(ccAfter);
}
var afterIsWhitespace = reUnicodeWhitespaceChar.test(charAfter);
var afterIsPunctuation = rePunctuation.test(charAfter);
var beforeIsWhitespace = reUnicodeWhitespaceChar.test(charBefore);
var beforeIsPunctuation = rePunctuation.test(charBefore);
var leftFlanking = !afterIsWhitespace && (!afterIsPunctuation || beforeIsWhitespace || beforeIsPunctuation);
var rightFlanking = !beforeIsWhitespace && (!beforeIsPunctuation || afterIsWhitespace || afterIsPunctuation);
var canOpen;
var canClose;
if (cc === C_UNDERSCORE) {
canOpen = leftFlanking && (!rightFlanking || beforeIsPunctuation);
canClose = rightFlanking && (!leftFlanking || afterIsPunctuation);
}
else if (cc === C_SINGLEQUOTE || cc === C_DOUBLEQUOTE) {
canOpen = leftFlanking && !rightFlanking;
canClose = rightFlanking;
}
else if (cc === C_DOLLAR) {
canOpen = !afterIsWhitespace;
canClose = !beforeIsWhitespace;
}
else {
canOpen = leftFlanking;
canClose = rightFlanking;
}
this.pos = startpos;
return { numdelims: numdelims, canOpen: canOpen, canClose: canClose };
};
// Handle a delimiter marker for emphasis or a quote.
InlineParser.prototype.handleDelim = function (cc, block) {
var res = this.scanDelims(cc);
if (!res) {
return false;
}
var numdelims = res.numdelims;
var startpos = this.pos + 1;
var contents;
this.pos += numdelims;
if (cc === C_SINGLEQUOTE) {
contents = '\u2019';
}
else if (cc === C_DOUBLEQUOTE) {
contents = '\u201C';
}
else {
contents = this.subject.slice(startpos - 1, this.pos);
}
var node = esm_text(contents, this.sourcepos(startpos, this.pos));
block.appendChild(node);
// Add entry to stack for this opener
if ((res.canOpen || res.canClose) &&
(this.options.smart || (cc !== C_SINGLEQUOTE && cc !== C_DOUBLEQUOTE))) {
this.delimiters = {
cc: cc,
numdelims: numdelims,
origdelims: numdelims,
node: node,
previous: this.delimiters,
next: null,
canOpen: res.canOpen,
canClose: res.canClose,
};
if (this.delimiters.previous) {
this.delimiters.previous.next = this.delimiters;
}
}
return true;
};
InlineParser.prototype.removeDelimiter = function (delim) {
if (delim.previous !== null) {
delim.previous.next = delim.next;
}
if (delim.next === null) {
// top of stack
this.delimiters = delim.previous;
}
else {
delim.next.previous = delim.previous;
}
};
InlineParser.prototype.removeDelimitersBetween = function (bottom, top) {
if (bottom.next !== top) {
bottom.next = top;
top.previous = bottom;
}
};
/**
* Process all delimiters - emphasis, strong emphasis, strikethrough(gfm)
* If the smart punctuation options is true,
* convert single/double quotes to corresponding unicode characters.
**/
InlineParser.prototype.processEmphasis = function (stackBottom) {
var _a;
var opener;
var closer;
var oldCloser;
var openerInl, closerInl;
var openerFound;
var oddMatch = false;
var openersBottom = (_a = {},
_a[C_UNDERSCORE] = [stackBottom, stackBottom, stackBottom],
_a[C_ASTERISK] = [stackBottom, stackBottom, stackBottom],
_a[C_SINGLEQUOTE] = [stackBottom],
_a[C_DOUBLEQUOTE] = [stackBottom],
_a[C_TILDE] = [stackBottom],
_a[C_DOLLAR] = [stackBottom],
_a);
// find first closer above stackBottom:
closer = this.delimiters;
while (closer !== null && closer.previous !== stackBottom) {
closer = closer.previous;
}
// move forward, looking for closers, and handling each
while (closer !== null) {
var closercc = closer.cc;
var closerEmph = closercc === C_UNDERSCORE || closercc === C_ASTERISK;
if (!closer.canClose) {
closer = closer.next;
}
else {
// found emphasis closer. now look back for first matching opener:
opener = closer.previous;
openerFound = false;
while (opener !== null &&
opener !== stackBottom &&
opener !== openersBottom[closercc][closerEmph ? closer.origdelims % 3 : 0]) {
oddMatch =
closerEmph &&
(closer.canOpen || opener.canClose) &&
closer.origdelims % 3 !== 0 &&
(opener.origdelims + closer.origdelims) % 3 === 0;
if (opener.cc === closer.cc && opener.canOpen && !oddMatch) {
openerFound = true;
break;
}
opener = opener.previous;
}
oldCloser = closer;
if (closerEmph || closercc === C_TILDE || closercc === C_DOLLAR) {
if (!openerFound) {
closer = closer.next;
}
else if (opener) {
// (null opener check for type narrowing)
// calculate actual number of delimiters used from closer
var useDelims = closer.numdelims >= 2 && opener.numdelims >= 2 ? 2 : 1;
var emptyDelims = closerEmph ? 0 : 1;
openerInl = opener.node;
closerInl = closer.node;
// build contents for new emph element
var nodeType = closerEmph
? useDelims === 1
? 'emph'
: 'strong'
: 'strike';
if (closercc === C_DOLLAR) {
nodeType = 'customInline';
}
var newNode = createNode(nodeType);
var openerEndPos = openerInl.sourcepos[1];
var closerStartPos = closerInl.sourcepos[0];
newNode.sourcepos = [
[openerEndPos[0], openerEndPos[1] - useDelims + 1],
[closerStartPos[0], closerStartPos[1] + useDelims - 1],
];
openerInl.sourcepos[1][1] -= useDelims;
closerInl.sourcepos[0][1] += useDelims;
openerInl.literal = openerInl.literal.slice(useDelims);
closerInl.literal = closerInl.literal.slice(useDelims);
opener.numdelims -= useDelims;
closer.numdelims -= useDelims;
// remove used delimiters from stack elts and inlines
var tmp = openerInl.next;
var next = void 0;
while (tmp && tmp !== closerInl) {
next = tmp.next;
tmp.unlink();
newNode.appendChild(tmp);
tmp = next;
}
// build custom inline node
if (closercc === C_DOLLAR) {
var textNode = newNode.firstChild;
var literal = textNode.literal || '';
var info = literal.split(/\s/)[0];
newNode.info = info;
if (literal.length <= info.length) {
textNode.unlink();
}
else {
textNode.sourcepos[0][1] += info.length;
textNode.literal = literal.replace(info + " ", '');
}
}
openerInl.insertAfter(newNode);
// remove elts between opener and closer in delimiters stack
this.removeDelimitersBetween(opener, closer);
// if opener has 0 delims, remove it and the inline
// if opener has 1 delims and character is tilde, remove delimiter only
if (opener.numdelims <= emptyDelims) {
if (opener.numdelims === 0) {
openerInl.unlink();
}
this.removeDelimiter(opener);
}
// if closer has 0 delims, remove it and the inline
// if closer has 1 delims and character is tilde, remove delimiter only
if (closer.numdelims <= emptyDelims) {
if (closer.numdelims === 0) {
closerInl.unlink();
}
var tempstack = closer.next;
this.removeDelimiter(closer);
closer = tempstack;
}
}
}
else if (closercc === C_SINGLEQUOTE) {
closer.node.literal = '\u2019';
if (openerFound) {
opener.node.literal = '\u2018';
}
closer = closer.next;
}
else if (closercc === C_DOUBLEQUOTE) {
closer.node.literal = '\u201D';
if (openerFound) {
opener.node.literal = '\u201C';
}
closer = closer.next;
}
if (!openerFound) {
// Set lower bound for future searches for openers:
openersBottom[closercc][closerEmph ? oldCloser.origdelims % 3 : 0] = oldCloser.previous;
if (!oldCloser.canOpen) {
// We can remove a closer that can't be an opener,
// once we've seen there's no matching opener:
this.removeDelimiter(oldCloser);
}
}
}
}
// remove all delimiters
while (this.delimiters !== null && this.delimiters !== stackBottom) {
this.removeDelimiter(this.delimiters);
}
};
// Attempt to parse link title (sans quotes), returning the string
// or null if no match.
InlineParser.prototype.parseLinkTitle = function () {
var title = this.match(reLinkTitle);
if (title === null) {
return null;
}
// chop off quotes from title and unescape:
return unescapeString(title.substr(1, title.length - 2));
};
// Attempt to parse link destination, returning the string or null if no match.
InlineParser.prototype.parseLinkDestination = function () {
var res = this.match(reLinkDestinationBraces);
if (res === null) {
if (this.peek() === C_LESSTHAN$1) {
return null;
}
// @TODO handrolled parser; res should be null or the string
var savepos = this.pos;
var openparens = 0;
var c = void 0;
while ((c = this.peek()) !== -1) {
if (c === C_BACKSLASH && reEscapable.test(this.subject.charAt(this.pos + 1))) {
this.pos += 1;
if (this.peek() !== -1) {
this.pos += 1;
}
}
else if (c === C_OPEN_PAREN) {
this.pos += 1;
openparens += 1;
}
else if (c === C_CLOSE_PAREN) {
if (openparens < 1) {
break;
}
else {
this.pos += 1;
openparens -= 1;
}
}
else if (reWhitespaceChar.exec(fromCodePoint$1(c)) !== null) {
break;
}
else {
this.pos += 1;
}
}
if (this.pos === savepos && c !== C_CLOSE_PAREN) {
return null;
}
if (openparens !== 0) {
return null;
}
res = this.subject.substr(savepos, this.pos - savepos);
return normalizeURI(unescapeString(res));
} // chop off surrounding <..>:
return normalizeURI(unescapeString(res.substr(1, res.length - 2)));
};
// Attempt to parse a link label, returning number of characters parsed.
InlineParser.prototype.parseLinkLabel = function () {
var m = this.match(reLinkLabel);
if (m === null || m.length > 1001) {
return 0;
}
return m.length;
};
// Add open bracket to delimiter stack and add a text node to block's children.
InlineParser.prototype.parseOpenBracket = function (block) {
var startpos = this.pos;
this.pos += 1;
var node = esm_text('[', this.sourcepos(this.pos, this.pos));
block.appendChild(node);
// Add entry to stack for this opener
this.addBracket(node, startpos, false);
return true;
};
// IF next character is [, and ! delimiter to delimiter stack and
// add a text node to block's children. Otherwise just add a text node.
InlineParser.prototype.parseBang = function (block) {
var startpos = this.pos;
this.pos += 1;
if (this.peek() === C_OPEN_BRACKET$1) {
this.pos += 1;
var node = esm_text('![', this.sourcepos(this.pos - 1, this.pos));
block.appendChild(node);
// Add entry to stack for this opener
this.addBracket(node, startpos + 1, true);
}
else {
var node = esm_text('!', this.sourcepos(this.pos, this.pos));
block.appendChild(node);
}
return true;
};
// Try to match close bracket against an opening in the delimiter
// stack. Add either a link or image, or a plain [ character,
// to block's children. If there is a matching delimiter,
// remove it from the delimiter stack.
InlineParser.prototype.parseCloseBracket = function (block) {
var dest = null;
var title = null;
var matched = false;
this.pos += 1;
var startpos = this.pos;
// get last [ or ![
var opener = this.brackets;
if (opener === null) {
// no matched opener, just return a literal
block.appendChild(esm_text(']', this.sourcepos(startpos, startpos)));
return true;
}
if (!opener.active) {
// no matched opener, just return a literal
block.appendChild(esm_text(']', this.sourcepos(startpos, startpos)));
// take opener off brackets stack
this.removeBracket();
return true;
}
// If we got here, open is a potential opener
var isImage = opener.image;
// Check to see if we have a link/image
var savepos = this.pos;
// Inline link?
if (this.peek() === C_OPEN_PAREN) {
this.pos++;
if (this.spnl() &&
(dest = this.parseLinkDestination()) !== null &&
this.spnl() &&
// make sure there's a space before the title:
((reWhitespaceChar.test(this.subject.charAt(this.pos - 1)) &&
(title = this.parseLinkTitle())) ||
true) &&
this.spnl() &&
this.peek() === C_CLOSE_PAREN) {
this.pos += 1;
matched = true;
}
else {
this.pos = savepos;
}
}
var refLabel = '';
if (!matched) {
// Next, see if there's a link label
var beforelabel = this.pos;
var n = this.parseLinkLabel();
if (n > 2) {
refLabel = this.subject.slice(beforelabel, beforelabel + n);
}
else if (!opener.bracketAfter) {
// Empty or missing second label means to use the first label as the reference.
// The reference must not contain a bracket. If we know there's a bracket, we don't even bother checking it.
refLabel = this.subject.slice(opener.index, startpos);
}
if (n === 0) {
// If shortcut reference link, rewind before spaces we skipped.
this.pos = savepos;
}
if (refLabel) {
refLabel = normalizeReference(refLabel);
// lookup rawlabel in refMap
var link = this.refMap[refLabel];
if (link) {
dest = link.destination;
title = link.title;
matched = true;
}
}
}
if (matched) {
var node = createNode(isImage ? 'image' : 'link');
node.destination = dest;
node.title = title || '';
node.sourcepos = [opener.startpos, this.sourcepos(this.pos)];
var tmp = opener.node.next;
var next = void 0;
while (tmp) {
next = tmp.next;
tmp.unlink();
node.appendChild(tmp);
tmp = next;
}
block.appendChild(node);
this.processEmphasis(opener.previousDelimiter);
this.removeBracket();
opener.node.unlink();
// We remove this bracket and processEmphasis will remove later delimiters.
// Now, for a link, we also deactivate earlier link openers.
// (no links in links)
if (!isImage) {
opener = this.brackets;
while (opener !== null) {
if (!opener.image) {
opener.active = false; // deactivate this opener
}
opener = opener.previous;
}
}
if (this.options.referenceDefinition) {
this.refLinkCandidateMap[block.id] = { node: block, refLabel: refLabel };
}
return true;
} // no match
this.removeBracket(); // remove this opener from stack
this.pos = startpos;
block.appendChild(esm_text(']', this.sourcepos(startpos, startpos)));
if (this.options.referenceDefinition) {
this.refLinkCandidateMap[block.id] = { node: block, refLabel: refLabel };
}
return true;
};
InlineParser.prototype.addBracket = function (node, index, image) {
if (this.brackets !== null) {
this.brackets.bracketAfter = true;
}
this.brackets = {
node: node,
startpos: this.sourcepos(index + (image ? 0 : 1)),
previous: this.brackets,
previousDelimiter: this.delimiters,
index: index,
image: image,
active: true,
};
};
InlineParser.prototype.removeBracket = function () {
if (this.brackets) {
this.brackets = this.brackets.previous;
}
};
// Attempt to parse an entity.
InlineParser.prototype.parseEntity = function (block) {
var m;
var startpos = this.pos + 1;
if ((m = this.match(reEntityHere))) {
block.appendChild(esm_text(lib.decodeHTML(m), this.sourcepos(startpos, this.pos)));
return true;
}
return false;
};
// Parse a run of ordinary characters, or a single character with
// a special meaning in markdown, as a plain string.
InlineParser.prototype.parseString = function (block) {
var m;
var startpos = this.pos + 1;
if ((m = this.match(reMain))) {
if (this.options.smart) {
var lit = m.replace(reEllipses, '\u2026').replace(reDash, function (chars) {
var enCount = 0;
var emCount = 0;
if (chars.length % 3 === 0) {
// If divisible by 3, use all em dashes
emCount = chars.length / 3;
}
else if (chars.length % 2 === 0) {
// If divisible by 2, use all en dashes
enCount = chars.length / 2;
}
else if (chars.length % 3 === 2) {
// If 2 extra dashes, use en dash for last 2; em dashes for rest
enCount = 1;
emCount = (chars.length - 2) / 3;
}
else {
// Use en dashes for last 4 hyphens; em dashes for rest
enCount = 2;
emCount = (chars.length - 4) / 3;
}
return esm_repeat('\u2014', emCount) + esm_repeat('\u2013', enCount);
});
block.appendChild(esm_text(lit, this.sourcepos(startpos, this.pos)));
}
else {
var node = esm_text(m, this.sourcepos(startpos, this.pos));
block.appendChild(node);
}
return true;
}
return false;
};
// Parse a newline. If it was preceded by two spaces, return a hard
// line break; otherwise a soft line break.
InlineParser.prototype.parseNewline = function (block) {
this.pos += 1; // assume we're at a \n
// check previous node for trailing spaces
var lastc = block.lastChild;
if (lastc && lastc.type === 'text' && lastc.literal[lastc.literal.length - 1] === ' ') {
var hardbreak = lastc.literal[lastc.literal.length - 2] === ' ';
var litLen = lastc.literal.length;
lastc.literal = lastc.literal.replace(reFinalSpace, '');
var finalSpaceLen = litLen - lastc.literal.length;
lastc.sourcepos[1][1] -= finalSpaceLen;
block.appendChild(createNode(hardbreak ? 'linebreak' : 'softbreak', this.sourcepos(this.pos - finalSpaceLen, this.pos)));
}
else {
block.appendChild(createNode('softbreak', this.sourcepos(this.pos, this.pos)));
}
this.nextLine();
this.match(reInitialSpace); // gobble leading spaces in next line
return true;
};
// Attempt to parse a link reference, modifying refmap.
InlineParser.prototype.parseReference = function (block, refMap) {
if (!this.options.referenceDefinition) {
return 0;
}
this.subject = block.stringContent;
this.pos = 0;
var title = null;
var startpos = this.pos;
// label:
var matchChars = this.parseLinkLabel();
if (matchChars === 0) {
return 0;
}
var rawlabel = this.subject.substr(0, matchChars);
// colon:
if (this.peek() === C_COLON) {
this.pos++;
}
else {
this.pos = startpos;
return 0;
}
// link url
this.spnl();
var dest = this.parseLinkDestination();
if (dest === null) {
this.pos = startpos;
return 0;
}
var beforetitle = this.pos;
this.spnl();
if (this.pos !== beforetitle) {
title = this.parseLinkTitle();
}
if (title === null) {
title = '';
// rewind before spaces
this.pos = beforetitle;
}
// make sure we're at line end:
var atLineEnd = true;
if (this.match(reSpaceAtEndOfLine) === null) {
if (title === '') {
atLineEnd = false;
}
else {
// the potential title we found is not at the line end,
// but it could still be a legal link reference if we
// discard the title
title = '';
// rewind before spaces
this.pos = beforetitle;
// and instead check if the link URL is at the line end
atLineEnd = this.match(reSpaceAtEndOfLine) !== null;
}
}
if (!atLineEnd) {
this.pos = startpos;
return 0;
}
var normalLabel = normalizeReference(rawlabel);
if (normalLabel === '') {
// label must contain non-whitespace characters
this.pos = startpos;
return 0;
}
var sourcepos = this.getReferenceDefSourcepos(block);
block.sourcepos[0][0] = sourcepos[1][0] + 1;
var node = createNode('refDef', sourcepos);
node.title = title;
node.dest = dest;
node.label = normalLabel;
block.insertBefore(node);
if (!refMap[normalLabel]) {
refMap[normalLabel] = createRefDefState(node);
}
else {
this.refDefCandidateMap[node.id] = node;
}
return this.pos - startpos;
};
InlineParser.prototype.mergeTextNodes = function (walker) {
var event;
var textNodes = [];
while ((event = walker.next())) {
var entering = event.entering, node = event.node;
if (entering && node.type === 'text') {
textNodes.push(node);
}
else if (textNodes.length === 1) {
textNodes = [];
}
else if (textNodes.length > 1) {
var firstNode = textNodes[0];
var lastNode = textNodes[textNodes.length - 1];
if (firstNode.sourcepos && lastNode.sourcepos) {
firstNode.sourcepos[1] = lastNode.sourcepos[1];
}
firstNode.next = lastNode.next;
if (firstNode.next) {
firstNode.next.prev = firstNode;
}
for (var i = 1; i < textNodes.length; i += 1) {
firstNode.literal += textNodes[i].literal;
textNodes[i].unlink();
}
textNodes = [];
}
}
};
InlineParser.prototype.getReferenceDefSourcepos = function (block) {
var lines = block.stringContent.split(/\n|\r\n/);
var passedUrlLine = false;
var quotationCount = 0;
var lastLineOffset = { line: 0, ch: 0 };
for (var i = 0; i < lines.length; i += 1) {
var line = lines[i];
if (reWhitespaceChar.test(line)) {
break;
}
if (/\:/.test(line) && quotationCount === 0) {
if (passedUrlLine) {
break;
}
var lineOffset = line.indexOf(':') === line.length - 1 ? i + 1 : i;
lastLineOffset = { line: lineOffset, ch: lines[lineOffset].length };
passedUrlLine = true;
}
// should consider extendable title
var matched = line.match(/'|"/g);
if (matched) {
quotationCount += matched.length;
}
if (quotationCount === 2) {
lastLineOffset = { line: i, ch: line.length };
break;
}
}
return [
[block.sourcepos[0][0], block.sourcepos[0][1]],
[block.sourcepos[0][0] + lastLineOffset.line, lastLineOffset.ch],
];
};
// Parse the next inline element in subject, advancing subject position.
// On success, add the result to block's children and return true.
// On failure, return false.
InlineParser.prototype.parseInline = function (block) {
var _a;
var res = false;
var c = this.peek();
if (c === -1) {
return false;
}
switch (c) {
case C_NEWLINE:
res = this.parseNewline(block);
break;
case C_BACKSLASH:
res = this.parseBackslash(block);
break;
case C_BACKTICK:
res = this.parseBackticks(block);
break;
case C_ASTERISK:
case C_UNDERSCORE:
case C_TILDE:
case C_DOLLAR:
res = this.handleDelim(c, block);
break;
case C_SINGLEQUOTE:
case C_DOUBLEQUOTE:
res = !!((_a = this.options) === null || _a === void 0 ? void 0 : _a.smart) && this.handleDelim(c, block);
break;
case C_OPEN_BRACKET$1:
res = this.parseOpenBracket(block);
break;
case C_BANG:
res = this.parseBang(block);
break;
case C_CLOSE_BRACKET:
res = this.parseCloseBracket(block);
break;
case C_LESSTHAN$1:
res = this.parseAutolink(block) || this.parseHtmlTag(block);
break;
case C_AMPERSAND:
if (!block.disabledEntityParse) {
res = this.parseEntity(block);
}
break;
default:
res = this.parseString(block);
break;
}
if (!res) {
this.pos += 1;
block.appendChild(esm_text(fromCodePoint$1(c), this.sourcepos(this.pos, this.pos + 1)));
}
return true;
};
// Parse string content in block into inline children,
// using refmap to resolve references.
InlineParser.prototype.parse = function (block) {
this.subject = block.stringContent.trim();
this.pos = 0;
this.delimiters = null;
this.brackets = null;
this.lineOffsets = block.lineOffsets || [0];
this.lineIdx = 0;
this.linePosOffset = 0;
this.lineStartNum = block.sourcepos[0][0];
if (isHeading(block)) {
this.lineOffsets[0] += block.level + 1;
}
while (this.parseInline(block)) { }
block.stringContent = null; // allow raw string to be garbage collected
this.processEmphasis(null);
this.mergeTextNodes(block.walker());
var _a = this.options, extendedAutolinks = _a.extendedAutolinks, customParser = _a.customParser;
if (extendedAutolinks) {
convertExtAutoLinks(block.walker(), extendedAutolinks);
}
if (customParser && block.firstChild) {
var event_1;
var walker = block.firstChild.walker();
while ((event_1 = walker.next())) {
var node = event_1.node, entering = event_1.entering;
if (customParser[node.type]) {
customParser[node.type](node, { entering: entering, options: this.options });
}
}
}
};
return InlineParser;
}());
var reTaskListItemMarker = /^\[([ \txX])\][ \t]+/;
// finalize for block handler
function taskListItemFinalize(_, block) {
if (block.firstChild && block.firstChild.type === 'paragraph') {
var p = block.firstChild;
var m = p.stringContent.match(reTaskListItemMarker);
if (m) {
var mLen = m[0].length;
p.stringContent = p.stringContent.substring(mLen - 1);
p.sourcepos[0][1] += mLen;
p.lineOffsets[0] += mLen;
block.listData.task = true;
block.listData.checked = /[xX]/.test(m[1]);
}
}
}
var table = {
continue: function () {
return 0 /* Go */;
},
finalize: function () { },
canContain: function (t) {
return t === 'tableHead' || t === 'tableBody';
},
acceptsLines: false,
};
var tableBody$1 = {
continue: function () {
return 0 /* Go */;
},
finalize: function () { },
canContain: function (t) {
return t === 'tableRow';
},
acceptsLines: false,
};
var tableHead$1 = {
continue: function () {
return 1 /* Stop */;
},
finalize: function () { },
canContain: function (t) {
return t === 'tableRow' || t === 'tableDelimRow';
},
acceptsLines: false,
};
var tableDelimRow = {
continue: function () {
return 1 /* Stop */;
},
finalize: function () { },
canContain: function (t) {
return t === 'tableDelimCell';
},
acceptsLines: false,
};
var tableDelimCell = {
continue: function () {
return 1 /* Stop */;
},
finalize: function () { },
canContain: function () {
return false;
},
acceptsLines: false,
};
var tableRow = {
continue: function () {
return 1 /* Stop */;
},
finalize: function () { },
canContain: function (t) {
return t === 'tableCell';
},
acceptsLines: false,
};
var tableCell = {
continue: function () {
return 1 /* Stop */;
},
finalize: function () { },
canContain: function () {
return false;
},
acceptsLines: false,
};
var CODE_INDENT = 4;
var C_TAB = 9;
var C_GREATERTHAN = 62;
var C_LESSTHAN = 60;
var C_SPACE = 32;
var C_OPEN_BRACKET = 91;
var reNonSpace = /[^ \t\f\v\r\n]/;
var reClosingCodeFence = /^(?:`{3,}|~{3,})(?= *$)/;
// Returns true if block ends with a blank line, descending if needed
// into lists and sublists.
function endsWithBlankLine(block) {
var curBlock = block;
while (curBlock) {
if (curBlock.lastLineBlank) {
return true;
}
var t = curBlock.type;
if (!curBlock.lastLineChecked && (t === 'list' || t === 'item')) {
curBlock.lastLineChecked = true;
curBlock = curBlock.lastChild;
}
else {
curBlock.lastLineChecked = true;
break;
}
}
return false;
}
function peek(ln, pos) {
if (pos < ln.length) {
return ln.charCodeAt(pos);
}
return -1;
}
// Returns true if string contains only space characters.
function isBlank(s) {
return !reNonSpace.test(s);
}
function isSpaceOrTab(c) {
return c === C_SPACE || c === C_TAB;
}
var reClosingCustomBlock = /^\$\$$/;
var customBlock$1 = {
continue: function (parser, container) {
var line = parser.currentLine;
var match = line.match(reClosingCustomBlock);
if (match) {
// closing custom block
parser.lastLineLength = match[0].length;
parser.finalize(container, parser.lineNumber);
return 2 /* Finished */;
}
// skip optional spaces of custom block offset
var i = container.offset;
while (i > 0 && isSpaceOrTab(peek(line, parser.offset))) {
parser.advanceOffset(1, true);
i--;
}
return 0 /* Go */;
},
finalize: function (_, block) {
if (block.stringContent === null) {
return;
}
// first line becomes info string
var content = block.stringContent;
var newlinePos = content.indexOf('\n');
var firstLine = content.slice(0, newlinePos);
var rest = content.slice(newlinePos + 1);
var infoString = firstLine.match(/^(\s*)(.*)/);
block.info = unescapeString(infoString[2].trim());
block.literal = rest;
block.stringContent = null;
},
canContain: function () {
return false;
},
acceptsLines: true,
};
var noop = {
continue: function () {
return 1 /* Stop */;
},
finalize: function () { },
canContain: function () {
return false;
},
acceptsLines: true,
};
var document$1 = {
continue: function () {
return 0 /* Go */;
},
finalize: function () { },
canContain: function (t) {
return t !== 'item';
},
acceptsLines: false,
};
var list = {
continue: function () {
return 0 /* Go */;
},
finalize: function (_, block) {
var item = block.firstChild;
while (item) {
// check for non-final list item ending with blank line:
if (endsWithBlankLine(item) && item.next) {
block.listData.tight = false;
break;
}
// recurse into children of list item, to see if there are
// spaces between any of them:
var subitem = item.firstChild;
while (subitem) {
if (endsWithBlankLine(subitem) && (item.next || subitem.next)) {
block.listData.tight = false;
break;
}
subitem = subitem.next;
}
item = item.next;
}
},
canContain: function (t) {
return t === 'item';
},
acceptsLines: false,
};
var blockQuote$1 = {
continue: function (parser) {
var ln = parser.currentLine;
if (!parser.indented && peek(ln, parser.nextNonspace) === C_GREATERTHAN) {
parser.advanceNextNonspace();
parser.advanceOffset(1, false);
if (isSpaceOrTab(peek(ln, parser.offset))) {
parser.advanceOffset(1, true);
}
}
else {
return 1 /* Stop */;
}
return 0 /* Go */;
},
finalize: function () { },
canContain: function (t) {
return t !== 'item';
},
acceptsLines: false,
};
var esm_item = {
continue: function (parser, container) {
if (parser.blank) {
if (container.firstChild === null) {
// Blank line after empty list item
return 1 /* Stop */;
}
parser.advanceNextNonspace();
}
else if (parser.indent >= container.listData.markerOffset + container.listData.padding) {
parser.advanceOffset(container.listData.markerOffset + container.listData.padding, true);
}
else {
return 1 /* Stop */;
}
return 0 /* Go */;
},
finalize: taskListItemFinalize,
canContain: function (t) {
return t !== 'item';
},
acceptsLines: false,
};
var esm_heading = {
continue: function () {
// a heading can never container > 1 line, so fail to match:
return 1 /* Stop */;
},
finalize: function () { },
canContain: function () {
return false;
},
acceptsLines: false,
};
var thematicBreak$1 = {
continue: function () {
// a thematic break can never container > 1 line, so fail to match:
return 1 /* Stop */;
},
finalize: function () { },
canContain: function () {
return false;
},
acceptsLines: false,
};
var esm_codeBlock = {
continue: function (parser, container) {
var ln = parser.currentLine;
var indent = parser.indent;
if (container.isFenced) {
// fenced
var match = indent <= 3 &&
ln.charAt(parser.nextNonspace) === container.fenceChar &&
ln.slice(parser.nextNonspace).match(reClosingCodeFence);
if (match && match[0].length >= container.fenceLength) {
// closing fence - we're at end of line, so we can return
parser.lastLineLength = parser.offset + indent + match[0].length;
parser.finalize(container, parser.lineNumber);
return 2 /* Finished */;
}
// skip optional spaces of fence offset
var i = container.fenceOffset;
while (i > 0 && isSpaceOrTab(peek(ln, parser.offset))) {
parser.advanceOffset(1, true);
i--;
}
}
else {
// indented
if (indent >= CODE_INDENT) {
parser.advanceOffset(CODE_INDENT, true);
}
else if (parser.blank) {
parser.advanceNextNonspace();
}
else {
return 1 /* Stop */;
}
}
return 0 /* Go */;
},
finalize: function (_, block) {
var _a;
if (block.stringContent === null) {
return;
}
if (block.isFenced) {
// fenced
// first line becomes info string
var content = block.stringContent;
var newlinePos = content.indexOf('\n');
var firstLine = content.slice(0, newlinePos);
var rest = content.slice(newlinePos + 1);
var infoString = firstLine.match(/^(\s*)(.*)/);
block.infoPadding = infoString[1].length;
block.info = unescapeString(infoString[2].trim());
block.literal = rest;
}
else {
// indented
block.literal = (_a = block.stringContent) === null || _a === void 0 ? void 0 : _a.replace(/(\n *)+$/, '\n');
}
block.stringContent = null; // allow GC
},
canContain: function () {
return false;
},
acceptsLines: true,
};
var htmlBlock$1 = {
continue: function (parser, container) {
return parser.blank && (container.htmlBlockType === 6 || container.htmlBlockType === 7)
? 1 /* Stop */
: 0 /* Go */;
},
finalize: function (_, block) {
var _a;
block.literal = ((_a = block.stringContent) === null || _a === void 0 ? void 0 : _a.replace(/(\n *)+$/, '')) || null;
block.stringContent = null; // allow GC
},
canContain: function () {
return false;
},
acceptsLines: true,
};
var paragraph = {
continue: function (parser) {
return parser.blank ? 1 /* Stop */ : 0 /* Go */;
},
finalize: function (parser, block) {
if (block.stringContent === null) {
return;
}
var pos;
var hasReferenceDefs = false;
// try parsing the beginning as link reference definitions:
while (peek(block.stringContent, 0) === C_OPEN_BRACKET &&
(pos = parser.inlineParser.parseReference(block, parser.refMap))) {
block.stringContent = block.stringContent.slice(pos);
hasReferenceDefs = true;
}
if (hasReferenceDefs && isBlank(block.stringContent)) {
block.unlink();
}
},
canContain: function () {
return false;
},
acceptsLines: true,
};
var refDef = noop;
var frontMatter$2 = noop;
var blockHandlers = {
document: document$1,
list: list,
blockQuote: blockQuote$1,
item: esm_item,
heading: esm_heading,
thematicBreak: thematicBreak$1,
codeBlock: esm_codeBlock,
htmlBlock: htmlBlock$1,
paragraph: paragraph,
table: table,
tableBody: tableBody$1,
tableHead: tableHead$1,
tableRow: tableRow,
tableCell: tableCell,
tableDelimRow: tableDelimRow,
tableDelimCell: tableDelimCell,
refDef: refDef,
customBlock: customBlock$1,
frontMatter: frontMatter$2,
};
function parseRowContent(content) {
var startIdx = 0;
var offset = 0;
var cells = [];
for (var i = 0; i < content.length; i += 1) {
if (content[i] === '|' && content[i - 1] !== '\\') {
var cell = content.substring(startIdx, i);
if (startIdx === 0 && isEmpty(cell)) {
offset = i + 1;
}
else {
cells.push(cell);
}
startIdx = i + 1;
}
}
if (startIdx < content.length) {
var cell = content.substring(startIdx, content.length);
if (!isEmpty(cell)) {
cells.push(cell);
}
}
return [offset, cells];
}
function generateTableCells(cellType, contents, lineNum, chPos) {
var cells = [];
for (var _i = 0, contents_1 = contents; _i < contents_1.length; _i++) {
var content = contents_1[_i];
var preSpaces = content.match(/^[ \t]+/);
var paddingLeft = preSpaces ? preSpaces[0].length : 0;
var paddingRight = void 0, trimmed = void 0;
if (paddingLeft === content.length) {
paddingLeft = 0;
paddingRight = 0;
trimmed = '';
}
else {
var postSpaces = content.match(/[ \t]+$/);
paddingRight = postSpaces ? postSpaces[0].length : 0;
trimmed = content.slice(paddingLeft, content.length - paddingRight);
}
var chPosStart = chPos + paddingLeft;
var tableCell = createNode(cellType, [
[lineNum, chPos],
[lineNum, chPos + content.length - 1],
]);
tableCell.stringContent = trimmed.replace(/\\\|/g, '|'); // replace esacped pipe(\|)
tableCell.startIdx = cells.length;
tableCell.endIdx = cells.length;
tableCell.lineOffsets = [chPosStart - 1];
tableCell.paddingLeft = paddingLeft;
tableCell.paddingRight = paddingRight;
cells.push(tableCell);
chPos += content.length + 1;
}
return cells;
}
function getColumnFromDelimCell(cellNode) {
var align = null;
var content = cellNode.stringContent;
var firstCh = content[0];
var lastCh = content[content.length - 1];
if (lastCh === ':') {
align = firstCh === ':' ? 'center' : 'right';
}
else if (firstCh === ':') {
align = 'left';
}
return { align: align };
}
var tableHead = function (parser, container) {
var stringContent = container.stringContent;
if (container.type === 'paragraph' && !parser.indented && !parser.blank) {
var lastNewLineIdx = stringContent.length - 1;
var lastLineStartIdx = stringContent.lastIndexOf('\n', lastNewLineIdx - 1) + 1;
var headerContent = stringContent.slice(lastLineStartIdx, lastNewLineIdx);
var delimContent = parser.currentLine.slice(parser.nextNonspace);
var _a = parseRowContent(headerContent), headerOffset = _a[0], headerCells = _a[1];
var _b = parseRowContent(delimContent), delimOffset = _b[0], delimCells = _b[1];
var reValidDelimCell_1 = /^[ \t]*:?-+:?[ \t]*$/;
if (
// not checking if the number of header cells and delimiter cells are the same
// to consider the case of merged-column (via plugin)
!headerCells.length ||
!delimCells.length ||
delimCells.some(function (cell) { return !reValidDelimCell_1.test(cell); }) ||
// to prevent to regard setTextHeading as tabel delim cell with 'disallowDeepHeading' option
(delimCells.length === 1 && delimContent.indexOf('|') !== 0)) {
return 0 /* None */;
}
var lineOffsets = container.lineOffsets;
var firstLineNum = parser.lineNumber - 1;
var firstLineStart = esm_last(lineOffsets) + 1;
var table = createNode('table', [
[firstLineNum, firstLineStart],
[parser.lineNumber, parser.offset],
]);
// eslint-disable-next-line arrow-body-style
table.columns = delimCells.map(function () { return ({ align: null }); });
container.insertAfter(table);
if (lineOffsets.length === 1) {
container.unlink();
}
else {
container.stringContent = stringContent.slice(0, lastLineStartIdx);
var paraLastLineStartIdx = stringContent.lastIndexOf('\n', lastLineStartIdx - 2) + 1;
var paraLastLineLen = lastLineStartIdx - paraLastLineStartIdx - 1;
parser.lastLineLength = lineOffsets[lineOffsets.length - 2] + paraLastLineLen;
parser.finalize(container, firstLineNum - 1);
}
parser.advanceOffset(parser.currentLine.length - parser.offset, false);
var tableHead_1 = createNode('tableHead', [
[firstLineNum, firstLineStart],
[parser.lineNumber, parser.offset],
]);
table.appendChild(tableHead_1);
var tableHeadRow_1 = createNode('tableRow', [
[firstLineNum, firstLineStart],
[firstLineNum, firstLineStart + headerContent.length - 1],
]);
var tableDelimRow_1 = createNode('tableDelimRow', [
[parser.lineNumber, parser.nextNonspace + 1],
[parser.lineNumber, parser.offset],
]);
tableHead_1.appendChild(tableHeadRow_1);
tableHead_1.appendChild(tableDelimRow_1);
generateTableCells('tableCell', headerCells, firstLineNum, firstLineStart + headerOffset).forEach(function (cellNode) {
tableHeadRow_1.appendChild(cellNode);
});
var delimCellNodes = generateTableCells('tableDelimCell', delimCells, parser.lineNumber, parser.nextNonspace + 1 + delimOffset);
delimCellNodes.forEach(function (cellNode) {
tableDelimRow_1.appendChild(cellNode);
});
table.columns = delimCellNodes.map(getColumnFromDelimCell);
parser.tip = table;
return 2 /* Leaf */;
}
return 0 /* None */;
};
var tableBody = function (parser, container) {
if ((container.type !== 'table' && container.type !== 'tableBody') ||
(!parser.blank && parser.currentLine.indexOf('|') === -1)) {
return 0 /* None */;
}
parser.advanceOffset(parser.currentLine.length - parser.offset, false);
if (parser.blank) {
var table_1 = container;
if (container.type === 'tableBody') {
table_1 = container.parent;
parser.finalize(container, parser.lineNumber - 1);
}
parser.finalize(table_1, parser.lineNumber - 1);
return 0 /* None */;
}
var tableBody = container;
if (container.type === 'table') {
tableBody = parser.addChild('tableBody', parser.nextNonspace);
tableBody.stringContent = null;
}
var tableRow = createNode('tableRow', [
[parser.lineNumber, parser.nextNonspace + 1],
[parser.lineNumber, parser.currentLine.length],
]);
tableBody.appendChild(tableRow);
var table = tableBody.parent;
var content = parser.currentLine.slice(parser.nextNonspace);
var _a = parseRowContent(content), offset = _a[0], cellContents = _a[1];
generateTableCells('tableCell', cellContents, parser.lineNumber, parser.nextNonspace + 1 + offset).forEach(function (cellNode, idx) {
if (idx >= table.columns.length) {
cellNode.ignored = true;
}
tableRow.appendChild(cellNode);
});
return 2 /* Leaf */;
};
var reCustomBlock = /^(\$\$)(\s*[a-zA-Z])+/;
var reCanBeCustomInline = /^(\$\$)(\s*[a-zA-Z])+.*(\$\$)/;
var esm_customBlock = function (parser) {
var match;
if (!parser.indented &&
!reCanBeCustomInline.test(parser.currentLine) &&
(match = parser.currentLine.match(reCustomBlock))) {
var syntaxLength = match[1].length;
parser.closeUnmatchedBlocks();
var container = parser.addChild('customBlock', parser.nextNonspace);
container.syntaxLength = syntaxLength;
container.offset = parser.indent;
parser.advanceNextNonspace();
parser.advanceOffset(syntaxLength, false);
return 2 /* Leaf */;
}
return 0 /* None */;
};
var reCodeFence = /^`{3,}(?!.*`)|^~{3,}/;
var reHtmlBlockOpen = [
/./,
/^<(?:script|pre|style)(?:\s|>|$)/i,
/^/,
/\?>/,
/>/,
/\]\]>/,
];
var reMaybeSpecial = /^[#`~*+_=<>0-9-;$]/;
var reLineEnding$1 = /\r\n|\n|\r/;
function esm_document() {
return createNode('document', [
[1, 1],
[0, 0],
]);
}
var defaultOptions$1 = {
smart: false,
tagFilter: false,
extendedAutolinks: false,
disallowedHtmlBlockTags: [],
referenceDefinition: false,
disallowDeepHeading: false,
customParser: null,
frontMatter: false,
};
var Parser = /** @class */ (function () {
function Parser(options) {
this.options = esm_assign(esm_assign({}, defaultOptions$1), options);
this.doc = esm_document();
this.tip = this.doc;
this.oldtip = this.doc;
this.lineNumber = 0;
this.offset = 0;
this.column = 0;
this.nextNonspace = 0;
this.nextNonspaceColumn = 0;
this.indent = 0;
this.currentLine = '';
this.indented = false;
this.blank = false;
this.partiallyConsumedTab = false;
this.allClosed = true;
this.lastMatchedContainer = this.doc;
this.refMap = {};
this.refLinkCandidateMap = {};
this.refDefCandidateMap = {};
this.lastLineLength = 0;
this.lines = [];
if (this.options.frontMatter) {
blockHandlers.frontMatter = frontMatter;
blockStarts.unshift(frontMatter$1);
}
this.inlineParser = new InlineParser(this.options);
}
Parser.prototype.advanceOffset = function (count, columns) {
if (columns === void 0) {
columns = false;
}
var currentLine = this.currentLine;
var charsToTab, charsToAdvance;
var c;
while (count > 0 && (c = currentLine[this.offset])) {
if (c === '\t') {
charsToTab = 4 - (this.column % 4);
if (columns) {
this.partiallyConsumedTab = charsToTab > count;
charsToAdvance = charsToTab > count ? count : charsToTab;
this.column += charsToAdvance;
this.offset += this.partiallyConsumedTab ? 0 : 1;
count -= charsToAdvance;
}
else {
this.partiallyConsumedTab = false;
this.column += charsToTab;
this.offset += 1;
count -= 1;
}
}
else {
this.partiallyConsumedTab = false;
this.offset += 1;
this.column += 1; // assume ascii; block starts are ascii
count -= 1;
}
}
};
Parser.prototype.advanceNextNonspace = function () {
this.offset = this.nextNonspace;
this.column = this.nextNonspaceColumn;
this.partiallyConsumedTab = false;
};
Parser.prototype.findNextNonspace = function () {
var currentLine = this.currentLine;
var i = this.offset;
var cols = this.column;
var c;
while ((c = currentLine.charAt(i)) !== '') {
if (c === ' ') {
i++;
cols++;
}
else if (c === '\t') {
i++;
cols += 4 - (cols % 4);
}
else {
break;
}
}
this.blank = c === '\n' || c === '\r' || c === '';
this.nextNonspace = i;
this.nextNonspaceColumn = cols;
this.indent = this.nextNonspaceColumn - this.column;
this.indented = this.indent >= CODE_INDENT;
};
// Add a line to the block at the tip. We assume the tip
// can accept lines -- that check should be done before calling this.
Parser.prototype.addLine = function () {
if (this.partiallyConsumedTab) {
this.offset += 1; // skip over tab
// add space characters:
var charsToTab = 4 - (this.column % 4);
this.tip.stringContent += esm_repeat(' ', charsToTab);
}
if (this.tip.lineOffsets) {
this.tip.lineOffsets.push(this.offset);
}
else {
this.tip.lineOffsets = [this.offset];
}
this.tip.stringContent += this.currentLine.slice(this.offset) + "\n";
};
// Add block of type tag as a child of the tip. If the tip can't
// accept children, close and finalize it and try its parent,
// and so on til we find a block that can accept children.
Parser.prototype.addChild = function (tag, offset) {
while (!blockHandlers[this.tip.type].canContain(tag)) {
this.finalize(this.tip, this.lineNumber - 1);
}
var columnNumber = offset + 1; // offset 0 = column 1
var newBlock = createNode(tag, [
[this.lineNumber, columnNumber],
[0, 0],
]);
newBlock.stringContent = '';
this.tip.appendChild(newBlock);
this.tip = newBlock;
return newBlock;
};
// Finalize and close any unmatched blocks.
Parser.prototype.closeUnmatchedBlocks = function () {
if (!this.allClosed) {
// finalize any blocks not matched
while (this.oldtip !== this.lastMatchedContainer) {
var parent_1 = this.oldtip.parent;
this.finalize(this.oldtip, this.lineNumber - 1);
this.oldtip = parent_1;
}
this.allClosed = true;
}
};
// Finalize a block. Close it and do any necessary postprocessing,
// e.g. creating stringContent from strings, setting the 'tight'
// or 'loose' status of a list, and parsing the beginnings
// of paragraphs for reference definitions. Reset the tip to the
// parent of the closed block.
Parser.prototype.finalize = function (block, lineNumber) {
var above = block.parent;
block.open = false;
block.sourcepos[1] = [lineNumber, this.lastLineLength];
blockHandlers[block.type].finalize(this, block);
this.tip = above;
};
// Walk through a block & children recursively, parsing string content
// into inline content where appropriate.
Parser.prototype.processInlines = function (block) {
var event;
var customParser = this.options.customParser;
var walker = block.walker();
this.inlineParser.refMap = this.refMap;
this.inlineParser.refLinkCandidateMap = this.refLinkCandidateMap;
this.inlineParser.refDefCandidateMap = this.refDefCandidateMap;
this.inlineParser.options = this.options;
while ((event = walker.next())) {
var node = event.node, entering = event.entering;
var t = node.type;
if (customParser && customParser[t]) {
customParser[t](node, { entering: entering, options: this.options });
}
if (!entering &&
(t === 'paragraph' ||
t === 'heading' ||
(t === 'tableCell' && !node.ignored))) {
this.inlineParser.parse(node);
}
}
};
// Analyze a line of text and update the document appropriately.
// We parse markdown text by calling this on each line of input,
// then finalizing the document.
Parser.prototype.incorporateLine = function (ln) {
var container = this.doc;
this.oldtip = this.tip;
this.offset = 0;
this.column = 0;
this.blank = false;
this.partiallyConsumedTab = false;
this.lineNumber += 1;
// replace NUL characters for security
if (ln.indexOf('\u0000') !== -1) {
ln = ln.replace(/\0/g, '\uFFFD');
}
this.currentLine = ln;
// For each containing block, try to parse the associated line start.
// Bail out on failure: container will point to the last matching block.
// Set allMatched to false if not all containers match.
var allMatched = true;
var lastChild;
while ((lastChild = container.lastChild) && lastChild.open) {
container = lastChild;
this.findNextNonspace();
switch (blockHandlers[container.type]['continue'](this, container)) {
case 0 /* Go */: // we've matched, keep going
break;
case 1 /* Stop */: // we've failed to match a block
allMatched = false;
break;
case 2 /* Finished */: // we've hit end of line for fenced code close and can return
this.lastLineLength = ln.length;
return;
default:
throw new Error('continue returned illegal value, must be 0, 1, or 2');
}
if (!allMatched) {
container = container.parent; // back up to last matching block
break;
}
}
this.allClosed = container === this.oldtip;
this.lastMatchedContainer = container;
var matchedLeaf = container.type !== 'paragraph' && blockHandlers[container.type].acceptsLines;
var blockStartsLen = blockStarts.length;
// Unless last matched container is a code block, try new container starts,
// adding children to the last matched container:
while (!matchedLeaf) {
this.findNextNonspace();
// this is a little performance optimization:
if (container.type !== 'table' &&
container.type !== 'tableBody' &&
container.type !== 'paragraph' &&
!this.indented &&
!reMaybeSpecial.test(ln.slice(this.nextNonspace))) {
this.advanceNextNonspace();
break;
}
var i = 0;
while (i < blockStartsLen) {
var res = blockStarts[i](this, container);
if (res === 1 /* Container */) {
container = this.tip;
break;
}
else if (res === 2 /* Leaf */) {
container = this.tip;
matchedLeaf = true;
break;
}
else {
i++;
}
}
if (i === blockStartsLen) {
// nothing matched
this.advanceNextNonspace();
break;
}
}
// What remains at the offset is a text line. Add the text to the
// appropriate container.
// First check for a lazy paragraph continuation:
if (!this.allClosed && !this.blank && this.tip.type === 'paragraph') {
// lazy paragraph continuation
this.addLine();
}
else {
// not a lazy continuation
// finalize any blocks not matched
this.closeUnmatchedBlocks();
if (this.blank && container.lastChild) {
container.lastChild.lastLineBlank = true;
}
var t = container.type;
// Block quote lines are never blank as they start with >
// and we don't count blanks in fenced code for purposes of tight/loose
// lists or breaking out of lists. We also don't set _lastLineBlank
// on an empty list item, or if we just closed a fenced block.
var lastLineBlank = this.blank &&
!(t === 'blockQuote' ||
(isCodeBlock(container) && container.isFenced) ||
(t === 'item' && !container.firstChild && container.sourcepos[0][0] === this.lineNumber));
// propagate lastLineBlank up through parents:
var cont = container;
while (cont) {
cont.lastLineBlank = lastLineBlank;
cont = cont.parent;
}
if (blockHandlers[t].acceptsLines) {
this.addLine();
// if HtmlBlock, check for end condition
if (isHtmlBlock(container) &&
container.htmlBlockType >= 1 &&
container.htmlBlockType <= 5 &&
reHtmlBlockClose[container.htmlBlockType].test(this.currentLine.slice(this.offset))) {
this.lastLineLength = ln.length;
this.finalize(container, this.lineNumber);
}
}
else if (this.offset < ln.length && !this.blank) {
// create paragraph container for line
container = this.addChild('paragraph', this.offset);
this.advanceNextNonspace();
this.addLine();
}
}
this.lastLineLength = ln.length;
};
// The main parsing function. Returns a parsed document AST.
Parser.prototype.parse = function (input, lineTexts) {
this.doc = esm_document();
this.tip = this.doc;
this.lineNumber = 0;
this.lastLineLength = 0;
this.offset = 0;
this.column = 0;
this.lastMatchedContainer = this.doc;
this.currentLine = '';
var lines = input.split(reLineEnding$1);
var len = lines.length;
this.lines = lineTexts ? lineTexts : lines;
if (this.options.referenceDefinition) {
this.clearRefMaps();
}
if (input.charCodeAt(input.length - 1) === C_NEWLINE) {
// ignore last blank line created by final newline
len -= 1;
}
for (var i = 0; i < len; i++) {
this.incorporateLine(lines[i]);
}
while (this.tip) {
this.finalize(this.tip, len);
}
this.processInlines(this.doc);
return this.doc;
};
Parser.prototype.partialParseStart = function (lineNumber, lines) {
this.doc = esm_document();
this.tip = this.doc;
this.lineNumber = lineNumber - 1;
this.lastLineLength = 0;
this.offset = 0;
this.column = 0;
this.lastMatchedContainer = this.doc;
this.currentLine = '';
var len = lines.length;
for (var i = 0; i < len; i++) {
this.incorporateLine(lines[i]);
}
return this.doc;
};
Parser.prototype.partialParseExtends = function (lines) {
for (var i = 0; i < lines.length; i++) {
this.incorporateLine(lines[i]);
}
};
Parser.prototype.partialParseFinish = function () {
while (this.tip) {
this.finalize(this.tip, this.lineNumber);
}
this.processInlines(this.doc);
};
Parser.prototype.setRefMaps = function (refMap, refLinkCandidateMap, refDefCandidateMap) {
this.refMap = refMap;
this.refLinkCandidateMap = refLinkCandidateMap;
this.refDefCandidateMap = refDefCandidateMap;
};
Parser.prototype.clearRefMaps = function () {
[this.refMap, this.refLinkCandidateMap, this.refDefCandidateMap].forEach(function (map) {
clearObj(map);
});
};
return Parser;
}());
function comparePos(p1, p2) {
if (p1[0] < p2[0]) {
return 1 /* LT */;
}
if (p1[0] > p2[0]) {
return -1 /* GT */;
}
if (p1[1] < p2[1]) {
return 1 /* LT */;
}
if (p1[1] > p2[1]) {
return -1 /* GT */;
}
return 0 /* EQ */;
}
function compareRangeAndPos(_a, pos) {
var startPos = _a[0], endPos = _a[1];
if (comparePos(endPos, pos) === 1 /* LT */) {
return 1 /* LT */;
}
if (comparePos(startPos, pos) === -1 /* GT */) {
return -1 /* GT */;
}
return 0 /* EQ */;
}
function removeNextUntil(node, last) {
if (node.parent !== last.parent || node === last) {
return;
}
var next = node.next;
while (next && next !== last) {
var temp = next.next;
for (var _i = 0, _a = ['parent', 'prev', 'next']; _i < _a.length; _i++) {
var type = _a[_i];
if (next[type]) {
removeNodeById(next[type].id);
next[type] = null;
}
}
next = temp;
}
node.next = last.next;
if (last.next) {
last.next.prev = node;
}
else {
node.parent.lastChild = node;
}
}
function getChildNodes(parent) {
var nodes = [];
var curr = parent.firstChild;
while (curr) {
nodes.push(curr);
curr = curr.next;
}
return nodes;
}
function insertNodesBefore(target, nodes) {
for (var _i = 0, nodes_1 = nodes; _i < nodes_1.length; _i++) {
var node = nodes_1[_i];
target.insertBefore(node);
}
}
function prependChildNodes(parent, nodes) {
for (var i = nodes.length - 1; i >= 0; i -= 1) {
parent.prependChild(nodes[i]);
}
}
function updateNextLineNumbers(base, diff) {
if (!base || !base.parent || diff === 0) {
return;
}
var walker = base.parent.walker();
walker.resumeAt(base, true);
var event;
while ((event = walker.next())) {
var node = event.node, entering = event.entering;
if (entering) {
node.sourcepos[0][0] += diff;
node.sourcepos[1][0] += diff;
}
}
}
function compareRangeAndLine(_a, line) {
var startPos = _a[0], endPos = _a[1];
if (endPos[0] < line) {
return 1 /* LT */;
}
if (startPos[0] > line) {
return -1 /* GT */;
}
return 0 /* EQ */;
}
function findChildNodeAtLine(parent, line) {
var node = parent.firstChild;
while (node) {
var comp = compareRangeAndLine(node.sourcepos, line);
if (comp === 0 /* EQ */) {
return node;
}
if (comp === -1 /* GT */) {
// To consider that top line is blank line
return node.prev || node;
}
node = node.next;
}
return parent.lastChild;
}
function lastLeafNode(node) {
while (node.lastChild) {
node = node.lastChild;
}
return node;
}
function sameLineTopAncestor(node) {
while (node.parent &&
node.parent.type !== 'document' &&
node.parent.sourcepos[0][0] === node.sourcepos[0][0]) {
node = node.parent;
}
return node;
}
function findFirstNodeAtLine(parent, line) {
var node = parent.firstChild;
var prev = null;
while (node) {
var comp = compareRangeAndLine(node.sourcepos, line);
if (comp === 0 /* EQ */) {
if (node.sourcepos[0][0] === line || !node.firstChild) {
return node;
}
prev = node;
node = node.firstChild;
}
else if (comp === -1 /* GT */) {
break;
}
else {
prev = node;
node = node.next;
}
}
if (prev) {
return sameLineTopAncestor(lastLeafNode(prev));
}
return null;
}
function findNodeAtPosition(parent, pos) {
var node = parent;
var prev = null;
while (node) {
var comp = compareRangeAndPos(node.sourcepos, pos);
if (comp === 0 /* EQ */) {
if (node.firstChild) {
prev = node;
node = node.firstChild;
}
else {
return node;
}
}
else if (comp === -1 /* GT */) {
return prev;
}
else if (node.next) {
node = node.next;
}
else {
return prev;
}
}
return node;
}
function findNodeById(id) {
return getNodeById(id) || null;
}
function invokeNextUntil(callback, start, end) {
if (end === void 0) {
end = null;
}
if (start) {
var walker = start.walker();
while (start && start !== end) {
callback(start);
var next = walker.next();
if (next) {
start = next.node;
}
else {
break;
}
}
}
}
function isUnlinked(id) {
var node = findNodeById(id);
if (!node) {
return true;
}
while (node && node.type !== 'document') {
// eslint-disable-next-line no-loop-func
if (!node.parent && !node.prev && !node.next) {
return true;
}
node = node.parent;
}
return false;
}
var esm_reLineEnding = /\r\n|\n|\r/;
function canBeContinuedListItem(lineText) {
var spaceMatch = lineText.match(/^[ \t]+/);
if (spaceMatch && (spaceMatch[0].length >= 2 || /\t/.test(spaceMatch[0]))) {
return true;
}
var leftTrimmed = spaceMatch ? lineText.slice(spaceMatch.length) : lineText;
return reBulletListMarker.test(leftTrimmed) || reOrderedListMarker.test(leftTrimmed);
}
function canBeContinuedTableBody(lineText) {
return !isBlank(lineText) && lineText.indexOf('|') !== -1;
}
function createRefDefState(node) {
var id = node.id, title = node.title, sourcepos = node.sourcepos, dest = node.dest;
return {
id: id,
title: title,
sourcepos: sourcepos,
unlinked: false,
destination: dest,
};
}
var ToastMark = /** @class */ (function () {
function ToastMark(contents, options) {
this.refMap = {};
this.refLinkCandidateMap = {};
this.refDefCandidateMap = {};
this.referenceDefinition = !!(options === null || options === void 0 ? void 0 : options.referenceDefinition);
this.parser = new Parser(options);
this.parser.setRefMaps(this.refMap, this.refLinkCandidateMap, this.refDefCandidateMap);
this.eventHandlerMap = { change: [] };
contents = contents || '';
this.lineTexts = contents.split(esm_reLineEnding);
this.root = this.parser.parse(contents, this.lineTexts);
}
ToastMark.prototype.updateLineTexts = function (startPos, endPos, newText) {
var _a;
var startLine = startPos[0], startCol = startPos[1];
var endLine = endPos[0], endCol = endPos[1];
var newLines = newText.split(esm_reLineEnding);
var newLineLen = newLines.length;
var startLineText = this.lineTexts[startLine - 1];
var endLineText = this.lineTexts[endLine - 1];
newLines[0] = startLineText.slice(0, startCol - 1) + newLines[0];
newLines[newLineLen - 1] = newLines[newLineLen - 1] + endLineText.slice(endCol - 1);
var removedLineLen = endLine - startLine + 1;
(_a = this.lineTexts).splice.apply(_a, esm_spreadArray([startLine - 1, removedLineLen], newLines));
return newLineLen - removedLineLen;
};
ToastMark.prototype.updateRootNodeState = function () {
if (this.lineTexts.length === 1 && this.lineTexts[0] === '') {
this.root.lastLineBlank = true;
this.root.sourcepos = [
[1, 1],
[1, 0],
];
return;
}
if (this.root.lastChild) {
this.root.lastLineBlank = this.root.lastChild.lastLineBlank;
}
var lineTexts = this.lineTexts;
var idx = lineTexts.length - 1;
while (lineTexts[idx] === '') {
idx -= 1;
}
if (lineTexts.length - 2 > idx) {
idx += 1;
}
this.root.sourcepos[1] = [idx + 1, lineTexts[idx].length];
};
ToastMark.prototype.replaceRangeNodes = function (startNode, endNode, newNodes) {
if (!startNode) {
if (endNode) {
insertNodesBefore(endNode, newNodes);
removeNodeById(endNode.id);
endNode.unlink();
}
else {
prependChildNodes(this.root, newNodes);
}
}
else {
insertNodesBefore(startNode, newNodes);
removeNextUntil(startNode, endNode);
[startNode.id, endNode.id].forEach(function (id) { return removeNodeById(id); });
startNode.unlink();
}
};
ToastMark.prototype.getNodeRange = function (startPos, endPos) {
var startNode = findChildNodeAtLine(this.root, startPos[0]);
var endNode = findChildNodeAtLine(this.root, endPos[0]);
// extend node range to include a following block which doesn't have preceding blank line
if (endNode && endNode.next && endPos[0] + 1 === endNode.next.sourcepos[0][0]) {
endNode = endNode.next;
}
return [startNode, endNode];
};
ToastMark.prototype.trigger = function (eventName, param) {
this.eventHandlerMap[eventName].forEach(function (handler) {
handler(param);
});
};
ToastMark.prototype.extendEndLine = function (line) {
while (this.lineTexts[line] === '') {
line += 1;
}
return line;
};
ToastMark.prototype.parseRange = function (startNode, endNode, startLine, endLine) {
// extends starting range if the first node can be a continued list item
if (startNode &&
startNode.prev &&
((isList(startNode.prev) && canBeContinuedListItem(this.lineTexts[startLine - 1])) ||
(isTable(startNode.prev) && canBeContinuedTableBody(this.lineTexts[startLine - 1])))) {
startNode = startNode.prev;
startLine = startNode.sourcepos[0][0];
}
var editedLines = this.lineTexts.slice(startLine - 1, endLine);
var root = this.parser.partialParseStart(startLine, editedLines);
// extends ending range if the following node can be a fenced code block or a continued list item
var nextNode = endNode ? endNode.next : this.root.firstChild;
var lastChild = root.lastChild;
var isOpenedLastChildCodeBlock = lastChild && isCodeBlock(lastChild) && lastChild.open;
var isOpenedLastChildCustomBlock = lastChild && isCustomBlock(lastChild) && lastChild.open;
var isLastChildList = lastChild && isList(lastChild);
while (((isOpenedLastChildCodeBlock || isOpenedLastChildCustomBlock) && nextNode) ||
(isLastChildList && nextNode && (nextNode.type === 'list' || nextNode.sourcepos[0][1] >= 2))) {
var newEndLine = this.extendEndLine(nextNode.sourcepos[1][0]);
this.parser.partialParseExtends(this.lineTexts.slice(endLine, newEndLine));
if (!startNode) {
startNode = endNode;
}
endNode = nextNode;
endLine = newEndLine;
nextNode = nextNode.next;
}
this.parser.partialParseFinish();
var newNodes = getChildNodes(root);
return { newNodes: newNodes, extStartNode: startNode, extEndNode: endNode };
};
ToastMark.prototype.getRemovedNodeRange = function (extStartNode, extEndNode) {
if (!extStartNode ||
(extStartNode && isRefDef(extStartNode)) ||
(extEndNode && isRefDef(extEndNode))) {
return null;
}
return {
id: [extStartNode.id, extEndNode.id],
line: [extStartNode.sourcepos[0][0] - 1, extEndNode.sourcepos[1][0] - 1],
};
};
ToastMark.prototype.markDeletedRefMap = function (extStartNode, extEndNode) {
var _this = this;
if (!isEmptyObj(this.refMap)) {
var markDeleted = function (node) {
if (isRefDef(node)) {
var refDefState = _this.refMap[node.label];
if (refDefState && node.id === refDefState.id) {
refDefState.unlinked = true;
}
}
};
if (extStartNode) {
invokeNextUntil(markDeleted, extStartNode.parent, extEndNode);
}
if (extEndNode) {
invokeNextUntil(markDeleted, extEndNode);
}
}
};
ToastMark.prototype.replaceWithNewRefDefState = function (nodes) {
var _this = this;
if (!isEmptyObj(this.refMap)) {
var replaceWith_1 = function (node) {
if (isRefDef(node)) {
var label = node.label;
var refDefState = _this.refMap[label];
if (!refDefState || refDefState.unlinked) {
_this.refMap[label] = createRefDefState(node);
}
}
};
nodes.forEach(function (node) {
invokeNextUntil(replaceWith_1, node);
});
}
};
ToastMark.prototype.replaceWithRefDefCandidate = function () {
var _this = this;
if (!isEmptyObj(this.refDefCandidateMap)) {
iterateObject(this.refDefCandidateMap, function (_, candidate) {
var label = candidate.label, sourcepos = candidate.sourcepos;
var refDefState = _this.refMap[label];
if (!refDefState ||
refDefState.unlinked ||
refDefState.sourcepos[0][0] > sourcepos[0][0]) {
_this.refMap[label] = createRefDefState(candidate);
}
});
}
};
ToastMark.prototype.getRangeWithRefDef = function (startLine, endLine, startNode, endNode, lineDiff) {
if (this.referenceDefinition && !isEmptyObj(this.refMap)) {
var prevNode = findChildNodeAtLine(this.root, startLine - 1);
var nextNode = findChildNodeAtLine(this.root, endLine + 1);
if (prevNode && isRefDef(prevNode) && prevNode !== startNode && prevNode !== endNode) {
startNode = prevNode;
startLine = startNode.sourcepos[0][0];
}
if (nextNode && isRefDef(nextNode) && nextNode !== startNode && nextNode !== endNode) {
endNode = nextNode;
endLine = this.extendEndLine(endNode.sourcepos[1][0] + lineDiff);
}
}
return [startNode, endNode, startLine, endLine];
};
ToastMark.prototype.parse = function (startPos, endPos, lineDiff) {
if (lineDiff === void 0) {
lineDiff = 0;
}
var range = this.getNodeRange(startPos, endPos);
var startNode = range[0], endNode = range[1];
var startLine = startNode ? Math.min(startNode.sourcepos[0][0], startPos[0]) : startPos[0];
var endLine = this.extendEndLine((endNode ? Math.max(endNode.sourcepos[1][0], endPos[0]) : endPos[0]) + lineDiff);
var parseResult = this.parseRange.apply(this, this.getRangeWithRefDef(startLine, endLine, startNode, endNode, lineDiff));
var newNodes = parseResult.newNodes, extStartNode = parseResult.extStartNode, extEndNode = parseResult.extEndNode;
var removedNodeRange = this.getRemovedNodeRange(extStartNode, extEndNode);
var nextNode = extEndNode ? extEndNode.next : this.root.firstChild;
if (this.referenceDefinition) {
this.markDeletedRefMap(extStartNode, extEndNode);
this.replaceRangeNodes(extStartNode, extEndNode, newNodes);
this.replaceWithNewRefDefState(newNodes);
}
else {
this.replaceRangeNodes(extStartNode, extEndNode, newNodes);
}
return { nodes: newNodes, removedNodeRange: removedNodeRange, nextNode: nextNode };
};
ToastMark.prototype.parseRefLink = function () {
var _this = this;
var result = [];
if (!isEmptyObj(this.refMap)) {
iterateObject(this.refMap, function (label, value) {
if (value.unlinked) {
delete _this.refMap[label];
}
iterateObject(_this.refLinkCandidateMap, function (_, candidate) {
var node = candidate.node, refLabel = candidate.refLabel;
if (refLabel === label) {
result.push(_this.parse(node.sourcepos[0], node.sourcepos[1]));
}
});
});
}
return result;
};
ToastMark.prototype.removeUnlinkedCandidate = function () {
if (!isEmptyObj(this.refDefCandidateMap)) {
[this.refLinkCandidateMap, this.refDefCandidateMap].forEach(function (candidateMap) {
iterateObject(candidateMap, function (id) {
if (isUnlinked(id)) {
delete candidateMap[id];
}
});
});
}
};
ToastMark.prototype.editMarkdown = function (startPos, endPos, newText) {
var lineDiff = this.updateLineTexts(startPos, endPos, newText);
var parseResult = this.parse(startPos, endPos, lineDiff);
var editResult = omit(parseResult, 'nextNode');
updateNextLineNumbers(parseResult.nextNode, lineDiff);
this.updateRootNodeState();
var result = [editResult];
if (this.referenceDefinition) {
this.removeUnlinkedCandidate();
this.replaceWithRefDefCandidate();
result = result.concat(this.parseRefLink());
}
this.trigger('change', result);
return result;
};
ToastMark.prototype.getLineTexts = function () {
return this.lineTexts;
};
ToastMark.prototype.getRootNode = function () {
return this.root;
};
ToastMark.prototype.findNodeAtPosition = function (pos) {
var node = findNodeAtPosition(this.root, pos);
if (!node || node === this.root) {
return null;
}
return node;
};
ToastMark.prototype.findFirstNodeAtLine = function (line) {
return findFirstNodeAtLine(this.root, line);
};
ToastMark.prototype.on = function (eventName, callback) {
this.eventHandlerMap[eventName].push(callback);
};
ToastMark.prototype.off = function (eventName, callback) {
var handlers = this.eventHandlerMap[eventName];
var idx = handlers.indexOf(callback);
handlers.splice(idx, 1);
};
ToastMark.prototype.findNodeById = function (id) {
return findNodeById(id);
};
ToastMark.prototype.removeAllNode = function () {
removeAllNode();
};
return ToastMark;
}());
var disallowedTags = [
'title',
'textarea',
'style',
'xmp',
'iframe',
'noembed',
'noframes',
'script',
'plaintext',
];
var reDisallowedTag = new RegExp("<(/?(?:" + disallowedTags.join('|') + ")[^>]*>)", 'ig');
function filterDisallowedTags(str) {
if (reDisallowedTag.test(str)) {
return str.replace(reDisallowedTag, function (_, group) { return "<" + group; });
}
return str;
}
var baseConvertors = {
heading: function (node, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: "h" + node.level,
outerNewLine: true,
};
},
text: function (node) {
return {
type: 'text',
content: node.literal,
};
},
softbreak: function (_, _a) {
var options = _a.options;
return {
type: 'html',
content: options.softbreak,
};
},
linebreak: function () {
return {
type: 'html',
content: ' \n',
};
},
emph: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'em',
};
},
strong: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'strong',
};
},
paragraph: function (node, _a) {
var _b;
var entering = _a.entering;
var grandparent = (_b = node.parent) === null || _b === void 0 ? void 0 : _b.parent;
if (grandparent && grandparent.type === 'list') {
if (grandparent.listData.tight) {
return null;
}
}
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'p',
outerNewLine: true,
};
},
thematicBreak: function () {
return {
type: 'openTag',
tagName: 'hr',
outerNewLine: true,
selfClose: true,
};
},
blockQuote: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'blockquote',
outerNewLine: true,
innerNewLine: true,
};
},
list: function (node, _a) {
var entering = _a.entering;
var _b = node.listData, type = _b.type, start = _b.start;
var tagName = type === 'bullet' ? 'ul' : 'ol';
var attributes = {};
if (tagName === 'ol' && start !== null && start !== 1) {
attributes.start = start.toString();
}
return {
type: entering ? 'openTag' : 'closeTag',
tagName: tagName,
attributes: attributes,
outerNewLine: true,
};
},
item: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'li',
outerNewLine: true,
};
},
htmlInline: function (node, _a) {
var options = _a.options;
var content = options.tagFilter ? filterDisallowedTags(node.literal) : node.literal;
return { type: 'html', content: content };
},
htmlBlock: function (node, _a) {
var options = _a.options;
var content = options.tagFilter ? filterDisallowedTags(node.literal) : node.literal;
if (options.nodeId) {
return [
{ type: 'openTag', tagName: 'div', outerNewLine: true },
{ type: 'html', content: content },
{ type: 'closeTag', tagName: 'div', outerNewLine: true },
];
}
return { type: 'html', content: content, outerNewLine: true };
},
code: function (node) {
return [
{ type: 'openTag', tagName: 'code' },
{ type: 'text', content: node.literal },
{ type: 'closeTag', tagName: 'code' },
];
},
codeBlock: function (node) {
var infoStr = node.info;
var infoWords = infoStr ? infoStr.split(/\s+/) : [];
var codeClassNames = [];
if (infoWords.length > 0 && infoWords[0].length > 0) {
codeClassNames.push("language-" + esm_escapeXml(infoWords[0]));
}
return [
{ type: 'openTag', tagName: 'pre', outerNewLine: true },
{ type: 'openTag', tagName: 'code', classNames: codeClassNames },
{ type: 'text', content: node.literal },
{ type: 'closeTag', tagName: 'code' },
{ type: 'closeTag', tagName: 'pre', outerNewLine: true },
];
},
link: function (node, _a) {
var entering = _a.entering;
if (entering) {
var _b = node, title = _b.title, destination = _b.destination;
return {
type: 'openTag',
tagName: 'a',
attributes: esm_assign({ href: esm_escapeXml(destination) }, (title && { title: esm_escapeXml(title) })),
};
}
return { type: 'closeTag', tagName: 'a' };
},
image: function (node, _a) {
var getChildrenText = _a.getChildrenText, skipChildren = _a.skipChildren;
var _b = node, title = _b.title, destination = _b.destination;
skipChildren();
return {
type: 'openTag',
tagName: 'img',
selfClose: true,
attributes: esm_assign({ src: esm_escapeXml(destination), alt: getChildrenText(node) }, (title && { title: esm_escapeXml(title) })),
};
},
customBlock: function (node, context, convertors) {
var info = node.info.trim().toLowerCase();
var customConvertor = convertors[info];
if (customConvertor) {
try {
return customConvertor(node, context);
}
catch (e) {
console.warn("[@toast-ui/editor] - The error occurred when " + info + " block node was parsed in markdown renderer: " + e);
}
}
return [
{ type: 'openTag', tagName: 'div', outerNewLine: true },
{ type: 'text', content: node.literal },
{ type: 'closeTag', tagName: 'div', outerNewLine: true },
];
},
frontMatter: function (node) {
return [
{
type: 'openTag',
tagName: 'div',
outerNewLine: true,
// Because front matter is metadata, it should not be render.
attributes: { style: 'white-space: pre; display: none;' },
},
{ type: 'text', content: node.literal },
{ type: 'closeTag', tagName: 'div', outerNewLine: true },
];
},
customInline: function (node, context, convertors) {
var _a = node, info = _a.info, firstChild = _a.firstChild;
var nomalizedInfo = info.trim().toLowerCase();
var customConvertor = convertors[nomalizedInfo];
var entering = context.entering;
if (customConvertor) {
try {
return customConvertor(node, context);
}
catch (e) {
console.warn("[@toast-ui/editor] - The error occurred when " + nomalizedInfo + " inline node was parsed in markdown renderer: " + e);
}
}
return entering
? [
{ type: 'openTag', tagName: 'span' },
{ type: 'text', content: "$$" + info + (firstChild ? ' ' : '') },
]
: [
{ type: 'text', content: '$$' },
{ type: 'closeTag', tagName: 'span' },
];
},
};
var gfmConvertors = {
strike: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'del',
};
},
item: function (node, _a) {
var entering = _a.entering;
var _b = node.listData, checked = _b.checked, task = _b.task;
if (entering) {
var itemTag = {
type: 'openTag',
tagName: 'li',
outerNewLine: true,
};
if (task) {
return [
itemTag,
{
type: 'openTag',
tagName: 'input',
selfClose: true,
attributes: esm_assign(esm_assign({}, (checked && { checked: '' })), { disabled: '', type: 'checkbox' }),
},
{
type: 'text',
content: ' ',
},
];
}
return itemTag;
}
return {
type: 'closeTag',
tagName: 'li',
outerNewLine: true,
};
},
table: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'table',
outerNewLine: true,
};
},
tableHead: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'thead',
outerNewLine: true,
};
},
tableBody: function (_, _a) {
var entering = _a.entering;
return {
type: entering ? 'openTag' : 'closeTag',
tagName: 'tbody',
outerNewLine: true,
};
},
tableRow: function (node, _a) {
var entering = _a.entering;
if (entering) {
return {
type: 'openTag',
tagName: 'tr',
outerNewLine: true,
};
}
var result = [];
if (node.lastChild) {
var columnLen = node.parent.parent.columns.length;
var lastColIdx = node.lastChild.endIdx;
for (var i = lastColIdx + 1; i < columnLen; i += 1) {
result.push({
type: 'openTag',
tagName: 'td',
outerNewLine: true,
}, {
type: 'closeTag',
tagName: 'td',
outerNewLine: true,
});
}
}
result.push({
type: 'closeTag',
tagName: 'tr',
outerNewLine: true,
});
return result;
},
tableCell: function (node, _a) {
var entering = _a.entering;
if (node.ignored) {
return {
type: 'text',
content: '',
};
}
var tablePart = node.parent.parent;
var tagName = tablePart.type === 'tableHead' ? 'th' : 'td';
var table = tablePart.parent;
var columnInfo = table.columns[node.startIdx];
var attributes = (columnInfo === null || columnInfo === void 0 ? void 0 : columnInfo.align) ? { align: columnInfo.align } : null;
if (entering) {
return esm_assign({ type: 'openTag', tagName: tagName, outerNewLine: true }, (attributes && { attributes: attributes }));
}
return {
type: 'closeTag',
tagName: tagName,
outerNewLine: true,
};
},
};
var defaultOptions = {
softbreak: '\n',
gfm: false,
tagFilter: false,
nodeId: false,
};
function esm_getChildrenText(node) {
var buffer = [];
var walker = node.walker();
var event = null;
while ((event = walker.next())) {
var node_1 = event.node;
if (node_1.type === 'text') {
buffer.push(node_1.literal);
}
}
return buffer.join('');
}
var Renderer = /** @class */ (function () {
function Renderer(customOptions) {
this.buffer = [];
this.options = esm_assign(esm_assign({}, defaultOptions), customOptions);
this.convertors = this.createConvertors();
delete this.options.convertors;
}
Renderer.prototype.createConvertors = function () {
var convertors = esm_assign({}, baseConvertors);
if (this.options.gfm) {
convertors = esm_assign(esm_assign({}, convertors), gfmConvertors);
}
if (this.options.convertors) {
var customConvertors_1 = this.options.convertors;
var nodeTypes = Object.keys(customConvertors_1);
var defaultConvertors_1 = esm_assign(esm_assign({}, baseConvertors), gfmConvertors);
nodeTypes.forEach(function (nodeType) {
var orgConvertor = convertors[nodeType];
var convertor = customConvertors_1[nodeType];
var convertorType = Object.keys(defaultConvertors_1).indexOf(nodeType) === -1
? nodeType.toLowerCase()
: nodeType;
if (orgConvertor) {
convertors[convertorType] = function (node, context, convertors) {
context.origin = function () { return orgConvertor(node, context, convertors); };
return convertor(node, context);
};
}
else {
convertors[convertorType] = convertor;
}
});
}
return convertors;
};
Renderer.prototype.getConvertors = function () {
return this.convertors;
};
Renderer.prototype.getOptions = function () {
return this.options;
};
Renderer.prototype.render = function (rootNode) {
var _this = this;
this.buffer = [];
var walker = rootNode.walker();
var event = null;
var _loop_1 = function () {
var node = event.node, entering = event.entering;
var convertor = this_1.convertors[node.type];
if (!convertor) {
return "continue";
}
var skipped = false;
var context = {
entering: entering,
leaf: !esm_isContainer(node),
options: this_1.options,
getChildrenText: esm_getChildrenText,
skipChildren: function () {
skipped = true;
},
};
var converted = isCustomBlock(node) || isCustomInline(node)
? convertor(node, context, this_1.convertors)
: convertor(node, context);
if (converted) {
var htmlNodes = Array.isArray(converted) ? converted : [converted];
htmlNodes.forEach(function (htmlNode, index) {
if (htmlNode.type === 'openTag' && _this.options.nodeId && index === 0) {
if (!htmlNode.attributes) {
htmlNode.attributes = {};
}
htmlNode.attributes['data-nodeid'] = String(node.id);
}
_this.renderHTMLNode(htmlNode);
});
if (skipped) {
walker.resumeAt(node, false);
walker.next();
}
}
};
var this_1 = this;
while ((event = walker.next())) {
_loop_1();
}
this.addNewLine();
return this.buffer.join('');
};
Renderer.prototype.renderHTMLNode = function (node) {
switch (node.type) {
case 'openTag':
case 'closeTag':
this.renderElementNode(node);
break;
case 'text':
this.renderTextNode(node);
break;
case 'html':
this.renderRawHtmlNode(node);
break;
// no-default-case
}
};
Renderer.prototype.generateOpenTagString = function (node) {
var _this = this;
var tagName = node.tagName, classNames = node.classNames, attributes = node.attributes;
this.buffer.push("<" + tagName);
if (classNames && classNames.length > 0) {
this.buffer.push(" class=\"" + classNames.join(' ') + "\"");
}
if (attributes) {
Object.keys(attributes).forEach(function (attrName) {
var attrValue = attributes[attrName];
_this.buffer.push(" " + attrName + "=\"" + attrValue + "\"");
});
}
if (node.selfClose) {
this.buffer.push(' /');
}
this.buffer.push('>');
};
Renderer.prototype.generateCloseTagString = function (_a) {
var tagName = _a.tagName;
this.buffer.push("" + tagName + ">");
};
Renderer.prototype.addNewLine = function () {
if (this.buffer.length && esm_last(esm_last(this.buffer)) !== '\n') {
this.buffer.push('\n');
}
};
Renderer.prototype.addOuterNewLine = function (node) {
if (node.outerNewLine) {
this.addNewLine();
}
};
Renderer.prototype.addInnerNewLine = function (node) {
if (node.innerNewLine) {
this.addNewLine();
}
};
Renderer.prototype.renderTextNode = function (node) {
this.buffer.push(esm_escapeXml(node.content));
};
Renderer.prototype.renderRawHtmlNode = function (node) {
this.addOuterNewLine(node);
this.buffer.push(node.content);
this.addOuterNewLine(node);
};
Renderer.prototype.renderElementNode = function (node) {
if (node.type === 'openTag') {
this.addOuterNewLine(node);
this.generateOpenTagString(node);
if (node.selfClose) {
this.addOuterNewLine(node);
}
else {
this.addInnerNewLine(node);
}
}
else {
this.addInnerNewLine(node);
this.generateCloseTagString(node);
this.addOuterNewLine(node);
}
};
return Renderer;
}());
// EXTERNAL MODULE: ../../node_modules/dompurify/dist/purify.js
var purify = __webpack_require__(368);
var purify_default = /*#__PURE__*/__webpack_require__.n(purify);
;// CONCATENATED MODULE: ./src/sanitizer/htmlSanitizer.ts
var CAN_BE_WHITE_TAG_LIST = ['iframe', 'embed'];
var whiteTagList = [];
function registerTagWhitelistIfPossible(tagName) {
if (common_includes(CAN_BE_WHITE_TAG_LIST, tagName)) {
whiteTagList.push(tagName.toLowerCase());
}
}
function sanitizeHTML(html, options) {
return purify_default().sanitize(html, __assign({ ADD_TAGS: whiteTagList, ADD_ATTR: ['rel', 'target', 'hreflang', 'type'], FORBID_TAGS: [
'input',
'script',
'textarea',
'form',
'button',
'select',
'meta',
'style',
'link',
'title',
'object',
'base',
] }, options));
}
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/html.ts
function getChildrenHTML(node, typeName) {
return node
.literal.replace(new RegExp("(<\\s*" + typeName + "[^>]*>)|(" + typeName + "\\s*[>])", 'ig'), '')
.trim();
}
function getHTMLAttrsByHTMLString(html) {
html = html.match(reHTMLTag)[0];
var attrs = html.match(new RegExp(ATTRIBUTE, 'g'));
return attrs
? attrs.reduce(function (acc, attr) {
var _a = attr.trim().split('='), name = _a[0], values = _a.slice(1);
if (values.length) {
acc[name] = values.join('=').replace(/'|"/g, '').trim();
}
return acc;
}, {})
: {};
}
function getHTMLAttrs(dom) {
return toArray_default()(dom.attributes).reduce(function (acc, attr) {
acc[attr.nodeName] = attr.nodeValue;
return acc;
}, {});
}
function sanitizeDOM(node, typeName, sanitizer, wwToDOMAdaptor) {
var dom = wwToDOMAdaptor.getToDOMNode(typeName)(node);
var html = sanitizer(dom.outerHTML);
var container = document.createElement('div');
container.innerHTML = html;
dom = container.firstChild;
var htmlAttrs = getHTMLAttrs(dom);
return { dom: dom, htmlAttrs: htmlAttrs };
}
var schemaFactory = {
htmlBlock: function (typeName, sanitizeHTML, wwToDOMAdaptor) {
return {
atom: true,
content: 'block+',
group: 'block',
attrs: {
htmlAttrs: { default: {} },
childrenHTML: { default: '' },
htmlBlock: { default: true },
},
parseDOM: [
{
tag: typeName,
getAttrs: function (dom) {
return {
htmlAttrs: getHTMLAttrs(dom),
childrenHTML: dom.innerHTML,
};
},
},
],
toDOM: function (node) {
var _a = sanitizeDOM(node, typeName, sanitizeHTML, wwToDOMAdaptor), dom = _a.dom, htmlAttrs = _a.htmlAttrs;
htmlAttrs.class = htmlAttrs.class ? htmlAttrs.class + " html-block" : 'html-block';
return __spreadArray([typeName, htmlAttrs], toArray_default()(dom.childNodes));
},
};
},
htmlInline: function (typeName, sanitizeHTML, wwToDOMAdaptor) {
return {
attrs: {
htmlAttrs: { default: {} },
htmlInline: { default: true },
},
parseDOM: [
{
tag: typeName,
getAttrs: function (dom) {
return {
htmlAttrs: getHTMLAttrs(dom),
};
},
},
],
toDOM: function (node) {
var htmlAttrs = sanitizeDOM(node, typeName, sanitizeHTML, wwToDOMAdaptor).htmlAttrs;
return [typeName, htmlAttrs, 0];
},
};
},
};
function createHTMLSchemaMap(convertorMap, sanitizeHTML, wwToDOMAdaptor) {
var htmlSchemaMap = { nodes: {}, marks: {} };
['htmlBlock', 'htmlInline'].forEach(function (htmlType) {
if (convertorMap[htmlType]) {
Object.keys(convertorMap[htmlType]).forEach(function (type) {
var targetType = htmlType === 'htmlBlock' ? 'nodes' : 'marks';
// register tag white list for preventing to remove the html in sanitizer
registerTagWhitelistIfPossible(type);
htmlSchemaMap[targetType][type] = schemaFactory[htmlType](type, sanitizeHTML, wwToDOMAdaptor);
});
}
});
return htmlSchemaMap;
}
;// CONCATENATED MODULE: ./src/markdown/htmlRenderConvertors.ts
var reCloseTag = /^\s*<\s*\//;
var htmlRenderConvertors_baseConvertors = {
paragraph: function (_, _a) {
var entering = _a.entering, origin = _a.origin, options = _a.options;
if (options.nodeId) {
return {
type: entering ? 'openTag' : 'closeTag',
outerNewLine: true,
tagName: 'p',
};
}
return origin();
},
softbreak: function (node) {
var isPrevNodeHTML = node.prev && node.prev.type === 'htmlInline';
var isPrevBR = isPrevNodeHTML && / /.test(node.prev.literal);
var content = isPrevBR ? '\n' : ' \n';
return { type: 'html', content: content };
},
item: function (node, _a) {
var entering = _a.entering;
if (entering) {
var attributes = {};
var classNames = [];
if (node.listData.task) {
attributes['data-task'] = '';
classNames.push('task-list-item');
if (node.listData.checked) {
classNames.push('checked');
attributes['data-task-checked'] = '';
}
}
return {
type: 'openTag',
tagName: 'li',
classNames: classNames,
attributes: attributes,
outerNewLine: true,
};
}
return {
type: 'closeTag',
tagName: 'li',
outerNewLine: true,
};
},
code: function (node) {
var attributes = { 'data-backticks': String(node.tickCount) };
return [
{ type: 'openTag', tagName: 'code', attributes: attributes },
{ type: 'text', content: node.literal },
{ type: 'closeTag', tagName: 'code' },
];
},
codeBlock: function (node) {
var _a = node, fenceLength = _a.fenceLength, info = _a.info;
var infoWords = info ? info.split(/\s+/) : [];
var preClasses = [];
var codeAttrs = {};
if (fenceLength > 3) {
codeAttrs['data-backticks'] = fenceLength;
}
if (infoWords.length > 0 && infoWords[0].length > 0) {
var lang = infoWords[0];
preClasses.push("lang-" + lang);
codeAttrs['data-language'] = lang;
}
return [
{ type: 'openTag', tagName: 'pre', classNames: preClasses },
{ type: 'openTag', tagName: 'code', attributes: codeAttrs },
{ type: 'text', content: node.literal },
{ type: 'closeTag', tagName: 'code' },
{ type: 'closeTag', tagName: 'pre' },
];
},
customInline: function (node, _a) {
var origin = _a.origin, entering = _a.entering, skipChildren = _a.skipChildren;
var info = node.info;
if (info.indexOf('widget') !== -1 && entering) {
skipChildren();
var content = getWidgetContent(node);
var htmlInline = widgetToDOM(info, content).outerHTML;
return [
{ type: 'openTag', tagName: 'span', classNames: ['tui-widget'] },
{ type: 'html', content: htmlInline },
{ type: 'closeTag', tagName: 'span' },
];
}
return origin();
},
};
function getHTMLRenderConvertors(linkAttributes, customConvertors) {
var convertors = __assign({}, htmlRenderConvertors_baseConvertors);
if (linkAttributes) {
convertors.link = function (_, _a) {
var entering = _a.entering, origin = _a.origin;
var result = origin();
if (entering) {
result.attributes = __assign(__assign({}, result.attributes), linkAttributes);
}
return result;
};
}
if (customConvertors) {
Object.keys(customConvertors).forEach(function (nodeType) {
var orgConvertor = convertors[nodeType];
var customConvertor = customConvertors[nodeType];
if (orgConvertor && isFunction_default()(customConvertor)) {
convertors[nodeType] = function (node, context) {
var newContext = __assign({}, context);
newContext.origin = function () { return orgConvertor(node, context); };
return customConvertor(node, newContext);
};
}
else if (common_includes(['htmlBlock', 'htmlInline'], nodeType) && !isFunction_default()(customConvertor)) {
convertors[nodeType] = function (node, context) {
var matched = node.literal.match(reHTMLTag);
if (matched) {
var rootHTML = matched[0], openTagName = matched[1], closeTagName = matched[3];
var typeName = (openTagName || closeTagName).toLowerCase();
var htmlConvertor = customConvertor[typeName];
var childrenHTML = getChildrenHTML(node, typeName);
if (htmlConvertor) {
// copy for preventing to overwrite the originial property
var newNode = __assign({}, node);
newNode.attrs = getHTMLAttrsByHTMLString(rootHTML);
newNode.childrenHTML = childrenHTML;
newNode.type = typeName;
context.entering = !reCloseTag.test(node.literal);
return htmlConvertor(newNode, context);
}
}
return context.origin();
};
}
else {
convertors[nodeType] = customConvertor;
}
});
}
return convertors;
}
;// CONCATENATED MODULE: ./src/markdown/scroll/dom.ts
var nestableTypes = ['list', 'item', 'blockQuote'];
var nestableTagNames = ['UL', 'OL', 'BLOCKQUOTE'];
function isBlankLine(doc, index) {
var _a;
var pmNode = doc.child(index);
return !pmNode.childCount || (pmNode.childCount === 1 && !((_a = pmNode.firstChild.text) === null || _a === void 0 ? void 0 : _a.trim()));
}
function getEditorRangeHeightInfo(doc, mdNode, children) {
var start = getMdStartLine(mdNode) - 1;
var end = getMdEndLine(mdNode) - 1;
var rect = children[start].getBoundingClientRect();
var height = children[end].offsetTop -
children[start].offsetTop +
children[end].clientHeight;
return {
height: height <= 0
? children[start].clientHeight
: height + getBlankLinesHeight(doc, children, Math.min(end + 1, doc.childCount - 1)),
rect: rect,
};
}
function getBlankLinesHeight(doc, children, start) {
var end = doc.childCount - 1;
var height = 0;
while (start <= end && isBlankLine(doc, start)) {
height += children[start].clientHeight;
start += 1;
}
return height;
}
function findAncestorHavingId(el, root) {
while (!el.getAttribute('data-nodeid') && el.parentElement !== root) {
el = el.parentElement;
}
return el;
}
function getTotalOffsetTop(el, root) {
var offsetTop = 0;
while (el && el !== root) {
if (!common_includes(nestableTagNames, el.tagName)) {
offsetTop += el.offsetTop;
}
if (el.offsetParent === root.offsetParent) {
break;
}
el = el.parentElement;
}
return offsetTop;
}
function findAdjacentElementToScrollTop(scrollTop, root) {
var el = root;
var prev = null;
while (el) {
var firstElementChild = el.firstElementChild;
if (!firstElementChild) {
break;
}
var lastSibling = findLastSiblingElementToScrollTop(firstElementChild, scrollTop, getTotalOffsetTop(el, root));
prev = el;
el = lastSibling;
}
var adjacentEl = el || prev;
return adjacentEl === root ? null : adjacentEl;
}
function findLastSiblingElementToScrollTop(el, scrollTop, offsetTop) {
if (el && scrollTop > offsetTop + el.offsetTop) {
return (findLastSiblingElementToScrollTop(el.nextElementSibling, scrollTop, offsetTop) || el);
}
return null;
}
function getAdditionalPos(scrollTop, offsetTop, height, targetNodeHeight) {
var ratio = Math.min((scrollTop - offsetTop) / height, 1);
return ratio * targetNodeHeight;
}
function getParentNodeObj(previewContent, mdNode) {
var el = previewContent.querySelector("[data-nodeid=\"" + mdNode.id + "\"]");
while (!el || isStyledInlineNode(mdNode)) {
mdNode = mdNode.parent;
el = previewContent.querySelector("[data-nodeid=\"" + mdNode.id + "\"]");
}
return getNonNestableNodeObj({ mdNode: mdNode, el: el });
}
function getNonNestableNodeObj(_a) {
var mdNode = _a.mdNode, el = _a.el;
while ((common_includes(nestableTypes, mdNode.type) || mdNode.type === 'table') && mdNode.firstChild) {
mdNode = mdNode.firstChild;
el = el.firstElementChild;
}
return { mdNode: mdNode, el: el };
}
;// CONCATENATED MODULE: ./src/markdown/scroll/offset.ts
var offsetInfoMap = {};
function setHeight(id, height) {
offsetInfoMap[id] = offsetInfoMap[id] || {};
offsetInfoMap[id].height = height;
}
function setOffsetTop(id, offsetTop) {
offsetInfoMap[id] = offsetInfoMap[id] || {};
offsetInfoMap[id].offsetTop = offsetTop;
}
function getHeight(id) {
return offsetInfoMap[id] && offsetInfoMap[id].height;
}
function getOffsetTop(id) {
return offsetInfoMap[id] && offsetInfoMap[id].offsetTop;
}
function removeOffsetInfoByNode(node) {
if (node) {
delete offsetInfoMap[Number(node.getAttribute('data-nodeid'))];
toArray_default()(node.children).forEach(function (child) {
removeOffsetInfoByNode(child);
});
}
}
function getAndSaveOffsetInfo(node, root, mdNodeId) {
var cachedHeight = getHeight(mdNodeId);
var cachedTop = getOffsetTop(mdNodeId);
var nodeHeight = cachedHeight || node.clientHeight;
var offsetTop = cachedTop || getTotalOffsetTop(node, root) || node.offsetTop;
if (!cachedHeight) {
setHeight(mdNodeId, nodeHeight);
}
if (!cachedTop) {
setOffsetTop(mdNodeId, offsetTop);
}
return { nodeHeight: nodeHeight, offsetTop: offsetTop };
}
;// CONCATENATED MODULE: ./src/markdown/mdPreview.ts
var CLASS_HIGHLIGHT = cls('md-preview-highlight');
function findTableCell(tableRow, chOffset) {
var cell = tableRow.firstChild;
while (cell && cell.next) {
if (getMdStartCh(cell.next) > chOffset + 1) {
break;
}
cell = cell.next;
}
return cell;
}
/**
* Class Markdown Preview
* @param {HTMLElement} el - base element
* @param {eventEmitter} eventEmitter - event manager
* @param {object} options
* @param {boolean} options.isViewer - true for view-only mode
* @param {boolean} options.highlight - true for using live-highlight feature
* @param {object} opitons.linkAttributes - attributes for link element
* @param {object} opitons.customHTMLRenderer - map of custom HTML render functions
*
* @ignore
*/
var MarkdownPreview = /** @class */ (function () {
function MarkdownPreview(eventEmitter, options) {
var el = document.createElement('div');
this.el = el;
this.eventEmitter = eventEmitter;
this.isViewer = !!options.isViewer;
this.el.className = cls('md-preview');
var linkAttributes = options.linkAttributes, customHTMLRenderer = options.customHTMLRenderer, sanitizer = options.sanitizer, _a = options.highlight, highlight = _a === void 0 ? false : _a;
this.renderer = new Renderer({
gfm: true,
nodeId: true,
convertors: getHTMLRenderConvertors(linkAttributes, customHTMLRenderer),
});
this.cursorNodeId = null;
this.sanitizer = sanitizer;
this.initEvent(highlight);
this.initContentSection();
// To prevent overflowing contents in the viewer
if (this.isViewer) {
this.previewContent.style.overflowWrap = 'break-word';
}
}
MarkdownPreview.prototype.initContentSection = function () {
this.previewContent = createElementWith("
");
if (!this.isViewer) {
this.el.appendChild(this.previewContent);
}
};
MarkdownPreview.prototype.toggleActive = function (active) {
toggleClass(this.el, 'active', active);
};
MarkdownPreview.prototype.initEvent = function (highlight) {
var _this = this;
this.eventEmitter.listen('updatePreview', this.update.bind(this));
if (this.isViewer) {
return;
}
if (highlight) {
this.eventEmitter.listen('changeToolbarState', function (_a) {
var mdNode = _a.mdNode, cursorPos = _a.cursorPos;
_this.updateCursorNode(mdNode, cursorPos);
});
this.eventEmitter.listen('blur', function () {
_this.removeHighlight();
});
}
on_default()(this.el, 'scroll', function (event) {
_this.eventEmitter.emit('scroll', 'preview', findAdjacentElementToScrollTop(event.target.scrollTop, _this.previewContent));
});
this.eventEmitter.listen('changePreviewTabPreview', function () { return _this.toggleActive(true); });
this.eventEmitter.listen('changePreviewTabWrite', function () { return _this.toggleActive(false); });
};
MarkdownPreview.prototype.removeHighlight = function () {
if (this.cursorNodeId) {
var currentEl = this.getElementByNodeId(this.cursorNodeId);
if (currentEl) {
removeClass_default()(currentEl, CLASS_HIGHLIGHT);
}
}
};
MarkdownPreview.prototype.updateCursorNode = function (cursorNode, cursorPos) {
if (cursorNode) {
cursorNode = findClosestNode(cursorNode, function (mdNode) { return !isInlineNode(mdNode); });
if (cursorNode.type === 'tableRow') {
cursorNode = findTableCell(cursorNode, cursorPos[1]);
}
else if (cursorNode.type === 'tableBody') {
// empty line next to table
cursorNode = null;
}
}
var cursorNodeId = cursorNode ? cursorNode.id : null;
if (this.cursorNodeId === cursorNodeId) {
return;
}
var oldEL = this.getElementByNodeId(this.cursorNodeId);
var newEL = this.getElementByNodeId(cursorNodeId);
if (oldEL) {
removeClass_default()(oldEL, CLASS_HIGHLIGHT);
}
if (newEL) {
addClass_default()(newEL, CLASS_HIGHLIGHT);
}
this.cursorNodeId = cursorNodeId;
};
MarkdownPreview.prototype.getElementByNodeId = function (nodeId) {
return nodeId
? this.previewContent.querySelector("[data-nodeid=\"" + nodeId + "\"]")
: null;
};
MarkdownPreview.prototype.update = function (changed) {
var _this = this;
changed.forEach(function (editResult) { return _this.replaceRangeNodes(editResult); });
this.eventEmitter.emit('afterPreviewRender', this);
};
MarkdownPreview.prototype.replaceRangeNodes = function (editResult) {
var _this = this;
var nodes = editResult.nodes, removedNodeRange = editResult.removedNodeRange;
var contentEl = this.previewContent;
var newHtml = this.eventEmitter.emitReduce('beforePreviewRender', this.sanitizer(nodes.map(function (node) { return _this.renderer.render(node); }).join('')));
if (!removedNodeRange) {
contentEl.insertAdjacentHTML('afterbegin', newHtml);
}
else {
var _a = removedNodeRange.id, startNodeId = _a[0], endNodeId = _a[1];
var startEl = this.getElementByNodeId(startNodeId);
var endEl = this.getElementByNodeId(endNodeId);
if (startEl) {
startEl.insertAdjacentHTML('beforebegin', newHtml);
var el = startEl;
while (el && el !== endEl) {
var nextEl = el.nextElementSibling;
removeNode(el);
removeOffsetInfoByNode(el);
el = nextEl;
}
if (el === null || el === void 0 ? void 0 : el.parentNode) {
removeNode(el);
removeOffsetInfoByNode(el);
}
}
}
};
MarkdownPreview.prototype.getRenderer = function () {
return this.renderer;
};
MarkdownPreview.prototype.destroy = function () {
off_default()(this.el, 'scroll');
this.el = null;
};
MarkdownPreview.prototype.getElement = function () {
return this.el;
};
MarkdownPreview.prototype.getHTML = function () {
return removeProseMirrorHackNodes(this.previewContent.innerHTML);
};
MarkdownPreview.prototype.setHTML = function (html) {
this.previewContent.innerHTML = html;
};
MarkdownPreview.prototype.setHeight = function (height) {
css_default()(this.el, { height: height + "px" });
};
MarkdownPreview.prototype.setMinHeight = function (minHeight) {
css_default()(this.el, { minHeight: minHeight + "px" });
};
return MarkdownPreview;
}());
/* harmony default export */ var mdPreview = (MarkdownPreview);
;// CONCATENATED MODULE: ./src/wysiwyg/helper/node.ts
function findNodeBy(pos, condition) {
var depth = pos.depth;
while (depth) {
var node = pos.node(depth);
if (condition(node, depth)) {
return {
node: node,
depth: depth,
offset: depth > 0 ? pos.before(depth) : 0,
};
}
depth -= 1;
}
return null;
}
function node_isListNode(_a) {
var type = _a.type;
return type.name === 'bulletList' || type.name === 'orderedList';
}
function isInListNode(pos) {
return !!findNodeBy(pos, function (_a) {
var type = _a.type;
return type.name === 'listItem' || type.name === 'bulletList' || type.name === 'orderedList';
});
}
function isInTableNode(pos) {
return !!findNodeBy(pos, function (_a) {
var type = _a.type;
return type.name === 'tableHeadCell' || type.name === 'tableBodyCell';
});
}
function findListItem(pos) {
return findNodeBy(pos, function (_a) {
var type = _a.type;
return type.name === 'listItem';
});
}
function createDOMInfoParsedRawHTML(tag) {
return {
tag: tag,
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
};
}
function createCellAttrs(attrs) {
return Object.keys(attrs).reduce(function (acc, attrName) {
if (attrName !== 'rawHTML' && attrs[attrName]) {
attrName = attrName === 'className' ? 'class' : attrName;
acc[attrName] = attrs[attrName];
}
return acc;
}, {});
}
function createParsedCellDOM(tag) {
return {
tag: tag,
getAttrs: function (dom) {
return ['rawHTML', 'colspan', 'rowspan', 'extended'].reduce(function (acc, attrName) {
var attrNameInDOM = attrName === 'rawHTML' ? 'data-raw-html' : attrName;
var attrValue = dom.getAttribute(attrNameInDOM);
if (attrValue) {
acc[attrName] = common_includes(['rawHTML', 'extended'], attrName)
? attrValue
: Number(attrValue);
}
return acc;
}, {});
},
};
}
function getDefaultCustomAttrs() {
return {
htmlAttrs: { default: null },
classNames: { default: null },
};
}
function getCustomAttrs(attrs) {
var htmlAttrs = attrs.htmlAttrs, classNames = attrs.classNames;
return __assign(__assign({}, htmlAttrs), { class: classNames ? classNames.join(' ') : null });
}
;// CONCATENATED MODULE: ./src/wysiwyg/command/list.ts
function findWrappingOutside(range, type) {
var parent = range.parent, startIndex = range.startIndex, endIndex = range.endIndex;
var around = parent.contentMatchAt(startIndex).findWrapping(type);
if (around) {
var outer = around.length ? around[0] : type;
return parent.canReplaceWith(startIndex, endIndex, outer) ? around : null;
}
return null;
}
function findWrappingInside(range, type) {
var parent = range.parent, startIndex = range.startIndex, endIndex = range.endIndex;
var inner = parent.child(startIndex);
var inside = type.contentMatch.findWrapping(inner.type);
if (inside) {
var lastType = inside.length ? inside[inside.length - 1] : type;
var innerMatch = lastType.contentMatch;
for (var i = startIndex; innerMatch && i < endIndex; i += 1) {
innerMatch = innerMatch.matchType(parent.child(i).type);
}
if (innerMatch && innerMatch.validEnd) {
return inside;
}
}
return null;
}
function findWrappers(range, innerRange, nodeType, attrs) {
var around = findWrappingOutside(range, nodeType);
var inner = findWrappingInside(innerRange, nodeType);
if (around && inner) {
var aroundNodes = around.map(function (type) {
return { type: type };
});
var innerNodes = inner.map(function (type) {
return { type: type, attrs: attrs };
});
return aroundNodes.concat({ type: nodeType }).concat(innerNodes);
}
return null;
}
function wrapInList(tr, _a, wrappers, joinBefore, list) {
var start = _a.start, end = _a.end, startIndex = _a.startIndex, endIndex = _a.endIndex, parent = _a.parent;
var content = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty;
for (var i = wrappers.length - 1; i >= 0; i -= 1) {
content = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(wrappers[i].type.create(wrappers[i].attrs, content));
}
tr.step(new external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.ReplaceAroundStep(start - (joinBefore ? 2 : 0), end, start, end, new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(content, 0, 0), wrappers.length, true));
var foundListIndex = 0;
for (var i = 0; i < wrappers.length; i += 1) {
if (wrappers[i].type === list) {
foundListIndex = i + 1;
break;
}
}
var splitDepth = wrappers.length - foundListIndex;
var splitPos = start + wrappers.length - (joinBefore ? 2 : 0);
for (var i = startIndex, len = endIndex; i < len; i += 1) {
var first = i === startIndex;
if (!first && (0,external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.canSplit)(tr.doc, splitPos, splitDepth)) {
tr.split(splitPos, splitDepth);
splitPos += splitDepth * 2;
}
splitPos += parent.child(i).nodeSize;
}
return tr;
}
function changeToList(tr, range, list, attrs) {
var $from = range.$from, $to = range.$to, depth = range.depth;
var outerRange = range;
var joinBefore = false;
if (depth >= 2 &&
$from.node(depth - 1).type.compatibleContent(list) &&
range.startIndex === 0 &&
$from.index(depth - 1)) {
var start = tr.doc.resolve(range.start - 2);
outerRange = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.NodeRange(start, start, depth);
if (range.endIndex < range.parent.childCount) {
range = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.NodeRange($from, tr.doc.resolve($to.end(depth)), depth);
}
joinBefore = true;
}
var wrappers = findWrappers(outerRange, range, list, attrs);
if (wrappers) {
return wrapInList(tr, range, wrappers, joinBefore, list);
}
return tr;
}
function getBeforeLineListItem(doc, offset) {
var endListItemPos = doc.resolve(offset);
while (endListItemPos.node().type.name !== 'paragraph') {
offset -= 2; // The position value of
endListItemPos = doc.resolve(offset);
}
return findListItem(endListItemPos);
}
function toggleTaskListItems(tr, _a) {
var $from = _a.$from, $to = _a.$to;
var startListItem = findListItem($from);
var endListItem = findListItem($to);
if (startListItem && endListItem) {
while (endListItem) {
var offset = endListItem.offset, node = endListItem.node;
var attrs = { task: !node.attrs.task, checked: false };
tr.setNodeMarkup(offset, null, attrs);
if (offset === startListItem.offset) {
break;
}
endListItem = getBeforeLineListItem(tr.doc, offset);
}
}
return tr;
}
function changeListType(tr, _a, list) {
var $from = _a.$from, $to = _a.$to;
var startListItem = findListItem($from);
var endListItem = findListItem($to);
if (startListItem && endListItem) {
while (endListItem) {
var offset = endListItem.offset, node = endListItem.node, depth = endListItem.depth;
if (node.attrs.task) {
tr.setNodeMarkup(offset, null, { task: false, checked: false });
}
var resolvedPos = tr.doc.resolve(offset);
if (resolvedPos.parent.type !== list) {
var parentOffset = resolvedPos.before(depth - 1);
tr.setNodeMarkup(parentOffset, list);
}
if (offset === startListItem.offset) {
break;
}
endListItem = getBeforeLineListItem(tr.doc, offset);
}
}
return tr;
}
function changeList(list) {
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to);
if (range) {
var newTr = isInListNode($from)
? changeListType(tr, range, list)
: changeToList(tr, range, list);
dispatch(newTr);
return true;
}
return false;
};
}
function toggleTask() {
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr, schema = _a.schema;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to);
if (range) {
var newTr = isInListNode($from)
? toggleTaskListItems(tr, range)
: changeToList(tr, range, schema.nodes.bulletList, { task: true });
dispatch(newTr);
return true;
}
return false;
};
}
function sinkListItem(listItem) {
return function (_a, dispatch) {
var tr = _a.tr, selection = _a.selection;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to, function (_a) {
var childCount = _a.childCount, firstChild = _a.firstChild;
return !!childCount && firstChild.type === listItem;
});
if (range && range.startIndex > 0) {
var parent = range.parent;
var nodeBefore = parent.child(range.startIndex - 1);
if (nodeBefore.type !== listItem) {
return false;
}
var nestedBefore = nodeBefore.lastChild && nodeBefore.lastChild.type === parent.type;
var inner = nestedBefore ? external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(listItem.create()) : null;
var slice = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(listItem.create(null, external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(parent.type.create(null, inner)))), nestedBefore ? 3 : 1, 0);
var before = range.start;
var after = range.end;
tr.step(new external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.ReplaceAroundStep(before - (nestedBefore ? 3 : 1), after, before, after, slice, 1, true));
dispatch(tr);
return true;
}
return false;
};
}
function liftToOuterList(tr, range, listItem) {
var $from = range.$from, $to = range.$to, end = range.end, depth = range.depth, parent = range.parent;
var endOfList = $to.end(depth);
if (end < endOfList) {
// There are siblings after the lifted items, which must become
// children of the last item
tr.step(new external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.ReplaceAroundStep(end - 1, endOfList, end, endOfList, new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(listItem.create(null, parent.copy())), 1, 0), 1, true));
range = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.NodeRange(tr.doc.resolve($from.pos), tr.doc.resolve(endOfList), depth);
}
tr.lift(range, (0,external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.liftTarget)(range));
return tr;
}
function liftOutOfList(tr, range) {
var list = range.parent;
var pos = range.end;
// Merge the list items into a single big item
for (var i = range.endIndex - 1, len = range.startIndex; i > len; i -= 1) {
pos -= list.child(i).nodeSize;
tr.delete(pos - 1, pos + 1);
}
var startPos = tr.doc.resolve(range.start);
var listItem = startPos.nodeAfter;
var atStart = range.startIndex === 0;
var atEnd = range.endIndex === list.childCount;
var parent = startPos.node(-1);
var indexBefore = startPos.index(-1);
var canReplaceParent = parent.canReplace(indexBefore + (atStart ? 0 : 1), indexBefore + 1, listItem === null || listItem === void 0 ? void 0 : listItem.content.append(atEnd ? external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty : external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(list)));
if (listItem && canReplaceParent) {
var start = startPos.pos;
var end = start + listItem.nodeSize;
// Strip off the surrounding list. At the sides where we're not at
// the end of the list, the existing list is closed. At sides where
// this is the end, it is overwritten to its end.
tr.step(new external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.ReplaceAroundStep(start - (atStart ? 1 : 0), end + (atEnd ? 1 : 0), start + 1, end - 1, new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice((atStart ? external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty : external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(list.copy(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty))).append(atEnd ? external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty : external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(list.copy(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty))), atStart ? 0 : 1, atEnd ? 0 : 1), atStart ? 0 : 1));
}
return tr;
}
function liftListItem(listItem) {
return function (_a, dispatch) {
var tr = _a.tr, selection = _a.selection;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to, function (_a) {
var childCount = _a.childCount, firstChild = _a.firstChild;
return !!childCount && firstChild.type === listItem;
});
if (range) {
var topListItem = $from.node(range.depth - 1).type === listItem;
var newTr = topListItem ? liftToOuterList(tr, range, listItem) : liftOutOfList(tr, range);
dispatch(newTr);
return true;
}
return false;
};
}
function splitListItem(listItem) {
return function (_a, dispatch) {
var tr = _a.tr, selection = _a.selection;
var $from = selection.$from, $to = selection.$to;
if ($from.depth < 2 || !$from.sameParent($to)) {
return false;
}
var grandParent = $from.node(-1);
if (grandParent.type !== listItem) {
return false;
}
if ($from.parent.content.size === 0 && $from.node(-1).childCount === $from.indexAfter(-1)) {
// In an empty block. If this is a nested list, the wrapping
// list item should be split. Otherwise, bail out and let next
// command handle lifting.
if ($from.depth === 2 ||
$from.node(-3).type !== listItem ||
$from.index(-2) !== $from.node(-2).childCount - 1) {
return false;
}
var keepItem = $from.index(-1) > 0;
var wrapper = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.empty;
// Build a fragment containing empty versions of the structure
// from the outer list item to the parent node of the cursor
for (var depth = $from.depth - (keepItem ? 1 : 2); depth >= $from.depth - 3; depth -= 1) {
wrapper = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from($from.node(depth).copy(wrapper));
}
// Add a second list item with an empty default start node
wrapper = wrapper.append(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(listItem.createAndFill()));
tr.replace(keepItem ? $from.before() : $from.before(-1), $from.after(-3), new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(wrapper, keepItem ? 3 : 2, 2));
tr.setSelection(external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Selection.near(tr.doc.resolve($from.pos + (keepItem ? 3 : 2))));
dispatch(tr);
return true;
}
var nextType = $to.pos === $from.end() ? grandParent.contentMatchAt(0).defaultType : null;
var types = nextType && [null, { type: nextType }];
tr.delete($from.pos, $to.pos);
if ((0,external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.canSplit)(tr.doc, $from.pos, 2, types)) {
tr.split($from.pos, 2, types);
dispatch(tr);
return true;
}
return false;
};
}
;// CONCATENATED MODULE: ./src/commands/wwCommands.ts
function indent() {
return function () { return function (state, dispatch) {
var selection = state.selection, schema = state.schema;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to);
if (range && isInListNode($from)) {
return sinkListItem(schema.nodes.listItem)(state, dispatch);
}
return false;
}; };
}
function outdent() {
return function () { return function (state, dispatch) {
var selection = state.selection, schema = state.schema;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to);
if (range && isInListNode($from)) {
return liftListItem(schema.nodes.listItem)(state, dispatch);
}
return false;
}; };
}
function getWwCommands() {
return {
indent: indent(),
outdent: outdent(),
};
}
;// CONCATENATED MODULE: ./src/wysiwyg/helper/tableOffsetMap.ts
var cache = new Map();
/* eslint-disable @typescript-eslint/no-unused-vars */
var TableOffsetMap = /** @class */ (function () {
function TableOffsetMap(table, tableRows, tableStartPos, rowInfo) {
this.table = table;
this.tableRows = tableRows;
this.tableStartPos = tableStartPos;
this.rowInfo = rowInfo;
}
TableOffsetMap.create = function (cellPos) {
var table = findNodeBy(cellPos, function (_a) {
var type = _a.type;
return type.name === 'table';
});
if (table) {
var node = table.node, depth = table.depth, offset = table.offset;
var cached = cache.get(node);
if ((cached === null || cached === void 0 ? void 0 : cached.tableStartPos) === offset + 1) {
return cached;
}
var rows_1 = [];
var tablePos = cellPos.start(depth);
var thead = node.child(0);
var tbody = node.child(1);
var theadCellInfo = createOffsetMap(thead, tablePos);
var tbodyCellInfo = createOffsetMap(tbody, tablePos + thead.nodeSize);
thead.forEach(function (row) { return rows_1.push(row); });
tbody.forEach(function (row) { return rows_1.push(row); });
var map = new TableOffsetMap(node, rows_1, tablePos, theadCellInfo.concat(tbodyCellInfo));
cache.set(node, map);
return map;
}
return null;
};
Object.defineProperty(TableOffsetMap.prototype, "totalRowCount", {
get: function () {
return this.rowInfo.length;
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableOffsetMap.prototype, "totalColumnCount", {
get: function () {
return this.rowInfo[0].length;
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableOffsetMap.prototype, "tableStartOffset", {
get: function () {
return this.tableStartPos;
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableOffsetMap.prototype, "tableEndOffset", {
get: function () {
return this.tableStartPos + this.table.nodeSize - 1;
},
enumerable: false,
configurable: true
});
TableOffsetMap.prototype.getCellInfo = function (rowIdx, colIdx) {
return this.rowInfo[rowIdx][colIdx];
};
TableOffsetMap.prototype.posAt = function (rowIdx, colIdx) {
for (var i = 0, rowStart = this.tableStartPos;; i += 1) {
var rowEnd = rowStart + this.tableRows[i].nodeSize;
if (i === rowIdx) {
var index = colIdx;
// Skip the cells from previous row(via rowspan)
while (index < this.totalColumnCount && this.rowInfo[i][index].offset < rowStart) {
index += 1;
}
return index === this.totalColumnCount ? rowEnd : this.rowInfo[i][index].offset;
}
rowStart = rowEnd;
}
};
TableOffsetMap.prototype.getNodeAndPos = function (rowIdx, colIdx) {
var cellInfo = this.rowInfo[rowIdx][colIdx];
return {
node: this.table.nodeAt(cellInfo.offset - this.tableStartOffset),
pos: cellInfo.offset,
};
};
TableOffsetMap.prototype.extendedRowspan = function (rowIdx, colIdx) {
return false;
};
TableOffsetMap.prototype.extendedColspan = function (rowIdx, colIdx) {
return false;
};
TableOffsetMap.prototype.getRowspanCount = function (rowIdx, colIdx) {
return 0;
};
TableOffsetMap.prototype.getColspanCount = function (rowIdx, colIdx) {
return 0;
};
TableOffsetMap.prototype.decreaseColspanCount = function (rowIdx, colIdx) {
return 0;
};
TableOffsetMap.prototype.decreaseRowspanCount = function (rowIdx, colIdx) {
return 0;
};
TableOffsetMap.prototype.getColspanStartInfo = function (rowIdx, colIdx) {
return null;
};
TableOffsetMap.prototype.getRowspanStartInfo = function (rowIdx, colIdx) {
return null;
};
TableOffsetMap.prototype.getCellStartOffset = function (rowIdx, colIdx) {
var offset = this.rowInfo[rowIdx][colIdx].offset;
return this.extendedRowspan(rowIdx, colIdx) ? this.posAt(rowIdx, colIdx) : offset;
};
TableOffsetMap.prototype.getCellEndOffset = function (rowIdx, colIdx) {
var _a = this.rowInfo[rowIdx][colIdx], offset = _a.offset, nodeSize = _a.nodeSize;
return this.extendedRowspan(rowIdx, colIdx) ? this.posAt(rowIdx, colIdx) : offset + nodeSize;
};
TableOffsetMap.prototype.getCellIndex = function (cellPos) {
for (var rowIdx = 0; rowIdx < this.totalRowCount; rowIdx += 1) {
var rowInfo = this.rowInfo[rowIdx];
for (var colIdx = 0; colIdx < this.totalColumnCount; colIdx += 1) {
if (rowInfo[colIdx].offset + 1 > cellPos.pos) {
return [rowIdx, colIdx];
}
}
}
return [0, 0];
};
TableOffsetMap.prototype.getRectOffsets = function (startCellPos, endCellPos) {
var _a, _b, _c;
if (endCellPos === void 0) { endCellPos = startCellPos; }
if (startCellPos.pos > endCellPos.pos) {
_a = [endCellPos, startCellPos], startCellPos = _a[0], endCellPos = _a[1];
}
var _d = this.getCellIndex(startCellPos), startRowIdx = _d[0], startColIdx = _d[1];
var _e = this.getCellIndex(endCellPos), endRowIdx = _e[0], endColIdx = _e[1];
_b = getSortedNumPair(startRowIdx, endRowIdx), startRowIdx = _b[0], endRowIdx = _b[1];
_c = getSortedNumPair(startColIdx, endColIdx), startColIdx = _c[0], endColIdx = _c[1];
return this.getSpannedOffsets({ startRowIdx: startRowIdx, startColIdx: startColIdx, endRowIdx: endRowIdx, endColIdx: endColIdx });
};
TableOffsetMap.prototype.getSpannedOffsets = function (selectionInfo) {
return selectionInfo;
};
return TableOffsetMap;
}());
/* eslint-enable @typescript-eslint/no-unused-vars */
var createOffsetMap = function (headOrBody, startOffset) {
var cellInfoMatrix = [];
headOrBody.forEach(function (row, rowOffset) {
// get row index based on table(not table head or table body)
var rowInfo = { rowspanMap: {}, colspanMap: {}, length: 0 };
row.forEach(function (_a, cellOffset) {
var nodeSize = _a.nodeSize;
var colIdx = 0;
while (rowInfo[colIdx]) {
colIdx += 1;
}
rowInfo[colIdx] = {
// 2 is the sum of the front and back positions of the tag
offset: startOffset + rowOffset + cellOffset + 2,
nodeSize: nodeSize,
};
rowInfo.length += 1;
});
cellInfoMatrix.push(rowInfo);
});
return cellInfoMatrix;
};
function mixinTableOffsetMapPrototype(offsetMapMixin, createOffsetMapMixin) {
common_assign(TableOffsetMap.prototype, offsetMapMixin);
createOffsetMap = createOffsetMapMixin;
return TableOffsetMap;
}
;// CONCATENATED MODULE: ./src/wysiwyg/plugins/selection/cellSelection.ts
function getSelectionRanges(doc, map, _a) {
var startRowIdx = _a.startRowIdx, startColIdx = _a.startColIdx, endRowIdx = _a.endRowIdx, endColIdx = _a.endColIdx;
var ranges = [];
for (var rowIdx = startRowIdx; rowIdx <= endRowIdx; rowIdx += 1) {
for (var colIdx = startColIdx; colIdx <= endColIdx; colIdx += 1) {
var _b = map.getCellInfo(rowIdx, colIdx), offset = _b.offset, nodeSize = _b.nodeSize;
ranges.push(new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.SelectionRange(doc.resolve(offset + 1), doc.resolve(offset + nodeSize - 1)));
}
}
return ranges;
}
function createTableFragment(tableHead, tableBody) {
var fragment = [];
if (tableHead.childCount) {
fragment.push(tableHead);
}
if (tableBody.childCount) {
fragment.push(tableBody);
}
return external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(fragment);
}
var CellSelection = /** @class */ (function (_super) {
__extends(CellSelection, _super);
function CellSelection(startCellPos, endCellPos) {
if (endCellPos === void 0) { endCellPos = startCellPos; }
var _this = this;
var doc = startCellPos.node(0);
var map = TableOffsetMap.create(startCellPos);
var selectionInfo = map.getRectOffsets(startCellPos, endCellPos);
var ranges = getSelectionRanges(doc, map, selectionInfo);
_this = _super.call(this, ranges[0].$from, ranges[0].$to, ranges) || this;
_this.startCell = startCellPos;
_this.endCell = endCellPos;
_this.offsetMap = map;
_this.isCellSelection = true;
// This property is the api of the 'Selection' in prosemirror,
// and is used to disable the text selection.
_this.visible = false;
return _this;
}
CellSelection.prototype.map = function (doc, mapping) {
var startPos = this.startCell.pos;
var endPos = this.endCell.pos;
var startCell = doc.resolve(mapping.map(startPos));
var endCell = doc.resolve(mapping.map(endPos));
var map = TableOffsetMap.create(startCell);
// text selection when rows or columns are deleted
if (this.offsetMap.totalColumnCount > map.totalColumnCount ||
this.offsetMap.totalRowCount > map.totalRowCount) {
var depthMap = { tableBody: 1, tableRow: 2, tableCell: 3, paragraph: 4 };
var depthFromTable = depthMap[endCell.parent.type.name];
var tableEndPos = endCell.end(endCell.depth - depthFromTable);
// subtract 4( tag length)
var from = Math.min(tableEndPos - 4, endCell.pos);
return external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.TextSelection.create(doc, from);
}
return new CellSelection(startCell, endCell);
};
CellSelection.prototype.eq = function (cell) {
return (cell instanceof CellSelection &&
cell.startCell.pos === this.startCell.pos &&
cell.endCell.pos === this.endCell.pos);
};
CellSelection.prototype.content = function () {
var table = this.startCell.node(-2);
var tableOffset = this.startCell.start(-2);
var row = table.child(1).firstChild;
var tableHead = table.child(0).type.create();
var tableBody = table.child(1).type.create();
var map = TableOffsetMap.create(this.startCell);
var selectionInfo = map.getRectOffsets(this.startCell, this.endCell);
var startRowIdx = selectionInfo.startRowIdx, startColIdx = selectionInfo.startColIdx, endRowIdx = selectionInfo.endRowIdx, endColIdx = selectionInfo.endColIdx;
var isTableHeadCell = false;
for (var rowIdx = startRowIdx; rowIdx <= endRowIdx; rowIdx += 1) {
var cells = [];
for (var colIdx = startColIdx; colIdx <= endColIdx; colIdx += 1) {
var offset = map.getCellInfo(rowIdx, colIdx).offset;
var cell = table.nodeAt(offset - tableOffset);
if (cell) {
isTableHeadCell = cell.type.name === 'tableHeadCell';
// mark the extended cell for pasting
if (map.extendedRowspan(rowIdx, colIdx) || map.extendedColspan(rowIdx, colIdx)) {
cells.push(cell.type.create({ extended: true }));
}
else {
cells.push(cell.copy(cell.content));
}
}
}
var copiedRow = row.copy(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(cells));
var targetNode = isTableHeadCell ? tableHead : tableBody;
// @ts-ignore
targetNode.content = targetNode.content.append(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(copiedRow));
}
return new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(createTableFragment(tableHead, tableBody), 1, 1);
};
CellSelection.prototype.toJSON = function () {
return JSON.stringify(this);
};
return CellSelection;
}(external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Selection));
/* harmony default export */ var selection_cellSelection = (CellSelection);
;// CONCATENATED MODULE: ./src/wysiwyg/helper/table.ts
function createTableHeadRow(columnCount, schema, data) {
var _a = schema.nodes, tableRow = _a.tableRow, tableHeadCell = _a.tableHeadCell, paragraph = _a.paragraph;
var cells = [];
for (var index = 0; index < columnCount; index += 1) {
var text = data && data[index];
var para = paragraph.create(null, text ? schema.text(text) : []);
cells.push(tableHeadCell.create(null, para));
}
return [tableRow.create(null, cells)];
}
function createTableBodyRows(rowCount, columnCount, schema, data) {
var _a = schema.nodes, tableRow = _a.tableRow, tableBodyCell = _a.tableBodyCell, paragraph = _a.paragraph;
var tableRows = [];
for (var rowIdx = 0; rowIdx < rowCount; rowIdx += 1) {
var cells = [];
for (var colIdx = 0; colIdx < columnCount; colIdx += 1) {
var text = data && data[rowIdx * columnCount + colIdx];
var para = paragraph.create(null, text ? schema.text(text) : []);
cells.push(tableBodyCell.create(null, para));
}
tableRows.push(tableRow.create(null, cells));
}
return tableRows;
}
function createDummyCells(columnCount, rowIdx, schema, attrs) {
if (attrs === void 0) { attrs = null; }
var _a = schema.nodes, tableHeadCell = _a.tableHeadCell, tableBodyCell = _a.tableBodyCell, paragraph = _a.paragraph;
var cell = rowIdx === 0 ? tableHeadCell : tableBodyCell;
var cells = [];
for (var index = 0; index < columnCount; index += 1) {
cells.push(cell.create(attrs, paragraph.create()));
}
return cells;
}
function findCellElement(node, root) {
while (node && node !== root) {
if (node.nodeName === 'TD' || node.nodeName === 'TH') {
return node;
}
node = node.parentNode;
}
return null;
}
function findCell(pos) {
return findNodeBy(pos, function (_a) {
var type = _a.type;
return type.name === 'tableHeadCell' || type.name === 'tableBodyCell';
});
}
function getResolvedSelection(selection) {
if (selection instanceof external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.TextSelection) {
var $anchor = selection.$anchor;
var foundCell = findCell($anchor);
if (foundCell) {
var anchor = $anchor.node(0).resolve($anchor.before(foundCell.depth));
return { anchor: anchor, head: anchor };
}
}
var _a = selection, startCell = _a.startCell, endCell = _a.endCell;
return { anchor: startCell, head: endCell };
}
function getTableContentFromSlice(slice) {
var _a;
if (slice.size) {
var content = slice.content, openStart = slice.openStart, openEnd = slice.openEnd;
if (content.childCount !== 1) {
return null;
}
while (content.childCount === 1 &&
((openStart > 0 && openEnd > 0) || ((_a = content.firstChild) === null || _a === void 0 ? void 0 : _a.type.name) === 'table')) {
openStart -= 1;
openEnd -= 1;
content = content.firstChild.content;
}
if (content.firstChild.type.name === 'tableHead' ||
content.firstChild.type.name === 'tableBody') {
return content;
}
}
return null;
}
function getRowAndColumnCount(_a) {
var startRowIdx = _a.startRowIdx, startColIdx = _a.startColIdx, endRowIdx = _a.endRowIdx, endColIdx = _a.endColIdx;
var rowCount = endRowIdx - startRowIdx + 1;
var columnCount = endColIdx - startColIdx + 1;
return { rowCount: rowCount, columnCount: columnCount };
}
function setAttrs(cell, attrs) {
return __assign(__assign({}, cell.attrs), attrs);
}
;// CONCATENATED MODULE: ./src/wysiwyg/plugins/selection/tableSelectionView.ts
var tableSelectionView_pluginKey = new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.PluginKey('cellSelection');
var MOUSE_RIGHT_BUTTON = 2;
var TableSelection = /** @class */ (function () {
function TableSelection(view) {
this.view = view;
this.handlers = {
mousedown: this.handleMousedown.bind(this),
mousemove: this.handleMousemove.bind(this),
mouseup: this.handleMouseup.bind(this),
};
this.startCellPos = null;
this.init();
}
TableSelection.prototype.init = function () {
this.view.dom.addEventListener('mousedown', this.handlers.mousedown);
};
TableSelection.prototype.handleMousedown = function (ev) {
var foundCell = findCellElement(ev.target, this.view.dom);
if (ev.button === MOUSE_RIGHT_BUTTON) {
ev.preventDefault();
return;
}
if (foundCell) {
var startCellPos = this.getCellPos(ev);
if (startCellPos) {
this.startCellPos = startCellPos;
}
this.bindEvent();
}
};
TableSelection.prototype.handleMousemove = function (ev) {
var prevEndCellOffset = tableSelectionView_pluginKey.getState(this.view.state);
var endCellPos = this.getCellPos(ev);
var startCellPos = this.startCellPos;
var prevEndCellPos;
if (prevEndCellOffset) {
prevEndCellPos = this.view.state.doc.resolve(prevEndCellOffset);
}
else if (startCellPos !== endCellPos) {
prevEndCellPos = startCellPos;
}
if (prevEndCellPos && startCellPos && endCellPos) {
this.setCellSelection(startCellPos, endCellPos);
}
};
TableSelection.prototype.handleMouseup = function () {
this.startCellPos = null;
this.unbindEvent();
if (tableSelectionView_pluginKey.getState(this.view.state) !== null) {
this.view.dispatch(this.view.state.tr.setMeta(tableSelectionView_pluginKey, -1));
}
};
TableSelection.prototype.bindEvent = function () {
var dom = this.view.dom;
dom.addEventListener('mousemove', this.handlers.mousemove);
dom.addEventListener('mouseup', this.handlers.mouseup);
};
TableSelection.prototype.unbindEvent = function () {
var dom = this.view.dom;
dom.removeEventListener('mousemove', this.handlers.mousemove);
dom.removeEventListener('mouseup', this.handlers.mouseup);
};
TableSelection.prototype.getCellPos = function (_a) {
var clientX = _a.clientX, clientY = _a.clientY;
var mousePos = this.view.posAtCoords({ left: clientX, top: clientY });
if (mousePos) {
var doc = this.view.state.doc;
var currentPos = doc.resolve(mousePos.pos);
var foundCell = findCell(currentPos);
if (foundCell) {
var cellOffset = currentPos.before(foundCell.depth);
return doc.resolve(cellOffset);
}
}
return null;
};
TableSelection.prototype.setCellSelection = function (startCellPos, endCellPos) {
var _a = this.view.state, selection = _a.selection, tr = _a.tr;
var starting = tableSelectionView_pluginKey.getState(this.view.state) === null;
var cellSelection = new selection_cellSelection(startCellPos, endCellPos);
if (starting || !selection.eq(cellSelection)) {
var newTr = tr.setSelection(cellSelection);
if (starting) {
newTr.setMeta(tableSelectionView_pluginKey, endCellPos.pos);
}
this.view.dispatch(newTr);
}
};
TableSelection.prototype.destroy = function () {
this.view.dom.removeEventListener('mousedown', this.handlers.mousedown);
};
return TableSelection;
}());
/* harmony default export */ var tableSelectionView = (TableSelection);
;// CONCATENATED MODULE: ./src/wysiwyg/plugins/selection/tableSelection.ts
var SELECTED_CELL_CLASS_NAME = cls('cell-selected');
function drawCellSelection(_a) {
var selection = _a.selection, doc = _a.doc;
if (selection instanceof selection_cellSelection) {
var cells_1 = [];
var ranges = selection.ranges;
ranges.forEach(function (_a) {
var $from = _a.$from, $to = _a.$to;
cells_1.push(external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.Decoration.node($from.pos - 1, $to.pos + 1, { class: SELECTED_CELL_CLASS_NAME }));
});
return external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.DecorationSet.create(doc, cells_1);
}
return null;
}
function tableSelection() {
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
key: tableSelectionView_pluginKey,
state: {
init: function () {
return null;
},
apply: function (tr, value) {
var cellOffset = tr.getMeta(tableSelectionView_pluginKey);
if (cellOffset) {
return cellOffset === -1 ? null : cellOffset;
}
if (isNull_default()(value) || !tr.docChanged) {
return value;
}
var _a = tr.mapping.mapResult(value), deleted = _a.deleted, pos = _a.pos;
return deleted ? null : pos;
},
},
props: {
decorations: drawCellSelection,
createSelectionBetween: function (_a) {
var state = _a.state;
if (!isNull_default()(tableSelectionView_pluginKey.getState(state))) {
return state.selection;
}
return null;
},
},
view: function (editorView) {
return new tableSelectionView(editorView);
},
});
}
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/array/inArray.js
var inArray = __webpack_require__(928);
var inArray_default = /*#__PURE__*/__webpack_require__.n(inArray);
;// CONCATENATED MODULE: ./src/utils/map.ts
/**
* @class
* @ignore
* @classdesc ES6 Map
*/
var map_Map = /** @class */ (function () {
function Map() {
this.keys = [];
this.values = [];
}
Map.prototype.getKeyIndex = function (key) {
return inArray_default()(key, this.keys);
};
Map.prototype.get = function (key) {
return this.values[this.getKeyIndex(key)];
};
Map.prototype.set = function (key, value) {
var keyIndex = this.getKeyIndex(key);
if (keyIndex > -1) {
this.values[keyIndex] = value;
}
else {
this.keys.push(key);
this.values.push(value);
}
return this;
};
Map.prototype.has = function (key) {
return this.getKeyIndex(key) > -1;
};
Map.prototype.delete = function (key) {
var keyIndex = this.getKeyIndex(key);
if (keyIndex > -1) {
this.keys.splice(keyIndex, 1);
this.values.splice(keyIndex, 1);
return true;
}
return false;
};
Map.prototype.forEach = function (callback, thisArg) {
var _this = this;
if (thisArg === void 0) { thisArg = this; }
this.values.forEach(function (value, index) {
if (value && _this.keys[index]) {
callback.call(thisArg, value, _this.keys[index], _this);
}
});
};
Map.prototype.clear = function () {
this.keys = [];
this.values = [];
};
return Map;
}());
/* harmony default export */ var utils_map = (map_Map);
;// CONCATENATED MODULE: ./src/i18n/i18n.ts
/**
* @fileoverview Implements i18n
* @author NHN Cloud FE Development Lab
*/
var DEFAULT_CODE = 'en-US';
/**
* Class I18n
* @ignore
*/
var I18n = /** @class */ (function () {
function I18n() {
this.code = DEFAULT_CODE;
this.langs = new utils_map();
}
I18n.prototype.setCode = function (code) {
this.code = code || DEFAULT_CODE;
};
/**
* Set language set
* @param {string|string[]} codes locale code
* @param {object} data language set
*/
I18n.prototype.setLanguage = function (codes, data) {
var _this = this;
codes = [].concat(codes);
codes.forEach(function (code) {
if (!_this.langs.has(code)) {
_this.langs.set(code, data);
}
else {
var langData = _this.langs.get(code);
_this.langs.set(code, extend_default()(langData, data));
}
});
};
I18n.prototype.get = function (key, code) {
if (!code) {
code = this.code;
}
var langSet = this.langs.get(code);
if (!langSet) {
langSet = this.langs.get(DEFAULT_CODE);
}
var text = langSet[key];
if (!text) {
throw new Error("There is no text key \"" + key + "\" in " + code);
}
return text;
};
return I18n;
}());
/* harmony default export */ var i18n = (new I18n());
;// CONCATENATED MODULE: ./src/wysiwyg/plugins/tableContextMenu.ts
var contextMenuGroups = [
[
{
action: 'Add row to up',
command: 'addRowToUp',
disableInThead: true,
className: 'add-row-up',
},
{
action: 'Add row to down',
command: 'addRowToDown',
disableInThead: true,
className: 'add-row-down',
},
{ action: 'Remove row', command: 'removeRow', disableInThead: true, className: 'remove-row' },
],
[
{ action: 'Add column to left', command: 'addColumnToLeft', className: 'add-column-left' },
{ action: 'Add column to right', command: 'addColumnToRight', className: 'add-column-right' },
{ action: 'Remove column', command: 'removeColumn', className: 'remove-column' },
],
[
{
action: 'Align column to left',
command: 'alignColumn',
payload: { align: 'left' },
className: 'align-column-left',
},
{
action: 'Align column to center',
command: 'alignColumn',
payload: { align: 'center' },
className: 'align-column-center',
},
{
action: 'Align column to right',
command: 'alignColumn',
payload: { align: 'right' },
className: 'align-column-right',
},
],
[{ action: 'Remove table', command: 'removeTable', className: 'remove-table' }],
];
function getContextMenuGroups(eventEmitter, inTableHead) {
return contextMenuGroups
.map(function (contextMenuGroup) {
return contextMenuGroup.map(function (_a) {
var action = _a.action, command = _a.command, payload = _a.payload, disableInThead = _a.disableInThead, className = _a.className;
return {
label: i18n.get(action),
onClick: function () {
eventEmitter.emit('command', command, payload);
},
disabled: inTableHead && !!disableInThead,
className: className,
};
});
})
.concat();
}
function tableContextMenu(eventEmitter) {
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
props: {
handleDOMEvents: {
contextmenu: function (view, ev) {
var tableCell = findCellElement(ev.target, view.dom);
if (tableCell) {
ev.preventDefault();
var _a = ev, clientX = _a.clientX, clientY = _a.clientY;
var _b = view.dom.parentNode.getBoundingClientRect(), left = _b.left, top = _b.top;
var inTableHead = tableCell.nodeName === 'TH';
eventEmitter.emit('contextmenu', {
pos: { left: clientX - left + 10 + "px", top: clientY - top + 30 + "px" },
menuGroups: getContextMenuGroups(eventEmitter, inTableHead),
tableCell: tableCell,
});
return true;
}
return false;
},
},
},
});
}
;// CONCATENATED MODULE: ./src/wysiwyg/plugins/task.ts
function task() {
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
props: {
handleDOMEvents: {
mousedown: function (view, ev) {
var _a = ev, clientX = _a.clientX, clientY = _a.clientY;
var mousePos = view.posAtCoords({ left: clientX, top: clientY });
if (mousePos) {
var _b = view.state, doc = _b.doc, tr = _b.tr;
var currentPos = doc.resolve(mousePos.pos);
var listItem = findListItem(currentPos);
var target = ev.target;
var style = getComputedStyle(target, ':before');
var _c = ev, offsetX = _c.offsetX, offsetY = _c.offsetY;
if (!listItem || !isPositionInBox(style, offsetX, offsetY)) {
return false;
}
ev.preventDefault();
var offset = currentPos.before(listItem.depth);
var attrs = listItem.node.attrs;
tr.setNodeMarkup(offset, null, __assign(__assign({}, attrs), { checked: !attrs.checked }));
view.dispatch(tr);
return true;
}
return false;
},
},
},
});
}
;// CONCATENATED MODULE: ./src/wysiwyg/plugins/toolbarState.ts
var EXCEPT_TYPES = ['image', 'link', 'customBlock', 'frontMatter'];
var MARK_TYPES = ['strong', 'strike', 'emph', 'code'];
var LIST_TYPES = ['bulletList', 'orderedList', 'taskList'];
function toolbarState_getToolbarStateType(node, parentNode) {
var type = node.type.name;
if (type === 'listItem') {
return node.attrs.task ? 'taskList' : parentNode.type.name;
}
if (type.indexOf('table') !== -1) {
return 'table';
}
return type;
}
function setListNodeToolbarState(type, nodeTypeState) {
nodeTypeState[type] = { active: true };
LIST_TYPES.filter(function (listName) { return listName !== type; }).forEach(function (listType) {
if (nodeTypeState[listType]) {
delete nodeTypeState[listType];
}
});
}
function setMarkTypeStates(from, to, schema, toolbarState) {
MARK_TYPES.forEach(function (type) {
var mark = schema.marks[type];
var marksAtPos = from.marksAcross(to) || [];
var foundMark = !!mark.isInSet(marksAtPos);
if (foundMark) {
toolbarState[type] = { active: true };
}
});
}
function toolbarState_getToolbarState(selection, doc, schema) {
var $from = selection.$from, $to = selection.$to, from = selection.from, to = selection.to;
var toolbarState = {
indent: { active: false, disabled: true },
outdent: { active: false, disabled: true },
};
doc.nodesBetween(from, to, function (node, _, parentNode) {
var type = toolbarState_getToolbarStateType(node, parentNode);
if (common_includes(EXCEPT_TYPES, type)) {
return;
}
if (common_includes(LIST_TYPES, type)) {
setListNodeToolbarState(type, toolbarState);
toolbarState.indent.disabled = false;
toolbarState.outdent.disabled = false;
}
else if (type === 'paragraph' || type === 'text') {
setMarkTypeStates($from, $to, schema, toolbarState);
}
else {
toolbarState[type] = { active: true };
}
});
return toolbarState;
}
function toolbarStateHighlight(eventEmitter) {
return new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin({
view: function () {
return {
update: function (view) {
var _a = view.state, selection = _a.selection, doc = _a.doc, schema = _a.schema;
eventEmitter.emit('changeToolbarState', {
toolbarState: toolbarState_getToolbarState(selection, doc, schema),
});
},
};
},
});
}
;// CONCATENATED MODULE: ./src/wysiwyg/nodeview/customBlockView.ts
var CustomBlockView = /** @class */ (function () {
function CustomBlockView(node, view, getPos, toDOMAdaptor) {
var _this = this;
this.openEditor = function () {
if (_this.innerEditorView) {
throw new Error('The editor is already opened.');
}
_this.dom.draggable = false;
_this.wrapper.style.display = 'none';
_this.innerViewContainer.style.display = 'block';
_this.innerEditorView = new external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.EditorView(_this.innerViewContainer, {
state: external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.EditorState.create({
doc: _this.node,
plugins: [
(0,external_commonjs_prosemirror_keymap_commonjs2_prosemirror_keymap_amd_prosemirror_keymap_.keymap)({
'Mod-z': function () { return (0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.undo)(_this.innerEditorView.state, _this.innerEditorView.dispatch); },
'Shift-Mod-z': function () { return (0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.redo)(_this.innerEditorView.state, _this.innerEditorView.dispatch); },
Tab: function (state, dispatch) {
dispatch(state.tr.insertText('\t'));
return true;
},
Enter: external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.newlineInCode,
Escape: function () {
_this.cancelEditing();
return true;
},
'Ctrl-Enter': function () {
_this.saveAndFinishEditing();
return true;
},
}),
(0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.history)(),
],
}),
dispatchTransaction: function (tr) { return _this.dispatchInner(tr); },
handleDOMEvents: {
mousedown: function () {
if (_this.editorView.hasFocus()) {
_this.innerEditorView.focus();
}
return true;
},
blur: function () {
_this.saveAndFinishEditing();
return true;
},
},
});
_this.innerEditorView.focus();
};
this.node = node;
this.editorView = view;
this.getPos = getPos;
this.toDOMAdaptor = toDOMAdaptor;
this.innerEditorView = null;
this.canceled = false;
this.dom = document.createElement('div');
this.dom.className = cls('custom-block');
this.wrapper = document.createElement('div');
this.wrapper.className = cls('custom-block-view');
this.createInnerViewContainer();
this.renderCustomBlock();
this.dom.appendChild(this.innerViewContainer);
this.dom.appendChild(this.wrapper);
}
CustomBlockView.prototype.renderToolArea = function () {
var _this = this;
var tool = document.createElement('div');
var span = document.createElement('span');
var button = document.createElement('button');
tool.className = 'tool';
span.textContent = this.node.attrs.info;
span.className = 'info';
button.type = 'button';
button.addEventListener('click', function () { return _this.openEditor(); });
tool.appendChild(span);
tool.appendChild(button);
this.wrapper.appendChild(tool);
};
CustomBlockView.prototype.renderCustomBlock = function () {
var toDOMNode = this.toDOMAdaptor.getToDOMNode(this.node.attrs.info);
if (toDOMNode) {
var node = toDOMNode(this.node);
while (this.wrapper.hasChildNodes()) {
this.wrapper.removeChild(this.wrapper.lastChild);
}
if (node) {
this.wrapper.appendChild(node);
}
this.renderToolArea();
}
};
CustomBlockView.prototype.createInnerViewContainer = function () {
this.innerViewContainer = document.createElement('div');
this.innerViewContainer.className = cls('custom-block-editor');
this.innerViewContainer.style.display = 'none';
};
CustomBlockView.prototype.closeEditor = function () {
if (this.innerEditorView) {
this.innerEditorView.destroy();
this.innerEditorView = null;
this.innerViewContainer.style.display = 'none';
}
this.wrapper.style.display = 'block';
};
CustomBlockView.prototype.saveAndFinishEditing = function () {
var to = this.editorView.state.selection.to;
var outerState = this.editorView.state;
this.editorView.dispatch(outerState.tr.setSelection(createTextSelection(outerState.tr, to)));
this.editorView.focus();
this.renderCustomBlock();
this.closeEditor();
};
CustomBlockView.prototype.cancelEditing = function () {
var undoableCount = (0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.undoDepth)(this.innerEditorView.state);
this.canceled = true;
// should undo editing result
// eslint-disable-next-line no-plusplus
while (undoableCount--) {
(0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.undo)(this.innerEditorView.state, this.innerEditorView.dispatch);
(0,external_commonjs_prosemirror_history_commonjs2_prosemirror_history_amd_prosemirror_history_.undo)(this.editorView.state, this.editorView.dispatch);
}
this.canceled = false;
var to = this.editorView.state.selection.to;
var outerState = this.editorView.state;
this.editorView.dispatch(outerState.tr.setSelection(external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.TextSelection.create(outerState.doc, to)));
this.editorView.focus();
this.closeEditor();
};
CustomBlockView.prototype.dispatchInner = function (tr) {
var _a = this.innerEditorView.state.applyTransaction(tr), state = _a.state, transactions = _a.transactions;
this.innerEditorView.updateState(state);
if (!this.canceled && isFunction_default()(this.getPos)) {
var outerTr = this.editorView.state.tr;
var offsetMap = external_commonjs_prosemirror_transform_commonjs2_prosemirror_transform_amd_prosemirror_transform_.StepMap.offset(this.getPos() + 1);
for (var i = 0; i < transactions.length; i += 1) {
var steps = transactions[i].steps;
for (var j = 0; j < steps.length; j += 1) {
outerTr.step(steps[j].map(offsetMap));
}
}
if (outerTr.docChanged) {
this.editorView.dispatch(outerTr);
}
}
};
CustomBlockView.prototype.update = function (node) {
if (!node.sameMarkup(this.node)) {
return false;
}
this.node = node;
if (!this.innerEditorView) {
this.renderCustomBlock();
}
return true;
};
CustomBlockView.prototype.stopEvent = function (event) {
return (!!this.innerEditorView &&
!!event.target &&
this.innerEditorView.dom.contains(event.target));
};
CustomBlockView.prototype.ignoreMutation = function () {
return true;
};
CustomBlockView.prototype.destroy = function () {
this.dom.removeEventListener('dblclick', this.openEditor);
this.closeEditor();
};
return CustomBlockView;
}());
;// CONCATENATED MODULE: ./src/wysiwyg/nodeview/imageView.ts
var IMAGE_LINK_CLASS_NAME = 'image-link';
var ImageView = /** @class */ (function () {
function ImageView(node, view, getPos, eventEmitter) {
var _this = this;
var _a;
this.handleMousedown = function (ev) {
ev.preventDefault();
var target = ev.target, offsetX = ev.offsetX, offsetY = ev.offsetY;
if (_this.imageLink &&
isFunction_default()(_this.getPos) &&
hasClass_default()(target, IMAGE_LINK_CLASS_NAME)) {
var style = getComputedStyle(target, ':before');
ev.stopPropagation();
if (isPositionInBox(style, offsetX, offsetY)) {
var tr = _this.view.state.tr;
var pos = _this.getPos();
tr.setSelection(createTextSelection(tr, pos, pos + 1));
_this.view.dispatch(tr);
_this.eventEmitter.emit('openPopup', 'link', _this.imageLink.attrs);
}
}
};
this.node = node;
this.view = view;
this.getPos = getPos;
this.eventEmitter = eventEmitter;
this.imageLink = (_a = node.marks.filter(function (_a) {
var type = _a.type;
return type.name === 'link';
})[0]) !== null && _a !== void 0 ? _a : null;
this.dom = this.createElement();
this.bindEvent();
}
ImageView.prototype.createElement = function () {
var image = this.createImageElement(this.node);
if (this.imageLink) {
var wrapper = document.createElement('span');
wrapper.className = IMAGE_LINK_CLASS_NAME;
wrapper.appendChild(image);
return wrapper;
}
return image;
};
ImageView.prototype.createImageElement = function (node) {
var image = document.createElement('img');
var _a = node.attrs, imageUrl = _a.imageUrl, altText = _a.altText;
var attrs = getCustomAttrs(node.attrs);
image.src = imageUrl;
if (altText) {
image.alt = altText;
}
setAttributes(attrs, image);
return image;
};
ImageView.prototype.bindEvent = function () {
if (this.imageLink) {
this.dom.addEventListener('mousedown', this.handleMousedown);
}
};
ImageView.prototype.stopEvent = function () {
return true;
};
ImageView.prototype.destroy = function () {
if (this.imageLink) {
this.dom.removeEventListener('mousedown', this.handleMousedown);
}
};
return ImageView;
}());
;// CONCATENATED MODULE: ./src/wysiwyg/nodeview/codeBlockView.ts
var WRAPPER_CLASS_NAME = 'toastui-editor-ww-code-block';
var CODE_BLOCK_LANG_CLASS_NAME = 'toastui-editor-ww-code-block-language';
var CodeBlockView = /** @class */ (function () {
function CodeBlockView(node, view, getPos, eventEmitter) {
var _this = this;
this.contentDOM = null;
this.input = null;
this.timer = null;
this.handleMousedown = function (ev) {
var target = ev.target;
var style = getComputedStyle(target, ':after');
// judge to click pseudo element with background image for IE11
if (style.backgroundImage !== 'none' && isFunction_default()(_this.getPos)) {
var _a = _this.view.coordsAtPos(_this.getPos()), top = _a.top, right = _a.right;
_this.createLanguageEditor({ top: top, right: right });
}
};
this.handleKeydown = function (ev) {
if (ev.key === 'Enter' && _this.input) {
ev.preventDefault();
_this.changeLanguage();
}
};
this.node = node;
this.view = view;
this.getPos = getPos;
this.eventEmitter = eventEmitter;
this.createElement();
this.bindDOMEvent();
this.bindEvent();
}
CodeBlockView.prototype.createElement = function () {
var language = this.node.attrs.language;
var wrapper = document.createElement('div');
wrapper.setAttribute('data-language', language || 'text');
wrapper.className = WRAPPER_CLASS_NAME;
var pre = this.createCodeBlockElement();
var code = pre.firstChild;
wrapper.appendChild(pre);
this.dom = wrapper;
this.contentDOM = code;
};
CodeBlockView.prototype.createCodeBlockElement = function () {
var pre = document.createElement('pre');
var code = document.createElement('code');
var language = this.node.attrs.language;
var attrs = getCustomAttrs(this.node.attrs);
if (language) {
code.setAttribute('data-language', language);
}
setAttributes(attrs, pre);
pre.appendChild(code);
return pre;
};
CodeBlockView.prototype.createLanguageEditor = function (_a) {
var _this = this;
var top = _a.top, right = _a.right;
var wrapper = document.createElement('span');
wrapper.className = CODE_BLOCK_LANG_CLASS_NAME;
var input = document.createElement('input');
input.type = 'text';
input.value = this.node.attrs.language;
wrapper.appendChild(input);
this.view.dom.parentElement.appendChild(wrapper);
var wrpperWidth = wrapper.clientWidth;
css_default()(wrapper, {
top: top + 10 + "px",
left: right - wrpperWidth - 10 + "px",
width: wrpperWidth + "px",
});
this.input = input;
this.input.addEventListener('blur', function () { return _this.changeLanguage(); });
this.input.addEventListener('keydown', this.handleKeydown);
this.clearTimer();
this.timer = setTimeout(function () {
_this.input.focus();
});
};
CodeBlockView.prototype.bindDOMEvent = function () {
if (this.dom) {
this.dom.addEventListener('click', this.handleMousedown);
}
};
CodeBlockView.prototype.bindEvent = function () {
var _this = this;
this.eventEmitter.listen('scroll', function () {
if (_this.input) {
_this.reset();
}
});
};
CodeBlockView.prototype.changeLanguage = function () {
if (this.input && isFunction_default()(this.getPos)) {
var value = this.input.value;
this.reset();
var pos = this.getPos();
var tr = this.view.state.tr;
tr.setNodeMarkup(pos, null, { language: value });
this.view.dispatch(tr);
}
};
CodeBlockView.prototype.reset = function () {
var _a;
if ((_a = this.input) === null || _a === void 0 ? void 0 : _a.parentElement) {
var parent = this.input.parentElement;
this.input = null;
removeNode(parent);
}
};
CodeBlockView.prototype.clearTimer = function () {
if (this.timer) {
clearTimeout(this.timer);
this.timer = null;
}
};
CodeBlockView.prototype.stopEvent = function () {
return true;
};
CodeBlockView.prototype.update = function (node) {
if (!node.sameMarkup(this.node)) {
return false;
}
this.node = node;
return true;
};
CodeBlockView.prototype.destroy = function () {
this.reset();
this.clearTimer();
if (this.dom) {
this.dom.removeEventListener('click', this.handleMousedown);
}
};
return CodeBlockView;
}());
;// CONCATENATED MODULE: ./src/wysiwyg/clipboard/pasteMsoList.ts
var reMSOListClassName = /MsoListParagraph/;
var reMSOStylePrefix = /style=(.|\n)*mso-/;
var reMSOListStyle = /mso-list:(.*)/;
var reMSOTagName = /O:P/;
var reMSOListBullet = /^(n|u|l)/;
var MSO_CLASS_NAME_LIST_PARA = 'p.MsoListParagraph';
function isFromMso(html) {
return reMSOStylePrefix.test(html);
}
function getListItemContents(para) {
var removedNodes = [];
var walker = document.createTreeWalker(para, 1, null, false);
while (walker.nextNode()) {
var node = walker.currentNode;
if (isElemNode(node)) {
var _a = node, outerHTML = _a.outerHTML, textContent = _a.textContent;
var msoSpan = reMSOStylePrefix.test(outerHTML);
var bulletSpan = reMSOListStyle.test(outerHTML);
if (msoSpan && !bulletSpan && textContent) {
removedNodes.push([node, true]);
}
else if (reMSOTagName.test(node.nodeName) || (msoSpan && !textContent) || bulletSpan) {
removedNodes.push([node, false]);
}
}
}
removedNodes.forEach(function (_a) {
var node = _a[0], isUnwrap = _a[1];
if (isUnwrap) {
unwrapNode(node);
}
else {
removeNode(node);
}
});
return para.innerHTML.trim();
}
function createListItemDataFromParagraph(para, index) {
var styleAttr = para.getAttribute('style');
if (styleAttr) {
var _a = styleAttr.match(reMSOListStyle), listItemInfo = _a[1];
var _b = listItemInfo.trim().split(' '), levelStr = _b[1];
var level = parseInt(levelStr.replace('level', ''), 10);
var unordered = reMSOListBullet.test(para.textContent || '');
return {
id: index,
level: level,
prev: null,
parent: null,
children: [],
unordered: unordered,
contents: getListItemContents(para),
};
}
return null;
}
function addListItemDetailData(data, prevData) {
if (prevData.level < data.level) {
prevData.children.push(data);
data.parent = prevData;
}
else {
while (prevData) {
if (prevData.level === data.level) {
break;
}
prevData = prevData.parent;
}
if (prevData) {
data.prev = prevData;
data.parent = prevData.parent;
if (data.parent) {
data.parent.children.push(data);
}
}
}
}
function createListData(paras) {
var listData = [];
paras.forEach(function (para, index) {
var prevListItemData = listData[index - 1];
var listItemData = createListItemDataFromParagraph(para, index);
if (listItemData) {
if (prevListItemData) {
addListItemDetailData(listItemData, prevListItemData);
}
listData.push(listItemData);
}
});
return listData;
}
function makeList(listData) {
var listTagName = listData[0].unordered ? 'ul' : 'ol';
var list = document.createElement(listTagName);
listData.forEach(function (data) {
var children = data.children, contents = data.contents;
var listItem = document.createElement('li');
listItem.innerHTML = contents;
list.appendChild(listItem);
if (children.length) {
list.appendChild(makeList(children));
}
});
return list;
}
function makeListFromParagraphs(paras) {
var listData = createListData(paras);
var rootChildren = listData.filter(function (_a) {
var parent = _a.parent;
return !parent;
});
return makeList(rootChildren);
}
function isMsoListParagraphEnd(node) {
while (node) {
if (isElemNode(node)) {
break;
}
node = node.nextSibling;
}
return node ? !reMSOListClassName.test(node.className) : true;
}
function convertMsoParagraphsToList(html) {
var container = document.createElement('div');
container.innerHTML = html;
var paras = [];
var foundParas = findNodes(container, MSO_CLASS_NAME_LIST_PARA);
foundParas.forEach(function (para) {
var msoListParaEnd = isMsoListParagraphEnd(para.nextSibling);
paras.push(para);
if (msoListParaEnd) {
var list = makeListFromParagraphs(paras);
var nextSibling = para.nextSibling;
if (nextSibling) {
insertBeforeNode(list, nextSibling);
}
else {
appendNodes(container, list);
}
paras = [];
}
removeNode(para);
});
// without `
`, the list string was parsed as a paragraph node and added
var extraHTML = foundParas.length ? '
' : '';
return "" + extraHTML + container.innerHTML;
}
;// CONCATENATED MODULE: ./src/wysiwyg/clipboard/paste.ts
var START_FRAGMENT_COMMENT = '';
var END_FRAGMENT_COMMENT = '';
function getContentBetweenFragmentComments(html) {
var startFragmentIndex = html.indexOf(START_FRAGMENT_COMMENT);
var endFragmentIndex = html.lastIndexOf(END_FRAGMENT_COMMENT);
if (startFragmentIndex > -1 && endFragmentIndex > -1) {
html = html.slice(startFragmentIndex + START_FRAGMENT_COMMENT.length, endFragmentIndex);
}
return html.replace(/ ]*>/g, ALTERNATIVE_TAG_FOR_BR);
}
function convertMsoTableToCompletedTable(html) {
// wrap with if html contains dangling tags
// dangling tag is that tag does not have as parent node
if (/<\/td>((?!<\/tr>)[\s\S])*$/i.test(html)) {
html = " " + html + " ";
}
// wrap with if html contains dangling tags
// dangling tag is that tag does not have as parent node
if (/<\/tr>((?!<\/table>)[\s\S])*$/i.test(html)) {
html = "";
}
return html;
}
function changePastedHTML(html) {
html = getContentBetweenFragmentComments(html);
html = convertMsoTableToCompletedTable(html);
if (isFromMso(html)) {
html = convertMsoParagraphsToList(html);
}
return html;
}
function getMaxColumnCount(rows) {
var row = rows.reduce(function (prevRow, currentRow) {
return prevRow.childCount > currentRow.childCount ? prevRow : currentRow;
});
return row.childCount;
}
function createCells(orgRow, maxColumnCount, cell) {
var cells = [];
var cellCount = orgRow.childCount;
for (var colIdx = 0; colIdx < cellCount; colIdx += 1) {
if (!orgRow.child(colIdx).attrs.extended) {
var copiedCell = colIdx < cellCount
? cell.create(orgRow.child(colIdx).attrs, orgRow.child(colIdx).content)
: cell.createAndFill();
cells.push(copiedCell);
}
}
return cells;
}
function copyTableHeadRow(orgRow, maxColumnCount, schema) {
var _a = schema.nodes, tableRow = _a.tableRow, tableHeadCell = _a.tableHeadCell;
var cells = createCells(orgRow, maxColumnCount, tableHeadCell);
return tableRow.create(null, cells);
}
function copyTableBodyRow(orgRow, maxColumnCount, schema) {
var _a = schema.nodes, tableRow = _a.tableRow, tableBodyCell = _a.tableBodyCell;
var cells = createCells(orgRow, maxColumnCount, tableBodyCell);
return tableRow.create(null, cells);
}
function creatTableBodyDummyRow(columnCount, schema) {
var _a = schema.nodes, tableRow = _a.tableRow, tableBodyCell = _a.tableBodyCell;
var cells = [];
for (var columnIndex = 0; columnIndex < columnCount; columnIndex += 1) {
var dummyCell = tableBodyCell.createAndFill();
cells.push(dummyCell);
}
return tableRow.create({ dummyRowForPasting: true }, cells);
}
function createRowsFromPastingTable(tableContent) {
var tableHeadRows = [];
var tableBodyRows = [];
if (tableContent.firstChild.type.name === 'tableHead') {
var tableHead = tableContent.firstChild;
tableHead.forEach(function (row) { return tableHeadRows.push(row); });
}
if (tableContent.lastChild.type.name === 'tableBody') {
var tableBody = tableContent.lastChild;
tableBody.forEach(function (row) { return tableBodyRows.push(row); });
}
return __spreadArray(__spreadArray([], tableHeadRows), tableBodyRows);
}
function createTableHead(tableHeadRow, maxColumnCount, schema) {
var copiedRow = copyTableHeadRow(tableHeadRow, maxColumnCount, schema);
return schema.nodes.tableHead.create(null, copiedRow);
}
function paste_createTableBody(tableBodyRows, maxColumnCount, schema) {
var copiedRows = tableBodyRows.map(function (tableBodyRow) {
return copyTableBodyRow(tableBodyRow, maxColumnCount, schema);
});
if (!tableBodyRows.length) {
var dummyTableRow = creatTableBodyDummyRow(maxColumnCount, schema);
copiedRows.push(dummyTableRow);
}
return schema.nodes.tableBody.create(null, copiedRows);
}
function createTableFromPastingTable(rows, schema, startFromBody, isInTable) {
var columnCount = getMaxColumnCount(rows);
if (startFromBody && isInTable) {
return schema.nodes.table.create(null, [paste_createTableBody(rows, columnCount, schema)]);
}
var tableHeadRow = rows[0];
var tableBodyRows = rows.slice(1);
var nodes = [createTableHead(tableHeadRow, columnCount, schema)];
if (tableBodyRows.length) {
nodes.push(paste_createTableBody(tableBodyRows, columnCount, schema));
}
return schema.nodes.table.create(null, nodes);
}
function changePastedSlice(slice, schema, isInTable) {
var nodes = [];
var content = slice.content, openStart = slice.openStart, openEnd = slice.openEnd;
content.forEach(function (node) {
if (node.type.name === 'table') {
var tableContent = getTableContentFromSlice(new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(node), 0, 0));
if (tableContent) {
var rows = createRowsFromPastingTable(tableContent);
var startFromBody = tableContent.firstChild.type.name === 'tableBody';
var table = createTableFromPastingTable(rows, schema, startFromBody, isInTable);
nodes.push(table);
}
}
else {
nodes.push(node);
}
});
return new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(nodes), openStart, openEnd);
}
;// CONCATENATED MODULE: ./src/wysiwyg/clipboard/pasteToTable.ts
var DUMMY_CELL_SIZE = 4;
var TR_NODES_SIZE = 2;
function getDummyCellSize(dummyCellCount) {
return dummyCellCount * DUMMY_CELL_SIZE;
}
function createPastingCells(tableContent, curSelectionInfo, schema) {
var pastingRows = [];
var pastingTableRows = createRowsFromPastingTable(tableContent);
var columnCount = pastingTableRows[0].childCount;
var rowCount = pastingTableRows.length;
var startToTableHead = curSelectionInfo.startRowIdx === 0;
var slicedRows = pastingTableRows.slice(0, rowCount);
if (startToTableHead) {
var tableHeadRow = slicedRows.shift();
if (tableHeadRow) {
var content = copyTableHeadRow(tableHeadRow, columnCount, schema).content;
pastingRows.push(content);
}
}
slicedRows.forEach(function (tableBodyRow) {
if (!tableBodyRow.attrs.dummyRowForPasting) {
var content = copyTableBodyRow(tableBodyRow, columnCount, schema).content;
pastingRows.push(content);
}
});
return pastingRows;
}
function getPastingRangeInfo(map, _a, pastingCells) {
var startRowIdx = _a.startRowIdx, startColIdx = _a.startColIdx;
var pastingRowCount = pastingCells.length;
var pastingColumnCount = 0;
var _loop_1 = function (i) {
var columnCount = pastingCells[i].childCount;
pastingCells[i].forEach(function (_a) {
var attrs = _a.attrs;
var colspan = attrs.colspan;
if (colspan > 1) {
columnCount += colspan - 1;
}
});
pastingColumnCount = Math.max(pastingColumnCount, columnCount);
};
for (var i = 0; i < pastingRowCount; i += 1) {
_loop_1(i);
}
var endRowIdx = startRowIdx + pastingRowCount - 1;
var endColIdx = startColIdx + pastingColumnCount - 1;
var addedRowCount = Math.max(endRowIdx + 1 - map.totalRowCount, 0);
var addedColumnCount = Math.max(endColIdx + 1 - map.totalColumnCount, 0);
return {
startRowIdx: startRowIdx,
startColIdx: startColIdx,
endRowIdx: endRowIdx,
endColIdx: endColIdx,
addedRowCount: addedRowCount,
addedColumnCount: addedColumnCount,
};
}
function addReplacedOffsets(_a, cellsOffsets) {
var startRowIdx = _a.startRowIdx, startColIdx = _a.startColIdx, endRowIdx = _a.endRowIdx, endColIdx = _a.endColIdx, addedRowCount = _a.addedRowCount, addedColumnCount = _a.addedColumnCount;
for (var rowIdx = startRowIdx; rowIdx <= endRowIdx - addedRowCount; rowIdx += 1) {
cellsOffsets.push({
rowIdx: rowIdx,
startColIdx: startColIdx,
endColIdx: endColIdx - addedColumnCount,
});
}
}
function expandColumns(tr, schema, map, _a, cellsOffsets) {
var startRowIdx = _a.startRowIdx, startColIdx = _a.startColIdx, endRowIdx = _a.endRowIdx, endColIdx = _a.endColIdx, addedRowCount = _a.addedRowCount, addedColumnCount = _a.addedColumnCount;
var totalRowCount = map.totalRowCount;
var index = 0;
for (var rowIdx = 0; rowIdx < totalRowCount; rowIdx += 1) {
var _b = map.getCellInfo(rowIdx, endColIdx - addedColumnCount), offset = _b.offset, nodeSize = _b.nodeSize;
var insertOffset = tr.mapping.map(offset + nodeSize);
var cells = createDummyCells(addedColumnCount, rowIdx, schema);
tr.insert(insertOffset, cells);
if (rowIdx >= startRowIdx && rowIdx <= endRowIdx - addedRowCount) {
var cellInfo = map.getCellInfo(rowIdx, endColIdx - addedColumnCount);
var startCellOffset = tr.mapping.map(cellInfo.offset);
var endCellOffset = insertOffset + getDummyCellSize(addedColumnCount);
cellsOffsets[index] = {
rowIdx: rowIdx,
startColIdx: startColIdx,
endColIdx: endColIdx,
dummyOffsets: [startCellOffset, endCellOffset],
};
index += 1;
}
}
}
function expandRows(tr, schema, map, _a, cellsOffsets) {
var addedRowCount = _a.addedRowCount, addedColumnCount = _a.addedColumnCount, startColIdx = _a.startColIdx, endColIdx = _a.endColIdx;
var mapStart = tr.mapping.maps.length;
var tableEndPos = map.tableEndOffset - 2;
var rows = createTableBodyRows(addedRowCount, map.totalColumnCount + addedColumnCount, schema);
var startOffset = tableEndPos;
tr.insert(tr.mapping.slice(mapStart).map(startOffset), rows);
for (var rowIndex = 0; rowIndex < addedRowCount; rowIndex += 1) {
var startCellOffset = startOffset + getDummyCellSize(startColIdx) + 1;
var endCellOffset = startOffset + getDummyCellSize(endColIdx + 1) + 1;
var nextCellOffset = startOffset + getDummyCellSize(map.totalColumnCount + addedColumnCount) + TR_NODES_SIZE;
cellsOffsets.push({
rowIdx: rowIndex + map.totalRowCount,
startColIdx: startColIdx,
endColIdx: endColIdx,
dummyOffsets: [startCellOffset, endCellOffset],
});
startOffset = nextCellOffset;
}
}
function replaceCells(tr, pastingRows, cellsOffsets, map) {
var mapStart = tr.mapping.maps.length;
cellsOffsets.forEach(function (offsets, index) {
var rowIdx = offsets.rowIdx, startColIdx = offsets.startColIdx, endColIdx = offsets.endColIdx, dummyOffsets = offsets.dummyOffsets;
var mapping = tr.mapping.slice(mapStart);
var cells = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(pastingRows[index], 0, 0);
var from = dummyOffsets ? dummyOffsets[0] : map.getCellStartOffset(rowIdx, startColIdx);
var to = dummyOffsets ? dummyOffsets[1] : map.getCellEndOffset(rowIdx, endColIdx);
tr.replace(mapping.map(from), mapping.map(to), cells);
});
}
function pasteToTable(view, slice) {
var _a = view.state, selection = _a.selection, schema = _a.schema, tr = _a.tr;
var _b = getResolvedSelection(selection), anchor = _b.anchor, head = _b.head;
if (anchor && head) {
var tableContent = getTableContentFromSlice(slice);
if (!tableContent) {
return false;
}
var map = TableOffsetMap.create(anchor);
var curSelectionInfo = map.getRectOffsets(anchor, head);
var pastingCells = createPastingCells(tableContent, curSelectionInfo, schema);
var pastingInfo = getPastingRangeInfo(map, curSelectionInfo, pastingCells);
var cellsOffsets = [];
// @TODO: unmerge the span and paste the cell
if (canMerge(map, pastingInfo)) {
addReplacedOffsets(pastingInfo, cellsOffsets);
if (pastingInfo.addedColumnCount) {
expandColumns(tr, schema, map, pastingInfo, cellsOffsets);
}
if (pastingInfo.addedRowCount) {
expandRows(tr, schema, map, pastingInfo, cellsOffsets);
}
replaceCells(tr, pastingCells, cellsOffsets, map);
view.dispatch(tr);
setSelection(view, cellsOffsets, map.getCellInfo(0, 0).offset);
}
return true;
}
return false;
}
function setSelection(view, cellsOffsets, pos) {
var _a = view.state, tr = _a.tr, doc = _a.doc;
// get changed cell offsets
var map = TableOffsetMap.create(doc.resolve(pos));
// eslint-disable-next-line prefer-destructuring
var _b = cellsOffsets[0], startRowIdx = _b.rowIdx, startColIdx = _b.startColIdx;
var _c = last(cellsOffsets), endRowIdx = _c.rowIdx, endColIdx = _c.endColIdx;
var startOffset = map.getCellInfo(startRowIdx, startColIdx).offset;
var endOffset = map.getCellInfo(endRowIdx, endColIdx).offset;
view.dispatch(tr.setSelection(new selection_cellSelection(doc.resolve(startOffset), doc.resolve(endOffset))));
}
function canMerge(map, pastingInfo) {
var ranges = map.getSpannedOffsets(pastingInfo);
var _a = getRowAndColumnCount(ranges), rowCount = _a.rowCount, columnCount = _a.columnCount;
var _b = getRowAndColumnCount(pastingInfo), pastingRowCount = _b.rowCount, pastingColumnCount = _b.columnCount;
return rowCount === pastingRowCount && columnCount === pastingColumnCount;
}
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/doc.ts
var doc_Doc = /** @class */ (function (_super) {
__extends(Doc, _super);
function Doc() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Doc.prototype, "name", {
get: function () {
return 'doc';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Doc.prototype, "schema", {
get: function () {
return {
content: 'block+',
};
},
enumerable: false,
configurable: true
});
return Doc;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/paragraph.ts
var paragraph_Paragraph = /** @class */ (function (_super) {
__extends(Paragraph, _super);
function Paragraph() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Paragraph.prototype, "name", {
get: function () {
return 'paragraph';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Paragraph.prototype, "schema", {
get: function () {
return {
content: 'inline*',
group: 'block',
attrs: __assign({}, getDefaultCustomAttrs()),
parseDOM: [{ tag: 'p' }],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['p', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
return Paragraph;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/text.ts
var reSoftTabLen = /\s{1,4}$/;
var text_Text = /** @class */ (function (_super) {
__extends(Text, _super);
function Text() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Text.prototype, "name", {
get: function () {
return 'text';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Text.prototype, "schema", {
get: function () {
return {
group: 'inline',
};
},
enumerable: false,
configurable: true
});
Text.prototype.addSpaces = function () {
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr;
var $from = selection.$from, $to = selection.$to;
var range = $from.blockRange($to);
if (range && !isInListNode($from) && !isInTableNode($from)) {
dispatch(tr.insertText(' ', $from.pos, $to.pos));
return true;
}
return false;
};
};
Text.prototype.removeSpaces = function () {
return function (_a, dispatch) {
var selection = _a.selection, tr = _a.tr;
var $from = selection.$from, $to = selection.$to, from = selection.from;
var range = $from.blockRange($to);
if (range && !isInListNode($from) && !isInTableNode($from)) {
var nodeBefore = $from.nodeBefore;
if (nodeBefore && nodeBefore.isText) {
var text = nodeBefore.text;
var removedSpaceText = text.replace(reSoftTabLen, '');
var spaces = text.length - removedSpaceText.length;
dispatch(tr.delete(from - spaces, from));
return true;
}
}
return false;
};
};
Text.prototype.keymaps = function () {
return {
Tab: this.addSpaces(),
'Shift-Tab': this.removeSpaces(),
};
};
return Text;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/heading.ts
var heading_Heading = /** @class */ (function (_super) {
__extends(Heading, _super);
function Heading() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Heading.prototype, "name", {
get: function () {
return 'heading';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Heading.prototype, "levels", {
get: function () {
return [1, 2, 3, 4, 5, 6];
},
enumerable: false,
configurable: true
});
Object.defineProperty(Heading.prototype, "schema", {
get: function () {
var parseDOM = this.levels.map(function (level) {
return {
tag: "h" + level,
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({ level: level }, (rawHTML && { rawHTML: rawHTML }));
},
};
});
return {
attrs: __assign({ level: { default: 1 }, headingType: { default: 'atx' }, rawHTML: { default: null } }, getDefaultCustomAttrs()),
content: 'inline*',
group: 'block',
defining: true,
parseDOM: parseDOM,
toDOM: function (_a) {
var attrs = _a.attrs;
return ["h" + attrs.level, getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
Heading.prototype.commands = function () {
return function (payload) { return function (state, dispatch) {
var nodeType = state.schema.nodes[payload.level ? 'heading' : 'paragraph'];
return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.setBlockType)(nodeType, payload)(state, dispatch);
}; };
};
return Heading;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/codeBlock.ts
var codeBlock_CodeBlock = /** @class */ (function (_super) {
__extends(CodeBlock, _super);
function CodeBlock() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(CodeBlock.prototype, "name", {
get: function () {
return 'codeBlock';
},
enumerable: false,
configurable: true
});
Object.defineProperty(CodeBlock.prototype, "schema", {
get: function () {
return {
content: 'text*',
group: 'block',
attrs: __assign({ language: { default: null }, rawHTML: { default: null } }, getDefaultCustomAttrs()),
code: true,
defining: true,
marks: '',
parseDOM: [
{
tag: 'pre',
preserveWhitespace: 'full',
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
var child = dom.firstElementChild;
return __assign({ language: (child === null || child === void 0 ? void 0 : child.getAttribute('data-language')) || null }, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return [
attrs.rawHTML || 'pre',
['code', __assign({ 'data-language': attrs.language }, getCustomAttrs(attrs)), 0],
];
},
};
},
enumerable: false,
configurable: true
});
CodeBlock.prototype.commands = function () {
return function () { return function (state, dispatch) { return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.setBlockType)(state.schema.nodes.codeBlock)(state, dispatch); }; };
};
CodeBlock.prototype.moveCursor = function (direction) {
var _this = this;
return function (state, dispatch) {
var tr = state.tr, doc = state.doc, schema = state.schema;
var $from = state.selection.$from;
var view = _this.context.view;
if (view.endOfTextblock(direction) && $from.node().type.name === 'codeBlock') {
var lines = $from.parent.textContent.split('\n');
var offset = direction === 'up' ? $from.start() : $from.end();
var range = direction === 'up'
? [offset, lines[0].length + offset]
: [offset - last(lines).length, offset];
var pos = doc.resolve(direction === 'up' ? $from.before() : $from.after());
var node = direction === 'up' ? pos.nodeBefore : pos.nodeAfter;
if (between($from.pos, range[0], range[1]) && !node) {
var newTr = addParagraph(tr, pos, schema);
if (newTr) {
dispatch(newTr);
return true;
}
}
}
return false;
};
};
CodeBlock.prototype.keymaps = function () {
var codeCommand = this.commands()();
return {
'Shift-Mod-p': codeCommand,
'Shift-Mod-P': codeCommand,
ArrowUp: this.moveCursor('up'),
ArrowDown: this.moveCursor('down'),
};
};
return CodeBlock;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/bulletList.ts
var BulletList = /** @class */ (function (_super) {
__extends(BulletList, _super);
function BulletList() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(BulletList.prototype, "name", {
get: function () {
return 'bulletList';
},
enumerable: false,
configurable: true
});
Object.defineProperty(BulletList.prototype, "schema", {
get: function () {
return {
content: 'listItem+',
group: 'block',
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [createDOMInfoParsedRawHTML('ul')],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['ul', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
BulletList.prototype.changeList = function () {
return function (state, dispatch) { return changeList(state.schema.nodes.bulletList)(state, dispatch); };
};
BulletList.prototype.commands = function () {
return {
bulletList: this.changeList,
taskList: toggleTask,
};
};
BulletList.prototype.keymaps = function () {
var bulletListCommand = this.changeList();
var _a = getWwCommands(), indent = _a.indent, outdent = _a.outdent;
return {
'Mod-u': bulletListCommand,
'Mod-U': bulletListCommand,
Tab: indent(),
'Shift-Tab': outdent(),
};
};
return BulletList;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/orderedList.ts
var OrderedList = /** @class */ (function (_super) {
__extends(OrderedList, _super);
function OrderedList() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(OrderedList.prototype, "name", {
get: function () {
return 'orderedList';
},
enumerable: false,
configurable: true
});
Object.defineProperty(OrderedList.prototype, "schema", {
get: function () {
return {
content: 'listItem+',
group: 'block',
attrs: __assign({ order: { default: 1 }, rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [
{
tag: 'ol',
getAttrs: function (dom) {
var start = dom.getAttribute('start');
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({ order: dom.hasAttribute('start') ? Number(start) : 1 }, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return [
attrs.rawHTML || 'ol',
__assign({ start: attrs.order === 1 ? null : attrs.order }, getCustomAttrs(attrs)),
0,
];
},
};
},
enumerable: false,
configurable: true
});
OrderedList.prototype.commands = function () {
return function () { return function (state, dispatch) { return changeList(state.schema.nodes.orderedList)(state, dispatch); }; };
};
OrderedList.prototype.keymaps = function () {
var orderedListCommand = this.commands()();
var _a = getWwCommands(), indent = _a.indent, outdent = _a.outdent;
return {
'Mod-o': orderedListCommand,
'Mod-O': orderedListCommand,
Tab: indent(),
'Shift-Tab': outdent(),
};
};
return OrderedList;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/listItem.ts
var listItem_ListItem = /** @class */ (function (_super) {
__extends(ListItem, _super);
function ListItem() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(ListItem.prototype, "name", {
get: function () {
return 'listItem';
},
enumerable: false,
configurable: true
});
Object.defineProperty(ListItem.prototype, "schema", {
get: function () {
return {
content: 'paragraph block*',
selectable: false,
attrs: {
task: { default: false },
checked: { default: false },
rawHTML: { default: null },
},
defining: true,
parseDOM: [
{
tag: 'li',
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({ task: dom.hasAttribute('data-task'), checked: dom.hasAttribute('data-task-checked') }, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
var task = attrs.task, checked = attrs.checked;
if (!task) {
return [attrs.rawHTML || 'li', 0];
}
var classNames = ['task-list-item'];
if (checked) {
classNames.push('checked');
}
return [
attrs.rawHTML || 'li',
__assign({ class: classNames.join(' '), 'data-task': task }, (checked && { 'data-task-checked': checked })),
0,
];
},
};
},
enumerable: false,
configurable: true
});
ListItem.prototype.liftToPrevListItem = function () {
return function (state, dispatch) {
var selection = state.selection, tr = state.tr, schema = state.schema;
var $from = selection.$from, empty = selection.empty;
var listItem = schema.nodes.listItem;
var parent = $from.parent;
var listItemParent = $from.node(-1);
if (empty && !parent.childCount && listItemParent.type === listItem) {
// move to previous sibling list item when the current list item is not top list item
if ($from.index(-2) >= 1) {
// should subtract '1' for considering tag length()
tr.delete($from.start(-1) - 1, $from.end(-1));
dispatch(tr);
return true;
}
var grandParentListItem = $from.node(-3);
// move to parent list item when the current list item is top list item
if (grandParentListItem.type === listItem) {
// should subtract '1' for considering tag length()
tr.delete($from.start(-2) - 1, $from.end(-1));
dispatch(tr);
return true;
}
}
return false;
};
};
ListItem.prototype.keymaps = function () {
var split = function (state, dispatch) {
return splitListItem(state.schema.nodes.listItem)(state, dispatch);
};
return {
Backspace: this.liftToPrevListItem(),
Enter: split,
};
};
return ListItem;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/blockQuote.ts
var blockQuote_BlockQuote = /** @class */ (function (_super) {
__extends(BlockQuote, _super);
function BlockQuote() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(BlockQuote.prototype, "name", {
get: function () {
return 'blockQuote';
},
enumerable: false,
configurable: true
});
Object.defineProperty(BlockQuote.prototype, "schema", {
get: function () {
return {
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
content: 'block+',
group: 'block',
parseDOM: [createDOMInfoParsedRawHTML('blockquote')],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['blockquote', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
BlockQuote.prototype.commands = function () {
return function () { return function (state, dispatch) { return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.wrapIn)(state.schema.nodes.blockQuote)(state, dispatch); }; };
};
BlockQuote.prototype.keymaps = function () {
var blockQutoeCommand = this.commands()();
return {
'Alt-q': blockQutoeCommand,
'Alt-Q': blockQutoeCommand,
};
};
return BlockQuote;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/command/table.ts
var cellOffsetFnMap = {
left: getLeftCellOffset,
right: getRightCellOffset,
up: getUpCellOffset,
down: getDownCellOffset,
};
function isInFirstListItem(pos, doc, _a) {
var paraDepth = _a[0], listDepth = _a[1];
var listItemNode = doc.resolve(pos.before(paraDepth - 1));
return listDepth === paraDepth && !listItemNode.nodeBefore;
}
function isInLastListItem(pos) {
var _a;
var depth = pos.depth;
var parentNode;
while (depth) {
parentNode = pos.node(depth);
if (parentNode.type.name === 'tableBodyCell') {
break;
}
if (parentNode.type.name === 'listItem') {
var grandParent = pos.node(depth - 1);
var lastListItem = grandParent.lastChild === parentNode;
var hasChildren = ((_a = parentNode.lastChild) === null || _a === void 0 ? void 0 : _a.type.name) !== 'paragraph';
if (!lastListItem) {
return false;
}
return !hasChildren;
}
depth -= 1;
}
return false;
}
function canMoveToBeforeCell(direction, _a, from, doc, inList) {
var paraDepth = _a[0], listDepth = _a[1], curDepth = _a[2];
if (direction === Direction.LEFT || direction === Direction.UP) {
if (inList && !isInFirstListItem(from, doc, [paraDepth, listDepth])) {
return false;
}
var endOffset = from.before(curDepth);
var nodeBefore = doc.resolve(endOffset).nodeBefore;
if (nodeBefore) {
return false;
}
}
return true;
}
function canMoveToAfterCell(direction, curDepth, from, doc, inList) {
if (direction === Direction.RIGHT || direction === Direction.DOWN) {
if (inList && !isInLastListItem(from)) {
return false;
}
var endOffset = from.after(curDepth);
var nodeAfter = doc.resolve(endOffset).nodeAfter;
if (nodeAfter) {
return false;
}
}
return true;
}
function canMoveBetweenCells(direction, _a, from, doc) {
var cellDepth = _a[0], paraDepth = _a[1];
var listDepth = cellDepth + 3; // 3 is position of
var inList = paraDepth >= listDepth;
var curDepth = inList ? cellDepth + 1 : paraDepth;
var moveBeforeCell = canMoveToBeforeCell(direction, [paraDepth, listDepth, curDepth], from, doc, inList);
var moveAfterCell = canMoveToAfterCell(direction, curDepth, from, doc, inList);
return moveBeforeCell && moveAfterCell;
}
function canBeOutOfTable(direction, map, _a) {
var rowIdx = _a[0], colIdx = _a[1];
var rowspanInfo = map.getRowspanStartInfo(rowIdx, colIdx);
var inFirstRow = direction === Direction.UP && rowIdx === 0;
var inLastRow = direction === Direction.DOWN &&
((rowspanInfo === null || rowspanInfo === void 0 ? void 0 : rowspanInfo.count) > 1 ? rowIdx + rowspanInfo.count - 1 : rowIdx) === map.totalRowCount - 1;
return inFirstRow || inLastRow;
}
function addParagraphBeforeTable(tr, map, schema) {
var tableStartPos = tr.doc.resolve(map.tableStartOffset - 1);
if (!tableStartPos.nodeBefore) {
return addParagraph(tr, tableStartPos, schema);
}
return tr.setSelection(external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Selection.near(tableStartPos, -1));
}
function addParagraphAfterTable(tr, map, schema, forcedAddtion) {
if (forcedAddtion === void 0) { forcedAddtion = false; }
var tableEndPos = tr.doc.resolve(map.tableEndOffset);
if (forcedAddtion || !tableEndPos.nodeAfter) {
return addParagraph(tr, tableEndPos, schema);
}
return tr.setSelection(external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Selection.near(tableEndPos, 1));
}
function getRightCellOffset(_a, map) {
var rowIdx = _a[0], colIdx = _a[1];
var totalRowCount = map.totalRowCount, totalColumnCount = map.totalColumnCount;
var lastCellInRow = colIdx === totalColumnCount - 1;
var lastCellInTable = rowIdx === totalRowCount - 1 && lastCellInRow;
if (!lastCellInTable) {
var nextColIdx = colIdx + 1;
var colspanInfo = map.getColspanStartInfo(rowIdx, colIdx);
if ((colspanInfo === null || colspanInfo === void 0 ? void 0 : colspanInfo.count) > 1) {
nextColIdx += colspanInfo.count - 1;
}
if (lastCellInRow || nextColIdx === totalColumnCount) {
rowIdx += 1;
nextColIdx = 0;
}
var offset = map.getCellInfo(rowIdx, nextColIdx).offset;
return offset + 2;
}
return null;
}
function getLeftCellOffset(_a, map) {
var rowIdx = _a[0], colIdx = _a[1];
var totalColumnCount = map.totalColumnCount;
var firstCellInRow = colIdx === 0;
var firstCellInTable = rowIdx === 0 && firstCellInRow;
if (!firstCellInTable) {
colIdx -= 1;
if (firstCellInRow) {
rowIdx -= 1;
colIdx = totalColumnCount - 1;
}
var _b = map.getCellInfo(rowIdx, colIdx), offset = _b.offset, nodeSize = _b.nodeSize;
return offset + nodeSize - 2;
}
return null;
}
function getUpCellOffset(_a, map) {
var rowIdx = _a[0], colIdx = _a[1];
if (rowIdx > 0) {
var _b = map.getCellInfo(rowIdx - 1, colIdx), offset = _b.offset, nodeSize = _b.nodeSize;
return offset + nodeSize - 2;
}
return null;
}
function getDownCellOffset(_a, map) {
var rowIdx = _a[0], colIdx = _a[1];
var totalRowCount = map.totalRowCount;
if (rowIdx < totalRowCount - 1) {
var nextRowIdx = rowIdx + 1;
var rowspanInfo = map.getRowspanStartInfo(rowIdx, colIdx);
if ((rowspanInfo === null || rowspanInfo === void 0 ? void 0 : rowspanInfo.count) > 1) {
nextRowIdx += rowspanInfo.count - 1;
}
var offset = map.getCellInfo(nextRowIdx, colIdx).offset;
return offset + 2;
}
return null;
}
function moveToCell(direction, tr, cellIndex, map) {
var cellOffsetFn = cellOffsetFnMap[direction];
var offset = cellOffsetFn(cellIndex, map);
if (offset) {
var dir = direction === Direction.RIGHT || direction === Direction.DOWN ? 1 : -1;
return tr.setSelection(external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Selection.near(tr.doc.resolve(offset), dir));
}
return null;
}
function canSelectTableNode(direction, map, _a) {
var rowIdx = _a[0], colIdx = _a[1];
if (direction === Direction.UP || direction === Direction.DOWN) {
return false;
}
var tableStartOffset = map.tableStartOffset, tableEndOffset = map.tableEndOffset;
var _b = map.getCellInfo(rowIdx, colIdx), offset = _b.offset, nodeSize = _b.nodeSize;
var pos = direction === Direction.LEFT ? tableStartOffset : tableEndOffset;
var curPos = direction === Direction.LEFT ? offset - 2 : offset + nodeSize + 3;
return pos === curPos;
}
function selectNode(tr, pos, depth) {
var tablePos = tr.doc.resolve(pos.before(depth - 3));
return tr.setSelection(new external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.NodeSelection(tablePos));
}
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/table.ts
// eslint-disable-next-line no-shadow
var Direction;
(function (Direction) {
Direction["LEFT"] = "left";
Direction["RIGHT"] = "right";
Direction["UP"] = "up";
Direction["DOWN"] = "down";
})(Direction || (Direction = {}));
function getTargetRowInfo(direction, map, selectionInfo) {
var targetRowIdx;
var insertColIdx;
var nodeSize;
if (direction === Direction.UP) {
targetRowIdx = selectionInfo.startRowIdx;
insertColIdx = 0;
nodeSize = -1;
}
else {
targetRowIdx = selectionInfo.endRowIdx;
insertColIdx = map.totalColumnCount - 1;
nodeSize = map.getCellInfo(targetRowIdx, insertColIdx).nodeSize + 1;
}
return { targetRowIdx: targetRowIdx, insertColIdx: insertColIdx, nodeSize: nodeSize };
}
function getRowRanges(map, rowIdx, totalColumnCount) {
var startOffset = map.getCellInfo(rowIdx, 0).offset;
var _a = map.getCellInfo(rowIdx, totalColumnCount - 1), offset = _a.offset, nodeSize = _a.nodeSize;
return { from: startOffset, to: offset + nodeSize };
}
var table_Table = /** @class */ (function (_super) {
__extends(Table, _super);
function Table() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Table.prototype, "name", {
get: function () {
return 'table';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Table.prototype, "schema", {
get: function () {
return {
content: 'tableHead{1} tableBody{1}',
group: 'block',
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [createDOMInfoParsedRawHTML('table')],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['table', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
Table.prototype.addTable = function () {
return function (payload) {
if (payload === void 0) { payload = { rowCount: 2, columnCount: 1, data: [] }; }
return function (state, dispatch) {
var rowCount = payload.rowCount, columnCount = payload.columnCount, data = payload.data;
var schema = state.schema, selection = state.selection, tr = state.tr;
var from = selection.from, to = selection.to, $from = selection.$from;
var collapsed = from === to;
if (collapsed && !isInTableNode($from)) {
var _a = schema.nodes, tableHead = _a.tableHead, tableBody = _a.tableBody;
var theadData = data === null || data === void 0 ? void 0 : data.slice(0, columnCount);
var tbodyData = data === null || data === void 0 ? void 0 : data.slice(columnCount, data.length);
var tableHeadRow = createTableHeadRow(columnCount, schema, theadData);
var tableBodyRows = createTableBodyRows(rowCount - 1, columnCount, schema, tbodyData);
var table = schema.nodes.table.create(null, [
tableHead.create(null, tableHeadRow),
tableBody.create(null, tableBodyRows),
]);
dispatch(tr.replaceSelectionWith(table));
return true;
}
return false;
};
};
};
Table.prototype.removeTable = function () {
return function () { return function (state, dispatch) {
var selection = state.selection, tr = state.tr;
var map = TableOffsetMap.create(selection.$anchor);
if (map) {
var tableStartOffset = map.tableStartOffset, tableEndOffset = map.tableEndOffset;
var startOffset = tableStartOffset - 1;
var cursorPos = createTextSelection(tr.delete(startOffset, tableEndOffset), startOffset);
dispatch(tr.setSelection(cursorPos));
return true;
}
return false;
}; };
};
Table.prototype.addColumn = function (direction) {
return function () { return function (state, dispatch) {
var selection = state.selection, tr = state.tr, schema = state.schema;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
if (anchor && head) {
var map = TableOffsetMap.create(anchor);
var selectionInfo = map.getRectOffsets(anchor, head);
var targetColIdx = direction === Direction.LEFT ? selectionInfo.startColIdx : selectionInfo.endColIdx + 1;
var columnCount = getRowAndColumnCount(selectionInfo).columnCount;
var totalRowCount = map.totalRowCount;
for (var rowIdx = 0; rowIdx < totalRowCount; rowIdx += 1) {
var cells = createDummyCells(columnCount, rowIdx, schema);
tr.insert(tr.mapping.map(map.posAt(rowIdx, targetColIdx)), cells);
}
dispatch(tr);
return true;
}
return false;
}; };
};
Table.prototype.removeColumn = function () {
return function () { return function (state, dispatch) {
var selection = state.selection, tr = state.tr;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
if (anchor && head) {
var map = TableOffsetMap.create(anchor);
var selectionInfo = map.getRectOffsets(anchor, head);
var totalColumnCount = map.totalColumnCount, totalRowCount = map.totalRowCount;
var columnCount = getRowAndColumnCount(selectionInfo).columnCount;
var selectedAllColumn = columnCount === totalColumnCount;
if (selectedAllColumn) {
return false;
}
var startColIdx = selectionInfo.startColIdx, endColIdx = selectionInfo.endColIdx;
var mapStart = tr.mapping.maps.length;
for (var rowIdx = 0; rowIdx < totalRowCount; rowIdx += 1) {
for (var colIdx = endColIdx; colIdx >= startColIdx; colIdx -= 1) {
var _b = map.getCellInfo(rowIdx, colIdx), offset = _b.offset, nodeSize = _b.nodeSize;
var from = tr.mapping.slice(mapStart).map(offset);
var to = from + nodeSize;
tr.delete(from, to);
}
}
dispatch(tr);
return true;
}
return false;
}; };
};
Table.prototype.addRow = function (direction) {
return function () { return function (state, dispatch) {
var selection = state.selection, schema = state.schema, tr = state.tr;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
if (anchor && head) {
var map = TableOffsetMap.create(anchor);
var totalColumnCount = map.totalColumnCount;
var selectionInfo = map.getRectOffsets(anchor, head);
var rowCount = getRowAndColumnCount(selectionInfo).rowCount;
var _b = getTargetRowInfo(direction, map, selectionInfo), targetRowIdx = _b.targetRowIdx, insertColIdx = _b.insertColIdx, nodeSize = _b.nodeSize;
var selectedThead = targetRowIdx === 0;
if (!selectedThead) {
var rows = [];
var from = tr.mapping.map(map.posAt(targetRowIdx, insertColIdx)) + nodeSize;
var cells = [];
for (var colIdx = 0; colIdx < totalColumnCount; colIdx += 1) {
cells = cells.concat(createDummyCells(1, targetRowIdx, schema));
}
for (var i = 0; i < rowCount; i += 1) {
rows.push(schema.nodes.tableRow.create(null, cells));
}
dispatch(tr.insert(from, rows));
return true;
}
}
return false;
}; };
};
Table.prototype.removeRow = function () {
return function () { return function (state, dispatch) {
var selection = state.selection, tr = state.tr;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
if (anchor && head) {
var map = TableOffsetMap.create(anchor);
var totalRowCount = map.totalRowCount, totalColumnCount = map.totalColumnCount;
var selectionInfo = map.getRectOffsets(anchor, head);
var rowCount = getRowAndColumnCount(selectionInfo).rowCount;
var startRowIdx = selectionInfo.startRowIdx, endRowIdx = selectionInfo.endRowIdx;
var selectedThead = startRowIdx === 0;
var selectedAllTbodyRow = rowCount === totalRowCount - 1;
if (selectedAllTbodyRow || selectedThead) {
return false;
}
for (var rowIdx = endRowIdx; rowIdx >= startRowIdx; rowIdx -= 1) {
var _b = getRowRanges(map, rowIdx, totalColumnCount), from = _b.from, to = _b.to;
// delete table row
tr.delete(from - 1, to + 1);
}
dispatch(tr);
return true;
}
return false;
}; };
};
Table.prototype.alignColumn = function () {
return function (payload) {
if (payload === void 0) { payload = { align: 'center' }; }
return function (state, dispatch) {
var align = payload.align;
var selection = state.selection, tr = state.tr;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
if (anchor && head) {
var map = TableOffsetMap.create(anchor);
var totalRowCount = map.totalRowCount;
var selectionInfo = map.getRectOffsets(anchor, head);
var startColIdx = selectionInfo.startColIdx, endColIdx = selectionInfo.endColIdx;
for (var rowIdx = 0; rowIdx < totalRowCount; rowIdx += 1) {
for (var colIdx = startColIdx; colIdx <= endColIdx; colIdx += 1) {
if (!map.extendedRowspan(rowIdx, colIdx) && !map.extendedColspan(rowIdx, colIdx)) {
var _b = map.getNodeAndPos(rowIdx, colIdx), node = _b.node, pos = _b.pos;
var attrs = setAttrs(node, { align: align });
tr.setNodeMarkup(pos, null, attrs);
}
}
}
dispatch(tr);
return true;
}
return false;
};
};
};
Table.prototype.moveToCell = function (direction) {
return function (state, dispatch) {
var selection = state.selection, tr = state.tr, schema = state.schema;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
if (anchor && head) {
var map = TableOffsetMap.create(anchor);
var cellIndex = map.getCellIndex(anchor);
var newTr = void 0;
if (canBeOutOfTable(direction, map, cellIndex)) {
// When there is no content before or after the table,
// an empty line('paragraph') is created by pressing the arrow keys.
newTr = addParagraphAfterTable(tr, map, schema);
}
else {
newTr = moveToCell(direction, tr, cellIndex, map);
}
if (newTr) {
dispatch(newTr);
return true;
}
}
return false;
};
};
Table.prototype.moveInCell = function (direction) {
var _this = this;
return function (state, dispatch) {
var selection = state.selection, tr = state.tr, doc = state.doc, schema = state.schema;
var $from = selection.$from;
var view = _this.context.view;
if (!view.endOfTextblock(direction)) {
return false;
}
var cell = findNodeBy($from, function (_a) {
var type = _a.type;
return type.name === 'tableHeadCell' || type.name === 'tableBodyCell';
});
if (cell) {
var para = findNodeBy($from, function (_a) {
var type = _a.type;
return type.name === 'paragraph';
});
var cellDepth = cell.depth;
if (para && canMoveBetweenCells(direction, [cellDepth, para.depth], $from, doc)) {
var anchor = getResolvedSelection(selection).anchor;
var map = TableOffsetMap.create(anchor);
var cellIndex = map.getCellIndex(anchor);
var newTr = void 0;
if (canSelectTableNode(direction, map, cellIndex)) {
// When the cursor position is at the end of the cell,
// the table is selected when the left / right arrow keys are pressed.
newTr = selectNode(tr, $from, cellDepth);
}
else if (canBeOutOfTable(direction, map, cellIndex)) {
// When there is no content before or after the table,
// an empty line('paragraph') is created by pressing the arrow keys.
if (direction === Direction.UP) {
newTr = addParagraphBeforeTable(tr, map, schema);
}
else if (direction === Direction.DOWN) {
newTr = addParagraphAfterTable(tr, map, schema);
}
}
else {
newTr = moveToCell(direction, tr, cellIndex, map);
}
if (newTr) {
dispatch(newTr);
return true;
}
}
}
return false;
};
};
Table.prototype.deleteCells = function () {
return function (state, dispatch) {
var schema = state.schema, selection = state.selection, tr = state.tr;
var _a = getResolvedSelection(selection), anchor = _a.anchor, head = _a.head;
var textSelection = selection instanceof external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.TextSelection;
if (anchor && head && !textSelection) {
var map = TableOffsetMap.create(anchor);
var _b = map.getRectOffsets(anchor, head), startRowIdx = _b.startRowIdx, startColIdx = _b.startColIdx, endRowIdx = _b.endRowIdx, endColIdx = _b.endColIdx;
for (var rowIdx = startRowIdx; rowIdx <= endRowIdx; rowIdx += 1) {
for (var colIdx = startColIdx; colIdx <= endColIdx; colIdx += 1) {
if (!map.extendedRowspan(rowIdx, colIdx) && !map.extendedColspan(rowIdx, colIdx)) {
var _c = map.getNodeAndPos(rowIdx, colIdx), node = _c.node, pos = _c.pos;
var cells = createDummyCells(1, rowIdx, schema, node.attrs);
tr.replaceWith(tr.mapping.map(pos), tr.mapping.map(pos + node.nodeSize), cells);
}
}
}
dispatch(tr);
return true;
}
return false;
};
};
Table.prototype.exitTable = function () {
return function (state, dispatch) {
var selection = state.selection, tr = state.tr, schema = state.schema;
var $from = selection.$from;
var cell = findNodeBy($from, function (_a) {
var type = _a.type;
return type.name === 'tableHeadCell' || type.name === 'tableBodyCell';
});
if (cell) {
var para = findNodeBy($from, function (_a) {
var type = _a.type;
return type.name === 'paragraph';
});
if (para) {
var anchor = getResolvedSelection(selection).anchor;
var map = TableOffsetMap.create(anchor);
dispatch(addParagraphAfterTable(tr, map, schema, true));
return true;
}
}
return false;
};
};
Table.prototype.commands = function () {
return {
addTable: this.addTable(),
removeTable: this.removeTable(),
addColumnToLeft: this.addColumn(Direction.LEFT),
addColumnToRight: this.addColumn(Direction.RIGHT),
removeColumn: this.removeColumn(),
addRowToUp: this.addRow(Direction.UP),
addRowToDown: this.addRow(Direction.DOWN),
removeRow: this.removeRow(),
alignColumn: this.alignColumn(),
};
};
Table.prototype.keymaps = function () {
var deleteCellContent = this.deleteCells();
return {
Tab: this.moveToCell(Direction.RIGHT),
'Shift-Tab': this.moveToCell(Direction.LEFT),
ArrowUp: this.moveInCell(Direction.UP),
ArrowDown: this.moveInCell(Direction.DOWN),
ArrowLeft: this.moveInCell(Direction.LEFT),
ArrowRight: this.moveInCell(Direction.RIGHT),
Backspace: deleteCellContent,
'Mod-Backspace': deleteCellContent,
Delete: deleteCellContent,
'Mod-Delete': deleteCellContent,
'Mod-Enter': this.exitTable(),
};
};
return Table;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/tableHead.ts
var TableHead = /** @class */ (function (_super) {
__extends(TableHead, _super);
function TableHead() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TableHead.prototype, "name", {
get: function () {
return 'tableHead';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableHead.prototype, "schema", {
get: function () {
return {
content: 'tableRow{1}',
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [createDOMInfoParsedRawHTML('thead')],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['thead', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
return TableHead;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/tableBody.ts
var TableBody = /** @class */ (function (_super) {
__extends(TableBody, _super);
function TableBody() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TableBody.prototype, "name", {
get: function () {
return 'tableBody';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableBody.prototype, "schema", {
get: function () {
return {
content: 'tableRow+',
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [
{
tag: 'tbody',
getAttrs: function (dom) {
var rows = dom.querySelectorAll('tr');
var columns = rows[0].children.length;
var rawHTML = dom.getAttribute('data-raw-html');
if (!columns) {
return false;
}
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['tbody', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
return TableBody;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/tableRow.ts
var TableRow = /** @class */ (function (_super) {
__extends(TableRow, _super);
function TableRow() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TableRow.prototype, "name", {
get: function () {
return 'tableRow';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableRow.prototype, "schema", {
get: function () {
return {
content: '(tableHeadCell | tableBodyCell)*',
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [
{
tag: 'tr',
getAttrs: function (dom) {
var columns = dom.children.length;
var rawHTML = dom.getAttribute('data-raw-html');
if (!columns) {
return false;
}
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['tr', getCustomAttrs(attrs), 0];
},
};
},
enumerable: false,
configurable: true
});
return TableRow;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/tableHeadCell.ts
var TableHeadCell = /** @class */ (function (_super) {
__extends(TableHeadCell, _super);
function TableHeadCell() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TableHeadCell.prototype, "name", {
get: function () {
return 'tableHeadCell';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableHeadCell.prototype, "schema", {
get: function () {
return {
content: 'paragraph+',
attrs: __assign({ align: { default: null }, className: { default: null }, rawHTML: { default: null }, colspan: { default: null }, extended: { default: null } }, getDefaultCustomAttrs()),
isolating: true,
parseDOM: [createParsedCellDOM('th')],
toDOM: function (_a) {
var attrs = _a.attrs;
var cellAttrs = createCellAttrs(attrs);
return ['th', __assign(__assign({}, cellAttrs), getCustomAttrs(attrs)), 0];
},
};
},
enumerable: false,
configurable: true
});
return TableHeadCell;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/tableBodyCell.ts
var TableBodyCell = /** @class */ (function (_super) {
__extends(TableBodyCell, _super);
function TableBodyCell() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(TableBodyCell.prototype, "name", {
get: function () {
return 'tableBodyCell';
},
enumerable: false,
configurable: true
});
Object.defineProperty(TableBodyCell.prototype, "schema", {
get: function () {
return {
content: '(paragraph | bulletList | orderedList)+',
attrs: {
align: { default: null },
className: { default: null },
rawHTML: { default: null },
colspan: { default: null },
rowspan: { default: null },
extended: { default: null },
},
isolating: true,
parseDOM: [createParsedCellDOM('td')],
toDOM: function (_a) {
var attrs = _a.attrs;
var cellAttrs = createCellAttrs(attrs);
return ['td', cellAttrs, 0];
},
};
},
enumerable: false,
configurable: true
});
return TableBodyCell;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/image.ts
var Image = /** @class */ (function (_super) {
__extends(Image, _super);
function Image() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Image.prototype, "name", {
get: function () {
return 'image';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Image.prototype, "schema", {
get: function () {
return {
inline: true,
attrs: __assign({ imageUrl: { default: '' }, altText: { default: null }, rawHTML: { default: null } }, getDefaultCustomAttrs()),
group: 'inline',
selectable: false,
parseDOM: [
{
tag: 'img[src]',
getAttrs: function (dom) {
var sanitizedDOM = sanitizeHTML(dom, { RETURN_DOM_FRAGMENT: true })
.firstChild;
var imageUrl = sanitizedDOM.getAttribute('src') || '';
var rawHTML = sanitizedDOM.getAttribute('data-raw-html');
var altText = sanitizedDOM.getAttribute('alt');
return __assign({ imageUrl: imageUrl,
altText: altText }, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return [
attrs.rawHTML || 'img',
__assign(__assign({ src: escapeXml(attrs.imageUrl) }, (attrs.altText && { alt: attrs.altText })), getCustomAttrs(attrs)),
];
},
};
},
enumerable: false,
configurable: true
});
Image.prototype.addImage = function () {
return function (payload) { return function (_a, dispatch) {
var schema = _a.schema, tr = _a.tr;
var _b = payload, imageUrl = _b.imageUrl, altText = _b.altText;
if (!imageUrl) {
return false;
}
var node = schema.nodes.image.createAndFill(__assign({ imageUrl: imageUrl }, (altText && { altText: altText })));
dispatch(tr.replaceSelectionWith(node).scrollIntoView());
return true;
}; };
};
Image.prototype.commands = function () {
return {
addImage: this.addImage(),
};
};
return Image;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/thematicBreak.ts
var ROOT_BLOCK_DEPTH = 1;
var thematicBreak_ThematicBreak = /** @class */ (function (_super) {
__extends(ThematicBreak, _super);
function ThematicBreak() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(ThematicBreak.prototype, "name", {
get: function () {
return 'thematicBreak';
},
enumerable: false,
configurable: true
});
Object.defineProperty(ThematicBreak.prototype, "schema", {
get: function () {
return {
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
group: 'block',
parseDOM: [{ tag: 'hr' }],
selectable: false,
toDOM: function (_a) {
var attrs = _a.attrs;
return ['div', getCustomAttrs(attrs), [attrs.rawHTML || 'hr']];
},
};
},
enumerable: false,
configurable: true
});
ThematicBreak.prototype.hr = function () {
var _this = this;
return function () { return function (state, dispatch) {
var _a;
var _b = state.selection, $from = _b.$from, $to = _b.$to;
if ($from === $to) {
var doc = state.doc;
var _c = state.schema.nodes, thematicBreak = _c.thematicBreak, paragraph = _c.paragraph;
var nodes = [thematicBreak.create()];
var rootBlock = $from.node(ROOT_BLOCK_DEPTH);
var lastBlock = doc.child(doc.childCount - 1) === rootBlock;
var blockEnd = doc.resolve($from.after(ROOT_BLOCK_DEPTH));
var nextHr = ((_a = $from.nodeAfter) === null || _a === void 0 ? void 0 : _a.type.name) === _this.name;
if (lastBlock || nextHr) {
nodes.push(paragraph.create());
}
dispatch(state.tr.insert(blockEnd.pos, nodes).scrollIntoView());
return true;
}
return false;
}; };
};
ThematicBreak.prototype.commands = function () {
return { hr: this.hr() };
};
ThematicBreak.prototype.keymaps = function () {
var hrCommand = this.hr()();
return {
'Mod-l': hrCommand,
'Mod-L': hrCommand,
};
};
return ThematicBreak;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/marks/strong.ts
var strong_Strong = /** @class */ (function (_super) {
__extends(Strong, _super);
function Strong() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Strong.prototype, "name", {
get: function () {
return 'strong';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Strong.prototype, "schema", {
get: function () {
var parseDOM = ['b', 'strong'].map(function (tag) {
return {
tag: tag,
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
};
});
return {
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: parseDOM,
toDOM: function (_a) {
var attrs = _a.attrs;
return [attrs.rawHTML || 'strong', getCustomAttrs(attrs)];
},
};
},
enumerable: false,
configurable: true
});
Strong.prototype.bold = function () {
return function () { return function (state, dispatch) { return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.toggleMark)(state.schema.marks.strong)(state, dispatch); }; };
};
Strong.prototype.commands = function () {
return { bold: this.bold() };
};
Strong.prototype.keymaps = function () {
var boldCommand = this.bold()();
return {
'Mod-b': boldCommand,
'Mod-B': boldCommand,
};
};
return Strong;
}(mark));
;// CONCATENATED MODULE: ./src/wysiwyg/marks/emph.ts
var emph_Emph = /** @class */ (function (_super) {
__extends(Emph, _super);
function Emph() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Emph.prototype, "name", {
get: function () {
return 'emph';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Emph.prototype, "schema", {
get: function () {
var parseDOM = ['i', 'em'].map(function (tag) {
return {
tag: tag,
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
};
});
return {
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: parseDOM,
toDOM: function (_a) {
var attrs = _a.attrs;
return [attrs.rawHTML || 'em', getCustomAttrs(attrs)];
},
};
},
enumerable: false,
configurable: true
});
Emph.prototype.italic = function () {
return function () { return function (state, dispatch) { return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.toggleMark)(state.schema.marks.emph)(state, dispatch); }; };
};
Emph.prototype.commands = function () {
return { italic: this.italic() };
};
Emph.prototype.keymaps = function () {
var italicCommand = this.italic()();
return {
'Mod-i': italicCommand,
'Mod-I': italicCommand,
};
};
return Emph;
}(mark));
;// CONCATENATED MODULE: ./src/wysiwyg/marks/strike.ts
var strike_Strike = /** @class */ (function (_super) {
__extends(Strike, _super);
function Strike() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Strike.prototype, "name", {
get: function () {
return 'strike';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Strike.prototype, "schema", {
get: function () {
var parseDOM = ['s', 'del'].map(function (tag) {
return {
tag: tag,
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
};
});
return {
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: parseDOM,
toDOM: function (_a) {
var attrs = _a.attrs;
return [attrs.rawHTML || 'del', getCustomAttrs(attrs)];
},
};
},
enumerable: false,
configurable: true
});
Strike.prototype.commands = function () {
return function () { return function (state, dispatch) { return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.toggleMark)(state.schema.marks.strike)(state, dispatch); }; };
};
Strike.prototype.keymaps = function () {
var strikeCommand = this.commands()();
return {
'Mod-s': strikeCommand,
'Mod-S': strikeCommand,
};
};
return Strike;
}(mark));
;// CONCATENATED MODULE: ./src/wysiwyg/marks/link.ts
var link_Link = /** @class */ (function (_super) {
__extends(Link, _super);
function Link(linkAttributes) {
var _this = _super.call(this) || this;
_this.linkAttributes = linkAttributes;
return _this;
}
Object.defineProperty(Link.prototype, "name", {
get: function () {
return 'link';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Link.prototype, "schema", {
get: function () {
var _this = this;
return {
attrs: __assign({ linkUrl: { default: '' }, title: { default: null }, rawHTML: { default: null } }, getDefaultCustomAttrs()),
inclusive: false,
parseDOM: [
{
tag: 'a[href]',
getAttrs: function (dom) {
var sanitizedDOM = sanitizeHTML(dom, { RETURN_DOM_FRAGMENT: true })
.firstChild;
var href = sanitizedDOM.getAttribute('href') || '';
var title = sanitizedDOM.getAttribute('title') || '';
var rawHTML = sanitizedDOM.getAttribute('data-raw-html');
return __assign({ linkUrl: href, title: title }, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return [
attrs.rawHTML || 'a',
__assign(__assign({ href: escapeXml(attrs.linkUrl) }, _this.linkAttributes), getCustomAttrs(attrs)),
];
},
};
},
enumerable: false,
configurable: true
});
Link.prototype.addLink = function () {
return function (payload) { return function (state, dispatch) {
var _a = payload, linkUrl = _a.linkUrl, _b = _a.linkText, linkText = _b === void 0 ? '' : _b;
var schema = state.schema, tr = state.tr, selection = state.selection;
var empty = selection.empty, from = selection.from, to = selection.to;
if (from && to && linkUrl) {
var attrs = { linkUrl: linkUrl };
var mark = schema.mark('link', attrs);
if (empty && linkText) {
var node = createTextNode(schema, linkText, mark);
tr.replaceRangeWith(from, to, node);
}
else {
tr.addMark(from, to, mark);
}
dispatch(tr.scrollIntoView());
return true;
}
return false;
}; };
};
Link.prototype.toggleLink = function () {
return function (payload) { return function (state, dispatch) {
return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.toggleMark)(state.schema.marks.link, payload)(state, dispatch);
}; };
};
Link.prototype.commands = function () {
return {
addLink: this.addLink(),
toggleLink: this.toggleLink(),
};
};
return Link;
}(mark));
;// CONCATENATED MODULE: ./src/wysiwyg/marks/code.ts
var code_Code = /** @class */ (function (_super) {
__extends(Code, _super);
function Code() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(Code.prototype, "name", {
get: function () {
return 'code';
},
enumerable: false,
configurable: true
});
Object.defineProperty(Code.prototype, "schema", {
get: function () {
return {
attrs: __assign({ rawHTML: { default: null } }, getDefaultCustomAttrs()),
parseDOM: [
{
tag: 'code',
getAttrs: function (dom) {
var rawHTML = dom.getAttribute('data-raw-html');
return __assign({}, (rawHTML && { rawHTML: rawHTML }));
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return [attrs.rawHTML || 'code', getCustomAttrs(attrs)];
},
};
},
enumerable: false,
configurable: true
});
Code.prototype.commands = function () {
return function () { return function (state, dispatch) { return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.toggleMark)(state.schema.marks.code)(state, dispatch); }; };
};
Code.prototype.keymaps = function () {
var codeCommand = this.commands()();
return {
'Shift-Mod-c': codeCommand,
'Shift-Mod-C': codeCommand,
};
};
return Code;
}(mark));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/customBlock.ts
var customBlock_CustomBlock = /** @class */ (function (_super) {
__extends(CustomBlock, _super);
function CustomBlock() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(CustomBlock.prototype, "name", {
get: function () {
return 'customBlock';
},
enumerable: false,
configurable: true
});
Object.defineProperty(CustomBlock.prototype, "schema", {
get: function () {
return {
content: 'text*',
group: 'block',
attrs: {
info: { default: null },
},
atom: true,
code: true,
defining: true,
parseDOM: [
{
tag: 'div[data-custom-info]',
getAttrs: function (dom) {
var info = dom.getAttribute('data-custom-info');
return { info: info };
},
},
],
toDOM: function (_a) {
var attrs = _a.attrs;
return ['div', { 'data-custom-info': attrs.info || null }, 0];
},
};
},
enumerable: false,
configurable: true
});
CustomBlock.prototype.commands = function () {
return function (payload) { return function (state, dispatch) {
return (payload === null || payload === void 0 ? void 0 : payload.info)
? (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.setBlockType)(state.schema.nodes.customBlock, payload)(state, dispatch)
: false;
}; };
};
return CustomBlock;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/frontMatter.ts
var FrontMatter = /** @class */ (function (_super) {
__extends(FrontMatter, _super);
function FrontMatter() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(FrontMatter.prototype, "name", {
get: function () {
return 'frontMatter';
},
enumerable: false,
configurable: true
});
Object.defineProperty(FrontMatter.prototype, "schema", {
get: function () {
return {
content: 'text*',
group: 'block',
code: true,
defining: true,
parseDOM: [
{
preserveWhitespace: 'full',
tag: 'div[data-front-matter]',
},
],
toDOM: function () {
return ['div', { 'data-front-matter': 'true' }, 0];
},
};
},
enumerable: false,
configurable: true
});
FrontMatter.prototype.commands = function () {
return function () { return function (state, dispatch, view) {
var $from = state.selection.$from;
if (view.endOfTextblock('down') && $from.node().type.name === 'frontMatter') {
return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.exitCode)(state, dispatch);
}
return false;
}; };
};
FrontMatter.prototype.keymaps = function () {
return {
Enter: this.commands()(),
};
};
return FrontMatter;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/nodes/htmlComment.ts
var HTMLComment = /** @class */ (function (_super) {
__extends(HTMLComment, _super);
function HTMLComment() {
return _super !== null && _super.apply(this, arguments) || this;
}
Object.defineProperty(HTMLComment.prototype, "name", {
get: function () {
return 'htmlComment';
},
enumerable: false,
configurable: true
});
Object.defineProperty(HTMLComment.prototype, "schema", {
get: function () {
return {
content: 'text*',
group: 'block',
code: true,
defining: true,
parseDOM: [{ preserveWhitespace: 'full', tag: 'div[data-html-comment]' }],
toDOM: function () {
return ['div', { 'data-html-comment': 'true' }, 0];
},
};
},
enumerable: false,
configurable: true
});
HTMLComment.prototype.commands = function () {
return function () { return function (state, dispatch, view) {
var $from = state.selection.$from;
if (view.endOfTextblock('down') && $from.node().type.name === 'htmlComment') {
return (0,external_commonjs_prosemirror_commands_commonjs2_prosemirror_commands_amd_prosemirror_commands_.exitCode)(state, dispatch);
}
return false;
}; };
};
HTMLComment.prototype.keymaps = function () {
return {
Enter: this.commands()(),
};
};
return HTMLComment;
}(node));
;// CONCATENATED MODULE: ./src/wysiwyg/specCreator.ts
function createSpecs(linkAttributes) {
return new specManager([
new doc_Doc(),
new paragraph_Paragraph(),
new text_Text(),
new heading_Heading(),
new codeBlock_CodeBlock(),
new BulletList(),
new OrderedList(),
new listItem_ListItem(),
new blockQuote_BlockQuote(),
new table_Table(),
new TableHead(),
new TableBody(),
new TableRow(),
new TableHeadCell(),
new TableBodyCell(),
new Image(),
new thematicBreak_ThematicBreak(),
new strong_Strong(),
new emph_Emph(),
new strike_Strike(),
new link_Link(linkAttributes),
new code_Code(),
new customBlock_CustomBlock(),
new FrontMatter(),
new Widget(),
new HTMLComment(),
]);
}
;// CONCATENATED MODULE: ./src/wysiwyg/wwEditor.ts
var CONTENTS_CLASS_NAME = cls('contents');
var WysiwygEditor = /** @class */ (function (_super) {
__extends(WysiwygEditor, _super);
function WysiwygEditor(eventEmitter, options) {
var _this = _super.call(this, eventEmitter) || this;
var toDOMAdaptor = options.toDOMAdaptor, _a = options.htmlSchemaMap, htmlSchemaMap = _a === void 0 ? {} : _a, _b = options.linkAttributes, linkAttributes = _b === void 0 ? {} : _b, _c = options.useCommandShortcut, useCommandShortcut = _c === void 0 ? true : _c, _d = options.wwPlugins, wwPlugins = _d === void 0 ? [] : _d, _e = options.wwNodeViews, wwNodeViews = _e === void 0 ? {} : _e;
_this.editorType = 'wysiwyg';
_this.el.classList.add('ww-mode');
_this.toDOMAdaptor = toDOMAdaptor;
_this.linkAttributes = linkAttributes;
_this.extraPlugins = wwPlugins;
_this.pluginNodeViews = wwNodeViews;
_this.specs = _this.createSpecs();
_this.schema = _this.createSchema(htmlSchemaMap);
_this.context = _this.createContext();
_this.keymaps = _this.createKeymaps(useCommandShortcut);
_this.view = _this.createView();
_this.commands = _this.createCommands();
_this.specs.setContext(__assign(__assign({}, _this.context), { view: _this.view }));
_this.initEvent();
return _this;
}
WysiwygEditor.prototype.createSpecs = function () {
return createSpecs(this.linkAttributes);
};
WysiwygEditor.prototype.createContext = function () {
return {
schema: this.schema,
eventEmitter: this.eventEmitter,
};
};
WysiwygEditor.prototype.createSchema = function (htmlSchemaMap) {
return new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Schema({
nodes: __assign(__assign({}, this.specs.nodes), htmlSchemaMap.nodes),
marks: __assign(__assign({}, this.specs.marks), htmlSchemaMap.marks),
});
};
WysiwygEditor.prototype.createPlugins = function () {
return __spreadArray([
tableSelection(),
tableContextMenu(this.eventEmitter),
task(),
toolbarStateHighlight(this.eventEmitter)
], this.createPluginProps()).concat(this.defaultPlugins);
};
WysiwygEditor.prototype.createPluginNodeViews = function () {
var _a = this, eventEmitter = _a.eventEmitter, pluginNodeViews = _a.pluginNodeViews;
var pluginNodeViewMap = {};
if (pluginNodeViews) {
Object.keys(pluginNodeViews).forEach(function (key) {
pluginNodeViewMap[key] = function (node, view, getPos) {
return pluginNodeViews[key](node, view, getPos, eventEmitter);
};
});
}
return pluginNodeViewMap;
};
WysiwygEditor.prototype.createView = function () {
var _this = this;
var _a = this, toDOMAdaptor = _a.toDOMAdaptor, eventEmitter = _a.eventEmitter;
return new external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.EditorView(this.el, {
state: this.createState(),
attributes: {
class: CONTENTS_CLASS_NAME,
},
nodeViews: __assign({ customBlock: function (node, view, getPos) {
return new CustomBlockView(node, view, getPos, toDOMAdaptor);
},
image: function (node, view, getPos) {
return new ImageView(node, view, getPos, eventEmitter);
},
codeBlock: function (node, view, getPos) {
return new CodeBlockView(node, view, getPos, eventEmitter);
}, widget: widgetNodeView }, this.createPluginNodeViews()),
dispatchTransaction: function (tr) {
var state = _this.view.state.applyTransaction(tr).state;
_this.view.updateState(state);
_this.emitChangeEvent(tr.scrollIntoView());
_this.eventEmitter.emit('setFocusedNode', state.selection.$from.node(1));
},
transformPastedHTML: changePastedHTML,
transformPasted: function (slice) {
return changePastedSlice(slice, _this.schema, isInTableNode(_this.view.state.selection.$from));
},
handlePaste: function (view, _, slice) { return pasteToTable(view, slice); },
handleKeyDown: function (_, ev) {
_this.eventEmitter.emit('keydown', _this.editorType, ev);
return false;
},
handleDOMEvents: {
paste: function (_, ev) {
var clipboardData = ev.clipboardData || window.clipboardData;
var items = clipboardData === null || clipboardData === void 0 ? void 0 : clipboardData.items;
if (items) {
var containRtfItem = toArray_default()(items).some(function (item) { return item.kind === 'string' && item.type === 'text/rtf'; });
// if it contains rtf, it's most likely copy paste from office -> no image
if (!containRtfItem) {
var imageBlob = pasteImageOnly(items);
if (imageBlob) {
ev.preventDefault();
emitImageBlobHook(_this.eventEmitter, imageBlob, ev.type);
}
}
}
return false;
},
keyup: function (_, ev) {
_this.eventEmitter.emit('keyup', _this.editorType, ev);
return false;
},
scroll: function () {
_this.eventEmitter.emit('scroll', 'editor');
return true;
},
},
});
};
WysiwygEditor.prototype.createCommands = function () {
return this.specs.commands(this.view, getWwCommands());
};
WysiwygEditor.prototype.getHTML = function () {
return removeProseMirrorHackNodes(this.view.dom.innerHTML);
};
WysiwygEditor.prototype.getModel = function () {
return this.view.state.doc;
};
WysiwygEditor.prototype.getSelection = function () {
var _a = this.view.state.selection, from = _a.from, to = _a.to;
return [from, to];
};
WysiwygEditor.prototype.getSchema = function () {
return this.view.state.schema;
};
WysiwygEditor.prototype.replaceSelection = function (text, start, end) {
var _a = this.view.state, schema = _a.schema, tr = _a.tr;
var lineTexts = text.split('\n');
var paras = lineTexts.map(function (lineText) {
return createParagraph(schema, createNodesWithWidget(lineText, schema));
});
var slice = new external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Slice(external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment.from(paras), 1, 1);
var newTr = isNumber_default()(start) && isNumber_default()(end)
? tr.replaceRange(start, end, slice)
: tr.replaceSelection(slice);
this.view.dispatch(newTr);
this.focus();
};
WysiwygEditor.prototype.deleteSelection = function (start, end) {
var tr = this.view.state.tr;
var newTr = isNumber_default()(start) && isNumber_default()(end) ? tr.deleteRange(start, end) : tr.deleteSelection();
this.view.dispatch(newTr.scrollIntoView());
};
WysiwygEditor.prototype.getSelectedText = function (start, end) {
var _a = this.view.state, doc = _a.doc, selection = _a.selection;
var from = selection.from, to = selection.to;
if (isNumber_default()(start) && isNumber_default()(end)) {
from = start;
to = end;
}
return doc.textBetween(from, to, '\n');
};
WysiwygEditor.prototype.setModel = function (newDoc, cursorToEnd) {
if (cursorToEnd === void 0) { cursorToEnd = false; }
var _a = this.view.state, tr = _a.tr, doc = _a.doc;
this.view.dispatch(tr.replaceWith(0, doc.content.size, newDoc));
if (cursorToEnd) {
this.moveCursorToEnd(true);
}
};
WysiwygEditor.prototype.setSelection = function (start, end) {
if (end === void 0) { end = start; }
var tr = this.view.state.tr;
var selection = createTextSelection(tr, start, end);
this.view.dispatch(tr.setSelection(selection).scrollIntoView());
};
WysiwygEditor.prototype.addWidget = function (node, style, pos) {
var _a = this.view, dispatch = _a.dispatch, state = _a.state;
dispatch(state.tr.setMeta('widget', { pos: pos !== null && pos !== void 0 ? pos : state.selection.to, node: node, style: style }));
};
WysiwygEditor.prototype.replaceWithWidget = function (start, end, text) {
var _a = this.view.state, tr = _a.tr, schema = _a.schema;
var nodes = createNodesWithWidget(text, schema);
this.view.dispatch(tr.replaceWith(start, end, nodes));
};
WysiwygEditor.prototype.getRangeInfoOfNode = function (pos) {
var _a = this.view.state, doc = _a.doc, selection = _a.selection;
var $pos = pos ? doc.resolve(pos) : selection.$from;
var marks = $pos.marks();
var node = $pos.node();
var start = $pos.start();
var end = $pos.end();
var type = node.type.name;
if (marks.length || type === 'paragraph') {
var mark_1 = marks[marks.length - 1];
var maybeHasMark_1 = function (nodeMarks) {
return nodeMarks.length ? common_includes(nodeMarks, mark_1) : true;
};
type = mark_1 ? mark_1.type.name : 'text';
node.forEach(function (child, offset) {
var isText = child.isText, nodeSize = child.nodeSize, nodeMarks = child.marks;
var startOffset = $pos.pos - start;
if (isText &&
offset <= startOffset &&
offset + nodeSize >= startOffset &&
maybeHasMark_1(nodeMarks)) {
start = start + offset;
end = start + nodeSize;
}
});
}
return { range: [start, end], type: type };
};
return WysiwygEditor;
}(base));
/* harmony default export */ var wwEditor = (WysiwygEditor);
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isFalsy.js
var isFalsy = __webpack_require__(404);
var isFalsy_default = /*#__PURE__*/__webpack_require__.n(isFalsy);
;// CONCATENATED MODULE: ./src/event/eventEmitter.ts
var eventTypeList = [
'afterPreviewRender',
'updatePreview',
'changeMode',
'needChangeMode',
'command',
'changePreviewStyle',
'changePreviewTabPreview',
'changePreviewTabWrite',
'scroll',
'contextmenu',
'show',
'hide',
'changeLanguage',
'changeToolbarState',
'toggleScrollSync',
'mixinTableOffsetMapPrototype',
'setFocusedNode',
'removePopupWidget',
'query',
// provide event for user
'openPopup',
'closePopup',
'addImageBlobHook',
'beforePreviewRender',
'beforeConvertWysiwygToMarkdown',
'load',
'loadUI',
'change',
'caretChange',
'destroy',
'focus',
'blur',
'keydown',
'keyup',
];
/**
* Class EventEmitter
* @ignore
*/
var EventEmitter = /** @class */ (function () {
function EventEmitter() {
var _this = this;
this.events = new utils_map();
this.eventTypes = eventTypeList.reduce(function (types, type) {
return __assign(__assign({}, types), { type: type });
}, {});
this.hold = false;
eventTypeList.forEach(function (eventType) {
_this.addEventType(eventType);
});
}
/**
* Listen event and bind event handler
* @param {string} type Event type string
* @param {function} handler Event handler
*/
EventEmitter.prototype.listen = function (type, handler) {
var typeInfo = this.getTypeInfo(type);
var eventHandlers = this.events.get(typeInfo.type) || [];
if (!this.hasEventType(typeInfo.type)) {
throw new Error("There is no event type " + typeInfo.type);
}
if (typeInfo.namespace) {
handler.namespace = typeInfo.namespace;
}
eventHandlers.push(handler);
this.events.set(typeInfo.type, eventHandlers);
};
/**
* Emit event
* @param {string} eventName Event name to emit
* @returns {Array}
*/
EventEmitter.prototype.emit = function (type) {
var args = [];
for (var _i = 1; _i < arguments.length; _i++) {
args[_i - 1] = arguments[_i];
}
var typeInfo = this.getTypeInfo(type);
var eventHandlers = this.events.get(typeInfo.type);
var results = [];
if (!this.hold && eventHandlers) {
eventHandlers.forEach(function (handler) {
var result = handler.apply(void 0, args);
if (!isUndefined_default()(result)) {
results.push(result);
}
});
}
return results;
};
/**
* Emit given event and return result
* @param {string} eventName Event name to emit
* @param {any} source Source to change
* @returns {string}
*/
EventEmitter.prototype.emitReduce = function (type, source) {
var args = [];
for (var _i = 2; _i < arguments.length; _i++) {
args[_i - 2] = arguments[_i];
}
var eventHandlers = this.events.get(type);
if (!this.hold && eventHandlers) {
eventHandlers.forEach(function (handler) {
var result = handler.apply(void 0, __spreadArray([source], args));
if (!isFalsy_default()(result)) {
source = result;
}
});
}
return source;
};
/**
* Get event type and namespace
* @param {string} type Event type name
* @returns {{type: string, namespace: string}}
* @private
*/
EventEmitter.prototype.getTypeInfo = function (type) {
var splited = type.split('.');
return {
type: splited[0],
namespace: splited[1],
};
};
/**
* Check whether event type exists or not
* @param {string} type Event type name
* @returns {boolean}
* @private
*/
EventEmitter.prototype.hasEventType = function (type) {
return !isUndefined_default()(this.eventTypes[this.getTypeInfo(type).type]);
};
/**
* Add event type when given event not exists
* @param {string} type Event type name
*/
EventEmitter.prototype.addEventType = function (type) {
if (this.hasEventType(type)) {
throw new Error("There is already have event type " + type);
}
this.eventTypes[type] = type;
};
/**
* Remove event handler from given event type
* @param {string} eventType Event type name
* @param {function} [handler] - registered event handler
*/
EventEmitter.prototype.removeEventHandler = function (eventType, handler) {
var _this = this;
var _a = this.getTypeInfo(eventType), type = _a.type, namespace = _a.namespace;
if (type && handler) {
this.removeEventHandlerWithHandler(type, handler);
}
else if (type && !namespace) {
this.events.delete(type);
}
else if (!type && namespace) {
this.events.forEach(function (_, evtType) {
_this.removeEventHandlerWithTypeInfo(evtType, namespace);
});
}
else if (type && namespace) {
this.removeEventHandlerWithTypeInfo(type, namespace);
}
};
/**
* Remove event handler with event handler
* @param {string} type - event type name
* @param {function} handler - event handler
* @private
*/
EventEmitter.prototype.removeEventHandlerWithHandler = function (type, handler) {
var eventHandlers = this.events.get(type);
if (eventHandlers) {
var handlerIndex = eventHandlers.indexOf(handler);
if (eventHandlers.indexOf(handler) >= 0) {
eventHandlers.splice(handlerIndex, 1);
}
}
};
/**
* Remove event handler with event type information
* @param {string} type Event type name
* @param {string} namespace Event namespace
* @private
*/
EventEmitter.prototype.removeEventHandlerWithTypeInfo = function (type, namespace) {
var handlersToSurvive = [];
var eventHandlers = this.events.get(type);
if (!eventHandlers) {
return;
}
eventHandlers.map(function (handler) {
if (handler.namespace !== namespace) {
handlersToSurvive.push(handler);
}
return null;
});
this.events.set(type, handlersToSurvive);
};
EventEmitter.prototype.getEvents = function () {
return this.events;
};
EventEmitter.prototype.holdEventInvoke = function (fn) {
this.hold = true;
fn();
this.hold = false;
};
return EventEmitter;
}());
/* harmony default export */ var eventEmitter = (EventEmitter);
;// CONCATENATED MODULE: ./src/commands/commandManager.ts
var CommandManager = /** @class */ (function () {
function CommandManager(eventEmitter, mdCommands, wwCommands, getEditorType) {
this.eventEmitter = eventEmitter;
this.mdCommands = mdCommands;
this.wwCommands = wwCommands;
this.getEditorType = getEditorType;
this.initEvent();
}
CommandManager.prototype.initEvent = function () {
var _this = this;
this.eventEmitter.listen('command', function (command, payload) {
_this.exec(command, payload);
});
};
CommandManager.prototype.addCommand = function (type, name, command) {
if (type === 'markdown') {
this.mdCommands[name] = command;
}
else {
this.wwCommands[name] = command;
}
};
CommandManager.prototype.deleteCommand = function (type, name) {
if (type === 'markdown') {
delete this.mdCommands[name];
}
else {
delete this.wwCommands[name];
}
};
CommandManager.prototype.exec = function (name, payload) {
var type = this.getEditorType();
if (type === 'markdown') {
this.mdCommands[name](payload);
}
else {
this.wwCommands[name](payload);
}
};
return CommandManager;
}());
/* harmony default export */ var commandManager = (CommandManager);
;// CONCATENATED MODULE: ./src/convertors/toWysiwyg/htmlToWwConvertors.ts
function getTextWithoutTrailingNewline(text) {
return text[text.length - 1] === '\n' ? text.slice(0, text.length - 1) : text;
}
function isCustomHTMLInlineNode(_a, node) {
var schema = _a.schema;
var html = node.literal;
var matched = html.match(reHTMLTag);
if (matched) {
var openTagName = matched[1], closeTagName = matched[3];
var typeName = (openTagName || closeTagName).toLowerCase();
return node.type === 'htmlInline' && !!(schema.marks[typeName] || schema.nodes[typeName]);
}
return false;
}
function htmlToWwConvertors_isInlineNode(_a) {
var type = _a.type;
return common_includes(['text', 'strong', 'emph', 'strike', 'image', 'link', 'code'], type);
}
function isSoftbreak(mdNode) {
return (mdNode === null || mdNode === void 0 ? void 0 : mdNode.type) === 'softbreak';
}
function htmlToWwConvertors_isListNode(_a) {
var type = _a.type, literal = _a.literal;
var matched = type === 'htmlInline' && literal.match(reHTMLTag);
if (matched) {
var openTagName = matched[1], closeTagName = matched[3];
var tagName = openTagName || closeTagName;
if (tagName) {
return common_includes(['ul', 'ol', 'li'], tagName.toLowerCase());
}
}
return false;
}
function getListItemAttrs(_a) {
var literal = _a.literal;
var task = /data-task/.test(literal);
var checked = /data-task-checked/.test(literal);
return { task: task, checked: checked };
}
function getMatchedAttributeValue(rawHTML) {
var attrNames = [];
for (var _i = 1; _i < arguments.length; _i++) {
attrNames[_i - 1] = arguments[_i];
}
var wrapper = document.createElement('div');
wrapper.innerHTML = sanitizeHTML(rawHTML);
var el = wrapper.firstChild;
return attrNames.map(function (attrName) { return el.getAttribute(attrName) || ''; });
}
function createConvertors(convertors) {
var convertorMap = {};
Object.keys(convertors).forEach(function (key) {
var tagNames = key.split(', ');
tagNames.forEach(function (tagName) {
var name = tagName.toLowerCase();
convertorMap[name] = convertors[key];
});
});
return convertorMap;
}
var convertors = {
'b, strong': function (state, _, openTagName) {
var strong = state.schema.marks.strong;
if (openTagName) {
state.openMark(strong.create({ rawHTML: openTagName }));
}
else {
state.closeMark(strong);
}
},
'i, em': function (state, _, openTagName) {
var emph = state.schema.marks.emph;
if (openTagName) {
state.openMark(emph.create({ rawHTML: openTagName }));
}
else {
state.closeMark(emph);
}
},
's, del': function (state, _, openTagName) {
var strike = state.schema.marks.strike;
if (openTagName) {
state.openMark(strike.create({ rawHTML: openTagName }));
}
else {
state.closeMark(strike);
}
},
code: function (state, _, openTagName) {
var code = state.schema.marks.code;
if (openTagName) {
state.openMark(code.create({ rawHTML: openTagName }));
}
else {
state.closeMark(code);
}
},
a: function (state, node, openTagName) {
var tag = node.literal;
var link = state.schema.marks.link;
if (openTagName) {
var linkUrl = getMatchedAttributeValue(tag, 'href')[0];
state.openMark(link.create({
linkUrl: linkUrl,
rawHTML: openTagName,
}));
}
else {
state.closeMark(link);
}
},
img: function (state, node, openTagName) {
var tag = node.literal;
if (openTagName) {
var _a = getMatchedAttributeValue(tag, 'src', 'alt'), imageUrl = _a[0], altText = _a[1];
var image = state.schema.nodes.image;
state.addNode(image, __assign({ rawHTML: openTagName, imageUrl: imageUrl }, (altText && { altText: altText })));
}
},
hr: function (state, _, openTagName) {
state.addNode(state.schema.nodes.thematicBreak, { rawHTML: openTagName });
},
br: function (state, node) {
var paragraph = state.schema.nodes.paragraph;
var parent = node.parent, prev = node.prev, next = node.next;
if ((parent === null || parent === void 0 ? void 0 : parent.type) === 'paragraph') {
// should open a paragraph node when line text has only tag
// ex) first line\n\n \nfourth line
if (isSoftbreak(prev)) {
state.openNode(paragraph);
}
// should close a paragraph node when line text has only tag
// ex) first line\n\n \nfourth line
if (isSoftbreak(next)) {
state.closeNode();
// should close a paragraph node and open a paragraph node to separate between blocks
// when tag is in the middle of the paragraph
// ex) first line\nthird line
}
else if (next) {
state.closeNode();
state.openNode(paragraph);
}
}
else if ((parent === null || parent === void 0 ? void 0 : parent.type) === 'tableCell') {
if (prev && (htmlToWwConvertors_isInlineNode(prev) || isCustomHTMLInlineNode(state, prev))) {
state.closeNode();
}
if (next && (htmlToWwConvertors_isInlineNode(next) || isCustomHTMLInlineNode(state, next))) {
state.openNode(paragraph);
}
}
},
pre: function (state, node, openTagName) {
var _a, _b;
var container = document.createElement('div');
container.innerHTML = node.literal;
var literal = (_b = (_a = container.firstChild) === null || _a === void 0 ? void 0 : _a.firstChild) === null || _b === void 0 ? void 0 : _b.textContent;
state.openNode(state.schema.nodes.codeBlock, { rawHTML: openTagName });
state.addText(getTextWithoutTrailingNewline(literal));
state.closeNode();
},
'ul, ol': function (state, node, openTagName) {
// in the table cell, '
', '' is parsed as 'htmlInline' node
if (node.parent.type === 'tableCell') {
var _a = state.schema.nodes, bulletList = _a.bulletList, orderedList = _a.orderedList, paragraph = _a.paragraph;
var list = openTagName === 'ul' ? bulletList : orderedList;
if (openTagName) {
if (node.prev && !htmlToWwConvertors_isListNode(node.prev)) {
state.closeNode();
}
state.openNode(list, { rawHTML: openTagName });
}
else {
state.closeNode();
if (node.next && !htmlToWwConvertors_isListNode(node.next)) {
state.openNode(paragraph);
}
}
}
},
li: function (state, node, openTagName) {
var _a;
// in the table cell, '' is parsed as 'htmlInline' node
if (((_a = node.parent) === null || _a === void 0 ? void 0 : _a.type) === 'tableCell') {
var _b = state.schema.nodes, listItem = _b.listItem, paragraph = _b.paragraph;
if (openTagName) {
var attrs = getListItemAttrs(node);
if (node.prev && !htmlToWwConvertors_isListNode(node.prev)) {
state.closeNode();
}
state.openNode(listItem, __assign({ rawHTML: openTagName }, attrs));
if (node.next && !htmlToWwConvertors_isListNode(node.next)) {
state.openNode(paragraph);
}
}
else {
if (node.prev && !htmlToWwConvertors_isListNode(node.prev)) {
state.closeNode();
}
state.closeNode();
}
}
},
};
var htmlToWwConvertors = createConvertors(convertors);
;// CONCATENATED MODULE: ./src/convertors/toWysiwyg/toWwConvertors.ts
function isBRTag(node) {
return node.type === 'htmlInline' && reBR.test(node.literal);
}
function addRawHTMLAttributeToDOM(parent) {
toArray_default()(parent.childNodes).forEach(function (child) {
if (isElemNode(child)) {
var openTagName = child.nodeName.toLowerCase();
child.setAttribute('data-raw-html', openTagName);
if (child.childNodes) {
addRawHTMLAttributeToDOM(child);
}
}
});
}
var toWwConvertors = {
text: function (state, node) {
state.addText(node.literal || '');
},
paragraph: function (state, node, _a, customAttrs) {
var _b;
var entering = _a.entering;
if (entering) {
var paragraph = state.schema.nodes.paragraph;
// The `\n\n` entered in markdown separates the paragraph.
// When changing to wysiwyg, a newline is added between the two paragraphs.
if (((_b = node.prev) === null || _b === void 0 ? void 0 : _b.type) === 'paragraph') {
state.openNode(paragraph, customAttrs);
state.closeNode();
}
state.openNode(paragraph, customAttrs);
}
else {
state.closeNode();
}
},
heading: function (state, node, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
var _b = node, level = _b.level, headingType = _b.headingType;
state.openNode(state.schema.nodes.heading, __assign({ level: level, headingType: headingType }, customAttrs));
}
else {
state.closeNode();
}
},
codeBlock: function (state, node, customAttrs) {
var codeBlock = state.schema.nodes.codeBlock;
var _a = node, info = _a.info, literal = _a.literal;
state.openNode(codeBlock, __assign({ language: info }, customAttrs));
state.addText(getTextWithoutTrailingNewline(literal || ''));
state.closeNode();
},
list: function (state, node, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
var _b = state.schema.nodes, bulletList = _b.bulletList, orderedList = _b.orderedList;
var _c = node.listData, type = _c.type, start = _c.start;
if (type === 'bullet') {
state.openNode(bulletList, customAttrs);
}
else {
state.openNode(orderedList, __assign({ order: start }, customAttrs));
}
}
else {
state.closeNode();
}
},
item: function (state, node, _a, customAttrs) {
var entering = _a.entering;
var listItem = state.schema.nodes.listItem;
var _b = node.listData, task = _b.task, checked = _b.checked;
if (entering) {
var attrs = __assign(__assign(__assign({}, (task && { task: task })), (checked && { checked: checked })), customAttrs);
state.openNode(listItem, attrs);
}
else {
state.closeNode();
}
},
blockQuote: function (state, _, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
state.openNode(state.schema.nodes.blockQuote, customAttrs);
}
else {
state.closeNode();
}
},
image: function (state, node, _a, customAttrs) {
var entering = _a.entering, skipChildren = _a.skipChildren;
var image = state.schema.nodes.image;
var _b = node, destination = _b.destination, firstChild = _b.firstChild;
if (entering && skipChildren) {
skipChildren();
}
state.addNode(image, __assign(__assign({ imageUrl: destination }, (firstChild && { altText: firstChild.literal })), customAttrs));
},
thematicBreak: function (state, node, _, customAttrs) {
state.addNode(state.schema.nodes.thematicBreak, customAttrs);
},
strong: function (state, _, _a, customAttrs) {
var entering = _a.entering;
var strong = state.schema.marks.strong;
if (entering) {
state.openMark(strong.create(customAttrs));
}
else {
state.closeMark(strong);
}
},
emph: function (state, _, _a, customAttrs) {
var entering = _a.entering;
var emph = state.schema.marks.emph;
if (entering) {
state.openMark(emph.create(customAttrs));
}
else {
state.closeMark(emph);
}
},
link: function (state, node, _a, customAttrs) {
var entering = _a.entering;
var link = state.schema.marks.link;
var _b = node, destination = _b.destination, title = _b.title;
if (entering) {
var attrs = __assign({ linkUrl: destination, title: title }, customAttrs);
state.openMark(link.create(attrs));
}
else {
state.closeMark(link);
}
},
softbreak: function (state, node) {
if (node.parent.type === 'paragraph') {
var prev = node.prev, next = node.next;
if (prev && !isBRTag(prev)) {
state.closeNode();
}
if (next && !isBRTag(next)) {
state.openNode(state.schema.nodes.paragraph);
}
}
},
// GFM specifications node
table: function (state, _, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
state.openNode(state.schema.nodes.table, customAttrs);
}
else {
state.closeNode();
}
},
tableHead: function (state, _, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
state.openNode(state.schema.nodes.tableHead, customAttrs);
}
else {
state.closeNode();
}
},
tableBody: function (state, _, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
state.openNode(state.schema.nodes.tableBody, customAttrs);
}
else {
state.closeNode();
}
},
tableRow: function (state, _, _a, customAttrs) {
var entering = _a.entering;
if (entering) {
state.openNode(state.schema.nodes.tableRow, customAttrs);
}
else {
state.closeNode();
}
},
tableCell: function (state, node, _a) {
var entering = _a.entering;
if (!node.ignored) {
var hasParaNode = function (childNode) {
return childNode && (htmlToWwConvertors_isInlineNode(childNode) || isCustomHTMLInlineNode(state, childNode));
};
if (entering) {
var _b = state.schema.nodes, tableHeadCell = _b.tableHeadCell, tableBodyCell = _b.tableBodyCell, paragraph = _b.paragraph;
var tablePart = node.parent.parent;
var cell = tablePart.type === 'tableHead' ? tableHeadCell : tableBodyCell;
var table = tablePart.parent;
var align = (table.columns[node.startIdx] || {}).align;
var attrs = __assign({}, node.attrs);
if (align) {
attrs.align = align;
}
state.openNode(cell, attrs);
if (hasParaNode(node.firstChild)) {
state.openNode(paragraph);
}
}
else {
if (hasParaNode(node.lastChild)) {
state.closeNode();
}
state.closeNode();
}
}
},
strike: function (state, _, _a, customAttrs) {
var entering = _a.entering;
var strike = state.schema.marks.strike;
if (entering) {
state.openMark(strike.create(customAttrs));
}
else {
state.closeMark(strike);
}
},
code: function (state, node, _, customAttrs) {
var code = state.schema.marks.code;
state.openMark(code.create(customAttrs));
state.addText(getTextWithoutTrailingNewline(node.literal || ''));
state.closeMark(code);
},
customBlock: function (state, node) {
var _a = state.schema.nodes, customBlock = _a.customBlock, paragraph = _a.paragraph;
var _b = node, info = _b.info, literal = _b.literal;
state.openNode(customBlock, { info: info });
state.addText(getTextWithoutTrailingNewline(literal || ''));
state.closeNode();
// add empty line to edit the content in next line
if (!node.next) {
state.openNode(paragraph);
state.closeNode();
}
},
frontMatter: function (state, node) {
state.openNode(state.schema.nodes.frontMatter);
state.addText(node.literal);
state.closeNode();
},
htmlInline: function (state, node) {
var html = node.literal;
var matched = html.match(reHTMLTag);
var openTagName = matched[1], closeTagName = matched[3];
var typeName = (openTagName || closeTagName).toLowerCase();
var markType = state.schema.marks[typeName];
var sanitizedHTML = sanitizeHTML(html);
// for user defined html schema
if (markType === null || markType === void 0 ? void 0 : markType.spec.attrs.htmlInline) {
if (openTagName) {
var htmlAttrs = getHTMLAttrsByHTMLString(sanitizedHTML);
state.openMark(markType.create({ htmlAttrs: htmlAttrs }));
}
else {
state.closeMark(markType);
}
}
else {
var htmlToWwConvertor = htmlToWwConvertors[typeName];
if (htmlToWwConvertor) {
htmlToWwConvertor(state, node, openTagName);
}
}
},
htmlBlock: function (state, node) {
var html = node.literal;
var container = document.createElement('div');
var isHTMLComment = reHTMLComment.test(html);
if (isHTMLComment) {
state.openNode(state.schema.nodes.htmlComment);
state.addText(node.literal);
state.closeNode();
}
else {
var matched = html.match(reHTMLTag);
var openTagName = matched[1], closeTagName = matched[3];
var typeName = (openTagName || closeTagName).toLowerCase();
var nodeType = state.schema.nodes[typeName];
var sanitizedHTML = sanitizeHTML(html);
// for user defined html schema
if (nodeType === null || nodeType === void 0 ? void 0 : nodeType.spec.attrs.htmlBlock) {
var htmlAttrs = getHTMLAttrsByHTMLString(sanitizedHTML);
var childrenHTML = getChildrenHTML(node, typeName);
state.addNode(nodeType, { htmlAttrs: htmlAttrs, childrenHTML: childrenHTML });
}
else {
container.innerHTML = sanitizedHTML;
addRawHTMLAttributeToDOM(container);
state.convertByDOMParser(container);
}
}
},
customInline: function (state, node, _a) {
var entering = _a.entering, skipChildren = _a.skipChildren;
var _b = node, info = _b.info, firstChild = _b.firstChild;
var schema = state.schema;
if (info.indexOf('widget') !== -1 && entering) {
var content = getWidgetContent(node);
skipChildren();
state.addNode(schema.nodes.widget, { info: info }, [
schema.text(createWidgetContent(info, content)),
]);
}
else {
var text = '$$';
if (entering) {
text += firstChild ? info + " " : info;
}
state.addText(text);
}
},
};
function createWwConvertors(customConvertors) {
var customConvertorTypes = Object.keys(customConvertors);
var convertors = __assign({}, toWwConvertors);
var renderer = new Renderer({
gfm: true,
nodeId: true,
convertors: customConvertors,
});
var orgConvertors = renderer.getConvertors();
customConvertorTypes.forEach(function (type) {
var wwConvertor = toWwConvertors[type];
if (wwConvertor && !common_includes(['htmlBlock', 'htmlInline'], type)) {
convertors[type] = function (state, node, context) {
context.origin = function () { return orgConvertors[type](node, context, orgConvertors); };
var tokens = customConvertors[type](node, context);
var attrs;
if (tokens) {
var _a = Array.isArray(tokens) ? tokens[0] : tokens, htmlAttrs = _a.attributes, classNames = _a.classNames;
attrs = { htmlAttrs: htmlAttrs, classNames: classNames };
}
wwConvertor(state, node, context, attrs);
};
}
});
return convertors;
}
;// CONCATENATED MODULE: ./src/convertors/toWysiwyg/toWwConvertorState.ts
function mergeMarkText(a, b) {
if (a.isText && b.isText && external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Mark.sameSet(a.marks, b.marks)) {
// @ts-ignore
// type is not defined for "withText" in prosemirror-model
return a.withText(a.text + b.text);
}
return false;
}
var ToWwConvertorState = /** @class */ (function () {
function ToWwConvertorState(schema, convertors) {
this.schema = schema;
this.convertors = convertors;
this.stack = [{ type: this.schema.topNodeType, attrs: null, content: [] }];
this.marks = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Mark.none;
}
ToWwConvertorState.prototype.top = function () {
return last(this.stack);
};
ToWwConvertorState.prototype.push = function (node) {
if (this.stack.length) {
this.top().content.push(node);
}
};
ToWwConvertorState.prototype.addText = function (text) {
if (text) {
var nodes = this.top().content;
var lastNode = last(nodes);
var node = this.schema.text(text, this.marks);
var merged = lastNode && mergeMarkText(lastNode, node);
if (merged) {
nodes[nodes.length - 1] = merged;
}
else {
nodes.push(node);
}
}
};
ToWwConvertorState.prototype.openMark = function (mark) {
this.marks = mark.addToSet(this.marks);
};
ToWwConvertorState.prototype.closeMark = function (mark) {
this.marks = mark.removeFromSet(this.marks);
};
ToWwConvertorState.prototype.addNode = function (type, attrs, content) {
var node = type.createAndFill(attrs, content, this.marks);
if (node) {
this.push(node);
return node;
}
return null;
};
ToWwConvertorState.prototype.openNode = function (type, attrs) {
this.stack.push({ type: type, attrs: attrs, content: [] });
};
ToWwConvertorState.prototype.closeNode = function () {
if (this.marks.length) {
this.marks = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Mark.none;
}
var _a = this.stack.pop(), type = _a.type, attrs = _a.attrs, content = _a.content;
return this.addNode(type, attrs, content);
};
ToWwConvertorState.prototype.convertByDOMParser = function (root) {
var _this = this;
var doc = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.DOMParser.fromSchema(this.schema).parse(root);
doc.content.forEach(function (node) { return _this.push(node); });
};
ToWwConvertorState.prototype.closeUnmatchedHTMLInline = function (node, entering) {
var _a;
if (!entering && node.type !== 'htmlInline') {
var length = this.stack.length - 1;
for (var i = length; i >= 0; i -= 1) {
var nodeInfo = this.stack[i];
if ((_a = nodeInfo.attrs) === null || _a === void 0 ? void 0 : _a.rawHTML) {
if (nodeInfo.content.length) {
this.closeNode();
}
else {
// just pop useless unmatched html inline node
this.stack.pop();
}
}
else {
break;
}
}
}
};
ToWwConvertorState.prototype.convert = function (mdNode, infoForPosSync) {
var walker = mdNode.walker();
var event = walker.next();
var _loop_1 = function () {
var node = event.node, entering = event.entering;
var convertor = this_1.convertors[node.type];
var skipped = false;
if (convertor) {
var context = {
entering: entering,
leaf: !isContainer(node),
getChildrenText: getChildrenText,
options: { gfm: true, nodeId: false, tagFilter: false, softbreak: '\n' },
skipChildren: function () {
skipped = true;
},
};
this_1.closeUnmatchedHTMLInline(node, entering);
convertor(this_1, node, context);
if ((infoForPosSync === null || infoForPosSync === void 0 ? void 0 : infoForPosSync.node) === node) {
var pos = this_1.stack.reduce(function (nodeSize, stackItem) {
return nodeSize +
stackItem.content.reduce(function (contentSize, pmNode) { return contentSize + pmNode.nodeSize; }, 0);
}, 0) + 1;
infoForPosSync.setMappedPos(pos);
}
}
if (skipped) {
walker.resumeAt(node, false);
walker.next();
}
event = walker.next();
};
var this_1 = this;
while (event) {
_loop_1();
}
};
ToWwConvertorState.prototype.convertNode = function (mdNode, infoForPosSync) {
this.convert(mdNode, infoForPosSync);
if (this.stack.length) {
return this.closeNode();
}
return null;
};
return ToWwConvertorState;
}());
/* harmony default export */ var toWwConvertorState = (ToWwConvertorState);
;// CONCATENATED MODULE: ./src/convertors/toMarkdown/toMdNodeTypeWriters.ts
function convertToRawHTMLHavingInlines(state, node, _a) {
var openTag = _a[0], closeTag = _a[1];
state.write(openTag);
state.convertInline(node);
state.write(closeTag);
}
function convertToRawHTMLHavingBlocks(state, _a, _b) {
var node = _a.node, parent = _a.parent;
var openTag = _b[0], closeTag = _b[1];
state.stopNewline = true;
state.write(openTag);
state.convertNode(node);
state.write(closeTag);
if ((parent === null || parent === void 0 ? void 0 : parent.type.name) === 'doc') {
state.closeBlock(node);
state.stopNewline = false;
}
}
function createTableHeadDelim(textContent, columnAlign) {
var textLen = textContent.length;
var leftDelim = '';
var rightDelim = '';
if (columnAlign === 'left') {
leftDelim = ':';
textLen -= 1;
}
else if (columnAlign === 'right') {
rightDelim = ':';
textLen -= 1;
}
else if (columnAlign === 'center') {
leftDelim = ':';
rightDelim = ':';
textLen -= 2;
}
return "" + leftDelim + repeat('-', Math.max(textLen, 3)) + rightDelim;
}
var nodeTypeWriters = {
text: function (state, _a) {
var _b;
var node = _a.node;
var text = (_b = node.text) !== null && _b !== void 0 ? _b : '';
if ((node.marks || []).some(function (mark) { return mark.type.name === 'link'; })) {
state.text(escapeTextForLink(text), false);
}
else {
state.text(text);
}
},
paragraph: function (state, _a) {
var node = _a.node, parent = _a.parent, _b = _a.index, index = _b === void 0 ? 0 : _b;
if (state.stopNewline) {
state.convertInline(node);
}
else {
var firstChildNode = index === 0;
var prevNode = !firstChildNode && parent.child(index - 1);
var prevEmptyNode = prevNode && prevNode.childCount === 0;
var nextNode = index < parent.childCount - 1 && parent.child(index + 1);
var nextParaNode = nextNode && nextNode.type.name === 'paragraph';
var emptyNode = node.childCount === 0;
if (emptyNode && prevEmptyNode) {
state.write(' \n');
}
else if (emptyNode && !prevEmptyNode && !firstChildNode) {
if ((parent === null || parent === void 0 ? void 0 : parent.type.name) === 'listItem') {
var prevDelim = state.getDelim();
state.setDelim('');
state.write(' ');
state.setDelim(prevDelim);
}
state.write('\n');
}
else {
state.convertInline(node);
if (nextParaNode) {
state.write('\n');
}
else {
state.closeBlock(node);
}
}
}
},
heading: function (state, _a, _b) {
var node = _a.node;
var delim = _b.delim;
var headingType = node.attrs.headingType;
if (headingType === 'atx') {
state.write(delim + " ");
state.convertInline(node);
state.closeBlock(node);
}
else {
state.convertInline(node);
state.ensureNewLine();
state.write(delim);
state.closeBlock(node);
}
},
codeBlock: function (state, _a, _b) {
var node = _a.node;
var delim = _b.delim, text = _b.text;
var _c = delim, openDelim = _c[0], closeDelim = _c[1];
state.write(openDelim);
state.ensureNewLine();
state.text(text, false);
state.ensureNewLine();
state.write(closeDelim);
state.closeBlock(node);
},
blockQuote: function (state, _a, _b) {
var node = _a.node, parent = _a.parent;
var delim = _b.delim;
if ((parent === null || parent === void 0 ? void 0 : parent.type.name) === node.type.name) {
state.flushClose(1);
}
state.wrapBlock(delim, null, node, function () { return state.convertNode(node); });
},
bulletList: function (state, _a, _b) {
var node = _a.node;
var delim = _b.delim;
// soft-tab(4)
state.convertList(node, repeat(' ', 4), function () { return delim + " "; });
},
orderedList: function (state, _a) {
var node = _a.node;
var start = node.attrs.order || 1;
// soft-tab(4)
state.convertList(node, repeat(' ', 4), function (index) {
var orderedNum = String(start + index);
return orderedNum + ". ";
});
},
listItem: function (state, _a) {
var node = _a.node;
var _b = node.attrs, task = _b.task, checked = _b.checked;
if (task) {
state.write("[" + (checked ? 'x' : ' ') + "] ");
}
state.convertNode(node);
},
image: function (state, _, _a) {
var attrs = _a.attrs;
state.write("![" + (attrs === null || attrs === void 0 ? void 0 : attrs.altText) + "](" + (attrs === null || attrs === void 0 ? void 0 : attrs.imageUrl) + ")");
},
thematicBreak: function (state, _a, _b) {
var node = _a.node;
var delim = _b.delim;
state.write(delim);
state.closeBlock(node);
},
table: function (state, _a) {
var node = _a.node;
state.convertNode(node);
state.closeBlock(node);
},
tableHead: function (state, _a, _b) {
var node = _a.node;
var delim = _b.delim;
var row = node.firstChild;
state.convertNode(node);
var result = delim !== null && delim !== void 0 ? delim : '';
if (!delim && row) {
row.forEach(function (_a) {
var textContent = _a.textContent, attrs = _a.attrs;
var headDelim = createTableHeadDelim(textContent, attrs.align);
result += "| " + headDelim + " ";
});
}
state.write(result + "|");
state.ensureNewLine();
},
tableBody: function (state, _a) {
var node = _a.node;
state.convertNode(node);
},
tableRow: function (state, _a) {
var node = _a.node;
state.convertNode(node);
state.write('|');
state.ensureNewLine();
},
tableHeadCell: function (state, _a, _b) {
var node = _a.node;
var _c = _b.delim, delim = _c === void 0 ? '| ' : _c;
state.write(delim);
state.convertTableCell(node);
state.write(' ');
},
tableBodyCell: function (state, _a, _b) {
var node = _a.node;
var _c = _b.delim, delim = _c === void 0 ? '| ' : _c;
state.write(delim);
state.convertTableCell(node);
state.write(' ');
},
customBlock: function (state, _a, _b) {
var node = _a.node;
var delim = _b.delim, text = _b.text;
var _c = delim, openDelim = _c[0], closeDelim = _c[1];
state.write(openDelim);
state.ensureNewLine();
state.text(text, false);
state.ensureNewLine();
state.write(closeDelim);
state.closeBlock(node);
},
frontMatter: function (state, _a, _b) {
var node = _a.node;
var text = _b.text;
state.text(text, false);
state.closeBlock(node);
},
widget: function (state, _, _a) {
var text = _a.text;
state.write(text);
},
html: function (state, _a, _b) {
var node = _a.node;
var text = _b.text;
state.write(text);
if (node.attrs.htmlBlock) {
state.closeBlock(node);
}
},
htmlComment: function (state, _a, _b) {
var node = _a.node;
var text = _b.text;
state.write(text);
state.closeBlock(node);
},
};
function write(type, _a) {
var state = _a.state, nodeInfo = _a.nodeInfo, params = _a.params;
var rawHTML = params.rawHTML;
if (rawHTML) {
if (inArray_default()(type, ['heading', 'codeBlock']) > -1) {
convertToRawHTMLHavingInlines(state, nodeInfo.node, rawHTML);
}
else if (inArray_default()(type, ['image', 'thematicBreak']) > -1) {
state.write(rawHTML);
}
else {
convertToRawHTMLHavingBlocks(state, nodeInfo, rawHTML);
}
}
else {
nodeTypeWriters[type](state, nodeInfo, params);
}
}
;// CONCATENATED MODULE: ./src/convertors/toMarkdown/toMdConvertors.ts
function addBackticks(node, side) {
var text = node.text;
var ticks = /`+/g;
var len = 0;
if (node.isText && text) {
var matched = ticks.exec(text);
while (matched) {
len = Math.max(len, matched[0].length);
matched = ticks.exec(text);
}
}
var result = len > 0 && side > 0 ? ' `' : '`';
for (var i = 0; i < len; i += 1) {
result += '`';
}
if (len > 0 && side < 0) {
result += ' ';
}
return result;
}
function getPairRawHTML(rawHTML) {
return rawHTML ? ["<" + rawHTML + ">", "" + rawHTML + ">"] : null;
}
function getOpenRawHTML(rawHTML) {
return rawHTML ? "<" + rawHTML + ">" : null;
}
function getCloseRawHTML(rawHTML) {
return rawHTML ? "" + rawHTML + ">" : null;
}
var toMdConvertors = {
heading: function (_a) {
var node = _a.node;
var attrs = node.attrs;
var level = attrs.level;
var delim = repeat('#', level);
if (attrs.headingType === 'setext') {
delim = level === 1 ? '===' : '---';
}
return {
delim: delim,
rawHTML: getPairRawHTML(attrs.rawHTML),
};
},
codeBlock: function (_a) {
var node = _a.node;
var _b = node, attrs = _b.attrs, textContent = _b.textContent;
return {
delim: ["```" + (attrs.language || ''), '```'],
rawHTML: getPairRawHTML(attrs.rawHTML),
text: textContent,
};
},
blockQuote: function (_a) {
var node = _a.node;
return {
delim: '> ',
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
bulletList: function (_a, _b) {
var node = _a.node;
var inTable = _b.inTable;
var rawHTML = node.attrs.rawHTML;
if (inTable) {
rawHTML = rawHTML || 'ul';
}
return {
delim: '*',
rawHTML: getPairRawHTML(rawHTML),
};
},
orderedList: function (_a, _b) {
var node = _a.node;
var inTable = _b.inTable;
var rawHTML = node.attrs.rawHTML;
if (inTable) {
rawHTML = rawHTML || 'ol';
}
return {
rawHTML: getPairRawHTML(rawHTML),
};
},
listItem: function (_a, _b) {
var node = _a.node;
var inTable = _b.inTable;
var _c = node.attrs, task = _c.task, checked = _c.checked;
var rawHTML = node.attrs.rawHTML;
if (inTable) {
rawHTML = rawHTML || 'li';
}
var className = task ? " class=\"task-list-item" + (checked ? ' checked' : '') + "\"" : '';
var dataset = task ? " data-task" + (checked ? " data-task-checked" : '') : '';
return {
rawHTML: rawHTML ? ["<" + rawHTML + className + dataset + ">", "" + rawHTML + ">"] : null,
};
},
table: function (_a) {
var node = _a.node;
return {
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
tableHead: function (_a) {
var node = _a.node;
return {
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
tableBody: function (_a) {
var node = _a.node;
return {
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
tableRow: function (_a) {
var node = _a.node;
return {
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
tableHeadCell: function (_a) {
var node = _a.node;
return {
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
tableBodyCell: function (_a) {
var node = _a.node;
return {
rawHTML: getPairRawHTML(node.attrs.rawHTML),
};
},
image: function (_a) {
var node = _a.node;
var attrs = node.attrs;
var rawHTML = attrs.rawHTML, altText = attrs.altText;
var imageUrl = attrs.imageUrl.replace(/&/g, '&');
var altAttr = altText ? " alt=\"" + escapeXml(altText) + "\"" : '';
return {
rawHTML: rawHTML ? "<" + rawHTML + " src=\"" + escapeXml(imageUrl) + "\"" + altAttr + ">" : null,
attrs: {
altText: escapeTextForLink(altText || ''),
imageUrl: imageUrl,
},
};
},
thematicBreak: function (_a) {
var node = _a.node;
return {
delim: '***',
rawHTML: getOpenRawHTML(node.attrs.rawHTML),
};
},
customBlock: function (_a) {
var node = _a.node;
var _b = node, attrs = _b.attrs, textContent = _b.textContent;
return {
delim: ["$$" + attrs.info, '$$'],
text: textContent,
};
},
frontMatter: function (_a) {
var node = _a.node;
return {
text: node.textContent,
};
},
widget: function (_a) {
var node = _a.node;
return {
text: node.textContent,
};
},
strong: function (_a, _b, betweenSpace) {
var node = _a.node;
var entering = _b.entering;
var rawHTML = node.attrs.rawHTML;
var delim = '**';
if (!betweenSpace) {
delim = entering ? '' : ' ';
}
return {
delim: delim,
rawHTML: entering ? getOpenRawHTML(rawHTML) : getCloseRawHTML(rawHTML),
};
},
emph: function (_a, _b, betweenSpace) {
var node = _a.node;
var entering = _b.entering;
var rawHTML = node.attrs.rawHTML;
var delim = '*';
if (!betweenSpace) {
delim = entering ? '' : ' ';
}
return {
delim: delim,
rawHTML: entering ? getOpenRawHTML(rawHTML) : getCloseRawHTML(rawHTML),
};
},
strike: function (_a, _b, betweenSpace) {
var node = _a.node;
var entering = _b.entering;
var rawHTML = node.attrs.rawHTML;
var delim = '~~';
if (!betweenSpace) {
delim = entering ? '' : '';
}
return {
delim: delim,
rawHTML: entering ? getOpenRawHTML(rawHTML) : getCloseRawHTML(rawHTML),
};
},
link: function (_a, _b) {
var node = _a.node;
var entering = _b.entering;
var attrs = node.attrs;
var title = attrs.title, rawHTML = attrs.rawHTML;
var linkUrl = attrs.linkUrl.replace(/&/g, '&');
var titleAttr = title ? " title=\"" + escapeXml(title) + "\"" : '';
if (entering) {
return {
delim: '[',
rawHTML: rawHTML ? "<" + rawHTML + " href=\"" + escapeXml(linkUrl) + "\"" + titleAttr + ">" : null,
};
}
return {
delim: "](" + linkUrl + (title ? " " + quote(escapeTextForLink(title)) : '') + ")",
rawHTML: getCloseRawHTML(rawHTML),
};
},
code: function (_a, _b) {
var node = _a.node, parent = _a.parent, _c = _a.index, index = _c === void 0 ? 0 : _c;
var entering = _b.entering;
var delim = entering
? addBackticks(parent.child(index), -1)
: addBackticks(parent.child(index - 1), 1);
var rawHTML = entering
? getOpenRawHTML(node.attrs.rawHTML)
: getCloseRawHTML(node.attrs.rawHTML);
return {
delim: delim,
rawHTML: rawHTML,
};
},
htmlComment: function (_a) {
var node = _a.node;
return {
text: node.textContent,
};
},
// html inline node, html block node
html: function (_a, _b) {
var node = _a.node;
var entering = _b.entering;
var tagName = node.type.name;
var attrs = node.attrs.htmlAttrs;
var openTag = "<" + tagName;
var closeTag = "" + tagName + ">";
Object.keys(attrs).forEach(function (attrName) {
// To prevent broken converting when attributes has double quote string
openTag += " " + attrName + "=\"" + attrs[attrName].replace(/"/g, "'") + "\"";
});
openTag += '>';
if (node.attrs.htmlInline) {
return {
rawHTML: entering ? openTag : closeTag,
};
}
return {
text: "" + openTag + node.attrs.childrenHTML + closeTag,
};
},
};
var markTypeOptions = {
strong: {
mixable: true,
removedEnclosingWhitespace: true,
},
emph: {
mixable: true,
removedEnclosingWhitespace: true,
},
strike: {
mixable: true,
removedEnclosingWhitespace: true,
},
code: {
escape: false,
},
link: null,
html: null,
};
function createNodeTypeConvertors(convertors) {
var nodeTypeConvertors = {};
var nodeTypes = Object.keys(nodeTypeWriters);
nodeTypes.forEach(function (type) {
nodeTypeConvertors[type] = function (state, nodeInfo) {
var writer = nodeTypeWriters[type];
if (writer) {
var convertor = convertors[type];
var params = convertor
? convertor(nodeInfo, {
inTable: state.inTable,
})
: {};
write(type, { state: state, nodeInfo: nodeInfo, params: params });
}
};
});
return nodeTypeConvertors;
}
function createMarkTypeConvertors(convertors) {
var markTypeConvertors = {};
var markTypes = Object.keys(markTypeOptions);
markTypes.forEach(function (type) {
markTypeConvertors[type] = function (nodeInfo, entering, betweenSpace) {
var markOption = markTypeOptions[type];
var convertor = convertors[type];
// There are two ways to call the mark type converter
// in the `toMdConvertorState` module.
// When calling the converter without using `delim` and `rawHTML` values,
// the converter is called without parameters.
var runConvertor = convertor && nodeInfo && !isUndefined_default()(entering);
var params = runConvertor
? convertor(nodeInfo, { entering: entering }, betweenSpace)
: {};
return __assign(__assign({}, params), markOption);
};
});
return markTypeConvertors;
}
// Step 1: Create the converter by overriding the custom converter
// to the original converter defined in the `toMdConvertors` module.
// If the node type is defined in the original converter,
// the `origin()` function is exported to the paramter of the converter.
// Step 2: Create a converter for the node type of ProseMirror by combining the converter
// created in Step 1 with the writers defined in the`toMdNodeTypeWriters` module.
// Each writer converts the ProseMirror's node to a string with the value returned
// by the converter, and then stores the state in the`toMdConverterState` class.
// Step 3: Create a converter for the mark type of ProseMirror by combining the converter
// created in Step 1 with `markTypeOptions`.
// Step 4: The created node type converter and mark type converter are injected
// when creating an instance of the`toMdConverterState` class.
function createMdConvertors(customConvertors) {
var customConvertorTypes = Object.keys(customConvertors);
customConvertorTypes.forEach(function (type) {
var baseConvertor = toMdConvertors[type];
var customConvertor = customConvertors[type];
if (baseConvertor) {
toMdConvertors[type] = function (nodeInfo, context) {
context.origin = function () { return baseConvertor(nodeInfo, context); };
return customConvertor(nodeInfo, context);
};
}
else {
toMdConvertors[type] = customConvertor;
}
delete customConvertors[type];
});
var nodeTypeConvertors = createNodeTypeConvertors(toMdConvertors);
var markTypeConvertors = createMarkTypeConvertors(toMdConvertors);
return {
nodeTypeConvertors: nodeTypeConvertors,
markTypeConvertors: markTypeConvertors,
};
}
;// CONCATENATED MODULE: ./src/convertors/toMarkdown/toMdConvertorState.ts
var ToMdConvertorState = /** @class */ (function () {
function ToMdConvertorState(_a) {
var nodeTypeConvertors = _a.nodeTypeConvertors, markTypeConvertors = _a.markTypeConvertors;
this.nodeTypeConvertors = nodeTypeConvertors;
this.markTypeConvertors = markTypeConvertors;
this.delim = '';
this.result = '';
this.closed = false;
this.tightList = false;
this.stopNewline = false;
this.inTable = false;
}
ToMdConvertorState.prototype.getMarkConvertor = function (mark) {
var type = mark.attrs.htmlInline ? 'html' : mark.type.name;
return this.markTypeConvertors[type];
};
ToMdConvertorState.prototype.isInBlank = function () {
return /(^|\n)$/.test(this.result);
};
ToMdConvertorState.prototype.isBetweenSpaces = function (parent, index) {
var _a, _b;
var content = parent.content;
var isFrontNodeEndWithSpace = index === 0 ||
isEndWithSpace((_a = content.child(index - 1).text) !== null && _a !== void 0 ? _a : DEFAULT_TEXT_NOT_START_OR_END_WITH_SPACE);
var isRearNodeStartWithSpace = index >= content.childCount - 1 ||
isStartWithSpace((_b = content.child(index + 1).text) !== null && _b !== void 0 ? _b : DEFAULT_TEXT_NOT_START_OR_END_WITH_SPACE);
return isFrontNodeEndWithSpace && isRearNodeStartWithSpace;
};
ToMdConvertorState.prototype.markText = function (mark, entering, parent, index) {
var convertor = this.getMarkConvertor(mark);
if (convertor) {
var betweenSpace = this.isBetweenSpaces(parent, entering ? index : index - 1);
var _a = convertor({ node: mark, parent: parent, index: index }, entering, betweenSpace), delim = _a.delim, rawHTML = _a.rawHTML;
return rawHTML || delim;
}
return '';
};
ToMdConvertorState.prototype.setDelim = function (delim) {
this.delim = delim;
};
ToMdConvertorState.prototype.getDelim = function () {
return this.delim;
};
ToMdConvertorState.prototype.flushClose = function (size) {
if (!this.stopNewline && this.closed) {
if (!this.isInBlank()) {
this.result += '\n';
}
if (!size) {
size = 2;
}
if (size > 1) {
var delimMin = this.delim;
var trim = /\s+$/.exec(delimMin);
if (trim) {
delimMin = delimMin.slice(0, delimMin.length - trim[0].length);
}
for (var i = 1; i < size; i += 1) {
this.result += delimMin + "\n";
}
}
this.closed = false;
}
};
ToMdConvertorState.prototype.wrapBlock = function (delim, firstDelim, node, fn) {
var old = this.getDelim();
this.write(firstDelim || delim);
this.setDelim(this.getDelim() + delim);
fn();
this.setDelim(old);
this.closeBlock(node);
};
ToMdConvertorState.prototype.ensureNewLine = function () {
if (!this.isInBlank()) {
this.result += '\n';
}
};
ToMdConvertorState.prototype.write = function (content) {
if (content === void 0) { content = ''; }
this.flushClose();
if (this.delim && this.isInBlank()) {
this.result += this.delim;
}
if (content) {
this.result += content;
}
};
ToMdConvertorState.prototype.closeBlock = function (node) {
this.closed = node;
};
ToMdConvertorState.prototype.text = function (text, escaped) {
if (escaped === void 0) { escaped = true; }
var lines = text.split('\n');
for (var i = 0; i < lines.length; i += 1) {
this.write();
this.result += escaped ? common_escape(lines[i]) : lines[i];
if (i !== lines.length - 1) {
this.result += '\n';
}
}
};
ToMdConvertorState.prototype.convertBlock = function (node, parent, index) {
var type = node.type.name;
var convertor = this.nodeTypeConvertors[type];
var nodeInfo = { node: node, parent: parent, index: index };
if (node.attrs.htmlBlock) {
this.nodeTypeConvertors.html(this, nodeInfo);
}
else if (convertor) {
convertor(this, nodeInfo);
}
};
ToMdConvertorState.prototype.convertInline = function (parent) {
var _this = this;
var active = [];
var trailing = '';
var progress = function (node, _, index) {
var marks = node ? node.marks : [];
var leading = trailing;
trailing = '';
// If whitespace has to be expelled from the node, adjust
// leading and trailing accordingly.
var removedWhitespace = node &&
node.isText &&
marks.some(function (mark) {
var markConvertor = _this.getMarkConvertor(mark);
var info = markConvertor && markConvertor();
return info && info.removedEnclosingWhitespace;
});
if (removedWhitespace && node && node.text) {
var _a = /^(\s*)(.*?)(\s*)$/m.exec(node.text), lead = _a[1], mark = _a[2], trail = _a[3];
leading += lead;
trailing = trail;
if (lead || trail) {
// @ts-ignore
// type is not defined for "withText" in prosemirror-model
node = mark ? node.withText(mark) : null;
if (!node) {
marks = active;
}
}
}
var lastMark = marks.length && last(marks);
var markConvertor = lastMark && _this.getMarkConvertor(lastMark);
var markType = markConvertor && markConvertor();
var noEscape = markType && markType.escape === false;
var len = marks.length - (noEscape ? 1 : 0);
// Try to reorder 'mixable' marks, such as em and strong, which
// in Markdown may be opened and closed in different order, so
// that order of the marks for the token matches the order in
// active.
for (var i = 0; i < len; i += 1) {
var mark = marks[i];
if (markType && !markType.mixable) {
break;
}
for (var j = 0; j < active.length; j += 1) {
var other = active[j];
if (markType && !markType.mixable) {
break;
}
if (mark.eq(other)) {
// eslint-disable-next-line max-depth
if (i > j) {
marks = marks
.slice(0, j)
.concat(mark)
.concat(marks.slice(j, i))
.concat(marks.slice(i + 1, len));
}
else if (j > i) {
marks = marks
.slice(0, i)
.concat(marks.slice(i + 1, j))
.concat(mark)
.concat(marks.slice(j, len));
}
break;
}
}
}
// Find the prefix of the mark set that didn't change
var keep = 0;
while (keep < Math.min(active.length, len) && marks[keep].eq(active[keep])) {
keep += 1;
}
// Close the marks that need to be closed
while (keep < active.length) {
var activedMark = active.pop();
if (activedMark) {
_this.text(_this.markText(activedMark, false, parent, index), false);
}
}
// Output any previously expelled trailing whitespace outside the marks
if (leading) {
_this.text(leading);
}
// Open the marks that need to be opened
if (node) {
while (active.length < len) {
var mark = marks[active.length];
active.push(mark);
_this.text(_this.markText(mark, true, parent, index), false);
}
// Render the node. Special case code marks, since their content
// may not be escaped.
if (noEscape && node.isText) {
_this.text(_this.markText(lastMark, true, parent, index) +
node.text +
_this.markText(lastMark, false, parent, index + 1), false);
}
else {
_this.convertBlock(node, parent, index);
}
}
};
parent.forEach(progress);
progress(null, null, parent.childCount);
};
// Render a node's content as a list. `delim` should be the extra
// indentation added to all lines except the first in an item,
// `firstDelimFn` is a function going from an item index to a
// delimiter for the first line of the item.
ToMdConvertorState.prototype.convertList = function (node, delim, firstDelimFn) {
var _this = this;
var _a;
if (this.closed && this.closed.type === node.type) {
this.flushClose(3);
}
else if (this.tightList) {
this.flushClose(1);
}
var tight = (_a = node.attrs.tight) !== null && _a !== void 0 ? _a : true;
var prevTight = this.tightList;
this.tightList = tight;
node.forEach(function (child, _, index) {
if (index && tight) {
_this.flushClose(1);
}
_this.wrapBlock(delim, firstDelimFn(index), node, function () { return _this.convertBlock(child, node, index); });
});
this.tightList = prevTight;
};
ToMdConvertorState.prototype.convertTableCell = function (node) {
var _this = this;
this.stopNewline = true;
this.inTable = true;
node.forEach(function (child, _, index) {
if (common_includes(['bulletList', 'orderedList'], child.type.name)) {
_this.convertBlock(child, node, index);
_this.closed = false;
}
else {
_this.convertInline(child);
if (index < node.childCount - 1) {
var nextChild = node.child(index + 1);
if (nextChild.type.name === 'paragraph') {
_this.write(' ');
}
}
}
});
this.stopNewline = false;
this.inTable = false;
};
ToMdConvertorState.prototype.convertNode = function (parent, infoForPosSync) {
var _this = this;
parent.forEach(function (node, _, index) {
_this.convertBlock(node, parent, index);
if ((infoForPosSync === null || infoForPosSync === void 0 ? void 0 : infoForPosSync.node) === node) {
var lineTexts = _this.result.split('\n');
infoForPosSync.setMappedPos([lineTexts.length, last(lineTexts).length + 1]);
}
});
return this.result;
};
return ToMdConvertorState;
}());
/* harmony default export */ var toMdConvertorState = (ToMdConvertorState);
;// CONCATENATED MODULE: ./src/convertors/convertor.ts
var Convertor = /** @class */ (function () {
function Convertor(schema, toMdConvertors, toHTMLConvertors, eventEmitter) {
var _this = this;
this.setMappedPos = function (pos) {
_this.mappedPosWhenConverting = pos;
};
this.schema = schema;
this.eventEmitter = eventEmitter;
this.focusedNode = null;
this.mappedPosWhenConverting = null;
this.toWwConvertors = createWwConvertors(toHTMLConvertors);
this.toMdConvertors = createMdConvertors(toMdConvertors || {});
this.eventEmitter.listen('setFocusedNode', function (node) { return (_this.focusedNode = node); });
}
Convertor.prototype.getMappedPos = function () {
return this.mappedPosWhenConverting;
};
Convertor.prototype.getInfoForPosSync = function () {
return { node: this.focusedNode, setMappedPos: this.setMappedPos };
};
Convertor.prototype.toWysiwygModel = function (mdNode) {
var state = new toWwConvertorState(this.schema, this.toWwConvertors);
return state.convertNode(mdNode, this.getInfoForPosSync());
};
Convertor.prototype.toMarkdownText = function (wwNode) {
var state = new toMdConvertorState(this.toMdConvertors);
var markdownText = state.convertNode(wwNode, this.getInfoForPosSync());
markdownText = this.eventEmitter.emitReduce('beforeConvertWysiwygToMarkdown', markdownText);
return markdownText;
};
return Convertor;
}());
/* harmony default export */ var convertor = (Convertor);
;// CONCATENATED MODULE: ./src/helper/plugin.ts
function execPlugin(pluginInfo) {
var plugin = pluginInfo.plugin, eventEmitter = pluginInfo.eventEmitter, usageStatistics = pluginInfo.usageStatistics, instance = pluginInfo.instance;
var pmState = { Plugin: external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Plugin, PluginKey: external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.PluginKey, Selection: external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.Selection, TextSelection: external_commonjs_prosemirror_state_commonjs2_prosemirror_state_amd_prosemirror_state_.TextSelection };
var pmView = { Decoration: external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.Decoration, DecorationSet: external_commonjs_prosemirror_view_commonjs2_prosemirror_view_amd_prosemirror_view_.DecorationSet };
var pmModel = { Fragment: external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Fragment };
var pmRules = { InputRule: external_commonjs_prosemirror_inputrules_commonjs2_prosemirror_inputrules_amd_prosemirror_inputrules_.InputRule, inputRules: external_commonjs_prosemirror_inputrules_commonjs2_prosemirror_inputrules_amd_prosemirror_inputrules_.inputRules, undoInputRule: external_commonjs_prosemirror_inputrules_commonjs2_prosemirror_inputrules_amd_prosemirror_inputrules_.undoInputRule };
var pmKeymap = { keymap: external_commonjs_prosemirror_keymap_commonjs2_prosemirror_keymap_amd_prosemirror_keymap_.keymap };
var context = {
eventEmitter: eventEmitter,
usageStatistics: usageStatistics,
instance: instance,
pmState: pmState,
pmView: pmView,
pmModel: pmModel,
pmRules: pmRules,
pmKeymap: pmKeymap,
i18n: i18n,
};
if (isArray_default()(plugin)) {
var pluginFn = plugin[0], _a = plugin[1], options = _a === void 0 ? {} : _a;
return pluginFn(context, options);
}
return plugin(context);
}
function getPluginInfo(pluginsInfo) {
var plugins = pluginsInfo.plugins, eventEmitter = pluginsInfo.eventEmitter, usageStatistics = pluginsInfo.usageStatistics, instance = pluginsInfo.instance;
eventEmitter.listen('mixinTableOffsetMapPrototype', mixinTableOffsetMapPrototype);
return (plugins !== null && plugins !== void 0 ? plugins : []).reduce(function (acc, plugin) {
var pluginInfoResult = execPlugin({
plugin: plugin,
eventEmitter: eventEmitter,
usageStatistics: usageStatistics,
instance: instance,
});
if (!pluginInfoResult) {
throw new Error('The return value of the executed plugin is empty.');
}
var markdownParsers = pluginInfoResult.markdownParsers, toHTMLRenderers = pluginInfoResult.toHTMLRenderers, toMarkdownRenderers = pluginInfoResult.toMarkdownRenderers, markdownPlugins = pluginInfoResult.markdownPlugins, wysiwygPlugins = pluginInfoResult.wysiwygPlugins, wysiwygNodeViews = pluginInfoResult.wysiwygNodeViews, markdownCommands = pluginInfoResult.markdownCommands, wysiwygCommands = pluginInfoResult.wysiwygCommands, toolbarItems = pluginInfoResult.toolbarItems;
if (toHTMLRenderers) {
acc.toHTMLRenderers = deepMergedCopy(acc.toHTMLRenderers, toHTMLRenderers);
}
if (toMarkdownRenderers) {
acc.toMarkdownRenderers = deepMergedCopy(acc.toMarkdownRenderers, toMarkdownRenderers);
}
if (markdownPlugins) {
acc.mdPlugins = acc.mdPlugins.concat(markdownPlugins);
}
if (wysiwygPlugins) {
acc.wwPlugins = acc.wwPlugins.concat(wysiwygPlugins);
}
if (wysiwygNodeViews) {
acc.wwNodeViews = __assign(__assign({}, acc.wwNodeViews), wysiwygNodeViews);
}
if (markdownCommands) {
acc.mdCommands = __assign(__assign({}, acc.mdCommands), markdownCommands);
}
if (wysiwygCommands) {
acc.wwCommands = __assign(__assign({}, acc.wwCommands), wysiwygCommands);
}
if (toolbarItems) {
acc.toolbarItems = acc.toolbarItems.concat(toolbarItems);
}
if (markdownParsers) {
acc.markdownParsers = __assign(__assign({}, acc.markdownParsers), markdownParsers);
}
return acc;
}, {
toHTMLRenderers: {},
toMarkdownRenderers: {},
mdPlugins: [],
wwPlugins: [],
wwNodeViews: {},
mdCommands: {},
wwCommands: {},
toolbarItems: [],
markdownParsers: {},
});
}
;// CONCATENATED MODULE: ./src/viewer.ts
var TASK_ATTR_NAME = 'data-task';
var DISABLED_TASK_ATTR_NAME = 'data-task-disabled';
var TASK_CHECKED_CLASS_NAME = 'checked';
function registerHTMLTagToWhitelist(convertorMap) {
['htmlBlock', 'htmlInline'].forEach(function (htmlType) {
if (convertorMap[htmlType]) {
// register tag white list for preventing to remove the html in sanitizer
Object.keys(convertorMap[htmlType]).forEach(function (type) { return registerTagWhitelistIfPossible(type); });
}
});
}
/**
* Class ToastUIEditorViewer
* @param {object} options Option object
* @param {HTMLElement} options.el - container element
* @param {string} [options.initialValue] Editor's initial value
* @param {Object} [options.events] - Events
* @param {function} [options.events.load] - It would be emitted when editor fully load
* @param {function} [options.events.change] - It would be emitted when content changed
* @param {function} [options.events.caretChange] - It would be emitted when format change by cursor position
* @param {function} [options.events.focus] - It would be emitted when editor get focus
* @param {function} [options.events.blur] - It would be emitted when editor loose focus
* @param {Array.} [options.plugins] - Array of plugins. A plugin can be either a function or an array in the form of [function, options].
* @param {Object} [options.extendedAutolinks] - Using extended Autolinks specified in GFM spec
* @param {Object} [options.linkAttributes] - Attributes of anchor element that should be rel, target, hreflang, type
* @param {Object} [options.customHTMLRenderer=null] - Object containing custom renderer functions correspond to change markdown node to preview HTML or wysiwyg node
* @param {boolean} [options.referenceDefinition=false] - whether use the specification of link reference definition
* @param {function} [options.customHTMLSanitizer=null] - custom HTML sanitizer
* @param {boolean} [options.frontMatter=false] - whether use the front matter
* @param {string} [options.theme] - The theme to style the viewer with. The default is included in toastui-editor.css.
*/
var ToastUIEditorViewer = /** @class */ (function () {
function ToastUIEditorViewer(options) {
var _this = this;
this.options = extend_default()({
linkAttributes: null,
extendedAutolinks: false,
customHTMLRenderer: null,
referenceDefinition: false,
customHTMLSanitizer: null,
frontMatter: false,
usageStatistics: true,
theme: 'light',
}, options);
this.eventEmitter = new eventEmitter();
var linkAttributes = sanitizeLinkAttribute(this.options.linkAttributes);
var _a = getPluginInfo({
plugins: this.options.plugins,
eventEmitter: this.eventEmitter,
usageStatistics: this.options.usageStatistics,
instance: this,
}) || {}, toHTMLRenderers = _a.toHTMLRenderers, markdownParsers = _a.markdownParsers;
var _b = this.options, customHTMLRenderer = _b.customHTMLRenderer, extendedAutolinks = _b.extendedAutolinks, referenceDefinition = _b.referenceDefinition, frontMatter = _b.frontMatter, customHTMLSanitizer = _b.customHTMLSanitizer;
var rendererOptions = {
linkAttributes: linkAttributes,
customHTMLRenderer: __assign(__assign({}, toHTMLRenderers), customHTMLRenderer),
extendedAutolinks: extendedAutolinks,
referenceDefinition: referenceDefinition,
frontMatter: frontMatter,
sanitizer: customHTMLSanitizer || sanitizeHTML,
};
registerHTMLTagToWhitelist(rendererOptions.customHTMLRenderer);
if (this.options.events) {
forEachOwnProperties_default()(this.options.events, function (fn, key) {
_this.on(key, fn);
});
}
var _c = this.options, el = _c.el, initialValue = _c.initialValue, theme = _c.theme;
var existingHTML = el.innerHTML;
if (theme !== 'light') {
el.classList.add(cls(theme));
}
el.innerHTML = '';
this.toastMark = new ToastMark('', {
disallowedHtmlBlockTags: ['br', 'img'],
extendedAutolinks: extendedAutolinks,
referenceDefinition: referenceDefinition,
disallowDeepHeading: true,
frontMatter: frontMatter,
customParser: markdownParsers,
});
this.preview = new mdPreview(this.eventEmitter, __assign(__assign({}, rendererOptions), { isViewer: true }));
on_default()(this.preview.previewContent, 'mousedown', this.toggleTask.bind(this));
if (initialValue) {
this.setMarkdown(initialValue);
}
else if (existingHTML) {
this.preview.setHTML(existingHTML);
}
el.appendChild(this.preview.previewContent);
this.eventEmitter.emit('load', this);
}
/**
* Toggle task by detecting mousedown event.
* @param {MouseEvent} ev - event
* @private
*/
ToastUIEditorViewer.prototype.toggleTask = function (ev) {
var element = ev.target;
var style = getComputedStyle(element, ':before');
if (!element.hasAttribute(DISABLED_TASK_ATTR_NAME) &&
element.hasAttribute(TASK_ATTR_NAME) &&
isPositionInBox(style, ev.offsetX, ev.offsetY)) {
toggleClass(element, TASK_CHECKED_CLASS_NAME);
this.eventEmitter.emit('change', {
source: 'viewer',
date: ev,
});
}
};
/**
* Set content for preview
* @param {string} markdown Markdown text
*/
ToastUIEditorViewer.prototype.setMarkdown = function (markdown) {
var lineTexts = this.toastMark.getLineTexts();
var length = lineTexts.length;
var lastLine = last(lineTexts);
var endSourcepos = [length, lastLine.length + 1];
var editResult = this.toastMark.editMarkdown([1, 1], endSourcepos, markdown || '');
this.eventEmitter.emit('updatePreview', editResult);
};
/**
* Bind eventHandler to event type
* @param {string} type Event type
* @param {function} handler Event handler
*/
ToastUIEditorViewer.prototype.on = function (type, handler) {
this.eventEmitter.listen(type, handler);
};
/**
* Unbind eventHandler from event type
* @param {string} type Event type
*/
ToastUIEditorViewer.prototype.off = function (type) {
this.eventEmitter.removeEventHandler(type);
};
/**
* Add hook to TUIEditor event
* @param {string} type Event type
* @param {function} handler Event handler
*/
ToastUIEditorViewer.prototype.addHook = function (type, handler) {
this.eventEmitter.removeEventHandler(type);
this.eventEmitter.listen(type, handler);
};
/**
* Remove Viewer preview from document
*/
ToastUIEditorViewer.prototype.destroy = function () {
off_default()(this.preview.el, 'mousedown', this.toggleTask.bind(this));
this.preview.destroy();
this.eventEmitter.emit('destroy');
};
/**
* Return true
* @returns {boolean}
*/
ToastUIEditorViewer.prototype.isViewer = function () {
return true;
};
/**
* Return false
* @returns {boolean}
*/
ToastUIEditorViewer.prototype.isMarkdownMode = function () {
return false;
};
/**
* Return false
* @returns {boolean}
*/
ToastUIEditorViewer.prototype.isWysiwygMode = function () {
return false;
};
return ToastUIEditorViewer;
}());
/* harmony default export */ var viewer = (ToastUIEditorViewer);
;// CONCATENATED MODULE: ./src/wysiwyg/adaptor/mdLikeNode.ts
function isPmNode(node) {
return node instanceof external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.Node;
}
function mdLikeNode_isContainer(type) {
var containerTypes = [
'document',
'blockQuote',
'bulletList',
'orderedList',
'listItem',
'paragraph',
'heading',
'emph',
'strong',
'strike',
'link',
'image',
'table',
'tableHead',
'tableBody',
'tableRow',
'tableHeadCell',
'tableBodyCell',
];
return common_includes(containerTypes, type);
}
function createMdLikeNode(node) {
var attrs = node.attrs, type = node.type;
var nodeType = type.name;
var mdLikeNode = {
type: nodeType,
wysiwygNode: true,
literal: !mdLikeNode_isContainer(nodeType) && isPmNode(node) ? node.textContent : null,
};
var nodeTypeMap = {
heading: { level: attrs.level },
link: { destination: attrs.linkUrl, title: attrs.title },
image: { destination: attrs.imageUrl },
codeBlock: { info: attrs.language },
bulletList: { type: 'list', listData: { type: 'bullet' } },
orderedList: { type: 'list', listData: { type: 'ordered', start: attrs.order } },
listItem: { type: 'item', listData: { task: attrs.task, checked: attrs.checked } },
tableHeadCell: { type: 'tableCell', cellType: 'head', align: attrs.align },
tableBodyCell: { type: 'tableCell', cellType: 'body', align: attrs.align },
customBlock: { info: attrs.info },
};
var nodeInfo = nodeTypeMap[nodeType];
var attributes = __assign(__assign({}, mdLikeNode), nodeInfo);
// html block, inline node
var _a = node.attrs, htmlAttrs = _a.htmlAttrs, childrenHTML = _a.childrenHTML;
if (htmlAttrs) {
return __assign(__assign({}, attributes), { attrs: htmlAttrs, childrenHTML: childrenHTML });
}
return attributes;
}
;// CONCATENATED MODULE: ./src/wysiwyg/adaptor/wwToDOMAdaptor.ts
var tokenToDOMNode = {
openTag: function (token, stack) {
var _a = token, tagName = _a.tagName, classNames = _a.classNames, attributes = _a.attributes;
var el = document.createElement(tagName);
var attrs = {};
if (classNames) {
el.className = classNames.join(' ');
}
if (attributes) {
attrs = __assign(__assign({}, attrs), attributes);
}
setAttributes(attrs, el);
stack.push(el);
},
closeTag: function (_, stack) {
if (stack.length > 1) {
var el = stack.pop();
last(stack).appendChild(el);
}
},
html: function (token, stack) {
last(stack).insertAdjacentHTML('beforeend', token.content);
},
text: function (token, stack) {
var textNode = document.createTextNode(token.content);
last(stack).appendChild(textNode);
},
};
var WwToDOMAdaptor = /** @class */ (function () {
function WwToDOMAdaptor(linkAttributes, customRenderer) {
var convertors = getHTMLRenderConvertors(linkAttributes, customRenderer);
var customHTMLConvertor = __assign(__assign({}, customRenderer.htmlBlock), customRenderer.htmlInline);
// flatten the html block, inline convertor to other custom convertors
this.customConvertorKeys = Object.keys(customRenderer).concat(Object.keys(customHTMLConvertor));
this.renderer = new Renderer({
gfm: true,
convertors: __assign(__assign({}, convertors), customHTMLConvertor),
});
this.convertors = this.renderer.getConvertors();
}
WwToDOMAdaptor.prototype.generateTokens = function (node) {
var mdLikeNode = createMdLikeNode(node);
var context = {
entering: true,
leaf: isPmNode(node) ? node.isLeaf : false,
options: this.renderer.getOptions(),
getChildrenText: function () { return (isPmNode(node) ? node.textContent : ''); },
skipChildren: function () { return false; },
};
var convertor = this.convertors[node.type.name];
var converted = convertor(mdLikeNode, context, this.convertors);
var tokens = isArray_default()(converted) ? converted : [converted];
if (mdLikeNode_isContainer(node.type.name) || node.attrs.htmlInline) {
context.entering = false;
tokens.push({ type: 'text', content: isPmNode(node) ? node.textContent : '' });
tokens = tokens.concat(convertor(mdLikeNode, context, this.convertors));
}
return tokens;
};
WwToDOMAdaptor.prototype.toDOMNode = function (node) {
var tokens = this.generateTokens(node);
var stack = [];
tokens.forEach(function (token) { return tokenToDOMNode[token.type](token, stack); });
return stack[0];
};
WwToDOMAdaptor.prototype.getToDOMNode = function (name) {
if (common_includes(this.customConvertorKeys, name)) {
return this.toDOMNode.bind(this);
}
return null;
};
return WwToDOMAdaptor;
}());
;// CONCATENATED MODULE: ./src/markdown/scroll/animation.ts
var ANIMATION_TIME = 100;
var SCROLL_BLOCKING_RESET_DELAY = 15;
var currentTimeoutId = null;
var releaseTimer = null;
function run(deltaScrollTop, _a) {
var syncScrollTop = _a.syncScrollTop, releaseEventBlock = _a.releaseEventBlock;
if (releaseTimer) {
clearTimeout(releaseTimer);
}
syncScrollTop(deltaScrollTop);
releaseTimer = setTimeout(function () {
releaseEventBlock();
}, SCROLL_BLOCKING_RESET_DELAY);
}
function animate(curScrollTop, targetScrollTop, syncCallbacks) {
var diff = targetScrollTop - curScrollTop;
var startTime = Date.now();
var step = function () {
var stepTime = Date.now();
var progress = (stepTime - startTime) / ANIMATION_TIME;
var deltaValue;
if (currentTimeoutId) {
clearTimeout(currentTimeoutId);
}
if (progress < 1) {
deltaValue = curScrollTop + diff * Math.cos(((1 - progress) * Math.PI) / 2);
run(Math.ceil(deltaValue), syncCallbacks);
currentTimeoutId = setTimeout(step, 1);
}
else {
run(targetScrollTop, syncCallbacks);
currentTimeoutId = null;
}
};
step();
}
;// CONCATENATED MODULE: ./src/markdown/scroll/scrollSync.ts
var EDITOR_BOTTOM_PADDING = 18;
var ScrollSync = /** @class */ (function () {
function ScrollSync(mdEditor, preview, eventEmitter) {
this.latestEditorScrollTop = null;
this.latestPreviewScrollTop = null;
this.blockedScroll = null;
this.active = true;
this.timer = null;
var previewRoot = preview.previewContent, previewEl = preview.el;
this.previewRoot = previewRoot;
this.previewEl = previewEl;
this.mdEditor = mdEditor;
this.editorView = mdEditor.view;
this.toastMark = mdEditor.getToastMark();
this.eventEmitter = eventEmitter;
this.addScrollSyncEvent();
}
ScrollSync.prototype.addScrollSyncEvent = function () {
var _this = this;
this.eventEmitter.listen('afterPreviewRender', function () {
_this.clearTimer();
// Immediately after the 'afterPreviewRender' event has occurred,
// browser rendering is not yet complete.
// So the size of elements can not be accurately measured.
_this.timer = setTimeout(function () {
_this.syncPreviewScrollTop(true);
}, 200);
});
this.eventEmitter.listen('scroll', function (type, data) {
if (_this.active) {
if (type === 'editor' && _this.blockedScroll !== 'editor') {
_this.syncPreviewScrollTop();
}
else if (type === 'preview' && _this.blockedScroll !== 'preview') {
_this.syncEditorScrollTop(data);
}
}
});
this.eventEmitter.listen('toggleScrollSync', function (active) {
_this.active = active;
});
};
ScrollSync.prototype.getMdNodeAtPos = function (doc, posInfo) {
var indexInfo = doc.content.findIndex(posInfo.pos);
var line = indexInfo.index;
return this.toastMark.findFirstNodeAtLine(line + 1);
};
ScrollSync.prototype.getScrollTopByCaretPos = function () {
var pos = this.mdEditor.getSelection();
var firstMdNode = this.toastMark.findFirstNodeAtLine(pos[0][0]);
var previewHeight = this.previewEl.clientHeight;
var el = getParentNodeObj(this.previewRoot, firstMdNode).el;
var totalOffsetTop = getTotalOffsetTop(el, this.previewRoot) || el.offsetTop;
var nodeHeight = el.clientHeight;
// multiply 0.5 for calculating the position in the middle of preview area
var targetScrollTop = totalOffsetTop + nodeHeight - previewHeight * 0.5;
this.latestEditorScrollTop = null;
var diff = el.getBoundingClientRect().top - this.previewEl.getBoundingClientRect().top;
return diff < previewHeight ? null : targetScrollTop;
};
ScrollSync.prototype.syncPreviewScrollTop = function (editing) {
if (editing === void 0) { editing = false; }
var _a = this, editorView = _a.editorView, previewEl = _a.previewEl, previewRoot = _a.previewRoot;
var _b = editorView.dom.getBoundingClientRect(), left = _b.left, top = _b.top;
var posInfo = editorView.posAtCoords({ left: left, top: top });
var doc = editorView.state.doc;
var firstMdNode = this.getMdNodeAtPos(doc, posInfo);
if (!firstMdNode || isHTMLNode(firstMdNode)) {
return;
}
var curScrollTop = previewEl.scrollTop;
var _c = editorView.dom, scrollTop = _c.scrollTop, scrollHeight = _c.scrollHeight, clientHeight = _c.clientHeight, children = _c.children;
var isBottomPos = scrollHeight - scrollTop <= clientHeight + EDITOR_BOTTOM_PADDING;
var targetScrollTop = isBottomPos ? previewEl.scrollHeight : 0;
if (scrollTop && !isBottomPos) {
if (editing) {
var scrollTopByEditing = this.getScrollTopByCaretPos();
if (!scrollTopByEditing) {
return;
}
targetScrollTop = scrollTopByEditing;
}
else {
var _d = getParentNodeObj(this.previewRoot, firstMdNode), el = _d.el, mdNode = _d.mdNode;
var _e = getEditorRangeHeightInfo(doc, mdNode, children), height = _e.height, rect = _e.rect;
var totalOffsetTop = getTotalOffsetTop(el, previewRoot) || el.offsetTop;
var nodeHeight = el.clientHeight;
var ratio = top > rect.top ? Math.min((top - rect.top) / height, 1) : 0;
targetScrollTop = totalOffsetTop + nodeHeight * ratio;
}
targetScrollTop = this.getResolvedScrollTop('editor', scrollTop, targetScrollTop, curScrollTop);
this.latestEditorScrollTop = scrollTop;
}
if (targetScrollTop !== curScrollTop) {
this.run('editor', targetScrollTop, curScrollTop);
}
};
ScrollSync.prototype.syncEditorScrollTop = function (targetNode) {
var _a = this, toastMark = _a.toastMark, editorView = _a.editorView, previewRoot = _a.previewRoot, previewEl = _a.previewEl;
var dom = editorView.dom, state = editorView.state;
var scrollTop = previewEl.scrollTop, clientHeight = previewEl.clientHeight, scrollHeight = previewEl.scrollHeight;
var isBottomPos = scrollHeight - scrollTop <= clientHeight;
var curScrollTop = dom.scrollTop;
var targetScrollTop = isBottomPos ? dom.scrollHeight : 0;
if (scrollTop && targetNode && !isBottomPos) {
targetNode = findAncestorHavingId(targetNode, previewRoot);
if (!targetNode.getAttribute('data-nodeid')) {
return;
}
var children = dom.children;
var mdNodeId = Number(targetNode.getAttribute('data-nodeid'));
var _b = getParentNodeObj(this.previewRoot, toastMark.findNodeById(mdNodeId)), mdNode = _b.mdNode, el = _b.el;
var mdNodeStartLine = getMdStartLine(mdNode);
targetScrollTop = children[mdNodeStartLine - 1].offsetTop;
var height = getEditorRangeHeightInfo(state.doc, mdNode, children).height;
var _c = getAndSaveOffsetInfo(el, previewRoot, mdNodeId), nodeHeight = _c.nodeHeight, offsetTop = _c.offsetTop;
targetScrollTop += getAdditionalPos(scrollTop, offsetTop, nodeHeight, height);
targetScrollTop = this.getResolvedScrollTop('preview', scrollTop, targetScrollTop, curScrollTop);
this.latestPreviewScrollTop = scrollTop;
}
if (targetScrollTop !== curScrollTop) {
this.run('preview', targetScrollTop, curScrollTop);
}
};
ScrollSync.prototype.getResolvedScrollTop = function (from, scrollTop, targetScrollTop, curScrollTop) {
var latestScrollTop = from === 'editor' ? this.latestEditorScrollTop : this.latestPreviewScrollTop;
if (latestScrollTop === null) {
return targetScrollTop;
}
return latestScrollTop < scrollTop
? Math.max(targetScrollTop, curScrollTop)
: Math.min(targetScrollTop, curScrollTop);
};
ScrollSync.prototype.run = function (from, targetScrollTop, curScrollTop) {
var _this = this;
var scrollTarget;
if (from === 'editor') {
scrollTarget = this.previewEl;
this.blockedScroll = 'preview';
}
else {
scrollTarget = this.editorView.dom;
this.blockedScroll = 'editor';
}
var syncCallbacks = {
syncScrollTop: function (scrollTop) { return (scrollTarget.scrollTop = scrollTop); },
releaseEventBlock: function () { return (_this.blockedScroll = null); },
};
animate(curScrollTop, targetScrollTop, syncCallbacks);
};
ScrollSync.prototype.clearTimer = function () {
if (this.timer) {
clearTimeout(this.timer);
this.timer = null;
}
};
ScrollSync.prototype.destroy = function () {
this.clearTimer();
this.eventEmitter.removeEventHandler('scroll');
this.eventEmitter.removeEventHandler('afterPreviewRender');
};
return ScrollSync;
}());
;// CONCATENATED MODULE: ./src/queries/queryManager.ts
var queryMap = {
getPopupInitialValues: function (editor, payload) {
var popupName = payload.popupName;
return popupName === 'link' ? { linkText: editor.getSelectedText() } : {};
},
};
function buildQuery(editor) {
editor.eventEmitter.listen('query', function (query, payload) {
return queryMap[query](editor, payload);
});
}
;// CONCATENATED MODULE: ./src/editorCore.ts
/**
* ToastUIEditorCore
* @param {Object} options Option object
* @param {HTMLElement} options.el - container element
* @param {string} [options.height='300px'] - Editor's height style value. Height is applied as border-box ex) '300px', '100%', 'auto'
* @param {string} [options.minHeight='200px'] - Editor's min-height style value in pixel ex) '300px'
* @param {string} [options.initialValue] - Editor's initial value
* @param {string} [options.previewStyle] - Markdown editor's preview style (tab, vertical)
* @param {boolean} [options.previewHighlight = true] - Highlight a preview element corresponds to the cursor position in the markdown editor
* @param {string} [options.initialEditType] - Initial editor type (markdown, wysiwyg)
* @param {Object} [options.events] - Events
* @param {function} [options.events.load] - It would be emitted when editor fully load
* @param {function} [options.events.change] - It would be emitted when content changed
* @param {function} [options.events.caretChange] - It would be emitted when format change by cursor position
* @param {function} [options.events.focus] - It would be emitted when editor get focus
* @param {function} [options.events.blur] - It would be emitted when editor loose focus
* @param {function} [options.events.keydown] - It would be emitted when the key is pressed in editor
* @param {function} [options.events.keyup] - It would be emitted when the key is released in editor
* @param {function} [options.events.beforePreviewRender] - It would be emitted before rendering the markdown preview with html string
* @param {function} [options.events.beforeConvertWysiwygToMarkdown] - It would be emitted before converting wysiwyg to markdown with markdown text
* @param {Object} [options.hooks] - Hooks
* @param {addImageBlobHook} [options.hooks.addImageBlobHook] - hook for image upload
* @param {string} [options.language='en-US'] - language
* @param {boolean} [options.useCommandShortcut=true] - whether use keyboard shortcuts to perform commands
* @param {boolean} [options.usageStatistics=true] - send hostname to google analytics
* @param {Array.} [options.toolbarItems] - toolbar items.
* @param {boolean} [options.hideModeSwitch=false] - hide mode switch tab bar
* @param {Array.} [options.plugins] - Array of plugins. A plugin can be either a function or an array in the form of [function, options].
* @param {Object} [options.extendedAutolinks] - Using extended Autolinks specified in GFM spec
* @param {string} [options.placeholder] - The placeholder text of the editable element.
* @param {Object} [options.linkAttributes] - Attributes of anchor element that should be rel, target, hreflang, type
* @param {Object} [options.customHTMLRenderer=null] - Object containing custom renderer functions correspond to change markdown node to preview HTML or wysiwyg node
* @param {Object} [options.customMarkdownRenderer=null] - Object containing custom renderer functions correspond to change wysiwyg node to markdown text
* @param {boolean} [options.referenceDefinition=false] - whether use the specification of link reference definition
* @param {function} [options.customHTMLSanitizer=null] - custom HTML sanitizer
* @param {boolean} [options.previewHighlight=false] - whether highlight preview area
* @param {boolean} [options.frontMatter=false] - whether use the front matter
* @param {Array.} [options.widgetRules=[]] - The rules for replacing the text with widget node
* @param {string} [options.theme] - The theme to style the editor with. The default is included in toastui-editor.css.
* @param {autofocus} [options.autofocus=true] - automatically focus the editor on creation.
*/
var ToastUIEditorCore = /** @class */ (function () {
function ToastUIEditorCore(options) {
var _this = this;
this.initialHTML = options.el.innerHTML;
options.el.innerHTML = '';
this.options = extend_default()({
previewStyle: 'tab',
previewHighlight: true,
initialEditType: 'markdown',
height: '300px',
minHeight: '200px',
language: 'en-US',
useCommandShortcut: true,
usageStatistics: true,
toolbarItems: [
['heading', 'bold', 'italic', 'strike'],
['hr', 'quote'],
['ul', 'ol', 'task', 'indent', 'outdent'],
['table', 'image', 'link'],
['code', 'codeblock'],
['scrollSync'],
],
hideModeSwitch: false,
linkAttributes: null,
extendedAutolinks: false,
customHTMLRenderer: null,
customMarkdownRenderer: null,
referenceDefinition: false,
customHTMLSanitizer: null,
frontMatter: false,
widgetRules: [],
theme: 'light',
autofocus: true,
}, options);
var _a = this.options, customHTMLRenderer = _a.customHTMLRenderer, extendedAutolinks = _a.extendedAutolinks, referenceDefinition = _a.referenceDefinition, frontMatter = _a.frontMatter, customMarkdownRenderer = _a.customMarkdownRenderer, useCommandShortcut = _a.useCommandShortcut, initialEditType = _a.initialEditType, widgetRules = _a.widgetRules, customHTMLSanitizer = _a.customHTMLSanitizer;
this.mode = initialEditType || 'markdown';
this.mdPreviewStyle = this.options.previewStyle;
this.i18n = i18n;
this.i18n.setCode(this.options.language);
this.eventEmitter = new eventEmitter();
setWidgetRules(widgetRules);
var linkAttributes = sanitizeLinkAttribute(this.options.linkAttributes);
this.pluginInfo = getPluginInfo({
plugins: this.options.plugins,
eventEmitter: this.eventEmitter,
usageStatistics: this.options.usageStatistics,
instance: this,
});
var _b = this.pluginInfo, toHTMLRenderers = _b.toHTMLRenderers, toMarkdownRenderers = _b.toMarkdownRenderers, mdPlugins = _b.mdPlugins, wwPlugins = _b.wwPlugins, wwNodeViews = _b.wwNodeViews, mdCommands = _b.mdCommands, wwCommands = _b.wwCommands, markdownParsers = _b.markdownParsers;
var rendererOptions = {
linkAttributes: linkAttributes,
customHTMLRenderer: deepMergedCopy(toHTMLRenderers, customHTMLRenderer),
extendedAutolinks: extendedAutolinks,
referenceDefinition: referenceDefinition,
frontMatter: frontMatter,
sanitizer: customHTMLSanitizer || sanitizeHTML,
};
var wwToDOMAdaptor = new WwToDOMAdaptor(linkAttributes, rendererOptions.customHTMLRenderer);
var htmlSchemaMap = createHTMLSchemaMap(rendererOptions.customHTMLRenderer, rendererOptions.sanitizer, wwToDOMAdaptor);
this.toastMark = new ToastMark('', {
disallowedHtmlBlockTags: ['br', 'img'],
extendedAutolinks: extendedAutolinks,
referenceDefinition: referenceDefinition,
disallowDeepHeading: true,
frontMatter: frontMatter,
customParser: markdownParsers,
});
this.mdEditor = new mdEditor(this.eventEmitter, {
toastMark: this.toastMark,
useCommandShortcut: useCommandShortcut,
mdPlugins: mdPlugins,
});
this.preview = new mdPreview(this.eventEmitter, __assign(__assign({}, rendererOptions), { isViewer: false, highlight: this.options.previewHighlight }));
this.wwEditor = new wwEditor(this.eventEmitter, {
toDOMAdaptor: wwToDOMAdaptor,
useCommandShortcut: useCommandShortcut,
htmlSchemaMap: htmlSchemaMap,
linkAttributes: linkAttributes,
wwPlugins: wwPlugins,
wwNodeViews: wwNodeViews,
});
this.convertor = new convertor(this.wwEditor.getSchema(), __assign(__assign({}, toMarkdownRenderers), customMarkdownRenderer), getHTMLRenderConvertors(linkAttributes, rendererOptions.customHTMLRenderer), this.eventEmitter);
this.setMinHeight(this.options.minHeight);
this.setHeight(this.options.height);
this.setMarkdown(this.options.initialValue, false);
if (this.options.placeholder) {
this.setPlaceholder(this.options.placeholder);
}
if (!this.options.initialValue) {
this.setHTML(this.initialHTML, false);
}
this.commandManager = new commandManager(this.eventEmitter, this.mdEditor.commands, this.wwEditor.commands, function () { return _this.mode; });
if (this.options.usageStatistics) {
sendHostName();
}
this.scrollSync = new ScrollSync(this.mdEditor, this.preview, this.eventEmitter);
this.addInitEvent();
this.addInitCommand(mdCommands, wwCommands);
buildQuery(this);
if (this.options.hooks) {
forEachOwnProperties_default()(this.options.hooks, function (fn, key) { return _this.addHook(key, fn); });
}
if (this.options.events) {
forEachOwnProperties_default()(this.options.events, function (fn, key) { return _this.on(key, fn); });
}
this.eventEmitter.emit('load', this);
this.moveCursorToStart(this.options.autofocus);
}
ToastUIEditorCore.prototype.addInitEvent = function () {
var _this = this;
this.on('needChangeMode', this.changeMode.bind(this));
this.on('loadUI', function () {
if (_this.height !== 'auto') {
// 75px equals default editor ui height - the editing area height
var minHeight = Math.min(parseInt(_this.minHeight, 10), parseInt(_this.height, 10) - 75) + "px";
_this.setMinHeight(minHeight);
}
});
addDefaultImageBlobHook(this.eventEmitter);
};
ToastUIEditorCore.prototype.addInitCommand = function (mdCommands, wwCommands) {
var _this = this;
var addPluginCommands = function (type, commandMap) {
Object.keys(commandMap).forEach(function (name) {
_this.addCommand(type, name, commandMap[name]);
});
};
this.addCommand('markdown', 'toggleScrollSync', function (payload) {
_this.eventEmitter.emit('toggleScrollSync', payload.active);
return true;
});
addPluginCommands('markdown', mdCommands);
addPluginCommands('wysiwyg', wwCommands);
};
ToastUIEditorCore.prototype.getCurrentModeEditor = function () {
return (this.isMarkdownMode() ? this.mdEditor : this.wwEditor);
};
/**
* Factory method for Editor
* @param {object} options Option for initialize TUIEditor
* @returns {object} ToastUIEditorCore or ToastUIEditorViewer
*/
ToastUIEditorCore.factory = function (options) {
return options.viewer ? new viewer(options) : new ToastUIEditorCore(options);
};
/**
* Set language
* @param {string|string[]} code - code for I18N language
* @param {object} data - language set
*/
ToastUIEditorCore.setLanguage = function (code, data) {
i18n.setLanguage(code, data);
};
/**
* change preview style
* @param {string} style - 'tab'|'vertical'
*/
ToastUIEditorCore.prototype.changePreviewStyle = function (style) {
if (this.mdPreviewStyle !== style) {
this.mdPreviewStyle = style;
this.eventEmitter.emit('changePreviewStyle', style);
}
};
/**
* execute editor command
* @param {string} name - command name
* @param {object} [payload] - payload for command
*/
ToastUIEditorCore.prototype.exec = function (name, payload) {
this.commandManager.exec(name, payload);
};
/**
* @param {string} type - editor type
* @param {string} name - command name
* @param {function} command - command handler
*/
ToastUIEditorCore.prototype.addCommand = function (type, name, command) {
var _this = this;
var commandHoc = function (paylaod) {
if (paylaod === void 0) { paylaod = {}; }
var view = (type === 'markdown' ? _this.mdEditor : _this.wwEditor).view;
command(paylaod, view.state, view.dispatch, view);
};
this.commandManager.addCommand(type, name, commandHoc);
};
/**
* Bind eventHandler to event type
* @param {string} type Event type
* @param {function} handler Event handler
*/
ToastUIEditorCore.prototype.on = function (type, handler) {
this.eventEmitter.listen(type, handler);
};
/**
* Unbind eventHandler from event type
* @param {string} type Event type
*/
ToastUIEditorCore.prototype.off = function (type) {
this.eventEmitter.removeEventHandler(type);
};
/**
* Add hook to TUIEditor event
* @param {string} type Event type
* @param {function} handler Event handler
*/
ToastUIEditorCore.prototype.addHook = function (type, handler) {
this.eventEmitter.removeEventHandler(type);
this.eventEmitter.listen(type, handler);
};
/**
* Remove hook from TUIEditor event
* @param {string} type Event type
*/
ToastUIEditorCore.prototype.removeHook = function (type) {
this.eventEmitter.removeEventHandler(type);
};
/**
* Set focus to current Editor
*/
ToastUIEditorCore.prototype.focus = function () {
this.getCurrentModeEditor().focus();
};
/**
* Remove focus of current Editor
*/
ToastUIEditorCore.prototype.blur = function () {
this.getCurrentModeEditor().blur();
};
/**
* Set cursor position to end
* @param {boolean} [focus] - automatically focus the editor
*/
ToastUIEditorCore.prototype.moveCursorToEnd = function (focus) {
if (focus === void 0) { focus = true; }
this.getCurrentModeEditor().moveCursorToEnd(focus);
};
/**
* Set cursor position to start
* @param {boolean} [focus] - automatically focus the editor
*/
ToastUIEditorCore.prototype.moveCursorToStart = function (focus) {
if (focus === void 0) { focus = true; }
this.getCurrentModeEditor().moveCursorToStart(focus);
};
/**
* Set markdown syntax text.
* @param {string} markdown - markdown syntax text.
* @param {boolean} [cursorToEnd=true] - move cursor to contents end
*/
ToastUIEditorCore.prototype.setMarkdown = function (markdown, cursorToEnd) {
if (markdown === void 0) { markdown = ''; }
if (cursorToEnd === void 0) { cursorToEnd = true; }
this.mdEditor.setMarkdown(markdown, cursorToEnd);
if (this.isWysiwygMode()) {
var mdNode = this.toastMark.getRootNode();
var wwNode = this.convertor.toWysiwygModel(mdNode);
this.wwEditor.setModel(wwNode, cursorToEnd);
}
};
/**
* Set html value.
* @param {string} html - html syntax text
* @param {boolean} [cursorToEnd=true] - move cursor to contents end
*/
ToastUIEditorCore.prototype.setHTML = function (html, cursorToEnd) {
if (html === void 0) { html = ''; }
if (cursorToEnd === void 0) { cursorToEnd = true; }
var container = document.createElement('div');
// the `br` tag should be replaced with empty block to separate between blocks
container.innerHTML = replaceBRWithEmptyBlock(html);
var wwNode = external_commonjs_prosemirror_model_commonjs2_prosemirror_model_amd_prosemirror_model_.DOMParser.fromSchema(this.wwEditor.schema).parse(container);
if (this.isMarkdownMode()) {
this.mdEditor.setMarkdown(this.convertor.toMarkdownText(wwNode), cursorToEnd);
}
else {
this.wwEditor.setModel(wwNode, cursorToEnd);
}
};
/**
* Get content to markdown
* @returns {string} markdown text
*/
ToastUIEditorCore.prototype.getMarkdown = function () {
if (this.isMarkdownMode()) {
return this.mdEditor.getMarkdown();
}
return this.convertor.toMarkdownText(this.wwEditor.getModel());
};
/**
* Get content to html
* @returns {string} html string
*/
ToastUIEditorCore.prototype.getHTML = function () {
var _this = this;
this.eventEmitter.holdEventInvoke(function () {
if (_this.isMarkdownMode()) {
var mdNode = _this.toastMark.getRootNode();
var wwNode = _this.convertor.toWysiwygModel(mdNode);
_this.wwEditor.setModel(wwNode);
}
});
var html = removeProseMirrorHackNodes(this.wwEditor.view.dom.innerHTML);
if (this.placeholder) {
var rePlaceholder = new RegExp("]+>" + this.placeholder + " ", 'i');
return html.replace(rePlaceholder, '');
}
return html;
};
/**
* Insert text
* @param {string} text - text content
*/
ToastUIEditorCore.prototype.insertText = function (text) {
this.getCurrentModeEditor().replaceSelection(text);
};
/**
* Set selection range
* @param {number|Array.} start - start position
* @param {number|Array.} end - end position
*/
ToastUIEditorCore.prototype.setSelection = function (start, end) {
this.getCurrentModeEditor().setSelection(start, end);
};
/**
* Replace selection range with given text content
* @param {string} text - text content
* @param {number|Array.} [start] - start position
* @param {number|Array.} [end] - end position
*/
ToastUIEditorCore.prototype.replaceSelection = function (text, start, end) {
this.getCurrentModeEditor().replaceSelection(text, start, end);
};
/**
* Delete the content of selection range
* @param {number|Array.} [start] - start position
* @param {number|Array.} [end] - end position
*/
ToastUIEditorCore.prototype.deleteSelection = function (start, end) {
this.getCurrentModeEditor().deleteSelection(start, end);
};
/**
* Get selected text content
* @param {number|Array.} [start] - start position
* @param {number|Array.} [end] - end position
* @returns {string} - selected text content
*/
ToastUIEditorCore.prototype.getSelectedText = function (start, end) {
return this.getCurrentModeEditor().getSelectedText(start, end);
};
/**
* Get range of the node
* @param {number|Array.} [pos] - position
* @returns {Array.|Array.} - node [start, end] range
* @example
* // Markdown mode
* const rangeInfo = editor.getRangeInfoOfNode();
*
* console.log(rangeInfo); // { range: [[startLineOffset, startCurorOffset], [endLineOffset, endCurorOffset]], type: 'emph' }
*
* // WYSIWYG mode
* const rangeInfo = editor.getRangeInfoOfNode();
*
* console.log(rangeInfo); // { range: [startCursorOffset, endCursorOffset], type: 'emph' }
*/
ToastUIEditorCore.prototype.getRangeInfoOfNode = function (pos) {
return this.getCurrentModeEditor().getRangeInfoOfNode(pos);
};
/**
* Add widget to selection
* @param {Node} node - widget node
* @param {string} style - Adding style "top" or "bottom"
* @param {number|Array.} [pos] - position
*/
ToastUIEditorCore.prototype.addWidget = function (node, style, pos) {
this.getCurrentModeEditor().addWidget(node, style, pos);
};
/**
* Replace node with widget to range
* @param {number|Array.} start - start position
* @param {number|Array.} end - end position
* @param {string} text - widget text content
*/
ToastUIEditorCore.prototype.replaceWithWidget = function (start, end, text) {
this.getCurrentModeEditor().replaceWithWidget(start, end, text);
};
/**
* Set editor height
* @param {string} height - editor height in pixel
*/
ToastUIEditorCore.prototype.setHeight = function (height) {
var el = this.options.el;
if (isString_default()(height)) {
if (height === 'auto') {
addClass_default()(el, 'auto-height');
}
else {
removeClass_default()(el, 'auto-height');
}
this.setMinHeight(this.getMinHeight());
}
css_default()(el, { height: height });
this.height = height;
};
/**
* Get editor height
* @returns {string} editor height in pixel
*/
ToastUIEditorCore.prototype.getHeight = function () {
return this.height;
};
/**
* Set minimum height to editor content
* @param {string} minHeight - min content height in pixel
*/
ToastUIEditorCore.prototype.setMinHeight = function (minHeight) {
if (minHeight !== this.minHeight) {
var height = this.height || this.options.height;
if (height !== 'auto' && this.options.el.querySelector("." + cls('main'))) {
// 75px equals default editor ui height - the editing area height
minHeight = Math.min(parseInt(minHeight, 10), parseInt(height, 10) - 75) + "px";
}
var minHeightNum = parseInt(minHeight, 10);
this.minHeight = minHeight;
this.wwEditor.setMinHeight(minHeightNum);
this.mdEditor.setMinHeight(minHeightNum);
this.preview.setMinHeight(minHeightNum);
}
};
/**
* Get minimum height of editor content
* @returns {string} min height in pixel
*/
ToastUIEditorCore.prototype.getMinHeight = function () {
return this.minHeight;
};
/**
* Return true if current editor mode is Markdown
* @returns {boolean}
*/
ToastUIEditorCore.prototype.isMarkdownMode = function () {
return this.mode === 'markdown';
};
/**
* Return true if current editor mode is WYSIWYG
* @returns {boolean}
*/
ToastUIEditorCore.prototype.isWysiwygMode = function () {
return this.mode === 'wysiwyg';
};
/**
* Return false
* @returns {boolean}
*/
ToastUIEditorCore.prototype.isViewer = function () {
return false;
};
/**
* Get current Markdown editor's preview style
* @returns {string}
*/
ToastUIEditorCore.prototype.getCurrentPreviewStyle = function () {
return this.mdPreviewStyle;
};
/**
* Change editor's mode to given mode string
* @param {string} mode - Editor mode name of want to change
* @param {boolean} [withoutFocus] - Change mode without focus
*/
ToastUIEditorCore.prototype.changeMode = function (mode, withoutFocus) {
if (this.mode === mode) {
return;
}
this.mode = mode;
if (this.isWysiwygMode()) {
var mdNode = this.toastMark.getRootNode();
var wwNode = this.convertor.toWysiwygModel(mdNode);
this.wwEditor.setModel(wwNode);
}
else {
var wwNode = this.wwEditor.getModel();
this.mdEditor.setMarkdown(this.convertor.toMarkdownText(wwNode), !withoutFocus);
}
this.eventEmitter.emit('removePopupWidget');
this.eventEmitter.emit('changeMode', mode);
if (!withoutFocus) {
var pos = this.convertor.getMappedPos();
this.focus();
if (this.isWysiwygMode() && isNumber_default()(pos)) {
this.wwEditor.setSelection(pos);
}
else if (Array.isArray(pos)) {
this.mdEditor.setSelection(pos);
}
}
};
/**
* Destroy TUIEditor from document
*/
ToastUIEditorCore.prototype.destroy = function () {
var _this = this;
this.wwEditor.destroy();
this.mdEditor.destroy();
this.preview.destroy();
this.scrollSync.destroy();
this.eventEmitter.emit('destroy');
this.eventEmitter.getEvents().forEach(function (_, type) { return _this.off(type); });
};
/**
* Hide TUIEditor
*/
ToastUIEditorCore.prototype.hide = function () {
this.eventEmitter.emit('hide');
};
/**
* Show TUIEditor
*/
ToastUIEditorCore.prototype.show = function () {
this.eventEmitter.emit('show');
};
/**
* Move on scroll position of the editor container
* @param {number} value scrollTop value of editor container
*/
ToastUIEditorCore.prototype.setScrollTop = function (value) {
this.getCurrentModeEditor().setScrollTop(value);
};
/**
* Get scroll position value of editor container
* @returns {number} scrollTop value of editor container
*/
ToastUIEditorCore.prototype.getScrollTop = function () {
return this.getCurrentModeEditor().getScrollTop();
};
/**
* Reset TUIEditor
*/
ToastUIEditorCore.prototype.reset = function () {
this.wwEditor.setModel([]);
this.mdEditor.setMarkdown('');
};
/**
* Get current selection range
* @returns {Array.|Array.} Returns the range of the selection depending on the editor mode
* @example
* // Markdown mode
* const mdSelection = editor.getSelection();
*
* console.log(mdSelection); // [[startLineOffset, startCurorOffset], [endLineOffset, endCurorOffset]]
*
* // WYSIWYG mode
* const wwSelection = editor.getSelection();
*
* console.log(wwSelection); // [startCursorOffset, endCursorOffset]
*/
ToastUIEditorCore.prototype.getSelection = function () {
return this.getCurrentModeEditor().getSelection();
};
/**
* Set the placeholder on all editors
* @param {string} placeholder - placeholder to set
*/
ToastUIEditorCore.prototype.setPlaceholder = function (placeholder) {
this.placeholder = placeholder;
this.mdEditor.setPlaceholder(placeholder);
this.wwEditor.setPlaceholder(placeholder);
};
/**
* Get markdown editor, preview, wysiwyg editor DOM elements
*/
ToastUIEditorCore.prototype.getEditorElements = function () {
return {
mdEditor: this.mdEditor.getElement(),
mdPreview: this.preview.getElement(),
wwEditor: this.wwEditor.getElement(),
};
};
/**
* Convert position to match editor mode
* @param {number|Array.} start - start position
* @param {number|Array.} end - end position
* @param {string} mode - Editor mode name of want to match converted position to
*/
ToastUIEditorCore.prototype.convertPosToMatchEditorMode = function (start, end, mode) {
var _a, _b;
if (end === void 0) { end = start; }
if (mode === void 0) { mode = this.mode; }
var doc = this.mdEditor.view.state.doc;
var isFromArray = Array.isArray(start);
var isToArray = Array.isArray(end);
var convertedFrom = start;
var convertedTo = end;
if (isFromArray !== isToArray) {
throw new Error('Types of arguments must be same');
}
if (mode === 'markdown' && !isFromArray && !isToArray) {
_a = getEditorToMdPos(doc, start, end), convertedFrom = _a[0], convertedTo = _a[1];
}
else if (mode === 'wysiwyg' && isFromArray && isToArray) {
_b = getMdToEditorPos(doc, start, end), convertedFrom = _b[0], convertedTo = _b[1];
}
return [convertedFrom, convertedTo];
};
return ToastUIEditorCore;
}());
// // (Not an official API)
// // Create a function converting markdown to HTML using the internal parser and renderer.
// ToastUIEditor._createMarkdownToHTML = createMarkdownToHTML;
/* harmony default export */ var editorCore = (ToastUIEditorCore);
;// CONCATENATED MODULE: ./src/ui/vdom/htm.js
// @TODO: change syntax with our convention
/* eslint-disable */
/* harmony default export */ function htm(n) {
for (var l, e, s = arguments, t = 1, r = '', u = '', a = [0], c = function (n) {
t === 1 && (n || (r = r.replace(/^\s*\n\s*|\s*\n\s*$/g, '')))
? a.push(n ? s[n] : r)
: t === 3 && (n || r)
? ((a[1] = n ? s[n] : r), (t = 2))
: t === 2 && r === '...' && n
? (a[2] = common_assign(a[2] || {}, s[n]))
: t === 2 && r && !n
? ((a[2] = a[2] || {})[r] = !0)
: t >= 5 &&
(t === 5
? (((a[2] = a[2] || {})[e] = n ? (r ? r + s[n] : s[n]) : r), (t = 6))
: (n || r) && (a[2][e] += n ? r + s[n] : r)),
(r = '');
}, h = 0; h < n.length; h++) {
h && (t === 1 && c(), c(h));
for (var i = 0; i < n[h].length; i++)
(l = n[h][i]),
t === 1
? l === '<'
? (c(), (a = [a, '', null]), (t = 3))
: (r += l)
: t === 4
? r === '--' && l === '>'
? ((t = 1), (r = ''))
: (r = l + r[0])
: u
? l === u
? (u = '')
: (r += l)
: l === '"' || l === "'"
? (u = l)
: l === '>'
? (c(), (t = 1))
: t &&
(l === '='
? ((t = 5), (e = r), (r = ''))
: l === '/' && (t < 5 || n[h][i + 1] === '>')
? (c(),
t === 3 && (a = a[0]),
(t = a),
(a = a[0]).push(this.apply(null, t.slice(1))),
(t = 0))
: l === ' ' || l === '\t' || l === '\n' || l === '\r'
? (c(), (t = 2))
: (r += l)),
t === 3 && r === '!--' && ((t = 4), (a = a[0]));
}
return c(), a.length > 2 ? a.slice(1) : a[1];
}
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isBoolean.js
var isBoolean = __webpack_require__(326);
var isBoolean_default = /*#__PURE__*/__webpack_require__.n(isBoolean);
;// CONCATENATED MODULE: ./src/ui/vdom/vnode.ts
var VNodeWalker = /** @class */ (function () {
function VNodeWalker(current) {
this.current = current;
this.root = current;
this.entering = true;
}
VNodeWalker.prototype.walk = function () {
var _a = this, entering = _a.entering, cur = _a.current;
if (!cur) {
return null;
}
if (entering) {
if (cur.firstChild) {
this.current = cur.firstChild;
this.entering = true;
}
else {
this.entering = false;
}
}
else if (cur === this.root) {
this.current = null;
}
else if (cur.next) {
this.current = cur.next;
this.entering = true;
}
else {
this.current = cur.parent;
this.entering = false;
}
return { vnode: cur, entering: entering };
};
return VNodeWalker;
}());
var VNode = /** @class */ (function () {
function VNode(type, props, children) {
this.parent = null;
this.old = null;
this.firstChild = null;
this.next = null;
this.skip = false;
this.type = type;
this.props = props;
this.children = children;
this.props.children = children;
if (props.ref) {
this.ref = props.ref;
delete props.ref;
}
if (props.key) {
this.key = props.key;
delete props.key;
}
}
VNode.prototype.walker = function () {
return new VNodeWalker(this);
};
VNode.removalNodes = [];
return VNode;
}());
;// CONCATENATED MODULE: ./src/ui/vdom/template.ts
function template_createTextNode(text) {
return new VNode('TEXT_NODE', { nodeValue: text }, []);
}
function excludeUnnecessaryChild(child, flatted) {
var vnode = child;
// eslint-disable-next-line no-eq-null,eqeqeq
if (isBoolean_default()(child) || child == null) {
vnode = null;
}
else if (isString_default()(child) || isNumber_default()(child)) {
vnode = template_createTextNode(String(child));
}
if (vnode) {
flatted.push(vnode);
}
}
function h(type, props) {
var children = [];
for (var _i = 2; _i < arguments.length; _i++) {
children[_i - 2] = arguments[_i];
}
var flatted = [];
children.forEach(function (child) {
if (Array.isArray(child)) {
child.forEach(function (vnode) {
excludeUnnecessaryChild(vnode, flatted);
});
}
else {
excludeUnnecessaryChild(child, flatted);
}
});
return new VNode(type, props || {}, flatted);
}
// @ts-ignore
/* harmony default export */ var template = (htm.bind(h));
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/type/isObject.js
var type_isObject = __webpack_require__(73);
var isObject_default = /*#__PURE__*/__webpack_require__.n(type_isObject);
;// CONCATENATED MODULE: ./src/ui/vdom/dom.ts
// @TODO: clearfy the type definition for CSSDeclaration
function dom_createNode(vnode) {
var node;
if (vnode.type === 'TEXT_NODE') {
node = document.createTextNode(vnode.props.nodeValue);
}
else {
node = document.createElement(vnode.type);
setProps(node, {}, vnode.props);
}
return node;
}
function dom_removeNode(vnode, parentNode) {
if (vnode.node) {
parentNode.removeChild(vnode.node);
}
else {
dom_removeNode(vnode.firstChild, parentNode);
}
}
function innerDiff(node, prevProps, nextProps) {
Object.keys(prevProps).forEach(function (propName) {
if (/^on/.test(propName)) {
if (!nextProps[propName] || prevProps[propName] !== nextProps[propName]) {
var eventName = propName.slice(2).toLowerCase();
node.removeEventListener(eventName, prevProps[propName]);
}
}
else if (propName !== 'children' && !nextProps[propName] && !isTextNode(node)) {
node.removeAttribute(propName);
}
});
setProps(node, prevProps, nextProps, function (propName) { return !shallowEqual(prevProps[propName], nextProps[propName]); });
}
var reNonDimension = /acit|ex(?:s|g|n|p|$)|rph|ows|mnc|ntw|ine[ch]|zoo|^ord/i;
function setProps(node, prevProps, props, condition) {
Object.keys(props).forEach(function (propName) {
if (!condition || condition(propName)) {
if (/^on/.test(propName)) {
var eventName = propName.slice(2).toLowerCase();
node.addEventListener(eventName, props[propName]);
}
else if (propName === 'nodeValue') {
node[propName] = props[propName];
}
else if (propName === 'style' && isObject_default()(props[propName])) {
setStyleProps(node, prevProps[propName], props[propName]);
}
else if (propName !== 'children') {
if (props[propName] === false) {
node.removeAttribute(propName);
}
else {
node.setAttribute(propName, props[propName]);
}
}
}
});
}
function setStyleProps(node, prevStyleProps, styleProps) {
if (prevStyleProps) {
Object.keys(prevStyleProps).forEach(function (styleProp) {
// @ts-ignore
node.style[styleProp] = '';
});
}
Object.keys(styleProps).forEach(function (styleProp) {
var value = styleProps[styleProp];
// @ts-ignore
node.style[styleProp] =
isNumber_default()(value) && !reNonDimension.test(styleProp) ? value + "px" : value;
});
}
;// CONCATENATED MODULE: ./src/ui/vdom/commit.ts
function commit(vnode) {
VNode.removalNodes.forEach(function (removalNode) { return diff(removalNode); });
if (vnode) {
var next = void 0;
var walker = vnode.walker();
while ((next = walker.walk())) {
vnode = next.vnode;
if (next.entering) {
diff(vnode);
}
else if (isFunction_default()(vnode.type)) {
var comp = vnode.component;
// lifecycle method
if (!vnode.old && comp.mounted) {
comp.mounted();
}
if (vnode.old && comp.updated) {
var prevProps = comp.prevProps || {};
comp.updated(prevProps);
}
}
}
}
}
function getParentNode(vnode) {
var parent = vnode.parent;
while (!parent.node) {
parent = parent.parent;
}
return parent.node;
}
function diff(vnode) {
if (!vnode || !vnode.parent) {
return;
}
if (vnode.node) {
var parentNode = getParentNode(vnode);
if (vnode.effect === 'A') {
parentNode.appendChild(vnode.node);
}
else if (vnode.effect === 'U') {
innerDiff(vnode.node, vnode.old.props, vnode.props);
}
}
if (vnode.effect === 'D') {
var next = void 0;
var walker = vnode.walker();
while ((next = walker.walk())) {
vnode = next.vnode;
if (!next.entering) {
if (isFunction_default()(vnode.type)) {
var comp = vnode.component;
// lifecycle method
if (comp.beforeDestroy) {
comp.beforeDestroy();
}
}
else {
var parentNode = getParentNode(vnode);
dom_removeNode(vnode, parentNode);
}
}
}
}
// apply ref
if (vnode.ref) {
if (vnode.component) {
vnode.ref(vnode.component);
}
else if (vnode.node) {
vnode.ref(vnode.node);
}
}
}
;// CONCATENATED MODULE: ./src/ui/vdom/render.ts
function createComponent(Comp, vnode) {
var props = vnode.props, component = vnode.component;
if (component) {
component.prevProps = component.props;
component.props = vnode.props;
return component;
}
return new Comp(props);
}
function buildVNode(vnode) {
var root = vnode;
while (vnode && !vnode.skip) {
if (isFunction_default()(vnode.type)) {
var instance = createComponent(vnode.type, vnode);
instance.vnode = vnode;
vnode.component = instance;
vnode.props.children = vnode.children = [instance.render()];
buildChildrenVNode(vnode);
}
else {
if (!vnode.node) {
vnode.node = dom_createNode(vnode);
}
buildChildrenVNode(vnode);
}
if (vnode.firstChild) {
vnode = vnode.firstChild;
}
else {
while (vnode && vnode.parent && !vnode.next) {
vnode = vnode.parent;
if (vnode === root) {
break;
}
}
vnode = vnode.next;
}
}
}
function isSameType(old, vnode) {
return old && vnode && vnode.type === old.type && (!vnode.key || vnode.key === old.key);
}
// @TODO: add key diff algorithm
function buildChildrenVNode(parent) {
var children = parent.children;
var old = parent.old ? parent.old.firstChild : null;
var prev = null;
children.forEach(function (vnode, index) {
var sameType = isSameType(old, vnode);
if (sameType) {
vnode.old = old;
vnode.parent = parent;
vnode.node = old.node;
vnode.component = old.component;
vnode.effect = 'U';
}
if (vnode && !sameType) {
vnode.old = null;
vnode.parent = parent;
vnode.node = null;
vnode.effect = 'A';
}
if (old && !sameType) {
VNode.removalNodes.push(old);
old.effect = 'D';
}
if (old) {
old = old.next;
}
if (index === 0) {
parent.firstChild = vnode;
}
else if (vnode) {
prev.next = vnode;
}
prev = vnode;
});
var lastChild = last(children);
if (!children.length) {
while (old) {
VNode.removalNodes.push(old);
old.effect = 'D';
old = old.next;
}
}
while (old && lastChild) {
if (old && lastChild.old !== old) {
VNode.removalNodes.push(old);
old.effect = 'D';
old = old.next;
}
}
}
;// CONCATENATED MODULE: ./src/ui/vdom/renderer.ts
function destroy(vnode) {
vnode.effect = 'D';
VNode.removalNodes = [vnode];
commit();
VNode.removalNodes = [];
}
function rerender(comp) {
var root = comp.vnode;
root.effect = 'U';
root.old = root;
// skip for unnecessary reconciliation
if (root.next) {
root.next.skip = true;
}
VNode.removalNodes = [];
buildVNode(root);
commit(root);
if (root.next) {
root.next.skip = false;
}
}
function render(container, vnode) {
var root = new VNode(container.tagName.toLowerCase(), {}, [vnode]);
root.node = container;
VNode.removalNodes = [];
buildVNode(root);
commit(root);
return function () { return destroy(root.firstChild); };
}
;// CONCATENATED MODULE: ./src/ui/vdom/component.ts
var Component = /** @class */ (function () {
function Component(props) {
this.props = props;
this.state = {};
this.refs = {};
}
Component.prototype.setState = function (state) {
var newState = __assign(__assign({}, this.state), state);
if (!shallowEqual(this.state, newState)) {
this.state = newState;
rerender(this);
}
};
return Component;
}());
;// CONCATENATED MODULE: ./src/ui/components/switch.ts
var Switch = /** @class */ (function (_super) {
__extends(Switch, _super);
function Switch(props) {
var _this = _super.call(this, props) || this;
_this.state = {
hide: false,
};
return _this;
}
Switch.prototype.show = function () {
this.setState({ hide: false });
};
Switch.prototype.hide = function () {
this.setState({ hide: true });
};
Switch.prototype.render = function () {
var _a = this.props, editorType = _a.editorType, eventEmitter = _a.eventEmitter;
return template(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n \n
\n ", "\n
\n
\n ", "\n
\n
\n "], ["\n \n
\n ", "\n
\n
\n ", "\n
\n
\n "])), cls('mode-switch'), this.state.hide ? 'none' : 'block', editorType === 'markdown' ? ' active' : '', function () {
eventEmitter.emit('needChangeMode', 'markdown');
}, i18n.get('Markdown'), editorType === 'wysiwyg' ? ' active' : '', function () {
eventEmitter.emit('needChangeMode', 'wysiwyg');
}, i18n.get('WYSIWYG'));
};
return Switch;
}(Component));
var templateObject_1;
// EXTERNAL MODULE: ../../node_modules/tui-code-snippet/tricks/throttle.js
var throttle = __webpack_require__(423);
var throttle_default = /*#__PURE__*/__webpack_require__.n(throttle);
;// CONCATENATED MODULE: ../../node_modules/resize-observer-polyfill/dist/ResizeObserver.es.js
/**
* A collection of shims that provide minimal functionality of the ES6 collections.
*
* These implementations are not meant to be used outside of the ResizeObserver
* modules as they cover only a limited range of use cases.
*/
/* eslint-disable require-jsdoc, valid-jsdoc */
var MapShim = (function () {
if (typeof Map !== 'undefined') {
return Map;
}
/**
* Returns index in provided array that matches the specified key.
*
* @param {Array} arr
* @param {*} key
* @returns {number}
*/
function getIndex(arr, key) {
var result = -1;
arr.some(function (entry, index) {
if (entry[0] === key) {
result = index;
return true;
}
return false;
});
return result;
}
return /** @class */ (function () {
function class_1() {
this.__entries__ = [];
}
Object.defineProperty(class_1.prototype, "size", {
/**
* @returns {boolean}
*/
get: function () {
return this.__entries__.length;
},
enumerable: true,
configurable: true
});
/**
* @param {*} key
* @returns {*}
*/
class_1.prototype.get = function (key) {
var index = getIndex(this.__entries__, key);
var entry = this.__entries__[index];
return entry && entry[1];
};
/**
* @param {*} key
* @param {*} value
* @returns {void}
*/
class_1.prototype.set = function (key, value) {
var index = getIndex(this.__entries__, key);
if (~index) {
this.__entries__[index][1] = value;
}
else {
this.__entries__.push([key, value]);
}
};
/**
* @param {*} key
* @returns {void}
*/
class_1.prototype.delete = function (key) {
var entries = this.__entries__;
var index = getIndex(entries, key);
if (~index) {
entries.splice(index, 1);
}
};
/**
* @param {*} key
* @returns {void}
*/
class_1.prototype.has = function (key) {
return !!~getIndex(this.__entries__, key);
};
/**
* @returns {void}
*/
class_1.prototype.clear = function () {
this.__entries__.splice(0);
};
/**
* @param {Function} callback
* @param {*} [ctx=null]
* @returns {void}
*/
class_1.prototype.forEach = function (callback, ctx) {
if (ctx === void 0) { ctx = null; }
for (var _i = 0, _a = this.__entries__; _i < _a.length; _i++) {
var entry = _a[_i];
callback.call(ctx, entry[1], entry[0]);
}
};
return class_1;
}());
})();
/**
* Detects whether window and document objects are available in current environment.
*/
var isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined' && window.document === document;
// Returns global object of a current environment.
var global$1 = (function () {
if (typeof __webpack_require__.g !== 'undefined' && __webpack_require__.g.Math === Math) {
return __webpack_require__.g;
}
if (typeof self !== 'undefined' && self.Math === Math) {
return self;
}
if (typeof window !== 'undefined' && window.Math === Math) {
return window;
}
// eslint-disable-next-line no-new-func
return Function('return this')();
})();
/**
* A shim for the requestAnimationFrame which falls back to the setTimeout if
* first one is not supported.
*
* @returns {number} Requests' identifier.
*/
var requestAnimationFrame$1 = (function () {
if (typeof requestAnimationFrame === 'function') {
// It's required to use a bounded function because IE sometimes throws
// an "Invalid calling object" error if rAF is invoked without the global
// object on the left hand side.
return requestAnimationFrame.bind(global$1);
}
return function (callback) { return setTimeout(function () { return callback(Date.now()); }, 1000 / 60); };
})();
// Defines minimum timeout before adding a trailing call.
var trailingTimeout = 2;
/**
* Creates a wrapper function which ensures that provided callback will be
* invoked only once during the specified delay period.
*
* @param {Function} callback - Function to be invoked after the delay period.
* @param {number} delay - Delay after which to invoke callback.
* @returns {Function}
*/
function ResizeObserver_es_throttle (callback, delay) {
var leadingCall = false, trailingCall = false, lastCallTime = 0;
/**
* Invokes the original callback function and schedules new invocation if
* the "proxy" was called during current request.
*
* @returns {void}
*/
function resolvePending() {
if (leadingCall) {
leadingCall = false;
callback();
}
if (trailingCall) {
proxy();
}
}
/**
* Callback invoked after the specified delay. It will further postpone
* invocation of the original function delegating it to the
* requestAnimationFrame.
*
* @returns {void}
*/
function timeoutCallback() {
requestAnimationFrame$1(resolvePending);
}
/**
* Schedules invocation of the original function.
*
* @returns {void}
*/
function proxy() {
var timeStamp = Date.now();
if (leadingCall) {
// Reject immediately following calls.
if (timeStamp - lastCallTime < trailingTimeout) {
return;
}
// Schedule new call to be in invoked when the pending one is resolved.
// This is important for "transitions" which never actually start
// immediately so there is a chance that we might miss one if change
// happens amids the pending invocation.
trailingCall = true;
}
else {
leadingCall = true;
trailingCall = false;
setTimeout(timeoutCallback, delay);
}
lastCallTime = timeStamp;
}
return proxy;
}
// Minimum delay before invoking the update of observers.
var REFRESH_DELAY = 20;
// A list of substrings of CSS properties used to find transition events that
// might affect dimensions of observed elements.
var transitionKeys = ['top', 'right', 'bottom', 'left', 'width', 'height', 'size', 'weight'];
// Check if MutationObserver is available.
var mutationObserverSupported = typeof MutationObserver !== 'undefined';
/**
* Singleton controller class which handles updates of ResizeObserver instances.
*/
var ResizeObserverController = /** @class */ (function () {
/**
* Creates a new instance of ResizeObserverController.
*
* @private
*/
function ResizeObserverController() {
/**
* Indicates whether DOM listeners have been added.
*
* @private {boolean}
*/
this.connected_ = false;
/**
* Tells that controller has subscribed for Mutation Events.
*
* @private {boolean}
*/
this.mutationEventsAdded_ = false;
/**
* Keeps reference to the instance of MutationObserver.
*
* @private {MutationObserver}
*/
this.mutationsObserver_ = null;
/**
* A list of connected observers.
*
* @private {Array}
*/
this.observers_ = [];
this.onTransitionEnd_ = this.onTransitionEnd_.bind(this);
this.refresh = ResizeObserver_es_throttle(this.refresh.bind(this), REFRESH_DELAY);
}
/**
* Adds observer to observers list.
*
* @param {ResizeObserverSPI} observer - Observer to be added.
* @returns {void}
*/
ResizeObserverController.prototype.addObserver = function (observer) {
if (!~this.observers_.indexOf(observer)) {
this.observers_.push(observer);
}
// Add listeners if they haven't been added yet.
if (!this.connected_) {
this.connect_();
}
};
/**
* Removes observer from observers list.
*
* @param {ResizeObserverSPI} observer - Observer to be removed.
* @returns {void}
*/
ResizeObserverController.prototype.removeObserver = function (observer) {
var observers = this.observers_;
var index = observers.indexOf(observer);
// Remove observer if it's present in registry.
if (~index) {
observers.splice(index, 1);
}
// Remove listeners if controller has no connected observers.
if (!observers.length && this.connected_) {
this.disconnect_();
}
};
/**
* Invokes the update of observers. It will continue running updates insofar
* it detects changes.
*
* @returns {void}
*/
ResizeObserverController.prototype.refresh = function () {
var changesDetected = this.updateObservers_();
// Continue running updates if changes have been detected as there might
// be future ones caused by CSS transitions.
if (changesDetected) {
this.refresh();
}
};
/**
* Updates every observer from observers list and notifies them of queued
* entries.
*
* @private
* @returns {boolean} Returns "true" if any observer has detected changes in
* dimensions of it's elements.
*/
ResizeObserverController.prototype.updateObservers_ = function () {
// Collect observers that have active observations.
var activeObservers = this.observers_.filter(function (observer) {
return observer.gatherActive(), observer.hasActive();
});
// Deliver notifications in a separate cycle in order to avoid any
// collisions between observers, e.g. when multiple instances of
// ResizeObserver are tracking the same element and the callback of one
// of them changes content dimensions of the observed target. Sometimes
// this may result in notifications being blocked for the rest of observers.
activeObservers.forEach(function (observer) { return observer.broadcastActive(); });
return activeObservers.length > 0;
};
/**
* Initializes DOM listeners.
*
* @private
* @returns {void}
*/
ResizeObserverController.prototype.connect_ = function () {
// Do nothing if running in a non-browser environment or if listeners
// have been already added.
if (!isBrowser || this.connected_) {
return;
}
// Subscription to the "Transitionend" event is used as a workaround for
// delayed transitions. This way it's possible to capture at least the
// final state of an element.
document.addEventListener('transitionend', this.onTransitionEnd_);
window.addEventListener('resize', this.refresh);
if (mutationObserverSupported) {
this.mutationsObserver_ = new MutationObserver(this.refresh);
this.mutationsObserver_.observe(document, {
attributes: true,
childList: true,
characterData: true,
subtree: true
});
}
else {
document.addEventListener('DOMSubtreeModified', this.refresh);
this.mutationEventsAdded_ = true;
}
this.connected_ = true;
};
/**
* Removes DOM listeners.
*
* @private
* @returns {void}
*/
ResizeObserverController.prototype.disconnect_ = function () {
// Do nothing if running in a non-browser environment or if listeners
// have been already removed.
if (!isBrowser || !this.connected_) {
return;
}
document.removeEventListener('transitionend', this.onTransitionEnd_);
window.removeEventListener('resize', this.refresh);
if (this.mutationsObserver_) {
this.mutationsObserver_.disconnect();
}
if (this.mutationEventsAdded_) {
document.removeEventListener('DOMSubtreeModified', this.refresh);
}
this.mutationsObserver_ = null;
this.mutationEventsAdded_ = false;
this.connected_ = false;
};
/**
* "Transitionend" event handler.
*
* @private
* @param {TransitionEvent} event
* @returns {void}
*/
ResizeObserverController.prototype.onTransitionEnd_ = function (_a) {
var _b = _a.propertyName, propertyName = _b === void 0 ? '' : _b;
// Detect whether transition may affect dimensions of an element.
var isReflowProperty = transitionKeys.some(function (key) {
return !!~propertyName.indexOf(key);
});
if (isReflowProperty) {
this.refresh();
}
};
/**
* Returns instance of the ResizeObserverController.
*
* @returns {ResizeObserverController}
*/
ResizeObserverController.getInstance = function () {
if (!this.instance_) {
this.instance_ = new ResizeObserverController();
}
return this.instance_;
};
/**
* Holds reference to the controller's instance.
*
* @private {ResizeObserverController}
*/
ResizeObserverController.instance_ = null;
return ResizeObserverController;
}());
/**
* Defines non-writable/enumerable properties of the provided target object.
*
* @param {Object} target - Object for which to define properties.
* @param {Object} props - Properties to be defined.
* @returns {Object} Target object.
*/
var defineConfigurable = (function (target, props) {
for (var _i = 0, _a = Object.keys(props); _i < _a.length; _i++) {
var key = _a[_i];
Object.defineProperty(target, key, {
value: props[key],
enumerable: false,
writable: false,
configurable: true
});
}
return target;
});
/**
* Returns the global object associated with provided element.
*
* @param {Object} target
* @returns {Object}
*/
var getWindowOf = (function (target) {
// Assume that the element is an instance of Node, which means that it
// has the "ownerDocument" property from which we can retrieve a
// corresponding global object.
var ownerGlobal = target && target.ownerDocument && target.ownerDocument.defaultView;
// Return the local global object if it's not possible extract one from
// provided element.
return ownerGlobal || global$1;
});
// Placeholder of an empty content rectangle.
var emptyRect = createRectInit(0, 0, 0, 0);
/**
* Converts provided string to a number.
*
* @param {number|string} value
* @returns {number}
*/
function toFloat(value) {
return parseFloat(value) || 0;
}
/**
* Extracts borders size from provided styles.
*
* @param {CSSStyleDeclaration} styles
* @param {...string} positions - Borders positions (top, right, ...)
* @returns {number}
*/
function getBordersSize(styles) {
var positions = [];
for (var _i = 1; _i < arguments.length; _i++) {
positions[_i - 1] = arguments[_i];
}
return positions.reduce(function (size, position) {
var value = styles['border-' + position + '-width'];
return size + toFloat(value);
}, 0);
}
/**
* Extracts paddings sizes from provided styles.
*
* @param {CSSStyleDeclaration} styles
* @returns {Object} Paddings box.
*/
function getPaddings(styles) {
var positions = ['top', 'right', 'bottom', 'left'];
var paddings = {};
for (var _i = 0, positions_1 = positions; _i < positions_1.length; _i++) {
var position = positions_1[_i];
var value = styles['padding-' + position];
paddings[position] = toFloat(value);
}
return paddings;
}
/**
* Calculates content rectangle of provided SVG element.
*
* @param {SVGGraphicsElement} target - Element content rectangle of which needs
* to be calculated.
* @returns {DOMRectInit}
*/
function getSVGContentRect(target) {
var bbox = target.getBBox();
return createRectInit(0, 0, bbox.width, bbox.height);
}
/**
* Calculates content rectangle of provided HTMLElement.
*
* @param {HTMLElement} target - Element for which to calculate the content rectangle.
* @returns {DOMRectInit}
*/
function getHTMLElementContentRect(target) {
// Client width & height properties can't be
// used exclusively as they provide rounded values.
var clientWidth = target.clientWidth, clientHeight = target.clientHeight;
// By this condition we can catch all non-replaced inline, hidden and
// detached elements. Though elements with width & height properties less
// than 0.5 will be discarded as well.
//
// Without it we would need to implement separate methods for each of
// those cases and it's not possible to perform a precise and performance
// effective test for hidden elements. E.g. even jQuery's ':visible' filter
// gives wrong results for elements with width & height less than 0.5.
if (!clientWidth && !clientHeight) {
return emptyRect;
}
var styles = getWindowOf(target).getComputedStyle(target);
var paddings = getPaddings(styles);
var horizPad = paddings.left + paddings.right;
var vertPad = paddings.top + paddings.bottom;
// Computed styles of width & height are being used because they are the
// only dimensions available to JS that contain non-rounded values. It could
// be possible to utilize the getBoundingClientRect if only it's data wasn't
// affected by CSS transformations let alone paddings, borders and scroll bars.
var width = toFloat(styles.width), height = toFloat(styles.height);
// Width & height include paddings and borders when the 'border-box' box
// model is applied (except for IE).
if (styles.boxSizing === 'border-box') {
// Following conditions are required to handle Internet Explorer which
// doesn't include paddings and borders to computed CSS dimensions.
//
// We can say that if CSS dimensions + paddings are equal to the "client"
// properties then it's either IE, and thus we don't need to subtract
// anything, or an element merely doesn't have paddings/borders styles.
if (Math.round(width + horizPad) !== clientWidth) {
width -= getBordersSize(styles, 'left', 'right') + horizPad;
}
if (Math.round(height + vertPad) !== clientHeight) {
height -= getBordersSize(styles, 'top', 'bottom') + vertPad;
}
}
// Following steps can't be applied to the document's root element as its
// client[Width/Height] properties represent viewport area of the window.
// Besides, it's as well not necessary as the itself neither has
// rendered scroll bars nor it can be clipped.
if (!isDocumentElement(target)) {
// In some browsers (only in Firefox, actually) CSS width & height
// include scroll bars size which can be removed at this step as scroll
// bars are the only difference between rounded dimensions + paddings
// and "client" properties, though that is not always true in Chrome.
var vertScrollbar = Math.round(width + horizPad) - clientWidth;
var horizScrollbar = Math.round(height + vertPad) - clientHeight;
// Chrome has a rather weird rounding of "client" properties.
// E.g. for an element with content width of 314.2px it sometimes gives
// the client width of 315px and for the width of 314.7px it may give
// 314px. And it doesn't happen all the time. So just ignore this delta
// as a non-relevant.
if (Math.abs(vertScrollbar) !== 1) {
width -= vertScrollbar;
}
if (Math.abs(horizScrollbar) !== 1) {
height -= horizScrollbar;
}
}
return createRectInit(paddings.left, paddings.top, width, height);
}
/**
* Checks whether provided element is an instance of the SVGGraphicsElement.
*
* @param {Element} target - Element to be checked.
* @returns {boolean}
*/
var isSVGGraphicsElement = (function () {
// Some browsers, namely IE and Edge, don't have the SVGGraphicsElement
// interface.
if (typeof SVGGraphicsElement !== 'undefined') {
return function (target) { return target instanceof getWindowOf(target).SVGGraphicsElement; };
}
// If it's so, then check that element is at least an instance of the
// SVGElement and that it has the "getBBox" method.
// eslint-disable-next-line no-extra-parens
return function (target) { return (target instanceof getWindowOf(target).SVGElement &&
typeof target.getBBox === 'function'); };
})();
/**
* Checks whether provided element is a document element ().
*
* @param {Element} target - Element to be checked.
* @returns {boolean}
*/
function isDocumentElement(target) {
return target === getWindowOf(target).document.documentElement;
}
/**
* Calculates an appropriate content rectangle for provided html or svg element.
*
* @param {Element} target - Element content rectangle of which needs to be calculated.
* @returns {DOMRectInit}
*/
function getContentRect(target) {
if (!isBrowser) {
return emptyRect;
}
if (isSVGGraphicsElement(target)) {
return getSVGContentRect(target);
}
return getHTMLElementContentRect(target);
}
/**
* Creates rectangle with an interface of the DOMRectReadOnly.
* Spec: https://drafts.fxtf.org/geometry/#domrectreadonly
*
* @param {DOMRectInit} rectInit - Object with rectangle's x/y coordinates and dimensions.
* @returns {DOMRectReadOnly}
*/
function createReadOnlyRect(_a) {
var x = _a.x, y = _a.y, width = _a.width, height = _a.height;
// If DOMRectReadOnly is available use it as a prototype for the rectangle.
var Constr = typeof DOMRectReadOnly !== 'undefined' ? DOMRectReadOnly : Object;
var rect = Object.create(Constr.prototype);
// Rectangle's properties are not writable and non-enumerable.
defineConfigurable(rect, {
x: x, y: y, width: width, height: height,
top: y,
right: x + width,
bottom: height + y,
left: x
});
return rect;
}
/**
* Creates DOMRectInit object based on the provided dimensions and the x/y coordinates.
* Spec: https://drafts.fxtf.org/geometry/#dictdef-domrectinit
*
* @param {number} x - X coordinate.
* @param {number} y - Y coordinate.
* @param {number} width - Rectangle's width.
* @param {number} height - Rectangle's height.
* @returns {DOMRectInit}
*/
function createRectInit(x, y, width, height) {
return { x: x, y: y, width: width, height: height };
}
/**
* Class that is responsible for computations of the content rectangle of
* provided DOM element and for keeping track of it's changes.
*/
var ResizeObservation = /** @class */ (function () {
/**
* Creates an instance of ResizeObservation.
*
* @param {Element} target - Element to be observed.
*/
function ResizeObservation(target) {
/**
* Broadcasted width of content rectangle.
*
* @type {number}
*/
this.broadcastWidth = 0;
/**
* Broadcasted height of content rectangle.
*
* @type {number}
*/
this.broadcastHeight = 0;
/**
* Reference to the last observed content rectangle.
*
* @private {DOMRectInit}
*/
this.contentRect_ = createRectInit(0, 0, 0, 0);
this.target = target;
}
/**
* Updates content rectangle and tells whether it's width or height properties
* have changed since the last broadcast.
*
* @returns {boolean}
*/
ResizeObservation.prototype.isActive = function () {
var rect = getContentRect(this.target);
this.contentRect_ = rect;
return (rect.width !== this.broadcastWidth ||
rect.height !== this.broadcastHeight);
};
/**
* Updates 'broadcastWidth' and 'broadcastHeight' properties with a data
* from the corresponding properties of the last observed content rectangle.
*
* @returns {DOMRectInit} Last observed content rectangle.
*/
ResizeObservation.prototype.broadcastRect = function () {
var rect = this.contentRect_;
this.broadcastWidth = rect.width;
this.broadcastHeight = rect.height;
return rect;
};
return ResizeObservation;
}());
var ResizeObserverEntry = /** @class */ (function () {
/**
* Creates an instance of ResizeObserverEntry.
*
* @param {Element} target - Element that is being observed.
* @param {DOMRectInit} rectInit - Data of the element's content rectangle.
*/
function ResizeObserverEntry(target, rectInit) {
var contentRect = createReadOnlyRect(rectInit);
// According to the specification following properties are not writable
// and are also not enumerable in the native implementation.
//
// Property accessors are not being used as they'd require to define a
// private WeakMap storage which may cause memory leaks in browsers that
// don't support this type of collections.
defineConfigurable(this, { target: target, contentRect: contentRect });
}
return ResizeObserverEntry;
}());
var ResizeObserverSPI = /** @class */ (function () {
/**
* Creates a new instance of ResizeObserver.
*
* @param {ResizeObserverCallback} callback - Callback function that is invoked
* when one of the observed elements changes it's content dimensions.
* @param {ResizeObserverController} controller - Controller instance which
* is responsible for the updates of observer.
* @param {ResizeObserver} callbackCtx - Reference to the public
* ResizeObserver instance which will be passed to callback function.
*/
function ResizeObserverSPI(callback, controller, callbackCtx) {
/**
* Collection of resize observations that have detected changes in dimensions
* of elements.
*
* @private {Array}
*/
this.activeObservations_ = [];
/**
* Registry of the ResizeObservation instances.
*
* @private {Map}
*/
this.observations_ = new MapShim();
if (typeof callback !== 'function') {
throw new TypeError('The callback provided as parameter 1 is not a function.');
}
this.callback_ = callback;
this.controller_ = controller;
this.callbackCtx_ = callbackCtx;
}
/**
* Starts observing provided element.
*
* @param {Element} target - Element to be observed.
* @returns {void}
*/
ResizeObserverSPI.prototype.observe = function (target) {
if (!arguments.length) {
throw new TypeError('1 argument required, but only 0 present.');
}
// Do nothing if current environment doesn't have the Element interface.
if (typeof Element === 'undefined' || !(Element instanceof Object)) {
return;
}
if (!(target instanceof getWindowOf(target).Element)) {
throw new TypeError('parameter 1 is not of type "Element".');
}
var observations = this.observations_;
// Do nothing if element is already being observed.
if (observations.has(target)) {
return;
}
observations.set(target, new ResizeObservation(target));
this.controller_.addObserver(this);
// Force the update of observations.
this.controller_.refresh();
};
/**
* Stops observing provided element.
*
* @param {Element} target - Element to stop observing.
* @returns {void}
*/
ResizeObserverSPI.prototype.unobserve = function (target) {
if (!arguments.length) {
throw new TypeError('1 argument required, but only 0 present.');
}
// Do nothing if current environment doesn't have the Element interface.
if (typeof Element === 'undefined' || !(Element instanceof Object)) {
return;
}
if (!(target instanceof getWindowOf(target).Element)) {
throw new TypeError('parameter 1 is not of type "Element".');
}
var observations = this.observations_;
// Do nothing if element is not being observed.
if (!observations.has(target)) {
return;
}
observations.delete(target);
if (!observations.size) {
this.controller_.removeObserver(this);
}
};
/**
* Stops observing all elements.
*
* @returns {void}
*/
ResizeObserverSPI.prototype.disconnect = function () {
this.clearActive();
this.observations_.clear();
this.controller_.removeObserver(this);
};
/**
* Collects observation instances the associated element of which has changed
* it's content rectangle.
*
* @returns {void}
*/
ResizeObserverSPI.prototype.gatherActive = function () {
var _this = this;
this.clearActive();
this.observations_.forEach(function (observation) {
if (observation.isActive()) {
_this.activeObservations_.push(observation);
}
});
};
/**
* Invokes initial callback function with a list of ResizeObserverEntry
* instances collected from active resize observations.
*
* @returns {void}
*/
ResizeObserverSPI.prototype.broadcastActive = function () {
// Do nothing if observer doesn't have active observations.
if (!this.hasActive()) {
return;
}
var ctx = this.callbackCtx_;
// Create ResizeObserverEntry instance for every active observation.
var entries = this.activeObservations_.map(function (observation) {
return new ResizeObserverEntry(observation.target, observation.broadcastRect());
});
this.callback_.call(ctx, entries, ctx);
this.clearActive();
};
/**
* Clears the collection of active observations.
*
* @returns {void}
*/
ResizeObserverSPI.prototype.clearActive = function () {
this.activeObservations_.splice(0);
};
/**
* Tells whether observer has active observations.
*
* @returns {boolean}
*/
ResizeObserverSPI.prototype.hasActive = function () {
return this.activeObservations_.length > 0;
};
return ResizeObserverSPI;
}());
// Registry of internal observers. If WeakMap is not available use current shim
// for the Map collection as it has all required methods and because WeakMap
// can't be fully polyfilled anyway.
var observers = typeof WeakMap !== 'undefined' ? new WeakMap() : new MapShim();
/**
* ResizeObserver API. Encapsulates the ResizeObserver SPI implementation
* exposing only those methods and properties that are defined in the spec.
*/
var ResizeObserver = /** @class */ (function () {
/**
* Creates a new instance of ResizeObserver.
*
* @param {ResizeObserverCallback} callback - Callback that is invoked when
* dimensions of the observed elements change.
*/
function ResizeObserver(callback) {
if (!(this instanceof ResizeObserver)) {
throw new TypeError('Cannot call a class as a function.');
}
if (!arguments.length) {
throw new TypeError('1 argument required, but only 0 present.');
}
var controller = ResizeObserverController.getInstance();
var observer = new ResizeObserverSPI(callback, controller, this);
observers.set(this, observer);
}
return ResizeObserver;
}());
// Expose public methods of ResizeObserver.
[
'observe',
'unobserve',
'disconnect'
].forEach(function (method) {
ResizeObserver.prototype[method] = function () {
var _a;
return (_a = observers.get(this))[method].apply(_a, arguments);
};
});
var index = (function () {
// Export existing implementation if available.
if (typeof global$1.ResizeObserver !== 'undefined') {
return global$1.ResizeObserver;
}
return ResizeObserver;
})();
/* harmony default export */ var ResizeObserver_es = (index);
;// CONCATENATED MODULE: ./src/ui/components/toolbar/headingPopupBody.ts
var HeadingPopupBody = /** @class */ (function (_super) {
__extends(HeadingPopupBody, _super);
function HeadingPopupBody() {
return _super !== null && _super.apply(this, arguments) || this;
}
HeadingPopupBody.prototype.execCommand = function (ev) {
var el = closest(ev.target, 'li');
this.props.execCommand('heading', {
level: Number(el.getAttribute('data-level')),
});
};
HeadingPopupBody.prototype.render = function () {
var _this = this;
return template(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n \n "], ["\n \n "])), function (ev) { return _this.execCommand(ev); }, i18n.get('Headings'), [1, 2, 3, 4, 5, 6].map(function (level) {
return template(headingPopupBody_templateObject_1 || (headingPopupBody_templateObject_1 = __makeTemplateObject(["\n \n <", ">", " ", "$>\n \n "], ["\n \n <", ">", " ", "$>\n \n "])), level, "h" + level, i18n.get('Heading'), level);
}), i18n.get('Paragraph'));
};
return HeadingPopupBody;
}(Component));
var headingPopupBody_templateObject_1, templateObject_2;
;// CONCATENATED MODULE: ./src/ui/components/tabs.ts
var Tabs = /** @class */ (function (_super) {
__extends(Tabs, _super);
function Tabs() {
return _super !== null && _super.apply(this, arguments) || this;
}
Tabs.prototype.toggleTab = function (ev, activeTab) {
this.props.onClick(ev, activeTab);
};
Tabs.prototype.render = function () {
var _this = this;
return template(tabs_templateObject_2 || (tabs_templateObject_2 = __makeTemplateObject(["\n \n ", "\n
\n "], ["\n \n ",
"\n
\n "])), cls('tabs'), this.props.tabs.map(function (_a) {
var name = _a.name, text = _a.text;
var isActive = _this.props.activeTab === name;
return template(tabs_templateObject_1 || (tabs_templateObject_1 = __makeTemplateObject(["\n \n ", "\n
\n "], ["\n \n ", "\n
\n "])), isActive ? ' active' : '', function (ev) { return _this.toggleTab(ev, name); }, i18n.get(text), isActive ? 'true' : 'false', isActive ? '0' : '-1', i18n.get(text));
}));
};
return Tabs;
}(Component));
var tabs_templateObject_1, tabs_templateObject_2;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/imagePopupBody.ts
var TYPE_UI = 'ui';
var ImagePopupBody = /** @class */ (function (_super) {
__extends(ImagePopupBody, _super);
function ImagePopupBody(props) {
var _this = _super.call(this, props) || this;
_this.initialize = function (activeTab) {
if (activeTab === void 0) { activeTab = 'file'; }
var urlEl = _this.refs.url;
urlEl.value = '';
_this.refs.altText.value = '';
_this.refs.file.value = '';
removeClass_default()(urlEl, 'wrong');
_this.setState({ activeTab: activeTab, file: null, fileNameElClassName: '' });
};
_this.execCommand = function () {
if (_this.state.activeTab === 'file') {
_this.emitAddImageBlob();
}
else {
_this.emitAddImage();
}
};
_this.toggleTab = function (_, activeTab) {
if (activeTab !== _this.state.activeTab) {
_this.initialize(activeTab);
}
};
_this.showFileSelectBox = function () {
_this.refs.file.click();
};
_this.changeFile = function (ev) {
var files = ev.target.files;
if (files === null || files === void 0 ? void 0 : files.length) {
_this.setState({ file: files[0] });
}
};
_this.state = { activeTab: 'file', file: null, fileNameElClassName: '' };
_this.tabs = [
{ name: 'file', text: 'File' },
{ name: 'url', text: 'URL' },
];
return _this;
}
ImagePopupBody.prototype.emitAddImageBlob = function () {
var _this = this;
var files = this.refs.file.files;
var altTextEl = this.refs.altText;
var fileNameElClassName = ' wrong';
if (files === null || files === void 0 ? void 0 : files.length) {
fileNameElClassName = '';
var imageFile = files.item(0);
var hookCallback = function (url, text) {
return _this.props.execCommand('addImage', { imageUrl: url, altText: text || altTextEl.value });
};
this.props.eventEmitter.emit('addImageBlobHook', imageFile, hookCallback, TYPE_UI);
}
this.setState({ fileNameElClassName: fileNameElClassName });
};
ImagePopupBody.prototype.emitAddImage = function () {
var imageUrlEl = this.refs.url;
var altTextEl = this.refs.altText;
var imageUrl = imageUrlEl.value;
var altText = altTextEl.value || 'image';
removeClass_default()(imageUrlEl, 'wrong');
if (!imageUrl.length) {
addClass_default()(imageUrlEl, 'wrong');
return;
}
if (imageUrl) {
this.props.execCommand('addImage', { imageUrl: imageUrl, altText: altText });
}
};
ImagePopupBody.prototype.preventSelectStart = function (ev) {
ev.preventDefault();
};
ImagePopupBody.prototype.updated = function () {
if (!this.props.show) {
this.initialize();
}
};
ImagePopupBody.prototype.render = function () {
var _this = this;
var _a = this.state, activeTab = _a.activeTab, file = _a.file, fileNameElClassName = _a.fileNameElClassName;
return template(imagePopupBody_templateObject_1 || (imagePopupBody_templateObject_1 = __makeTemplateObject(["\n \n <", " tabs=", " activeTab=", " onClick=", " />\n
\n ", " \n \n
\n
\n ", " \n \n ", "\n \n \n ", "\n \n \n
\n
", " \n
\n
\n \n ", "\n \n \n ", "\n \n
\n
\n "], ["\n \n <", " tabs=", " activeTab=", " onClick=", " />\n
\n ", " \n \n
\n
\n ", " \n \n ", "\n \n \n ", "\n \n \n
\n
", " \n
\n
\n \n ", "\n \n \n ", "\n \n
\n
\n "])), i18n.get('Insert image'), Tabs, this.tabs, activeTab, this.toggleTab, activeTab === 'url' ? 'block' : 'none', i18n.get('Image URL'), function (el) { return (_this.refs.url = el); }, activeTab === 'file' ? 'block' : 'none', i18n.get('Select image file'), cls('file-name'), file ? ' has-file' : fileNameElClassName, this.showFileSelectBox, this.preventSelectStart, file ? file.name : i18n.get('No file'), cls('file-select-button'), this.showFileSelectBox, i18n.get('Choose a file'), this.changeFile, function (el) { return (_this.refs.file = el); }, i18n.get('Description'), function (el) { return (_this.refs.altText = el); }, cls('button-container'), cls('close-button'), this.props.hidePopup, i18n.get('Cancel'), cls('ok-button'), this.execCommand, i18n.get('OK'));
};
return ImagePopupBody;
}(Component));
var imagePopupBody_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/linkPopupBody.ts
var LinkPopupBody = /** @class */ (function (_super) {
__extends(LinkPopupBody, _super);
function LinkPopupBody() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.execCommand = function () {
var linkUrlEl = _this.refs.url;
var linkTextEl = _this.refs.text;
removeClass_default()(linkUrlEl, 'wrong');
removeClass_default()(linkTextEl, 'wrong');
if (linkUrlEl.value.length < 1) {
addClass_default()(linkUrlEl, 'wrong');
return;
}
var checkLinkText = isUndefined_default()(_this.props.initialValues.linkUrl);
if (checkLinkText && linkTextEl.value.length < 1) {
addClass_default()(linkTextEl, 'wrong');
return;
}
_this.props.execCommand('addLink', {
linkUrl: linkUrlEl.value,
linkText: linkTextEl.value,
});
};
return _this;
}
LinkPopupBody.prototype.initialize = function () {
var _a = this.props.initialValues, linkUrl = _a.linkUrl, linkText = _a.linkText;
var linkUrlEl = this.refs.url;
var linkTextEl = this.refs.text;
removeClass_default()(linkUrlEl, 'wrong');
removeClass_default()(linkTextEl, 'wrong', 'disabled');
linkTextEl.removeAttribute('disabled');
if (linkUrl) {
addClass_default()(linkTextEl, 'disabled');
linkTextEl.setAttribute('disabled', 'disabled');
}
linkUrlEl.value = linkUrl || '';
linkTextEl.value = linkText || '';
};
LinkPopupBody.prototype.mounted = function () {
this.initialize();
};
LinkPopupBody.prototype.updated = function (prevProps) {
if (!prevProps.show && this.props.show) {
this.initialize();
}
};
LinkPopupBody.prototype.render = function () {
var _this = this;
return template(linkPopupBody_templateObject_1 || (linkPopupBody_templateObject_1 = __makeTemplateObject(["\n \n
", " \n
\n
", " \n
\n
\n \n ", "\n \n \n ", "\n \n
\n
\n "], ["\n \n
", " \n
\n
", " \n
\n
\n \n ", "\n \n \n ", "\n \n
\n
\n "])), i18n.get('Insert link'), i18n.get('URL'), function (el) { return (_this.refs.url = el); }, i18n.get('Link text'), function (el) { return (_this.refs.text = el); }, cls('button-container'), cls('close-button'), this.props.hidePopup, i18n.get('Cancel'), cls('ok-button'), this.execCommand, i18n.get('OK'));
};
return LinkPopupBody;
}(Component));
var linkPopupBody_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/tablePopupBody.ts
var CELL_WIDTH = 20;
var CELL_HEIGHT = 20;
var MIN_ROW_INDEX = 5;
var MAX_ROW_INDEX = 14;
var MIN_COL_INDEX = 5;
var MAX_COL_INDEX = 9;
var MIN_ROW_SELECTION_INDEX = 1;
var MIN_COL_SELECTION_INDEX = 1;
var BORDER_WIDTH = 1;
var TablePopupBody = /** @class */ (function (_super) {
__extends(TablePopupBody, _super);
function TablePopupBody(props) {
var _this = _super.call(this, props) || this;
_this.extendSelectionRange = function (_a) {
var pageX = _a.pageX, pageY = _a.pageY;
var x = pageX - _this.offsetRect.left;
var y = pageY - _this.offsetRect.top;
var range = _this.getSelectionRangeByOffset(x, y);
_this.setState(__assign({}, range));
};
_this.execCommand = function () {
_this.props.execCommand('addTable', {
rowCount: _this.state.rowIdx + 1,
columnCount: _this.state.colIdx + 1,
});
};
_this.state = {
rowIdx: -1,
colIdx: -1,
};
return _this;
}
TablePopupBody.prototype.getDescription = function () {
return this.state.colIdx === -1 ? '' : this.state.colIdx + 1 + " x " + (this.state.rowIdx + 1);
};
TablePopupBody.prototype.getBoundByRange = function (colIdx, rowIdx) {
return {
width: (colIdx + 1) * CELL_WIDTH,
height: (rowIdx + 1) * CELL_HEIGHT,
};
};
TablePopupBody.prototype.getRangeByOffset = function (x, y) {
return {
colIdx: Math.floor(x / CELL_WIDTH),
rowIdx: Math.floor(y / CELL_HEIGHT),
};
};
TablePopupBody.prototype.getTableRange = function () {
var _a = this.state, orgColIdx = _a.colIdx, orgRowIdx = _a.rowIdx;
var colIdx = Math.max(orgColIdx, MIN_COL_INDEX);
var rowIdx = Math.max(orgRowIdx, MIN_ROW_INDEX);
if (orgColIdx >= MIN_COL_INDEX && colIdx < MAX_COL_INDEX) {
colIdx += 1;
}
if (orgRowIdx >= MIN_ROW_INDEX && rowIdx < MAX_ROW_INDEX) {
rowIdx += 1;
}
return { colIdx: colIdx + 1, rowIdx: rowIdx + 1 };
};
TablePopupBody.prototype.getSelectionAreaBound = function () {
var _a = this.getBoundByRange(this.state.colIdx, this.state.rowIdx), width = _a.width, height = _a.height;
if (!width && !height) {
return { display: 'none' };
}
return { width: width - BORDER_WIDTH, height: height - BORDER_WIDTH, display: 'block' };
};
TablePopupBody.prototype.getSelectionRangeByOffset = function (x, y) {
var range = this.getRangeByOffset(x, y);
range.rowIdx = Math.min(Math.max(range.rowIdx, MIN_ROW_SELECTION_INDEX), MAX_ROW_INDEX);
range.colIdx = Math.min(Math.max(range.colIdx, MIN_COL_SELECTION_INDEX), MAX_COL_INDEX);
return range;
};
TablePopupBody.prototype.updated = function () {
if (!this.props.show) {
this.setState({ colIdx: -1, rowIdx: -1 });
}
else if (this.state.colIdx === -1 && this.state.rowIdx === -1) {
var _a = this.refs.tableEl.getBoundingClientRect(), left = _a.left, top = _a.top;
this.offsetRect = {
left: window.pageXOffset + left,
top: window.pageYOffset + top,
};
}
};
TablePopupBody.prototype.createTableArea = function (tableRange) {
var colIdx = tableRange.colIdx, rowIdx = tableRange.rowIdx;
var rows = [];
for (var i = 0; i < rowIdx; i += 1) {
var cells = [];
for (var j = 0; j < colIdx; j += 1) {
var cellClassNames = "" + cls('table-cell') + (i > 0 ? '' : ' header');
cells.push(template(tablePopupBody_templateObject_1 || (tablePopupBody_templateObject_1 = __makeTemplateObject(["
"], ["
"])), cellClassNames));
}
rows.push(template(tablePopupBody_templateObject_2 || (tablePopupBody_templateObject_2 = __makeTemplateObject(["", "
"], ["", "
"])), cls('table-row'), cells));
}
return template(templateObject_3 || (templateObject_3 = __makeTemplateObject(["", "
"], ["", "
"])), cls('table'), rows);
};
TablePopupBody.prototype.render = function () {
var _this = this;
var tableRange = this.getTableRange();
var selectionAreaBound = this.getSelectionAreaBound();
return template(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n \n "], ["\n \n "])), i18n.get('Insert table'), cls('table-selection'), function (el) { return (_this.refs.tableEl = el); }, this.extendSelectionRange, this.execCommand, this.createTableArea(tableRange), cls('table-selection-layer'), selectionAreaBound, cls('table-description'), this.getDescription());
};
return TablePopupBody;
}(Component));
var tablePopupBody_templateObject_1, tablePopupBody_templateObject_2, templateObject_3, templateObject_4;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/customPopupBody.ts
var CustomPopupBody = /** @class */ (function (_super) {
__extends(CustomPopupBody, _super);
function CustomPopupBody() {
return _super !== null && _super.apply(this, arguments) || this;
}
CustomPopupBody.prototype.mounted = function () {
// append the custom popup body element
this.refs.el.appendChild(this.props.body);
};
CustomPopupBody.prototype.updated = function (prevProps) {
// update custom popup element
this.refs.el.replaceChild(this.props.body, prevProps.body);
};
CustomPopupBody.prototype.render = function () {
var _this = this;
return template(customPopupBody_templateObject_1 || (customPopupBody_templateObject_1 = __makeTemplateObject(["
"], ["
"])), function (el) { return (_this.refs.el = el); });
};
return CustomPopupBody;
}(Component));
var customPopupBody_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/toolbarItemFactory.ts
function createToolbarItemInfo(type) {
return isString_default()(type) ? createDefaultToolbarItemInfo(type) : type;
}
function createScrollSyncToolbarItem() {
var label = document.createElement('label');
var checkbox = document.createElement('input');
var toggleSwitch = document.createElement('span');
label.className = 'scroll-sync active';
checkbox.type = 'checkbox';
checkbox.checked = true;
toggleSwitch.className = 'switch';
var onMounted = function (execCommand) {
return checkbox.addEventListener('change', function (ev) {
var checked = ev.target.checked;
if (checked) {
addClass_default()(label, 'active');
}
else {
removeClass_default()(label, 'active');
}
execCommand('toggleScrollSync', { active: checked });
});
};
label.appendChild(checkbox);
label.appendChild(toggleSwitch);
return {
name: 'scrollSync',
el: label,
onMounted: onMounted,
};
}
function createDefaultToolbarItemInfo(type) {
var info;
switch (type) {
case 'heading':
info = {
name: 'heading',
className: 'heading',
tooltip: i18n.get('Headings'),
state: 'heading',
};
break;
case 'bold':
info = {
name: 'bold',
className: 'bold',
command: 'bold',
tooltip: i18n.get('Bold'),
state: 'strong',
};
break;
case 'italic':
info = {
name: 'italic',
className: 'italic',
command: 'italic',
tooltip: i18n.get('Italic'),
state: 'emph',
};
break;
case 'strike':
info = {
name: 'strike',
className: 'strike',
command: 'strike',
tooltip: i18n.get('Strike'),
state: 'strike',
};
break;
case 'hr':
info = {
name: 'hr',
className: 'hrline',
command: 'hr',
tooltip: i18n.get('Line'),
state: 'thematicBreak',
};
break;
case 'quote':
info = {
name: 'quote',
className: 'quote',
command: 'blockQuote',
tooltip: i18n.get('Blockquote'),
state: 'blockQuote',
};
break;
case 'ul':
info = {
name: 'ul',
className: 'bullet-list',
command: 'bulletList',
tooltip: i18n.get('Unordered list'),
state: 'bulletList',
};
break;
case 'ol':
info = {
name: 'ol',
className: 'ordered-list',
command: 'orderedList',
tooltip: i18n.get('Ordered list'),
state: 'orderedList',
};
break;
case 'task':
info = {
name: 'task',
className: 'task-list',
command: 'taskList',
tooltip: i18n.get('Task'),
state: 'taskList',
};
break;
case 'table':
info = {
name: 'table',
className: 'table',
tooltip: i18n.get('Insert table'),
state: 'table',
};
break;
case 'image':
info = {
name: 'image',
className: 'image',
tooltip: i18n.get('Insert image'),
};
break;
case 'link':
info = {
name: 'link',
className: 'link',
tooltip: i18n.get('Insert link'),
};
break;
case 'code':
info = {
name: 'code',
className: 'code',
command: 'code',
tooltip: i18n.get('Code'),
state: 'code',
};
break;
case 'codeblock':
info = {
name: 'codeblock',
className: 'codeblock',
command: 'codeBlock',
tooltip: i18n.get('Insert CodeBlock'),
state: 'codeBlock',
};
break;
case 'indent':
info = {
name: 'indent',
className: 'indent',
command: 'indent',
tooltip: i18n.get('Indent'),
state: 'indent',
};
break;
case 'outdent':
info = {
name: 'outdent',
className: 'outdent',
command: 'outdent',
tooltip: i18n.get('Outdent'),
state: 'outdent',
};
break;
case 'scrollSync':
info = createScrollSyncToolbarItem();
break;
case 'more':
info = {
name: 'more',
className: 'more',
tooltip: i18n.get('More'),
};
break;
default:
// do nothing
}
if (info.name !== 'scrollSync') {
info.className += " " + cls('toolbar-icons');
}
return info;
}
function createPopupInfo(type, payload) {
var el = payload.el, pos = payload.pos, popup = payload.popup, initialValues = payload.initialValues;
switch (type) {
case 'heading':
return {
render: function (props) { return template(toolbarItemFactory_templateObject_1 || (toolbarItemFactory_templateObject_1 = __makeTemplateObject(["<", " ...", " />"], ["<", " ...", " />"])), HeadingPopupBody, props); },
className: cls('popup-add-heading'),
fromEl: el,
pos: pos,
};
case 'link':
return {
render: function (props) { return template(toolbarItemFactory_templateObject_2 || (toolbarItemFactory_templateObject_2 = __makeTemplateObject(["<", " ...", " />"], ["<", " ...", " />"])), LinkPopupBody, props); },
className: cls('popup-add-link'),
fromEl: el,
pos: pos,
initialValues: initialValues,
};
case 'image':
return {
render: function (props) { return template(toolbarItemFactory_templateObject_3 || (toolbarItemFactory_templateObject_3 = __makeTemplateObject(["<", " ...", " />"], ["<", " ...", " />"])), ImagePopupBody, props); },
className: cls('popup-add-image'),
fromEl: el,
pos: pos,
};
case 'table':
return {
render: function (props) { return template(toolbarItemFactory_templateObject_4 || (toolbarItemFactory_templateObject_4 = __makeTemplateObject(["<", " ...", " />"], ["<", " ...", " />"])), TablePopupBody, props); },
className: cls('popup-add-table'),
fromEl: el,
pos: pos,
};
case 'customPopupBody':
if (!popup) {
return null;
}
return __assign({ render: function (props) { return template(templateObject_5 || (templateObject_5 = __makeTemplateObject(["<", " ...", " body=", " />"], ["<", " ...", " body=", " />"])), CustomPopupBody, props, popup.body); }, fromEl: el, pos: pos }, popup);
default:
return null;
}
}
function setGroupState(group) {
group.hidden = group.length === group.filter(function (info) { return info.hidden; }).length;
}
function groupToolbarItems(toolbarItems, hiddenScrollSync) {
var toggleScrollSyncState = function (item) {
item.hidden = item.name === 'scrollSync' && hiddenScrollSync;
return item;
};
return toolbarItems.reduce(function (acc, item) {
acc.push(item.map(function (type) { return toggleScrollSyncState(createToolbarItemInfo(type)); }));
var group = acc[(acc.length || 1) - 1];
if (group) {
setGroupState(group);
}
return acc;
}, []);
}
function toggleScrollSync(toolbarItems, hiddenScrollSync) {
toolbarItems.forEach(function (group) {
group.forEach(function (item) { return (item.hidden = item.name === 'scrollSync' && hiddenScrollSync); });
setGroupState(group);
});
}
var toolbarItemFactory_templateObject_1, toolbarItemFactory_templateObject_2, toolbarItemFactory_templateObject_3, toolbarItemFactory_templateObject_4, templateObject_5;
;// CONCATENATED MODULE: ./src/ui/components/popup.ts
var MARGIN_FROM_RIGHT_SIDE = 20;
var Popup = /** @class */ (function (_super) {
__extends(Popup, _super);
function Popup() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.handleMousedown = function (ev) {
if (!closest(ev.target, "." + cls('popup')) &&
!closest(ev.target, _this.props.info.fromEl)) {
_this.props.hidePopup();
}
};
return _this;
}
Popup.prototype.mounted = function () {
document.addEventListener('mousedown', this.handleMousedown);
this.props.eventEmitter.listen('closePopup', this.props.hidePopup);
};
Popup.prototype.beforeDestroy = function () {
document.removeEventListener('mousedown', this.handleMousedown);
};
Popup.prototype.updated = function (prevProps) {
var _a = this.props, show = _a.show, info = _a.info;
if (show && info.pos && prevProps.show !== show) {
var popupPos = __assign({}, info.pos);
var offsetWidth = this.refs.el.offsetWidth;
var toolbarEl = closest(this.refs.el, "." + cls('toolbar'));
var toolbarOffsetWidth = toolbarEl.offsetWidth;
if (popupPos.left + offsetWidth >= toolbarOffsetWidth) {
popupPos.left = toolbarOffsetWidth - offsetWidth - MARGIN_FROM_RIGHT_SIDE;
}
if (!shallowEqual(this.state.popupPos, popupPos)) {
this.setState({ popupPos: popupPos });
}
}
};
Popup.prototype.render = function () {
var _this = this;
var _a = this.props, info = _a.info, show = _a.show, hidePopup = _a.hidePopup, eventEmitter = _a.eventEmitter, execCommand = _a.execCommand;
var _b = info || {}, _c = _b.className, className = _c === void 0 ? '' : _c, style = _b.style, render = _b.render, _d = _b.initialValues, initialValues = _d === void 0 ? {} : _d;
var popupStyle = __assign(__assign({ display: show ? 'block' : 'none' }, style), this.state.popupPos);
return template(popup_templateObject_1 || (popup_templateObject_1 = __makeTemplateObject(["\n \n "], ["\n \n "])), cls('popup'), className, popupStyle, function (el) { return (_this.refs.el = el); }, cls('popup-body'), render && render({ eventEmitter: eventEmitter, show: show, hidePopup: hidePopup, execCommand: execCommand, initialValues: initialValues }));
};
return Popup;
}(Component));
var popup_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/buttonHoc.ts
var TOOLTIP_INDENT = 6;
function connectHOC(WrappedComponent) {
return /** @class */ (function (_super) {
__extends(ButtonHOC, _super);
function ButtonHOC(props) {
var _this = _super.call(this, props) || this;
_this.showTooltip = function (el) {
var tooltip = _this.props.item.tooltip;
if (!_this.props.disabled && tooltip) {
var bound = _this.getBound(el);
var left = bound.left + TOOLTIP_INDENT + "px";
var top = bound.top + TOOLTIP_INDENT + "px";
css_default()(_this.props.tooltipRef.current, { display: 'block', left: left, top: top });
_this.props.tooltipRef.current.querySelector('.text').textContent = tooltip;
}
};
_this.hideTooltip = function () {
css_default()(_this.props.tooltipRef.current, 'display', 'none');
};
_this.state = { active: false, disabled: props.disabled };
_this.addEvent();
return _this;
}
ButtonHOC.prototype.addEvent = function () {
var _this = this;
var _a = this.props, item = _a.item, eventEmitter = _a.eventEmitter;
if (item.state) {
eventEmitter.listen('changeToolbarState', function (_a) {
var _b;
var toolbarState = _a.toolbarState;
var _c = (_b = toolbarState[item.state]) !== null && _b !== void 0 ? _b : {}, active = _c.active, disabled = _c.disabled;
_this.setState({ active: !!active, disabled: disabled !== null && disabled !== void 0 ? disabled : _this.props.disabled });
});
}
};
ButtonHOC.prototype.getBound = function (el) {
var _a = getTotalOffset(el, closest(el, "." + cls('toolbar'))), offsetLeft = _a.offsetLeft, offsetTop = _a.offsetTop;
return { left: offsetLeft, top: el.offsetHeight + offsetTop };
};
ButtonHOC.prototype.render = function () {
return template(buttonHoc_templateObject_1 || (buttonHoc_templateObject_1 = __makeTemplateObject(["\n <", "\n ...", "\n active=", "\n showTooltip=", "\n hideTooltip=", "\n getBound=", "\n disabled=", "\n />\n "], ["\n <", "\n ...", "\n active=", "\n showTooltip=", "\n hideTooltip=", "\n getBound=", "\n disabled=", "\n />\n "])), WrappedComponent, this.props, this.state.active, this.showTooltip, this.hideTooltip, this.getBound, this.state.disabled || this.props.disabled);
};
return ButtonHOC;
}(Component));
}
var buttonHoc_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/toolbarButton.ts
var DEFAULT_WIDTH = 80;
var ToolbarButtonComp = /** @class */ (function (_super) {
__extends(ToolbarButtonComp, _super);
function ToolbarButtonComp() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.showTooltip = function () {
_this.props.showTooltip(_this.refs.el);
};
_this.execCommand = function () {
var _a = _this.props, item = _a.item, execCommand = _a.execCommand, setPopupInfo = _a.setPopupInfo, getBound = _a.getBound, eventEmitter = _a.eventEmitter;
var command = item.command, name = item.name, popup = item.popup;
if (command) {
execCommand(command);
}
else {
var popupName = popup ? 'customPopupBody' : name;
var initialValues = eventEmitter.emit('query', 'getPopupInitialValues', { popupName: popupName })[0];
var info = createPopupInfo(popupName, {
el: _this.refs.el,
pos: getBound(_this.refs.el),
popup: popup,
initialValues: initialValues,
});
if (info) {
setPopupInfo(info);
}
}
};
return _this;
}
ToolbarButtonComp.prototype.mounted = function () {
this.setItemWidth();
};
ToolbarButtonComp.prototype.updated = function (prevProps) {
if (prevProps.item.name !== this.props.item.name) {
this.setItemWidth();
}
};
ToolbarButtonComp.prototype.setItemWidth = function () {
var _a = this.props, setItemWidth = _a.setItemWidth, item = _a.item;
// set width only if it is not a dropdown toolbar
if (setItemWidth) {
setItemWidth(item.name, getOuterWidth(this.refs.el) + (item.hidden ? DEFAULT_WIDTH : 0));
}
};
ToolbarButtonComp.prototype.render = function () {
var _this = this;
var _a = this.props, hideTooltip = _a.hideTooltip, disabled = _a.disabled, item = _a.item, active = _a.active;
var style = __assign({ display: item.hidden ? 'none' : null }, item.style);
var classNames = "" + (item.className || '') + (active ? ' active' : '');
return template(toolbarButton_templateObject_1 || (toolbarButton_templateObject_1 = __makeTemplateObject(["\n \n ", "\n \n "], ["\n \n ", "\n \n "])), function (el) { return (_this.refs.el = el); }, style, classNames, this.execCommand, this.showTooltip, hideTooltip, !!disabled, item.text || item.tooltip || '', item.text || '');
};
return ToolbarButtonComp;
}(Component));
var ToolbarButton = connectHOC(ToolbarButtonComp);
var toolbarButton_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/customToolbarItem.ts
var CustomToolbarItemComp = /** @class */ (function (_super) {
__extends(CustomToolbarItemComp, _super);
function CustomToolbarItemComp() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.showTooltip = function () {
_this.props.showTooltip(_this.refs.el);
};
_this.showPopup = function () {
var info = createPopupInfo('customPopupBody', {
el: _this.refs.el,
pos: _this.props.getBound(_this.refs.el),
popup: _this.props.item.popup,
});
if (info) {
_this.props.setPopupInfo(info);
}
};
return _this;
}
CustomToolbarItemComp.prototype.mounted = function () {
var _a = this.props, setItemWidth = _a.setItemWidth, item = _a.item;
// append the custom html element
this.refs.el.appendChild(item.el);
// set width only if it is not a dropdown toolbar
if (setItemWidth) {
setItemWidth(item.name, getOuterWidth(this.refs.el));
}
if (item.onMounted) {
item.onMounted(this.props.execCommand);
}
};
CustomToolbarItemComp.prototype.updated = function (prevProps) {
var _a;
var _b = this.props, item = _b.item, active = _b.active, disabled = _b.disabled;
if (prevProps.active !== active || prevProps.disabled !== disabled) {
(_a = item.onUpdated) === null || _a === void 0 ? void 0 : _a.call(item, { active: active, disabled: disabled });
}
};
CustomToolbarItemComp.prototype.render = function () {
var _this = this;
var _a = this.props, disabled = _a.disabled, item = _a.item;
var style = { display: item.hidden ? 'none' : 'inline-block' };
var getListener = function (listener) { return (disabled ? null : listener); };
return template(customToolbarItem_templateObject_1 || (customToolbarItem_templateObject_1 = __makeTemplateObject(["\n
\n "], ["\n
\n "])), function (el) { return (_this.refs.el = el); }, style, cls('toolbar-item-wrapper'), getListener(this.showPopup), getListener(this.showTooltip), getListener(this.props.hideTooltip));
};
return CustomToolbarItemComp;
}(Component));
var CustomToolbarItem = connectHOC(CustomToolbarItemComp);
var customToolbarItem_templateObject_1;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/toolbarGroup.ts
var ToolbarGroup = /** @class */ (function (_super) {
__extends(ToolbarGroup, _super);
function ToolbarGroup() {
return _super !== null && _super.apply(this, arguments) || this;
}
ToolbarGroup.prototype.render = function () {
var _this = this;
var _a = this.props, group = _a.group, hiddenDivider = _a.hiddenDivider;
var groupStyle = group.hidden ? { display: 'none' } : null;
var dividerStyle = hiddenDivider ? { display: 'none' } : null;
return template(toolbarGroup_templateObject_2 || (toolbarGroup_templateObject_2 = __makeTemplateObject(["\n \n "], ["\n \n "])), cls('toolbar-group'), groupStyle, group.map(function (item) {
var Comp = item.el ? CustomToolbarItem : ToolbarButton;
return template(toolbarGroup_templateObject_1 || (toolbarGroup_templateObject_1 = __makeTemplateObject(["<", " key=", " ...", " item=", " />"], ["<", " key=", " ...", " item=", " />"])), Comp, item.name, _this.props, item);
}), cls('toolbar-divider'), dividerStyle);
};
return ToolbarGroup;
}(Component));
var toolbarGroup_templateObject_1, toolbarGroup_templateObject_2;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/dropdownToolbarButton.ts
var POPUP_INDENT = 4;
var DropdownToolbarButtonComp = /** @class */ (function (_super) {
__extends(DropdownToolbarButtonComp, _super);
function DropdownToolbarButtonComp(props) {
var _this = _super.call(this, props) || this;
_this.handleClickDocument = function (_a) {
var target = _a.target;
if (!closest(target, "." + cls('dropdown-toolbar')) &&
!closest(target, '.more')) {
_this.setState({ showDropdown: false, dropdownPos: null });
}
};
_this.showTooltip = function () {
_this.props.showTooltip(_this.refs.el);
};
_this.state = { showDropdown: false, dropdownPos: null };
return _this;
}
DropdownToolbarButtonComp.prototype.getBound = function () {
var rect = this.props.getBound(this.refs.el);
rect.top += POPUP_INDENT;
return __assign(__assign({}, rect), { left: null, right: 10 });
};
DropdownToolbarButtonComp.prototype.mounted = function () {
document.addEventListener('click', this.handleClickDocument);
};
DropdownToolbarButtonComp.prototype.updated = function () {
if (this.state.showDropdown && !this.state.dropdownPos) {
this.setState({ dropdownPos: this.getBound() });
}
};
DropdownToolbarButtonComp.prototype.beforeDestroy = function () {
document.removeEventListener('click', this.handleClickDocument);
};
DropdownToolbarButtonComp.prototype.render = function () {
var _this = this;
var _a = this.state, showDropdown = _a.showDropdown, dropdownPos = _a.dropdownPos;
var _b = this.props, disabled = _b.disabled, item = _b.item, items = _b.items, hideTooltip = _b.hideTooltip;
var visibleItems = items.filter(function (dropdownItem) { return !dropdownItem.hidden; });
var groupStyle = visibleItems.length ? null : { display: 'none' };
var dropdownStyle = showDropdown ? null : { display: 'none' };
return template(dropdownToolbarButton_templateObject_2 || (dropdownToolbarButton_templateObject_2 = __makeTemplateObject(["\n \n "], ["\n \n "])), cls('toolbar-group'), groupStyle, function (el) { return (_this.refs.el = el); }, item.className, function () { return _this.setState({ showDropdown: true }); }, this.showTooltip, hideTooltip, disabled, cls('dropdown-toolbar'), __assign(__assign({}, dropdownStyle), dropdownPos), function (el) { return (_this.refs.dropdownEl = el); }, visibleItems.length
? visibleItems.map(function (group, index) {
var _a;
return template(dropdownToolbarButton_templateObject_1 || (dropdownToolbarButton_templateObject_1 = __makeTemplateObject(["\n <", "\n group=", "\n hiddenDivider=", "\n ...", "\n />\n "], ["\n <", "\n group=", "\n hiddenDivider=",
"\n ...", "\n />\n "])), ToolbarGroup, group, index === visibleItems.length - 1 ||
((_a = visibleItems[index + 1]) === null || _a === void 0 ? void 0 : _a.hidden), _this.props);
})
: null);
};
return DropdownToolbarButtonComp;
}(Component));
var DropdownToolbarButton = connectHOC(DropdownToolbarButtonComp);
var dropdownToolbarButton_templateObject_1, dropdownToolbarButton_templateObject_2;
;// CONCATENATED MODULE: ./src/ui/components/toolbar/toolbar.ts
var INLINE_PADDING = 50;
var Toolbar = /** @class */ (function (_super) {
__extends(Toolbar, _super);
function Toolbar(props) {
var _this = _super.call(this, props) || this;
_this.toggleTab = function (_, activeTab) {
var eventEmitter = _this.props.eventEmitter;
if (_this.state.activeTab !== activeTab) {
var event = activeTab === 'write' ? 'changePreviewTabWrite' : 'changePreviewTabPreview';
eventEmitter.emit(event);
_this.setState({ activeTab: activeTab });
}
};
_this.setItemWidth = function (name, width) {
_this.itemWidthMap[name] = width;
};
_this.setPopupInfo = function (popupInfo) {
_this.setState({ showPopup: true, popupInfo: popupInfo });
};
_this.openPopup = function (popupName, initialValues) {
if (initialValues === void 0) { initialValues = {}; }
var el = _this.refs.el.querySelector("." + cls('toolbar-group') + " ." + popupName);
if (el) {
var _a = getTotalOffset(el, closest(el, "." + cls('toolbar'))), offsetLeft = _a.offsetLeft, offsetTop = _a.offsetTop;
var info = createPopupInfo(popupName, {
el: el,
pos: { left: offsetLeft, top: el.offsetHeight + offsetTop },
initialValues: initialValues,
});
if (info) {
_this.setPopupInfo(info);
}
}
};
_this.hidePopup = function () {
if (_this.state.showPopup) {
_this.setState({ showPopup: false });
}
};
_this.execCommand = function (command, payload) {
var eventEmitter = _this.props.eventEmitter;
eventEmitter.emit('command', command, payload);
_this.hidePopup();
};
_this.tabs = [
{ name: 'write', text: 'Write' },
{ name: 'preview', text: 'Preview' },
];
_this.itemWidthMap = {};
_this.initialItems = groupToolbarItems(props.toolbarItems || [], _this.hiddenScrollSync());
_this.state = {
items: _this.initialItems,
dropdownItems: [],
showPopup: false,
popupInfo: {},
activeTab: 'write',
};
_this.tooltipRef = { current: null };
_this.resizeObserver = new ResizeObserver_es(function () { return _this.handleResize(); });
_this.addEvent();
return _this;
}
Toolbar.prototype.insertToolbarItem = function (indexList, item) {
var groupIndex = indexList.groupIndex, itemIndex = indexList.itemIndex;
var group = this.initialItems[groupIndex];
item = createToolbarItemInfo(item);
if (group) {
group.splice(itemIndex, 0, item);
}
else {
this.initialItems.push([item]);
}
this.setState(this.classifyToolbarItems());
};
Toolbar.prototype.removeToolbarItem = function (name) {
var _this = this;
forEachArray_default()(this.initialItems, function (group) {
var found = false;
forEachArray_default()(group, function (item, index) {
if (item.name === name) {
found = true;
group.splice(index, 1);
_this.setState(_this.classifyToolbarItems());
return false;
}
return true;
});
return !found;
});
};
Toolbar.prototype.addEvent = function () {
var _this = this;
var eventEmitter = this.props.eventEmitter;
this.handleResize = throttle_default()(function () {
// reset toolbar items to re-layout toolbar items with each clientWidth
_this.setState({ items: _this.initialItems, dropdownItems: [] });
_this.setState(_this.classifyToolbarItems());
}, 200);
eventEmitter.listen('openPopup', this.openPopup);
};
Toolbar.prototype.appendTooltipToRoot = function () {
var tooltip = "";
this.tooltipRef.current = createElementWith(tooltip, this.refs.el);
};
Toolbar.prototype.hiddenScrollSync = function () {
return this.props.editorType === 'wysiwyg' || this.props.previewStyle === 'tab';
};
Toolbar.prototype.movePrevItemToDropdownToolbar = function (itemIndex, items, group, dropdownGroup) {
var moveItem = function (targetGroup) {
var item = targetGroup.pop();
if (item) {
dropdownGroup.push(item);
}
};
if (itemIndex > 1) {
moveItem(group);
}
else {
var prevGroup = last(items);
if (prevGroup) {
moveItem(prevGroup);
}
}
};
Toolbar.prototype.classifyToolbarItems = function () {
var _this = this;
var totalWidth = 0;
var clientWidth = this.refs.el.clientWidth;
var divider = this.refs.el.querySelector("." + cls('toolbar-divider'));
var dividerWidth = divider ? getOuterWidth(divider) : 0;
var items = [];
var dropdownItems = [];
var moved = false;
this.initialItems.forEach(function (initialGroup, groupIndex) {
var group = [];
var dropdownGroup = [];
initialGroup.forEach(function (item, itemIndex) {
if (!item.hidden) {
totalWidth += _this.itemWidthMap[item.name];
if (totalWidth > clientWidth - INLINE_PADDING) {
// should move the prev item to dropdown toolbar for placing the more button
if (!moved) {
_this.movePrevItemToDropdownToolbar(itemIndex, items, group, dropdownGroup);
moved = true;
}
dropdownGroup.push(item);
}
else {
group.push(item);
}
}
});
if (group.length) {
setGroupState(group);
items.push(group);
}
if (dropdownGroup.length) {
setGroupState(dropdownGroup);
dropdownItems.push(dropdownGroup);
}
// add divider width
if (groupIndex < _this.state.items.length - 1) {
totalWidth += dividerWidth;
}
});
return { items: items, dropdownItems: dropdownItems };
};
Toolbar.prototype.mounted = function () {
if (this.props.previewStyle === 'tab') {
this.props.eventEmitter.emit('changePreviewTabWrite', true);
}
// classify toolbar and dropdown toolbar after DOM has been rendered
this.setState(this.classifyToolbarItems());
this.appendTooltipToRoot();
this.resizeObserver.observe(this.refs.el);
};
Toolbar.prototype.updated = function (prevProps) {
var _a = this.props, editorType = _a.editorType, previewStyle = _a.previewStyle, eventEmitter = _a.eventEmitter;
var changedStyle = previewStyle !== prevProps.previewStyle;
var changedType = editorType !== prevProps.editorType;
if (changedStyle || changedType) {
// show or hide scrollSync button
toggleScrollSync(this.initialItems, this.hiddenScrollSync());
var newState = this.classifyToolbarItems();
if (changedStyle || (previewStyle === 'tab' && editorType === 'markdown')) {
eventEmitter.emit('changePreviewTabWrite');
newState.activeTab = 'write';
}
this.setState(newState);
}
};
Toolbar.prototype.beforeDestroy = function () {
window.removeEventListener('resize', this.handleResize);
this.resizeObserver.disconnect();
removeNode(this.tooltipRef.current);
};
Toolbar.prototype.render = function () {
var _this = this;
var _a = this.props, previewStyle = _a.previewStyle, eventEmitter = _a.eventEmitter, editorType = _a.editorType;
var _b = this.state, popupInfo = _b.popupInfo, showPopup = _b.showPopup, activeTab = _b.activeTab, items = _b.items, dropdownItems = _b.dropdownItems;
var props = {
eventEmitter: eventEmitter,
tooltipRef: this.tooltipRef,
disabled: editorType === 'markdown' && previewStyle === 'tab' && activeTab === 'preview',
execCommand: this.execCommand,
setPopupInfo: this.setPopupInfo,
};
var toolbarStyle = previewStyle === 'tab' ? { borderTopLeftRadius: 0 } : null;
return template(toolbar_templateObject_2 || (toolbar_templateObject_2 = __makeTemplateObject(["\n \n
\n <", " tabs=", " activeTab=", " onClick=", " />\n
\n
\n ", "\n <", "\n item=", "\n items=", "\n ...", "\n />\n
\n <", "\n info=", "\n show=", "\n eventEmitter=", "\n hidePopup=", "\n execCommand=", "\n />\n
\n "], ["\n \n
\n <", " tabs=", " activeTab=", " onClick=", " />\n
\n
\n ",
"\n <", "\n item=", "\n items=", "\n ...", "\n />\n
\n <", "\n info=", "\n show=", "\n eventEmitter=", "\n hidePopup=", "\n execCommand=", "\n />\n
\n "])), cls('toolbar'), cls('md-tab-container'), editorType === 'wysiwyg' || previewStyle === 'vertical'
? 'none'
: 'block', Tabs, this.tabs, activeTab, this.toggleTab, cls('defaultUI-toolbar'), function (el) { return (_this.refs.el = el); }, toolbarStyle, items.map(function (group, index) {
var _a;
return template(toolbar_templateObject_1 || (toolbar_templateObject_1 = __makeTemplateObject(["\n <", "\n group=", "\n hiddenDivider=", "\n setItemWidth=", "\n ...", "\n />\n "], ["\n <", "\n group=", "\n hiddenDivider=", "\n setItemWidth=", "\n ...", "\n />\n "])), ToolbarGroup, group, index === items.length - 1 || ((_a = items[index + 1]) === null || _a === void 0 ? void 0 : _a.hidden), _this.setItemWidth, props);
}), DropdownToolbarButton, createToolbarItemInfo('more'), dropdownItems, props, Popup, popupInfo, showPopup, eventEmitter, this.hidePopup, this.execCommand);
};
return Toolbar;
}(Component));
var toolbar_templateObject_1, toolbar_templateObject_2;
;// CONCATENATED MODULE: ./src/ui/components/contextMenu.ts
var ContextMenu = /** @class */ (function (_super) {
__extends(ContextMenu, _super);
function ContextMenu(props) {
var _this = _super.call(this, props) || this;
_this.handleClickDocument = function (ev) {
if (!closest(ev.target, "." + cls('context-menu'))) {
_this.setState({ pos: null });
}
};
_this.state = {
pos: null,
menuGroups: [],
};
_this.addEvent();
return _this;
}
ContextMenu.prototype.addEvent = function () {
var _this = this;
this.props.eventEmitter.listen('contextmenu', function (_a) {
var pos = _a.pos, menuGroups = _a.menuGroups;
_this.setState({ pos: pos, menuGroups: menuGroups });
});
};
ContextMenu.prototype.mounted = function () {
document.addEventListener('click', this.handleClickDocument);
};
ContextMenu.prototype.beforeDestroy = function () {
document.removeEventListener('click', this.handleClickDocument);
};
ContextMenu.prototype.getMenuGroupElements = function () {
var _this = this;
var _a = this.state, pos = _a.pos, menuGroups = _a.menuGroups;
return pos
? menuGroups.reduce(function (acc, group) {
var menuItem = [];
group.forEach(function (_a) {
var label = _a.label, _b = _a.className, className = _b === void 0 ? false : _b, disabled = _a.disabled, onClick = _a.onClick;
var handleClick = function () {
if (!disabled) {
onClick();
_this.setState({ pos: null });
}
};
menuItem.push(template(contextMenu_templateObject_1 || (contextMenu_templateObject_1 = __makeTemplateObject(["\n \n "], ["\n \n "])), handleClick, disabled ? ' disabled' : '', className, label));
});
acc.push(template(contextMenu_templateObject_2 || (contextMenu_templateObject_2 = __makeTemplateObject([""], [""])), menuItem));
return acc;
}, [])
: [];
};
ContextMenu.prototype.render = function () {
var style = __assign({ display: this.state.pos ? 'block' : 'none' }, this.state.pos);
return template(contextMenu_templateObject_3 || (contextMenu_templateObject_3 = __makeTemplateObject(["\n ", "\n
"], ["\n ", "\n
"])), cls('context-menu'), style, this.getMenuGroupElements());
};
return ContextMenu;
}(Component));
var contextMenu_templateObject_1, contextMenu_templateObject_2, contextMenu_templateObject_3;
;// CONCATENATED MODULE: ./src/ui/components/layout.ts
var Layout = /** @class */ (function (_super) {
__extends(Layout, _super);
function Layout(props) {
var _this = _super.call(this, props) || this;
_this.changeMode = function (editorType) {
if (editorType !== _this.state.editorType) {
_this.setState({ editorType: editorType });
}
};
_this.changePreviewStyle = function (previewStyle) {
if (previewStyle !== _this.state.previewStyle) {
_this.setState({ previewStyle: previewStyle });
}
};
_this.hide = function () {
_this.setState({ hide: true });
};
_this.show = function () {
_this.setState({ hide: false });
};
var editorType = props.editorType, previewStyle = props.previewStyle;
_this.state = {
editorType: editorType,
previewStyle: previewStyle,
hide: false,
};
_this.addEvent();
return _this;
}
Layout.prototype.mounted = function () {
var _a = this.props.slots, wwEditor = _a.wwEditor, mdEditor = _a.mdEditor, mdPreview = _a.mdPreview;
this.refs.wwContainer.appendChild(wwEditor);
this.refs.mdContainer.insertAdjacentElement('afterbegin', mdEditor);
this.refs.mdContainer.appendChild(mdPreview);
};
Layout.prototype.insertToolbarItem = function (indexList, item) {
this.toolbar.insertToolbarItem(indexList, item);
};
Layout.prototype.removeToolbarItem = function (name) {
this.toolbar.removeToolbarItem(name);
};
Layout.prototype.render = function () {
var _this = this;
var _a = this.props, eventEmitter = _a.eventEmitter, hideModeSwitch = _a.hideModeSwitch, toolbarItems = _a.toolbarItems, theme = _a.theme;
var _b = this.state, hide = _b.hide, previewStyle = _b.previewStyle, editorType = _b.editorType;
var displayClassName = hide ? ' hidden' : '';
var editorTypeClassName = cls(editorType === 'markdown' ? 'md-mode' : 'ww-mode');
var previewClassName = cls('md') + "-" + previewStyle + "-style";
var themeClassName = cls([theme !== 'light', theme + " "]);
return template(layout_templateObject_2 || (layout_templateObject_2 = __makeTemplateObject(["\n \n <", "\n ref=", "\n eventEmitter=", "\n previewStyle=", "\n toolbarItems=", "\n editorType=", "\n />\n
\n ", "\n <", " eventEmitter=", " />\n
\n "], ["\n \n <", "\n ref=", "\n eventEmitter=", "\n previewStyle=", "\n toolbarItems=", "\n editorType=", "\n />\n
\n ",
"\n <", " eventEmitter=", " />\n
\n "])), themeClassName, cls('defaultUI'), displayClassName, function (el) { return (_this.refs.el = el); }, Toolbar, function (toolbar) { return (_this.toolbar = toolbar); }, eventEmitter, previewStyle, toolbarItems, editorType, cls('main'), editorTypeClassName, function (el) { return (_this.refs.editorSection = el); }, cls('main-container'), cls('md-container'), previewClassName, function (el) { return (_this.refs.mdContainer = el); }, cls('md-splitter'), cls('ww-container'), function (el) { return (_this.refs.wwContainer = el); }, !hideModeSwitch && template(layout_templateObject_1 || (layout_templateObject_1 = __makeTemplateObject(["<", " eventEmitter=", " editorType=", " />"], ["<", " eventEmitter=", " editorType=", " />"])), Switch, eventEmitter, editorType), ContextMenu, eventEmitter);
};
Layout.prototype.addEvent = function () {
var eventEmitter = this.props.eventEmitter;
eventEmitter.listen('hide', this.hide);
eventEmitter.listen('show', this.show);
eventEmitter.listen('changeMode', this.changeMode);
eventEmitter.listen('changePreviewStyle', this.changePreviewStyle);
};
return Layout;
}(Component));
var layout_templateObject_1, layout_templateObject_2;
;// CONCATENATED MODULE: ./src/editor.ts
/**
* ToastUI Editor
* @extends ToastUIEditorCore
*/
var ToastUIEditor = /** @class */ (function (_super) {
__extends(ToastUIEditor, _super);
function ToastUIEditor(options) {
var _a;
var _this = _super.call(this, options) || this;
var layoutComp;
var destroy = render(_this.options.el, template(editor_templateObject_1 || (editor_templateObject_1 = __makeTemplateObject(["\n <", "\n ref=", "\n eventEmitter=", "\n slots=", "\n hideModeSwitch=", "\n toolbarItems=", "\n previewStyle=", "\n editorType=", "\n theme=", "\n />\n "], ["\n <", "\n ref=", "\n eventEmitter=", "\n slots=", "\n hideModeSwitch=", "\n toolbarItems=", "\n previewStyle=", "\n editorType=", "\n theme=", "\n />\n "])), Layout, function (layout) { return (layoutComp = layout); }, _this.eventEmitter, _this.getEditorElements(), _this.options.hideModeSwitch, _this.options.toolbarItems, _this.options.previewStyle, _this.options.initialEditType, _this.options.theme));
_this.setMinHeight(_this.options.minHeight);
_this.setHeight(_this.options.height);
_this.defaultUI = {
insertToolbarItem: layoutComp.insertToolbarItem.bind(layoutComp),
removeToolbarItem: layoutComp.removeToolbarItem.bind(layoutComp),
destroy: destroy,
};
(_a = _this.pluginInfo.toolbarItems) === null || _a === void 0 ? void 0 : _a.forEach(function (toolbarItem) {
var groupIndex = toolbarItem.groupIndex, itemIndex = toolbarItem.itemIndex, item = toolbarItem.item;
_this.defaultUI.insertToolbarItem({ groupIndex: groupIndex, itemIndex: itemIndex }, item);
});
_this.eventEmitter.emit('loadUI', _this);
return _this;
}
/**
* Factory method for Editor
* @param {object} options Option for initialize TUIEditor
* @returns {object} ToastUIEditor or ToastUIEditorViewer
*/
ToastUIEditor.factory = function (options) {
return options.viewer ? new viewer(options) : new ToastUIEditor(options);
};
/**
* add toolbar item
* @param {Object} indexInfo group index and item index of the toolbar item
* @param {string|Object} item toolbar item
*/
ToastUIEditor.prototype.insertToolbarItem = function (indexInfo, item) {
this.defaultUI.insertToolbarItem(indexInfo, item);
};
/**
* Remove toolbar item
* @param {string} itemName toolbar item name
*/
ToastUIEditor.prototype.removeToolbarItem = function (itemName) {
this.defaultUI.removeToolbarItem(itemName);
};
/**
* Destroy TUIEditor from document
*/
ToastUIEditor.prototype.destroy = function () {
_super.prototype.destroy.call(this);
this.defaultUI.destroy();
};
return ToastUIEditor;
}(editorCore));
/* harmony default export */ var editor = (ToastUIEditor);
var editor_templateObject_1;
;// CONCATENATED MODULE: ../../node_modules/prosemirror-view/style/prosemirror.css
// extracted by mini-css-extract-plugin
;// CONCATENATED MODULE: ./src/i18n/en-us.ts
/**
* @fileoverview I18N for English
* @author NHN Cloud FE Development Lab
*/
editorCore.setLanguage(['en', 'en-US'], {
Markdown: 'Markdown',
WYSIWYG: 'WYSIWYG',
Write: 'Write',
Preview: 'Preview',
Headings: 'Headings',
Paragraph: 'Paragraph',
Bold: 'Bold',
Italic: 'Italic',
Strike: 'Strike',
Code: 'Inline code',
Line: 'Line',
Blockquote: 'Blockquote',
'Unordered list': 'Unordered list',
'Ordered list': 'Ordered list',
Task: 'Task',
Indent: 'Indent',
Outdent: 'Outdent',
'Insert link': 'Insert link',
'Insert CodeBlock': 'Insert codeBlock',
'Insert table': 'Insert table',
'Insert image': 'Insert image',
Heading: 'Heading',
'Image URL': 'Image URL',
'Select image file': 'Select image file',
'Choose a file': 'Choose a file',
'No file': 'No file',
Description: 'Description',
OK: 'OK',
More: 'More',
Cancel: 'Cancel',
File: 'File',
URL: 'URL',
'Link text': 'Link text',
'Add row to up': 'Add row to up',
'Add row to down': 'Add row to down',
'Add column to left': 'Add column to left',
'Add column to right': 'Add column to right',
'Remove row': 'Remove row',
'Remove column': 'Remove column',
'Align column to left': 'Align column to left',
'Align column to center': 'Align column to center',
'Align column to right': 'Align column to right',
'Remove table': 'Remove table',
'Would you like to paste as table?': 'Would you like to paste as table?',
'Text color': 'Text color',
'Auto scroll enabled': 'Auto scroll enabled',
'Auto scroll disabled': 'Auto scroll disabled',
'Choose language': 'Choose language',
});
;// CONCATENATED MODULE: ./src/index.ts
/* harmony default export */ var src = (editor);
}();
__webpack_exports__ = __webpack_exports__["default"];
/******/ return __webpack_exports__;
/******/ })()
;
});