@atlaskit/editor-common
Version:
A package that contains common classes and components for editor and renderer
49 lines (48 loc) • 2.64 kB
JavaScript
import { DOMSerializer } from '@atlaskit/editor-prosemirror/model';
import { NodeSelection } from '@atlaskit/editor-prosemirror/state';
import { findParentNodeOfType, findSelectedNodeOfType } from '@atlaskit/editor-prosemirror/utils';
import { copyHTMLToClipboard, copyHTMLToClipboardPolyfill } from '../clipboard';
import { getBrowserInfo } from '../utils/browser';
export function getSelectedNodeOrNodeParentByNodeType(_ref) {
var nodeType = _ref.nodeType,
selection = _ref.selection;
var node = findSelectedNodeOfType(nodeType)(selection);
if (!node) {
node = findParentNodeOfType(nodeType)(selection);
}
return node;
}
export var toDOM = function toDOM(node, schema) {
return DOMSerializer.fromSchema(schema).serializeNode(node);
};
export var copyDomNode = function copyDomNode(domNode, nodeType, selection) {
if (domNode) {
var div = document.createElement('div');
div.appendChild(domNode);
var schema = selection.$from.doc.type.schema;
var browser = getBrowserInfo();
// if copying inline content
if (nodeType.inlineContent) {
// The "1 1" refers to the start and end depth of the slice
// since we're copying the text inside a paragraph, it will always be 1 1
// https://github.com/ProseMirror/prosemirror-view/blob/master/src/clipboard.ts#L32
// Ignored via go/ees005
// eslint-disable-next-line @atlaskit/editor/no-as-casting
div.firstChild.setAttribute('data-pm-slice', '1 1 []');
} else {
// The "0 0" refers to the start and end depth of the slice
// since we're copying the block node only, it will always be 0 0
// https://github.com/ProseMirror/prosemirror-view/blob/master/src/clipboard.ts#L32
// Ignored via go/ees005
// eslint-disable-next-line @atlaskit/editor/no-as-casting
div.firstChild.setAttribute('data-pm-slice', '0 0 []');
}
// ED-17083 safari seems have bugs for extension copy because exntension do not have a child text(innerText) and it will not recognized as html in clipboard, this could be merge into one if this extension fixed children issue or safari fix the copy bug
// MEX-2528 safari has a bug related to the mediaSingle node with border or link. The image tag within the clipboard is not recognized as HTML when using the ClipboardItem API. To address this, we have to switch to ClipboardPolyfill
if (browser.safari && selection instanceof NodeSelection && (selection.node.type === schema.nodes.extension || selection.node.type === schema.nodes.mediaSingle)) {
copyHTMLToClipboardPolyfill(div);
} else {
copyHTMLToClipboard(div);
}
}
};