slate-angular 1.7.5 → 1.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -157,4 +157,31 @@ export const getPlainText = (domNode) => {
157
157
  }
158
158
  return text;
159
159
  };
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../packages/src/utils/dom.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Types.\n */\n\n// COMPAT: This is required to prevent TypeScript aliases from doing some very\n// weird things for Slate's types with the same name as globals. (2019/11/27)\n// https://github.com/microsoft/TypeScript/issues/35002\nimport DOMNode = globalThis.Node;\nimport DOMComment = globalThis.Comment;\nimport DOMElement = globalThis.Element;\nimport DOMText = globalThis.Text;\nimport DOMRange = globalThis.Range;\nimport DOMSelection = globalThis.Selection;\nimport DOMStaticRange = globalThis.StaticRange;\nexport {\n    DOMNode,\n    DOMComment,\n    DOMElement,\n    DOMText,\n    DOMRange,\n    DOMSelection,\n    DOMStaticRange\n};\n\ndeclare global {\n    interface Window {\n        Selection: typeof Selection['constructor'];\n        DataTransfer: typeof DataTransfer['constructor'];\n        Node: typeof Node['constructor'];\n    }\n}\n\nexport type DOMPoint = [Node, number];\n\n/**\n * Returns the host window of a DOM node\n */\nexport const getDefaultView = (value: any): Window | null => {\n    return (\n        (value && value.ownerDocument && value.ownerDocument.defaultView) || null\n    );\n}\n\n/**\n * Check if a DOM node is a comment node.\n */\nexport const isDOMComment = (value: any): value is DOMComment => {\n    return isDOMNode(value) && value.nodeType === 8;\n};\n\n/**\n * Check if a DOM node is an element node.\n */\nexport const isDOMElement = (value: any): value is DOMElement => {\n    return isDOMNode(value) && value.nodeType === 1;\n};\n\n/**\n * Check if a value is a DOM node.\n */\nexport const isDOMNode = (value: any): value is DOMNode => {\n    const window = getDefaultView(value)\n    return !!window && value instanceof window.Node;\n};\n\n/**\n * Check if a value is a DOM selection.\n */\nexport const isDOMSelection = (value: any): value is DOMSelection => {\n    const window = value && value.anchorNode && getDefaultView(value.anchorNode)\n    return !!window && value instanceof window.Selection\n}\n\n/**\n * Check if a DOM node is an element node.\n */\nexport const isDOMText = (value: any): value is DOMText => {\n    return isDOMNode(value) && value.nodeType === 3;\n};\n\n/**\n * Checks whether a paste event is a plaintext-only event.\n */\nexport const isPlainTextOnlyPaste = (event: ClipboardEvent) => {\n    return (\n        event.clipboardData &&\n        event.clipboardData.getData('text/plain') !== '' &&\n        event.clipboardData.types.length === 1\n    );\n};\n\n/**\n * Normalize a DOM point so that it always refers to a text node.\n */\nexport const normalizeDOMPoint = (domPoint: DOMPoint): DOMPoint => {\n    let [node, offset] = domPoint;\n\n    // If it's an element node, its offset refers to the index of its children\n    // including comment nodes, so try to find the right text child node.\n    if (isDOMElement(node) && node.childNodes.length) {\n        let isLast = offset === node.childNodes.length;\n        let index = isLast ? offset - 1 : offset;\n        ;[node, index] = getEditableChildAndIndex(node,\n            index,\n            isLast ? 'backward' : 'forward');\n\n        // If the editable child found is in front of input offset, we instead seek to its end\n        isLast = index < offset;\n\n        // If the node has children, traverse until we have a leaf node. Leaf nodes\n        // can be either text nodes, or other void DOM nodes.\n        while (isDOMElement(node) && node.childNodes.length) {\n            const i = isLast ? node.childNodes.length - 1 : 0;\n            node = getEditableChild(node, i, isLast ? 'backward' : 'forward');\n        }\n\n        // Determine the new offset inside the text node.\n        offset =\n            isLast && node.textContent != null ? node.textContent.length : 0;\n    }\n\n    // Return the node and offset.\n    return [node, offset];\n};\n\n/**\n * Determines wether the active element is nested within a shadowRoot\n */\n\nexport const hasShadowRoot = () => {\n    return !!(\n        window.document.activeElement && window.document.activeElement.shadowRoot\n    )\n}\n\n/**\n * Get the nearest editable child and index at `index` in a `parent`, preferring\n * `direction`.\n */\n\nexport const getEditableChildAndIndex = (\n    parent: DOMElement,\n    index: number,\n    direction: 'forward' | 'backward'\n): [DOMNode, number] => {\n    const { childNodes } = parent;\n    let child = childNodes[index];\n    let i = index;\n    let triedForward = false;\n    let triedBackward = false;\n\n    // While the child is a comment node, or an element node with no children,\n    // keep iterating to find a sibling non-void, non-comment node.\n    while (\n        isDOMComment(child) ||\n        (isDOMElement(child) && child.childNodes.length === 0) ||\n        (isDOMElement(child) && child.getAttribute('contenteditable') === 'false')\n    ) {\n        if (triedForward && triedBackward) {\n            break;\n        }\n\n        if (i >= childNodes.length) {\n            triedForward = true;\n            i = index - 1;\n            direction = 'backward';\n            continue;\n        }\n\n        if (i < 0) {\n            triedBackward = true;\n            i = index + 1;\n            direction = 'forward';\n            continue;\n        }\n\n        child = childNodes[i];\n        index = i;\n        i += direction === 'forward' ? 1 : -1;\n    }\n\n    return [child, index];\n}\n\n/**\n * Get the nearest editable child at `index` in a `parent`, preferring\n * `direction`.\n */\n\nexport const getEditableChild = (\n    parent: DOMElement,\n    index: number,\n    direction: 'forward' | 'backward'\n): DOMNode => {\n    const [child] = getEditableChildAndIndex(parent, index, direction);\n    return child;\n}\n\n/**\n * Get a plaintext representation of the content of a node, accounting for block\n * elements which get a newline appended.\n *\n * The domNode must be attached to the DOM.\n */\nexport const getPlainText = (domNode: DOMNode) => {\n    let text = '';\n\n    if (isDOMText(domNode) && domNode.nodeValue) {\n        return domNode.nodeValue;\n    }\n\n    if (isDOMElement(domNode)) {\n        for (const childNode of Array.from(domNode.childNodes)) {\n            text += getPlainText(childNode);\n        }\n\n        const display = getComputedStyle(domNode).getPropertyValue('display');\n\n        if (display === 'block' || display === 'list' || domNode.tagName === 'BR') {\n            text += '\\n';\n        }\n    }\n\n    return text;\n};\n\n"]}
160
+ /**
161
+ * Get x-slate-fragment attribute from data-slate-fragment
162
+ */
163
+ const catchSlateFragment = /data-slate-fragment="(.+?)"/m;
164
+ export const getSlateFragmentAttribute = (dataTransfer) => {
165
+ const htmlData = dataTransfer.getData('text/html');
166
+ const [, fragment] = htmlData.match(catchSlateFragment) || [];
167
+ return fragment;
168
+ };
169
+ /**
170
+ * Get the x-slate-fragment attribute that exist in text/html data
171
+ * and append it to the DataTransfer object
172
+ */
173
+ export const getClipboardData = (dataTransfer, clipboardFormatKey = 'x-slate-fragment') => {
174
+ if (!dataTransfer.getData(`application/${clipboardFormatKey}`)) {
175
+ const fragment = getSlateFragmentAttribute(dataTransfer);
176
+ if (fragment) {
177
+ const clipboardData = new DataTransfer();
178
+ dataTransfer.types.forEach(type => {
179
+ clipboardData.setData(type, dataTransfer.getData(type));
180
+ });
181
+ clipboardData.setData(`application/${clipboardFormatKey}`, fragment);
182
+ return clipboardData;
183
+ }
184
+ }
185
+ return dataTransfer;
186
+ };
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom.js","sourceRoot":"","sources":["../../../packages/src/utils/dom.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Types.\n */\n\n// COMPAT: This is required to prevent TypeScript aliases from doing some very\n// weird things for Slate's types with the same name as globals. (2019/11/27)\n// https://github.com/microsoft/TypeScript/issues/35002\nimport DOMNode = globalThis.Node;\nimport DOMComment = globalThis.Comment;\nimport DOMElement = globalThis.Element;\nimport DOMText = globalThis.Text;\nimport DOMRange = globalThis.Range;\nimport DOMSelection = globalThis.Selection;\nimport DOMStaticRange = globalThis.StaticRange;\nexport {\n    DOMNode,\n    DOMComment,\n    DOMElement,\n    DOMText,\n    DOMRange,\n    DOMSelection,\n    DOMStaticRange\n};\n\ndeclare global {\n    interface Window {\n        Selection: typeof Selection['constructor'];\n        DataTransfer: typeof DataTransfer['constructor'];\n        Node: typeof Node['constructor'];\n    }\n}\n\nexport type DOMPoint = [Node, number];\n\n/**\n * Returns the host window of a DOM node\n */\nexport const getDefaultView = (value: any): Window | null => {\n    return (\n        (value && value.ownerDocument && value.ownerDocument.defaultView) || null\n    );\n}\n\n/**\n * Check if a DOM node is a comment node.\n */\nexport const isDOMComment = (value: any): value is DOMComment => {\n    return isDOMNode(value) && value.nodeType === 8;\n};\n\n/**\n * Check if a DOM node is an element node.\n */\nexport const isDOMElement = (value: any): value is DOMElement => {\n    return isDOMNode(value) && value.nodeType === 1;\n};\n\n/**\n * Check if a value is a DOM node.\n */\nexport const isDOMNode = (value: any): value is DOMNode => {\n    const window = getDefaultView(value)\n    return !!window && value instanceof window.Node;\n};\n\n/**\n * Check if a value is a DOM selection.\n */\nexport const isDOMSelection = (value: any): value is DOMSelection => {\n    const window = value && value.anchorNode && getDefaultView(value.anchorNode)\n    return !!window && value instanceof window.Selection\n}\n\n/**\n * Check if a DOM node is an element node.\n */\nexport const isDOMText = (value: any): value is DOMText => {\n    return isDOMNode(value) && value.nodeType === 3;\n};\n\n/**\n * Checks whether a paste event is a plaintext-only event.\n */\nexport const isPlainTextOnlyPaste = (event: ClipboardEvent) => {\n    return (\n        event.clipboardData &&\n        event.clipboardData.getData('text/plain') !== '' &&\n        event.clipboardData.types.length === 1\n    );\n};\n\n/**\n * Normalize a DOM point so that it always refers to a text node.\n */\nexport const normalizeDOMPoint = (domPoint: DOMPoint): DOMPoint => {\n    let [node, offset] = domPoint;\n\n    // If it's an element node, its offset refers to the index of its children\n    // including comment nodes, so try to find the right text child node.\n    if (isDOMElement(node) && node.childNodes.length) {\n        let isLast = offset === node.childNodes.length;\n        let index = isLast ? offset - 1 : offset;\n        ;[node, index] = getEditableChildAndIndex(node,\n            index,\n            isLast ? 'backward' : 'forward');\n\n        // If the editable child found is in front of input offset, we instead seek to its end\n        isLast = index < offset;\n\n        // If the node has children, traverse until we have a leaf node. Leaf nodes\n        // can be either text nodes, or other void DOM nodes.\n        while (isDOMElement(node) && node.childNodes.length) {\n            const i = isLast ? node.childNodes.length - 1 : 0;\n            node = getEditableChild(node, i, isLast ? 'backward' : 'forward');\n        }\n\n        // Determine the new offset inside the text node.\n        offset =\n            isLast && node.textContent != null ? node.textContent.length : 0;\n    }\n\n    // Return the node and offset.\n    return [node, offset];\n};\n\n/**\n * Determines wether the active element is nested within a shadowRoot\n */\n\nexport const hasShadowRoot = () => {\n    return !!(\n        window.document.activeElement && window.document.activeElement.shadowRoot\n    )\n}\n\n/**\n * Get the nearest editable child and index at `index` in a `parent`, preferring\n * `direction`.\n */\n\nexport const getEditableChildAndIndex = (\n    parent: DOMElement,\n    index: number,\n    direction: 'forward' | 'backward'\n): [DOMNode, number] => {\n    const { childNodes } = parent;\n    let child = childNodes[index];\n    let i = index;\n    let triedForward = false;\n    let triedBackward = false;\n\n    // While the child is a comment node, or an element node with no children,\n    // keep iterating to find a sibling non-void, non-comment node.\n    while (\n        isDOMComment(child) ||\n        (isDOMElement(child) && child.childNodes.length === 0) ||\n        (isDOMElement(child) && child.getAttribute('contenteditable') === 'false')\n    ) {\n        if (triedForward && triedBackward) {\n            break;\n        }\n\n        if (i >= childNodes.length) {\n            triedForward = true;\n            i = index - 1;\n            direction = 'backward';\n            continue;\n        }\n\n        if (i < 0) {\n            triedBackward = true;\n            i = index + 1;\n            direction = 'forward';\n            continue;\n        }\n\n        child = childNodes[i];\n        index = i;\n        i += direction === 'forward' ? 1 : -1;\n    }\n\n    return [child, index];\n}\n\n/**\n * Get the nearest editable child at `index` in a `parent`, preferring\n * `direction`.\n */\n\nexport const getEditableChild = (\n    parent: DOMElement,\n    index: number,\n    direction: 'forward' | 'backward'\n): DOMNode => {\n    const [child] = getEditableChildAndIndex(parent, index, direction);\n    return child;\n}\n\n/**\n * Get a plaintext representation of the content of a node, accounting for block\n * elements which get a newline appended.\n *\n * The domNode must be attached to the DOM.\n */\nexport const getPlainText = (domNode: DOMNode) => {\n    let text = '';\n\n    if (isDOMText(domNode) && domNode.nodeValue) {\n        return domNode.nodeValue;\n    }\n\n    if (isDOMElement(domNode)) {\n        for (const childNode of Array.from(domNode.childNodes)) {\n            text += getPlainText(childNode);\n        }\n\n        const display = getComputedStyle(domNode).getPropertyValue('display');\n\n        if (display === 'block' || display === 'list' || domNode.tagName === 'BR') {\n            text += '\\n';\n        }\n    }\n\n    return text;\n};\n\n/**\n * Get x-slate-fragment attribute from data-slate-fragment\n */\nconst catchSlateFragment = /data-slate-fragment=\"(.+?)\"/m\nexport const getSlateFragmentAttribute = (\n    dataTransfer: DataTransfer\n): string | void => {\n    const htmlData = dataTransfer.getData('text/html')\n    const [, fragment] = htmlData.match(catchSlateFragment) || []\n    return fragment\n}\n\n/**\n * Get the x-slate-fragment attribute that exist in text/html data\n * and append it to the DataTransfer object\n */\nexport const getClipboardData = (dataTransfer: DataTransfer, clipboardFormatKey = 'x-slate-fragment'): DataTransfer => {\n    if (!dataTransfer.getData(`application/${clipboardFormatKey}`)) {\n        const fragment = getSlateFragmentAttribute(dataTransfer)\n        if (fragment) {\n            const clipboardData = new DataTransfer()\n            dataTransfer.types.forEach(type => {\n                clipboardData.setData(type, dataTransfer.getData(type))\n            })\n            clipboardData.setData(`application/${clipboardFormatKey}`, fragment)\n            return clipboardData\n        }\n    }\n    return dataTransfer\n}\n"]}
@@ -3,6 +3,7 @@ export const IS_IOS = typeof navigator !== 'undefined' &&
3
3
  /iPad|iPhone|iPod/.test(navigator.userAgent) &&
4
4
  !window.MSStream;
5
5
  export const IS_APPLE = typeof navigator !== 'undefined' && /Mac OS X/.test(navigator.userAgent);
6
+ export const IS_ANDROID = typeof navigator !== 'undefined' && /Android/.test(navigator.userAgent);
6
7
  export const IS_FIREFOX = typeof navigator !== 'undefined' &&
7
8
  /^(?!.*Seamonkey)(?=.*Firefox).*/i.test(navigator.userAgent);
8
9
  export const IS_SAFARI = typeof navigator !== 'undefined' &&
@@ -14,4 +15,22 @@ export const IS_CHROME = typeof navigator !== 'undefined' && /Chrome/i.test(navi
14
15
  // Native beforeInput events don't work well with react on Chrome 75 and older, Chrome 76+ can use beforeInput
15
16
  export const IS_CHROME_LEGACY = typeof navigator !== 'undefined' &&
16
17
  /Chrome?\/(?:[0-7][0-5]|[0-6][0-9])/i.test(navigator.userAgent);
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvZW52aXJvbm1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUNmLE9BQU8sU0FBUyxLQUFLLFdBQVc7SUFDaEMsT0FBTyxNQUFNLEtBQUssV0FBVztJQUM3QixrQkFBa0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztJQUM1QyxDQUFFLE1BQWMsQ0FBQyxRQUFRLENBQUM7QUFFOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUNqQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFN0UsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUNuQixPQUFPLFNBQVMsS0FBSyxXQUFXO0lBQ2hDLGtDQUFrQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFakUsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUNsQixPQUFPLFNBQVMsS0FBSyxXQUFXO0lBQ2hDLDBCQUEwQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFekQscUNBQXFDO0FBQ3JDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FDdkIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyxtQ0FBbUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRWxFLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FDbEIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTVFLDhHQUE4RztBQUM5RyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FDekIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyxxQ0FBcUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IElTX0lPUyA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICB0eXBlb2Ygd2luZG93ICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIC9pUGFkfGlQaG9uZXxpUG9kLy50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpICYmXG4gICAgISh3aW5kb3cgYXMgYW55KS5NU1N0cmVhbTtcblxuZXhwb3J0IGNvbnN0IElTX0FQUExFID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJiAvTWFjIE9TIFgvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbmV4cG9ydCBjb25zdCBJU19GSVJFRk9YID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIC9eKD8hLipTZWFtb25rZXkpKD89LipGaXJlZm94KS4qL2kudGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX1NBRkFSSSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvVmVyc2lvblxcL1tcXGRcXC5dKy4qU2FmYXJpLy50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuXG4vLyBcIm1vZGVyblwiIEVkZ2Ugd2FzIHJlbGVhc2VkIGF0IDc5LnhcbmV4cG9ydCBjb25zdCBJU19FREdFX0xFR0FDWSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvRWRnZT9cXC8oPzpbMC02XVswLTldfFswLTddWzAtOF0pL2kudGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX0NIUk9NRSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiYgL0Nocm9tZS9pLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbi8vIE5hdGl2ZSBiZWZvcmVJbnB1dCBldmVudHMgZG9uJ3Qgd29yayB3ZWxsIHdpdGggcmVhY3Qgb24gQ2hyb21lIDc1IGFuZCBvbGRlciwgQ2hyb21lIDc2KyBjYW4gdXNlIGJlZm9yZUlucHV0XG5leHBvcnQgY29uc3QgSVNfQ0hST01FX0xFR0FDWSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvQ2hyb21lP1xcLyg/OlswLTddWzAtNV18WzAtNl1bMC05XSkvaS50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuIl19
18
+ // Firefox did not support `beforeInput` until `v87`.
19
+ export const IS_FIREFOX_LEGACY = typeof navigator !== 'undefined' &&
20
+ /^(?!.*Seamonkey)(?=.*Firefox\/(?:[0-7][0-9]|[0-8][0-6])).*/i.test(navigator.userAgent);
21
+ // qq browser
22
+ export const IS_QQBROWSER = typeof navigator !== 'undefined' && /.*QQBrowser/.test(navigator.userAgent);
23
+ // UC mobile browser
24
+ export const IS_UC_MOBILE = typeof navigator !== 'undefined' && /.*UCBrowser/.test(navigator.userAgent);
25
+ // Wechat browser
26
+ export const IS_WECHATBROWSER = typeof navigator !== 'undefined' && /.*Wechat/.test(navigator.userAgent);
27
+ // COMPAT: Firefox/Edge Legacy don't support the `beforeinput` event
28
+ // Chrome Legacy doesn't support `beforeinput` correctly
29
+ export const HAS_BEFORE_INPUT_SUPPORT = !IS_CHROME_LEGACY &&
30
+ !IS_EDGE_LEGACY &&
31
+ // globalThis is undefined in older browsers
32
+ typeof globalThis !== 'undefined' &&
33
+ globalThis.InputEvent &&
34
+ // @ts-ignore The `getTargetRanges` property isn't recognized.
35
+ typeof globalThis.InputEvent.prototype.getTargetRanges === 'function';
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvZW52aXJvbm1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUNmLE9BQU8sU0FBUyxLQUFLLFdBQVc7SUFDaEMsT0FBTyxNQUFNLEtBQUssV0FBVztJQUM3QixrQkFBa0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztJQUM1QyxDQUFFLE1BQWMsQ0FBQyxRQUFRLENBQUM7QUFFOUIsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUNqQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFN0UsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUNuQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUE7QUFFM0UsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUNuQixPQUFPLFNBQVMsS0FBSyxXQUFXO0lBQ2hDLGtDQUFrQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFakUsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUNsQixPQUFPLFNBQVMsS0FBSyxXQUFXO0lBQ2hDLDBCQUEwQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFekQscUNBQXFDO0FBQ3JDLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FDdkIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyxtQ0FBbUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRWxFLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FDbEIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTVFLDhHQUE4RztBQUM5RyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FDekIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyxxQ0FBcUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBR3BFLHFEQUFxRDtBQUNyRCxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FDMUIsT0FBTyxTQUFTLEtBQUssV0FBVztJQUNoQyw2REFBNkQsQ0FBQyxJQUFJLENBQzlELFNBQVMsQ0FBQyxTQUFTLENBQ3RCLENBQUM7QUFFTixhQUFhO0FBQ2IsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUNyQixPQUFPLFNBQVMsS0FBSyxXQUFXLElBQUksYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFaEYsb0JBQW9CO0FBQ3BCLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FDckIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRWhGLGlCQUFpQjtBQUNqQixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FDekIsT0FBTyxTQUFTLEtBQUssV0FBVyxJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBRTdFLG9FQUFvRTtBQUNwRSx3REFBd0Q7QUFDeEQsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQ2pDLENBQUMsZ0JBQWdCO0lBQ2pCLENBQUMsY0FBYztJQUNmLDRDQUE0QztJQUM1QyxPQUFPLFVBQVUsS0FBSyxXQUFXO0lBQ2pDLFVBQVUsQ0FBQyxVQUFVO0lBQ3JCLDhEQUE4RDtJQUM5RCxPQUFPLFVBQVUsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLGVBQWUsS0FBSyxVQUFVLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgSVNfSU9TID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmXG4gICAgL2lQYWR8aVBob25lfGlQb2QvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCkgJiZcbiAgICAhKHdpbmRvdyBhcyBhbnkpLk1TU3RyZWFtO1xuXG5leHBvcnQgY29uc3QgSVNfQVBQTEUgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC9NYWMgT1MgWC8udGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX0FORFJPSUQgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC9BbmRyb2lkLy50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpXG5cbmV4cG9ydCBjb25zdCBJU19GSVJFRk9YID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIC9eKD8hLipTZWFtb25rZXkpKD89LipGaXJlZm94KS4qL2kudGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX1NBRkFSSSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvVmVyc2lvblxcL1tcXGRcXC5dKy4qU2FmYXJpLy50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuXG4vLyBcIm1vZGVyblwiIEVkZ2Ugd2FzIHJlbGVhc2VkIGF0IDc5LnhcbmV4cG9ydCBjb25zdCBJU19FREdFX0xFR0FDWSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvRWRnZT9cXC8oPzpbMC02XVswLTldfFswLTddWzAtOF0pL2kudGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuZXhwb3J0IGNvbnN0IElTX0NIUk9NRSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiYgL0Nocm9tZS9pLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbi8vIE5hdGl2ZSBiZWZvcmVJbnB1dCBldmVudHMgZG9uJ3Qgd29yayB3ZWxsIHdpdGggcmVhY3Qgb24gQ2hyb21lIDc1IGFuZCBvbGRlciwgQ2hyb21lIDc2KyBjYW4gdXNlIGJlZm9yZUlucHV0XG5leHBvcnQgY29uc3QgSVNfQ0hST01FX0xFR0FDWSA9XG4gICAgdHlwZW9mIG5hdmlnYXRvciAhPT0gJ3VuZGVmaW5lZCcgJiZcbiAgICAvQ2hyb21lP1xcLyg/OlswLTddWzAtNV18WzAtNl1bMC05XSkvaS50ZXN0KG5hdmlnYXRvci51c2VyQWdlbnQpO1xuXG5cbi8vIEZpcmVmb3ggZGlkIG5vdCBzdXBwb3J0IGBiZWZvcmVJbnB1dGAgdW50aWwgYHY4N2AuXG5leHBvcnQgY29uc3QgSVNfRklSRUZPWF9MRUdBQ1kgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmXG4gICAgL14oPyEuKlNlYW1vbmtleSkoPz0uKkZpcmVmb3hcXC8oPzpbMC03XVswLTldfFswLThdWzAtNl0pKS4qL2kudGVzdChcbiAgICAgICAgbmF2aWdhdG9yLnVzZXJBZ2VudFxuICAgICk7XG5cbi8vIHFxIGJyb3dzZXJcbmV4cG9ydCBjb25zdCBJU19RUUJST1dTRVIgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC8uKlFRQnJvd3Nlci8udGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuLy8gVUMgbW9iaWxlIGJyb3dzZXJcbmV4cG9ydCBjb25zdCBJU19VQ19NT0JJTEUgPVxuICAgIHR5cGVvZiBuYXZpZ2F0b3IgIT09ICd1bmRlZmluZWQnICYmIC8uKlVDQnJvd3Nlci8udGVzdChuYXZpZ2F0b3IudXNlckFnZW50KTtcblxuLy8gV2VjaGF0IGJyb3dzZXJcbmV4cG9ydCBjb25zdCBJU19XRUNIQVRCUk9XU0VSID1cbiAgICB0eXBlb2YgbmF2aWdhdG9yICE9PSAndW5kZWZpbmVkJyAmJiAvLipXZWNoYXQvLnRlc3QobmF2aWdhdG9yLnVzZXJBZ2VudCk7XG5cbi8vIENPTVBBVDogRmlyZWZveC9FZGdlIExlZ2FjeSBkb24ndCBzdXBwb3J0IHRoZSBgYmVmb3JlaW5wdXRgIGV2ZW50XG4vLyBDaHJvbWUgTGVnYWN5IGRvZXNuJ3Qgc3VwcG9ydCBgYmVmb3JlaW5wdXRgIGNvcnJlY3RseVxuZXhwb3J0IGNvbnN0IEhBU19CRUZPUkVfSU5QVVRfU1VQUE9SVCA9XG4gICAgIUlTX0NIUk9NRV9MRUdBQ1kgJiZcbiAgICAhSVNfRURHRV9MRUdBQ1kgJiZcbiAgICAvLyBnbG9iYWxUaGlzIGlzIHVuZGVmaW5lZCBpbiBvbGRlciBicm93c2Vyc1xuICAgIHR5cGVvZiBnbG9iYWxUaGlzICE9PSAndW5kZWZpbmVkJyAmJlxuICAgIGdsb2JhbFRoaXMuSW5wdXRFdmVudCAmJlxuICAgIC8vIEB0cy1pZ25vcmUgVGhlIGBnZXRUYXJnZXRSYW5nZXNgIHByb3BlcnR5IGlzbid0IHJlY29nbml6ZWQuXG4gICAgdHlwZW9mIGdsb2JhbFRoaXMuSW5wdXRFdmVudC5wcm90b3R5cGUuZ2V0VGFyZ2V0UmFuZ2VzID09PSAnZnVuY3Rpb24nIl19
@@ -89,6 +89,11 @@ export class ViewContainerItem {
89
89
  }
90
90
  }
91
91
  }
92
+ appendBlockCardElement() {
93
+ if (this.blockCardComponentRef) {
94
+ this.blockCardComponentRef.instance.append();
95
+ }
96
+ }
92
97
  }
93
98
  ViewContainerItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainerItem, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
94
99
  ViewContainerItem.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.7", type: ViewContainerItem, inputs: { viewContext: "viewContext" }, ngImport: i0 });
@@ -97,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
97
102
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }]; }, propDecorators: { viewContext: [{
98
103
  type: Input
99
104
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-item.js","sourceRoot":"","sources":["../../../packages/src/view/container-item.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, EmbeddedViewRef, Input, ViewContainerRef } from \"@angular/core\";\nimport { ViewType } from \"../types/view\";\nimport { isComponentType, isDOMElement, isTemplateRef } from \"../utils\";\nimport { BaseComponent, BaseEmbeddedView } from \"./base\";\nimport { SlateElementContext, SlateLeafContext, SlateStringContext, SlateTextContext, SlateViewContext } from \"./context\";\n\n/**\n * Dynamically create/update components or templates\n * Provide rootNodes for the view container\n * If the dynamically created component uses onpush mode, then it must call markForCheck when setting the context\n */\n@Directive()\nexport abstract class ViewContainerItem<T = SlateElementContext | SlateTextContext | SlateLeafContext | SlateStringContext, K extends BaseComponent<T> = BaseComponent<T>> {\n    initialized = false;\n    embeddedViewRef: EmbeddedViewRef<BaseEmbeddedView<T>>;\n    embeddedViewContext: BaseEmbeddedView<T>;\n    componentRef: ComponentRef<K>;\n    viewType: ViewType;\n\n    @Input() viewContext: SlateViewContext;\n\n    get rootNodes() {\n        return this.getRootNodes();\n    }\n\n    getRootNodes(): HTMLElement[] {\n        if (this.embeddedViewRef) {\n            return this.embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode));\n        }\n        if (this.componentRef) {\n            return [this.componentRef.instance.nativeElement];\n        }\n        return [];\n    }\n\n    constructor(\n        protected viewContainerRef: ViewContainerRef,\n        protected componentFactoryResolver: ComponentFactoryResolver\n    ) { }\n\n    destroyView() {\n        if (this.embeddedViewRef) {\n            this.embeddedViewRef.destroy();\n            this.embeddedViewRef = null;\n        }\n        if (this.componentRef) {\n            this.componentRef.destroy();\n            this.componentRef = null;\n        }\n    }\n\n    abstract getContext(): T;\n\n    abstract getViewType(): ViewType;\n\n    abstract memoizedContext(prev: T, next: T): boolean;\n\n    createView() {\n        this.initialized = true;\n        this.viewType = this.getViewType();\n        const context = this.getContext();\n        if (isTemplateRef(this.viewType)) {\n            this.embeddedViewContext = { context, viewContext: this.viewContext };\n            const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n            this.embeddedViewRef = embeddedViewRef;\n        }\n        if (isComponentType(this.viewType)) {\n            const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n            const componentRef = this.viewContainerRef.createComponent(componentFactory);\n            componentRef.instance.context = context;\n            componentRef.instance.viewContext = this.viewContext;\n            this.componentRef = componentRef;\n        }\n    }\n\n    updateView() {\n        const viewType = this.getViewType();\n        const context = this.getContext();\n        if (this.viewType === viewType) {\n            if (this.componentRef) {\n                if (this.memoizedContext(this.componentRef.instance.context, context)) {\n                    return;\n                }\n                this.componentRef.instance.context = context;\n            }\n            if (this.embeddedViewRef) {\n                if (this.memoizedContext(this.embeddedViewContext.context, context)) {\n                    return;\n                }\n                this.embeddedViewContext.context = context;\n            }\n        } else {\n            this.viewType = viewType;\n            const firstRootNode = this.rootNodes[0];\n            if (isTemplateRef(this.viewType)) {\n                this.embeddedViewContext = { context, viewContext: this.viewContext };\n                const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n                firstRootNode.replaceWith(...embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode)));\n                this.destroyView();\n                this.embeddedViewRef = embeddedViewRef;\n            }\n            if (isComponentType(this.viewType)) {\n                const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n                const componentRef = this.viewContainerRef.createComponent(componentFactory);\n                componentRef.instance.context = context;\n                componentRef.instance.viewContext = this.viewContext;\n                firstRootNode.replaceWith(componentRef.instance.nativeElement);\n                this.destroyView();\n                this.componentRef = componentRef;\n            }\n        }\n    }\n}"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-item.js","sourceRoot":"","sources":["../../../packages/src/view/container-item.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentFactoryResolver, ComponentRef, Directive, EmbeddedViewRef, Input, ViewContainerRef } from \"@angular/core\";\nimport { SlateBlockCardComponent } from \"../components/block-card/block-card.component\";\nimport { ViewType } from \"../types/view\";\nimport { isComponentType, isDOMElement, isTemplateRef } from \"../utils\";\nimport { BaseComponent, BaseEmbeddedView } from \"./base\";\nimport { SlateElementContext, SlateLeafContext, SlateStringContext, SlateTextContext, SlateViewContext } from \"./context\";\n\n/**\n * Dynamically create/update components or templates\n * Provide rootNodes for the view container\n * If the dynamically created component uses onpush mode, then it must call markForCheck when setting the context\n */\n@Directive()\nexport abstract class ViewContainerItem<T = SlateElementContext | SlateTextContext | SlateLeafContext | SlateStringContext, K extends BaseComponent<T> = BaseComponent<T>> {\n    initialized = false;\n    embeddedViewRef: EmbeddedViewRef<BaseEmbeddedView<T>>;\n    embeddedViewContext: BaseEmbeddedView<T>;\n    blockCardComponentRef: ComponentRef<SlateBlockCardComponent>;\n    componentRef: ComponentRef<K>;\n    viewType: ViewType;\n\n    @Input() viewContext: SlateViewContext;\n\n    get rootNodes() {\n        return this.getRootNodes();\n    }\n\n    getRootNodes(): HTMLElement[] {\n        if (this.embeddedViewRef) {\n            return this.embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode));\n        }\n        if (this.componentRef) {\n            return [this.componentRef.instance.nativeElement];\n        }\n        return [];\n    }\n\n    constructor(\n        protected viewContainerRef: ViewContainerRef,\n        protected componentFactoryResolver: ComponentFactoryResolver\n    ) { }\n\n    destroyView() {\n        if (this.embeddedViewRef) {\n            this.embeddedViewRef.destroy();\n            this.embeddedViewRef = null;\n        }\n        if (this.componentRef) {\n            this.componentRef.destroy();\n            this.componentRef = null;\n        }\n    }\n\n    abstract getContext(): T;\n\n    abstract getViewType(): ViewType;\n\n    abstract memoizedContext(prev: T, next: T): boolean;\n\n    createView() {\n        this.initialized = true;\n        this.viewType = this.getViewType();\n        const context = this.getContext();\n        if (isTemplateRef(this.viewType)) {\n            this.embeddedViewContext = { context, viewContext: this.viewContext };\n            const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n            this.embeddedViewRef = embeddedViewRef;\n        }\n        if (isComponentType(this.viewType)) {\n            const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n            const componentRef = this.viewContainerRef.createComponent(componentFactory);\n            componentRef.instance.context = context;\n            componentRef.instance.viewContext = this.viewContext;\n            this.componentRef = componentRef;\n        }\n    }\n\n    updateView() {\n        const viewType = this.getViewType();\n        const context = this.getContext();\n        if (this.viewType === viewType) {\n            if (this.componentRef) {\n                if (this.memoizedContext(this.componentRef.instance.context, context)) {\n                    return;\n                }\n                this.componentRef.instance.context = context;\n            }\n            if (this.embeddedViewRef) {\n                if (this.memoizedContext(this.embeddedViewContext.context, context)) {\n                    return;\n                }\n                this.embeddedViewContext.context = context;\n            }\n        } else {\n            this.viewType = viewType;\n            const firstRootNode = this.rootNodes[0];\n            if (isTemplateRef(this.viewType)) {\n                this.embeddedViewContext = { context, viewContext: this.viewContext };\n                const embeddedViewRef = this.viewContainerRef.createEmbeddedView<BaseEmbeddedView<T>>(this.viewType, this.embeddedViewContext);\n                firstRootNode.replaceWith(...embeddedViewRef.rootNodes.filter((rootNode) => isDOMElement(rootNode)));\n                this.destroyView();\n                this.embeddedViewRef = embeddedViewRef;\n            }\n            if (isComponentType(this.viewType)) {\n                const componentFactory = this.componentFactoryResolver.resolveComponentFactory<K>(this.viewType);\n                const componentRef = this.viewContainerRef.createComponent(componentFactory);\n                componentRef.instance.context = context;\n                componentRef.instance.viewContext = this.viewContext;\n                firstRootNode.replaceWith(componentRef.instance.nativeElement);\n                this.destroyView();\n                this.componentRef = componentRef;\n            }\n        }\n    }\n\n    appendBlockCardElement() {\n        if (this.blockCardComponentRef) {\n            this.blockCardComponentRef.instance.append();\n        }\n    }\n}"]}
@@ -88,6 +88,8 @@ export class ViewContainer {
88
88
  });
89
89
  }
90
90
  }
91
+ // Solve the block-card DOMElement loss when moving nodes
92
+ record.item.appendBlockCardElement();
91
93
  }
92
94
  }
93
95
  ViewContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainer, deps: [{ token: i0.ElementRef }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Directive });
@@ -97,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
97
99
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.IterableDiffers }]; }, propDecorators: { viewContext: [{
98
100
  type: Input
99
101
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../packages/src/view/container.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, Input, IterableChangeRecord, IterableDiffers, QueryList } from \"@angular/core\";\nimport { SlateViewContext } from \"./context\";\nimport { ViewContainerItem } from \"./container-item\";\nimport { SlateErrorCode } from \"../types/error\";\n\n/**\n * the sepcial container for angular template\n * Add the rootNodes of each child component to the parentElement\n * Remove useless DOM elements, eg: comment...\n */\n@Directive()\nexport abstract class ViewContainer<T extends ViewContainerItem> implements AfterViewInit {\n    abstract childrenComponent: QueryList<T>;\n\n    @Input() viewContext: SlateViewContext;\n\n    constructor(protected elementRef: ElementRef<any>,\n        protected differs: IterableDiffers) {\n    }\n\n    ngAfterViewInit() {\n        const differ = this.differs.find(this.childrenComponent).create((index, item) => {\n            return item;\n        });\n        // first diff\n        differ.diff(this.childrenComponent);\n        const parentElement: HTMLElement = this.elementRef.nativeElement.parentElement;\n        if (this.childrenComponent.length > 0) {\n            parentElement.insertBefore(this.createFragment(), this.elementRef.nativeElement);\n            this.elementRef.nativeElement.remove();\n        }\n        this.childrenComponent.changes.subscribe((value) => {\n            const iterableChanges = differ.diff(this.childrenComponent);\n            if (iterableChanges) {\n                iterableChanges.forEachOperation((record: IterableChangeRecord<T>, previousIndex: Number, currentIndex: number) => {\n                    // removed\n                    if (currentIndex === null) {\n                        return;\n                    }\n                    // added or moved\n                    this.handleContainerItemChange(record, parentElement);\n                });\n            }\n        });\n    }\n\n    getPreviousRootNode(currentIndex) {\n        if (currentIndex === 0) {\n            return null;\n        }\n        const previousComponent = this.childrenComponent.find((item, index) => index === currentIndex - 1);\n        let previousRootNode = previousComponent.rootNodes[previousComponent.rootNodes.length - 1];\n        if (previousRootNode) {\n            return previousRootNode;\n        } else {\n            return this.getPreviousRootNode(currentIndex - 1);\n        }\n    }\n\n    createFragment() {\n        const fragment = document.createDocumentFragment();\n        this.childrenComponent.forEach((component, index) => {\n            fragment.append(...component.rootNodes);\n        })\n        return fragment;\n    }\n\n    handleContainerItemChange(record: IterableChangeRecord<T>, parentElement: HTMLElement) {\n        // first insert\n        if (this.elementRef.nativeElement.parentElement && this.elementRef.nativeElement.parentElement === parentElement) {\n            const fragment = document.createDocumentFragment();\n            fragment.append(...record.item.rootNodes);\n            parentElement.insertBefore(fragment, this.elementRef.nativeElement);\n            this.elementRef.nativeElement.remove();\n            return;\n        }\n        // insert at start location\n        if (record.currentIndex === 0) {\n            const fragment = document.createDocumentFragment();\n            fragment.append(...record.item.rootNodes);\n            parentElement.prepend(fragment);\n        } else {\n            // insert afterend of previous component end\n            let previousRootNode = this.getPreviousRootNode(record.currentIndex);\n            if (previousRootNode) {\n                record.item.rootNodes.forEach((rootNode) => {\n                    previousRootNode.insertAdjacentElement('afterend', rootNode);\n                    previousRootNode = rootNode;\n                });\n            } else {\n                this.viewContext.editor.onError({\n                    code: SlateErrorCode.NotFoundPreviousRootNodeError,\n                    name: 'not found previous rootNode',\n                    nativeError: null\n                })\n            }\n        }\n    }\n}"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../../packages/src/view/container.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, Input, IterableChangeRecord, IterableDiffers, QueryList } from \"@angular/core\";\nimport { SlateViewContext } from \"./context\";\nimport { ViewContainerItem } from \"./container-item\";\nimport { SlateErrorCode } from \"../types/error\";\n\n/**\n * the sepcial container for angular template\n * Add the rootNodes of each child component to the parentElement\n * Remove useless DOM elements, eg: comment...\n */\n@Directive()\nexport abstract class ViewContainer<T extends ViewContainerItem> implements AfterViewInit {\n    abstract childrenComponent: QueryList<T>;\n\n    @Input() viewContext: SlateViewContext;\n\n    constructor(protected elementRef: ElementRef<any>,\n        protected differs: IterableDiffers) {\n    }\n\n    ngAfterViewInit() {\n        const differ = this.differs.find(this.childrenComponent).create((index, item) => {\n            return item;\n        });\n        // first diff\n        differ.diff(this.childrenComponent);\n        const parentElement: HTMLElement = this.elementRef.nativeElement.parentElement;\n        if (this.childrenComponent.length > 0) {\n            parentElement.insertBefore(this.createFragment(), this.elementRef.nativeElement);\n            this.elementRef.nativeElement.remove();\n        }\n        this.childrenComponent.changes.subscribe((value) => {\n            const iterableChanges = differ.diff(this.childrenComponent);\n            if (iterableChanges) {\n                iterableChanges.forEachOperation((record: IterableChangeRecord<T>, previousIndex: Number, currentIndex: number) => {\n                    // removed\n                    if (currentIndex === null) {\n                        return;\n                    }\n                    // added or moved\n                    this.handleContainerItemChange(record, parentElement);\n                });\n            }\n        });\n    }\n\n    getPreviousRootNode(currentIndex) {\n        if (currentIndex === 0) {\n            return null;\n        }\n        const previousComponent = this.childrenComponent.find((item, index) => index === currentIndex - 1);\n        let previousRootNode = previousComponent.rootNodes[previousComponent.rootNodes.length - 1];\n        if (previousRootNode) {\n            return previousRootNode;\n        } else {\n            return this.getPreviousRootNode(currentIndex - 1);\n        }\n    }\n\n    createFragment() {\n        const fragment = document.createDocumentFragment();\n        this.childrenComponent.forEach((component, index) => {\n            fragment.append(...component.rootNodes);\n        })\n        return fragment;\n    }\n\n    handleContainerItemChange(record: IterableChangeRecord<T>, parentElement: HTMLElement) {\n        // first insert\n        if (this.elementRef.nativeElement.parentElement && this.elementRef.nativeElement.parentElement === parentElement) {\n            const fragment = document.createDocumentFragment();\n            fragment.append(...record.item.rootNodes);\n            parentElement.insertBefore(fragment, this.elementRef.nativeElement);\n            this.elementRef.nativeElement.remove();\n            return;\n        }\n        // insert at start location\n        if (record.currentIndex === 0) {\n            const fragment = document.createDocumentFragment();\n            fragment.append(...record.item.rootNodes);\n            parentElement.prepend(fragment);\n        } else {\n            // insert afterend of previous component end\n            let previousRootNode = this.getPreviousRootNode(record.currentIndex);\n            if (previousRootNode) {\n                record.item.rootNodes.forEach((rootNode) => {\n                    previousRootNode.insertAdjacentElement('afterend', rootNode);\n                    previousRootNode = rootNode;\n                });\n            } else {\n                this.viewContext.editor.onError({\n                    code: SlateErrorCode.NotFoundPreviousRootNodeError,\n                    name: 'not found previous rootNode',\n                    nativeError: null\n                })\n            }\n        }\n        // Solve the block-card DOMElement loss when moving nodes\n        record.item.appendBlockCardElement();\n    }\n}"]}
@@ -208,6 +208,33 @@ const getPlainText = (domNode) => {
208
208
  }
209
209
  return text;
210
210
  };
211
+ /**
212
+ * Get x-slate-fragment attribute from data-slate-fragment
213
+ */
214
+ const catchSlateFragment = /data-slate-fragment="(.+?)"/m;
215
+ const getSlateFragmentAttribute = (dataTransfer) => {
216
+ const htmlData = dataTransfer.getData('text/html');
217
+ const [, fragment] = htmlData.match(catchSlateFragment) || [];
218
+ return fragment;
219
+ };
220
+ /**
221
+ * Get the x-slate-fragment attribute that exist in text/html data
222
+ * and append it to the DataTransfer object
223
+ */
224
+ const getClipboardData = (dataTransfer, clipboardFormatKey = 'x-slate-fragment') => {
225
+ if (!dataTransfer.getData(`application/${clipboardFormatKey}`)) {
226
+ const fragment = getSlateFragmentAttribute(dataTransfer);
227
+ if (fragment) {
228
+ const clipboardData = new DataTransfer();
229
+ dataTransfer.types.forEach(type => {
230
+ clipboardData.setData(type, dataTransfer.getData(type));
231
+ });
232
+ clipboardData.setData(`application/${clipboardFormatKey}`, fragment);
233
+ return clipboardData;
234
+ }
235
+ }
236
+ return dataTransfer;
237
+ };
211
238
 
212
239
  /**
213
240
  * An auto-incrementing identifier for keys.
@@ -228,6 +255,7 @@ const IS_IOS = typeof navigator !== 'undefined' &&
228
255
  /iPad|iPhone|iPod/.test(navigator.userAgent) &&
229
256
  !window.MSStream;
230
257
  const IS_APPLE = typeof navigator !== 'undefined' && /Mac OS X/.test(navigator.userAgent);
258
+ const IS_ANDROID = typeof navigator !== 'undefined' && /Android/.test(navigator.userAgent);
231
259
  const IS_FIREFOX = typeof navigator !== 'undefined' &&
232
260
  /^(?!.*Seamonkey)(?=.*Firefox).*/i.test(navigator.userAgent);
233
261
  const IS_SAFARI = typeof navigator !== 'undefined' &&
@@ -239,6 +267,24 @@ const IS_CHROME = typeof navigator !== 'undefined' && /Chrome/i.test(navigator.u
239
267
  // Native beforeInput events don't work well with react on Chrome 75 and older, Chrome 76+ can use beforeInput
240
268
  const IS_CHROME_LEGACY = typeof navigator !== 'undefined' &&
241
269
  /Chrome?\/(?:[0-7][0-5]|[0-6][0-9])/i.test(navigator.userAgent);
270
+ // Firefox did not support `beforeInput` until `v87`.
271
+ const IS_FIREFOX_LEGACY = typeof navigator !== 'undefined' &&
272
+ /^(?!.*Seamonkey)(?=.*Firefox\/(?:[0-7][0-9]|[0-8][0-6])).*/i.test(navigator.userAgent);
273
+ // qq browser
274
+ const IS_QQBROWSER = typeof navigator !== 'undefined' && /.*QQBrowser/.test(navigator.userAgent);
275
+ // UC mobile browser
276
+ const IS_UC_MOBILE = typeof navigator !== 'undefined' && /.*UCBrowser/.test(navigator.userAgent);
277
+ // Wechat browser
278
+ const IS_WECHATBROWSER = typeof navigator !== 'undefined' && /.*Wechat/.test(navigator.userAgent);
279
+ // COMPAT: Firefox/Edge Legacy don't support the `beforeinput` event
280
+ // Chrome Legacy doesn't support `beforeinput` correctly
281
+ const HAS_BEFORE_INPUT_SUPPORT = !IS_CHROME_LEGACY &&
282
+ !IS_EDGE_LEGACY &&
283
+ // globalThis is undefined in older browsers
284
+ typeof globalThis !== 'undefined' &&
285
+ globalThis.InputEvent &&
286
+ // @ts-ignore The `getTargetRanges` property isn't recognized.
287
+ typeof globalThis.InputEvent.prototype.getTargetRanges === 'function';
242
288
 
243
289
  const FAKE_LEFT_BLOCK_CARD_OFFSET = -1;
244
290
  const FAKE_RIGHT_BLOCK_CARD_OFFSET = -2;
@@ -321,27 +367,16 @@ const AngularEditor = {
321
367
  throw new Error(`Unable to find the path for Slate node: ${JSON.stringify(node)}`);
322
368
  },
323
369
  /**
324
- * Find the DOM node that implements DocumentOrShadowRoot for the editor.
325
- */
370
+ * Find the DOM node that implements DocumentOrShadowRoot for the editor.
371
+ */
326
372
  findDocumentOrShadowRoot(editor) {
327
373
  const el = AngularEditor.toDOMNode(editor, editor);
328
374
  const root = el.getRootNode();
329
- // The below exception will always be thrown for iframes because the document inside an iframe
330
- // does not inherit it's prototype from the parent document, therefore we return early
331
- if (el.ownerDocument !== document) {
332
- return el.ownerDocument;
333
- }
334
- if (!(root instanceof Document || root instanceof ShadowRoot)) {
335
- throw new Error(`Unable to find DocumentOrShadowRoot for editor element: ${el}`);
336
- }
337
- // COMPAT: Only Chrome implements the DocumentOrShadowRoot mixin for
338
- // ShadowRoot; other browsers still implement it on the Document
339
- // interface. (2020/08/08)
340
- // https://developer.mozilla.org/en-US/docs/Web/API/ShadowRoot#Properties
341
- if (root.getSelection === undefined && el.ownerDocument !== null) {
342
- return el.ownerDocument;
343
- }
344
- return root;
375
+ if ((root instanceof Document || root instanceof ShadowRoot) &&
376
+ root.getSelection != null) {
377
+ return root;
378
+ }
379
+ return el.ownerDocument;
345
380
  },
346
381
  /**
347
382
  * Check if the editor is focused.
@@ -438,6 +473,18 @@ const AngularEditor = {
438
473
  insertData(editor, data) {
439
474
  editor.insertData(data);
440
475
  },
476
+ /**
477
+ * Insert fragment data from a `DataTransfer` into the editor.
478
+ */
479
+ insertFragmentData(editor, data) {
480
+ return editor.insertFragmentData(data);
481
+ },
482
+ /**
483
+ * Insert text data from a `DataTransfer` into the editor.
484
+ */
485
+ insertTextData(editor, data) {
486
+ return editor.insertTextData(data);
487
+ },
441
488
  /**
442
489
  * onKeydown hook.
443
490
  */
@@ -453,8 +500,8 @@ const AngularEditor = {
453
500
  /**
454
501
  * Sets data from the currently selected fragment on a `DataTransfer`.
455
502
  */
456
- setFragmentData(editor, data) {
457
- editor.setFragmentData(data);
503
+ setFragmentData(editor, data, originEvent) {
504
+ editor.setFragmentData(data, originEvent);
458
505
  },
459
506
  deleteCutData(editor) {
460
507
  editor.deleteCutData();
@@ -711,7 +758,9 @@ const AngularEditor = {
711
758
  // composition the ASCII characters will be prepended to the zero-width
712
759
  // space, so subtract 1 from the offset to account for the zero-width
713
760
  // space character.
714
- if (domNode && offset === domNode.textContent.length && parentNode && parentNode.hasAttribute('data-slate-zero-width')) {
761
+ if (domNode &&
762
+ offset === domNode.textContent.length &&
763
+ (parentNode && parentNode.hasAttribute('data-slate-zero-width'))) {
715
764
  offset--;
716
765
  }
717
766
  }
@@ -1053,12 +1102,17 @@ const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
1053
1102
  break;
1054
1103
  }
1055
1104
  case 'move_node': {
1056
- for (const [node, path] of Editor.levels(e, {
1057
- at: Path.common(Path.parent(op.path), Path.parent(op.newPath)),
1058
- })) {
1105
+ const commonPath = Path.common(Path.parent(op.path), Path.parent(op.newPath));
1106
+ for (const [node, path] of Editor.levels(e, { at: Path.parent(op.path) })) {
1059
1107
  const key = AngularEditor.findKey(e, node);
1060
1108
  matches.push([path, key]);
1061
1109
  }
1110
+ for (const [node, path] of Editor.levels(e, { at: Path.parent(op.newPath) })) {
1111
+ if (path.length > commonPath.length) {
1112
+ const key = AngularEditor.findKey(e, node);
1113
+ matches.push([path, key]);
1114
+ }
1115
+ }
1062
1116
  break;
1063
1117
  }
1064
1118
  }
@@ -1125,7 +1179,7 @@ const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
1125
1179
  // in the HTML, and can be used for intra-Slate pasting. If it's a text
1126
1180
  // node, wrap it in a `<span>` so we have something to set an attribute on.
1127
1181
  if (isDOMText(attach)) {
1128
- const span = document.createElement('span');
1182
+ const span = attach.ownerDocument.createElement('span');
1129
1183
  // COMPAT: In Chrome and Safari, if we don't add the `white-space` style
1130
1184
  // then leading and trailing spaces will be ignored. (2017/09/21)
1131
1185
  span.style.whiteSpace = 'pre';
@@ -1139,13 +1193,14 @@ const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
1139
1193
  attach.setAttribute('data-slate-fragment', encoded);
1140
1194
  data.setData(`application/${clipboardFormatKey}`, encoded);
1141
1195
  // Add the content to a <div> so that we can get its inner HTML.
1142
- const div = document.createElement('div');
1196
+ const div = contents.ownerDocument.createElement('div');
1143
1197
  div.appendChild(contents);
1144
1198
  div.setAttribute('hidden', 'true');
1145
- document.body.appendChild(div);
1199
+ contents.ownerDocument.body.appendChild(div);
1146
1200
  data.setData('text/html', div.innerHTML);
1147
1201
  data.setData('text/plain', getPlainText(div));
1148
- document.body.removeChild(div);
1202
+ contents.ownerDocument.body.removeChild(div);
1203
+ return data;
1149
1204
  };
1150
1205
  e.deleteCutData = () => {
1151
1206
  const { selection } = editor;
@@ -1162,13 +1217,25 @@ const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
1162
1217
  }
1163
1218
  };
1164
1219
  e.insertData = (data) => {
1165
- const fragment = data.getData(`application/${clipboardFormatKey}`);
1220
+ if (!e.insertFragmentData(data)) {
1221
+ e.insertTextData(data);
1222
+ }
1223
+ };
1224
+ e.insertFragmentData = (data) => {
1225
+ /**
1226
+ * Checking copied fragment from application/x-slate-fragment or data-slate-fragment
1227
+ */
1228
+ const fragment = data.getData(`application/${clipboardFormatKey}`) ||
1229
+ getSlateFragmentAttribute(data);
1166
1230
  if (fragment) {
1167
1231
  const decoded = decodeURIComponent(window.atob(fragment));
1168
1232
  const parsed = JSON.parse(decoded);
1169
1233
  e.insertFragment(parsed);
1170
- return;
1234
+ return true;
1171
1235
  }
1236
+ return false;
1237
+ };
1238
+ e.insertTextData = (data) => {
1172
1239
  const text = data.getData('text/plain');
1173
1240
  if (text) {
1174
1241
  const lines = text.split(/\r\n|\r|\n/);
@@ -1180,7 +1247,9 @@ const withAngular = (editor, clipboardFormatKey = 'x-slate-fragment') => {
1180
1247
  e.insertText(line);
1181
1248
  split = true;
1182
1249
  }
1250
+ return true;
1183
1251
  }
1252
+ return false;
1184
1253
  };
1185
1254
  e.onKeydown = () => { };
1186
1255
  e.onClick = () => { };
@@ -1551,12 +1620,16 @@ class SlateBlockCardComponent {
1551
1620
  get nativeElement() {
1552
1621
  return this.elementRef.nativeElement;
1553
1622
  }
1623
+ get centerContainerElement() {
1624
+ return this.centerContianer.nativeElement;
1625
+ }
1554
1626
  ngOnInit() {
1555
- const fragment = document.createDocumentFragment();
1556
- fragment.append(...this.centerRootNodes);
1557
- this.centerContianer.nativeElement.appendChild(fragment);
1627
+ this.append();
1558
1628
  this.nativeElement.classList.add(`slate-block-card`);
1559
1629
  }
1630
+ append() {
1631
+ this.centerRootNodes.forEach((rootNode) => !this.centerContainerElement.contains(rootNode) && this.centerContainerElement.appendChild(rootNode));
1632
+ }
1560
1633
  initializeCenter(rootNodes) {
1561
1634
  this.centerRootNodes = rootNodes;
1562
1635
  }
@@ -1662,6 +1735,11 @@ class ViewContainerItem {
1662
1735
  }
1663
1736
  }
1664
1737
  }
1738
+ appendBlockCardElement() {
1739
+ if (this.blockCardComponentRef) {
1740
+ this.blockCardComponentRef.instance.append();
1741
+ }
1742
+ }
1665
1743
  }
1666
1744
  ViewContainerItem.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainerItem, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Directive });
1667
1745
  ViewContainerItem.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.7", type: ViewContainerItem, inputs: { viewContext: "viewContext" }, ngImport: i0 });
@@ -1964,6 +2042,8 @@ class ViewContainer {
1964
2042
  });
1965
2043
  }
1966
2044
  }
2045
+ // Solve the block-card DOMElement loss when moving nodes
2046
+ record.item.appendBlockCardElement();
1967
2047
  }
1968
2048
  }
1969
2049
  ViewContainer.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.7", ngImport: i0, type: ViewContainer, deps: [{ token: i0.ElementRef }, { token: i0.IterableDiffers }], target: i0.ɵɵFactoryTarget.Directive });
@@ -2443,13 +2523,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
2443
2523
  }] } });
2444
2524
 
2445
2525
  const timeDebug = Debug('slate-angular-time');
2446
- // COMPAT: Firefox/Edge Legacy don't support the `beforeinput` event
2447
- // Chrome Legacy doesn't support `beforeinput` correctly
2448
- const HAS_BEFORE_INPUT_SUPPORT = !IS_CHROME_LEGACY &&
2449
- !IS_EDGE_LEGACY &&
2450
- globalThis.InputEvent &&
2451
- // @ts-ignore The `getTargetRanges` property isn't recognized.
2452
- typeof globalThis.InputEvent.prototype.getTargetRanges === 'function';
2453
2526
  // not correctly clipboardData on beforeinput
2454
2527
  const forceOnDOMPaste = IS_SAFARI;
2455
2528
  class SlateEditableComponent {
@@ -2624,6 +2697,9 @@ class SlateEditableComponent {
2624
2697
  domSelection.setBaseAndExtent(newDomRange.startContainer, newDomRange.startOffset, newDomRange.endContainer, newDomRange.endOffset);
2625
2698
  }
2626
2699
  }
2700
+ else {
2701
+ domSelection.removeAllRanges();
2702
+ }
2627
2703
  setTimeout(() => {
2628
2704
  // COMPAT: In Firefox, it's not enough to create a range, you also need
2629
2705
  // to focus the contenteditable element too. (2016/11/16)
@@ -2880,7 +2956,10 @@ class SlateEditableComponent {
2880
2956
  case 'insertFromYank':
2881
2957
  case 'insertReplacementText':
2882
2958
  case 'insertText': {
2883
- if (data instanceof DataTransfer) {
2959
+ // use a weak comparison instead of 'instanceof' to allow
2960
+ // programmatic access of paste events coming from external windows
2961
+ // like cypress where cy.window does not work realibly
2962
+ if ((data === null || data === void 0 ? void 0 : data.constructor.name) === 'DataTransfer') {
2884
2963
  AngularEditor.insertData(editor, data);
2885
2964
  }
2886
2965
  else if (typeof data === 'string') {
@@ -2992,13 +3071,13 @@ class SlateEditableComponent {
2992
3071
  const isOutsideSlate = !hasStringTarget(window.getSelection()) && isTargetInsideVoid(this.editor, event.target);
2993
3072
  if (!isOutsideSlate && hasTarget(this.editor, event.target) && !this.readonly && !this.isDOMEventHandled(event, this.copy)) {
2994
3073
  event.preventDefault();
2995
- AngularEditor.setFragmentData(this.editor, event.clipboardData);
3074
+ AngularEditor.setFragmentData(this.editor, event.clipboardData, 'copy');
2996
3075
  }
2997
3076
  }
2998
3077
  onDOMCut(event) {
2999
3078
  if (!this.readonly && hasEditableTarget(this.editor, event.target) && !this.isDOMEventHandled(event, this.cut)) {
3000
3079
  event.preventDefault();
3001
- AngularEditor.setFragmentData(this.editor, event.clipboardData);
3080
+ AngularEditor.setFragmentData(this.editor, event.clipboardData, 'cut');
3002
3081
  const { selection } = this.editor;
3003
3082
  if (selection) {
3004
3083
  AngularEditor.deleteCutData(this.editor);
@@ -3017,7 +3096,7 @@ class SlateEditableComponent {
3017
3096
  }
3018
3097
  }
3019
3098
  onDOMDragStart(event) {
3020
- if (hasTarget(this.editor, event.target) && !this.isDOMEventHandled(event, this.dragStart)) {
3099
+ if (!this.readonly && hasTarget(this.editor, event.target) && !this.isDOMEventHandled(event, this.dragStart)) {
3021
3100
  const node = AngularEditor.toSlateNode(this.editor, event.target);
3022
3101
  const path = AngularEditor.findPath(this.editor, node);
3023
3102
  const voidMatch = Editor.isVoid(this.editor, node) ||
@@ -3029,7 +3108,7 @@ class SlateEditableComponent {
3029
3108
  Transforms.select(this.editor, range);
3030
3109
  }
3031
3110
  this.isDraggingInternally = true;
3032
- AngularEditor.setFragmentData(this.editor, event.dataTransfer);
3111
+ AngularEditor.setFragmentData(this.editor, event.dataTransfer, 'drag');
3033
3112
  }
3034
3113
  }
3035
3114
  onDOMDrop(event) {
@@ -3572,5 +3651,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.7", ngImpor
3572
3651
  * Generated bundle index. Do not edit.
3573
3652
  */
3574
3653
 
3575
- export { AngularEditor, BaseComponent, BaseElementComponent, BaseLeafComponent, BaseTextComponent, DOMComment, DOMElement, DOMNode, DOMRange, DOMSelection, DOMStaticRange, DOMText, EDITOR_TO_ELEMENT, EDITOR_TO_ON_CHANGE, EDITOR_TO_PLACEHOLDER, EDITOR_TO_WINDOW, ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, FAKE_LEFT_BLOCK_CARD_OFFSET, FAKE_RIGHT_BLOCK_CARD_OFFSET, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_CLICKING, IS_DRAGGING, IS_EDGE_LEGACY, IS_FIREFOX, IS_FOCUSED, IS_IOS, IS_READONLY, IS_SAFARI, KEY_TO_ELEMENT, Key, NODE_TO_ELEMENT, NODE_TO_INDEX, NODE_TO_KEY, NODE_TO_PARENT, PLACEHOLDER_SYMBOL, SlateChildrenComponent, SlateEditableComponent, SlateElementComponent, SlateErrorCode, SlateLeavesComponent, SlateModule, SlateStringComponent, check, getCardTargetAttribute, getDefaultView, getEditableChild, getEditableChildAndIndex, getPlainText, hasBeforeContextChange, hasBlockCard, hasBlockCardWithNode, hasShadowRoot, hotkeys, isCardCenterByTargetAttr, isCardLeft, isCardLeftByTargetAttr, isCardRightByTargetAttr, isComponentType, isDOMComment, isDOMElement, isDOMNode, isDOMSelection, isDOMText, isDecoratorRangeListEqual, isPlainTextOnlyPaste, isTemplateRef, isValid, normalize, normalizeDOMPoint, shallowCompare, withAngular };
3654
+ export { AngularEditor, BaseComponent, BaseElementComponent, BaseLeafComponent, BaseTextComponent, DOMComment, DOMElement, DOMNode, DOMRange, DOMSelection, DOMStaticRange, DOMText, EDITOR_TO_ELEMENT, EDITOR_TO_ON_CHANGE, EDITOR_TO_PLACEHOLDER, EDITOR_TO_WINDOW, ELEMENT_TO_COMPONENT, ELEMENT_TO_NODE, FAKE_LEFT_BLOCK_CARD_OFFSET, FAKE_RIGHT_BLOCK_CARD_OFFSET, HAS_BEFORE_INPUT_SUPPORT, IS_ANDROID, IS_APPLE, IS_CHROME, IS_CHROME_LEGACY, IS_CLICKING, IS_DRAGGING, IS_EDGE_LEGACY, IS_FIREFOX, IS_FIREFOX_LEGACY, IS_FOCUSED, IS_IOS, IS_QQBROWSER, IS_READONLY, IS_SAFARI, IS_UC_MOBILE, IS_WECHATBROWSER, KEY_TO_ELEMENT, Key, NODE_TO_ELEMENT, NODE_TO_INDEX, NODE_TO_KEY, NODE_TO_PARENT, PLACEHOLDER_SYMBOL, SlateChildrenComponent, SlateEditableComponent, SlateElementComponent, SlateErrorCode, SlateLeavesComponent, SlateModule, SlateStringComponent, check, getCardTargetAttribute, getClipboardData, getDefaultView, getEditableChild, getEditableChildAndIndex, getPlainText, getSlateFragmentAttribute, hasBeforeContextChange, hasBlockCard, hasBlockCardWithNode, hasShadowRoot, hotkeys, isCardCenterByTargetAttr, isCardLeft, isCardLeftByTargetAttr, isCardRightByTargetAttr, isComponentType, isDOMComment, isDOMElement, isDOMNode, isDOMSelection, isDOMText, isDecoratorRangeListEqual, isPlainTextOnlyPaste, isTemplateRef, isValid, normalize, normalizeDOMPoint, shallowCompare, withAngular };
3576
3655
  //# sourceMappingURL=slate-angular.js.map