@adaptabletools/adaptable
Version:
Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements
39 lines (38 loc) • 1.59 kB
JavaScript
import * as React from 'react';
import SimpleButton from '../SimpleButton';
import { useExpressionEditor } from './EditorContext';
let dragImage;
const DRAG_IMAGE_SRC = 'data:image/gif;base64,R0lGODlhAQABAIAAAAUEBAAAACwAAAAAAQABAAACAkQBADs=';
function EditorButton(props) {
const { data, ...buttonProps } = props;
const { textAreaRef } = useExpressionEditor();
return (React.createElement(SimpleButton, { "data-name": 'operator-or-fn', variant: "text", draggable: true, onDragStart: (event) => {
if (!dragImage) {
// we want to lazy init the image since otherwise it fails in SSR environments if it is declared outside the cmp - ReferenceError: Image is not defined
dragImage = new Image(0, 0);
dragImage.src = DRAG_IMAGE_SRC;
}
document.getSelection().empty();
event.dataTransfer.setData('text', data + ' ');
event.dataTransfer.setDragImage(dragImage, 0, 0);
}, onDragEnd: () => {
try {
document.getSelection()?.collapseToEnd();
}
catch (err) {
console.error(err);
}
}, onClick: () => {
textAreaRef.current?.focus();
try {
document.execCommand('insertText', false, data + ' ');
document.getSelection()?.collapseToEnd();
}
catch (err) {
console.error(err);
}
}, style: {
cursor: 'grab',
}, ...buttonProps }));
}
export default EditorButton;