@uiw/react-md-editor
Version:
A markdown editor with preview, implemented with React.js and TypeScript.
38 lines (36 loc) • 1.28 kB
JavaScript
import * as React from 'react';
import { selectWord } from '../utils/markdownUtils';
import { jsx as _jsx } from "react/jsx-runtime";
export var image = {
name: 'image',
keyCommand: 'image',
shortcuts: 'ctrlcmd+i',
buttonProps: {
'aria-label': 'Add image',
title: 'Add image'
},
icon: /*#__PURE__*/_jsx("svg", {
width: "12",
height: "12",
viewBox: "0 0 20 20",
children: /*#__PURE__*/_jsx("path", {
fill: "currentColor",
d: "M15 9c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm4-7H1c-.55 0-1 .45-1 1v14c0 .55.45 1 1 1h18c.55 0 1-.45 1-1V3c0-.55-.45-1-1-1zm-1 13l-6-5-2 2-4-5-4 8V4h16v11z"
})
}),
execute: (state, api) => {
// Select everything
var newSelectionRange = selectWord({
text: state.text,
selection: state.selection
});
var state1 = api.setSelectionRange(newSelectionRange); // Replaces the current selection with the image
var imageTemplate = state1.selectedText || 'https://example.com/your-image.png';
api.replaceSelection(""); // Adjust the selection to not contain the **
api.setSelectionRange({
start: 4 + state1.selection.start,
end: 4 + state1.selection.start + imageTemplate.length
});
}
};
//# sourceMappingURL=image.js.map