44 lines
1.3 KiB
TypeScript
44 lines
1.3 KiB
TypeScript
|
import { ViewPlugin, ViewUpdate } from "@codemirror/view";
|
||
|
|
||
|
const urlRegexp =
|
||
|
/^https?:\/\/[-a-zA-Z0-9@:%._\+~#=]{1,256}([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/;
|
||
|
|
||
|
export const pasteLinkExtension = ViewPlugin.fromClass(
|
||
|
class {
|
||
|
update(update: ViewUpdate): void {
|
||
|
update.transactions.forEach((tr) => {
|
||
|
if (tr.isUserEvent("input.paste")) {
|
||
|
let pastedText: string[] = [];
|
||
|
let from = 0;
|
||
|
let to = 0;
|
||
|
tr.changes.iterChanges((fromA, toA, fromB, toB, inserted) => {
|
||
|
pastedText.push(inserted.sliceString(0));
|
||
|
from = fromA;
|
||
|
to = toB;
|
||
|
});
|
||
|
let pastedString = pastedText.join("");
|
||
|
if (pastedString.match(urlRegexp)) {
|
||
|
let selection = update.startState.selection.main;
|
||
|
if (!selection.empty) {
|
||
|
setTimeout(() => {
|
||
|
update.view.dispatch({
|
||
|
changes: [
|
||
|
{
|
||
|
from: from,
|
||
|
to: to,
|
||
|
insert: `[${update.startState.sliceDoc(
|
||
|
selection.from,
|
||
|
selection.to
|
||
|
)}](${pastedString})`,
|
||
|
},
|
||
|
],
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
);
|