rme 0.3.0-beta.4 → 0.3.0-beta.6
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.
- package/dist/index.d.ts +7 -0
- package/dist/index.mjs +115 -68
- package/dist/index.mjs.map +4 -4
- package/package.json +7 -7
package/dist/index.d.ts
CHANGED
|
@@ -237,6 +237,12 @@ declare const createSourceCodeDelegate: (options?: CreateSourceCodeManagerOption
|
|
|
237
237
|
|
|
238
238
|
declare const _default$1: react__default.NamedExoticComponent<EditorProps>;
|
|
239
239
|
|
|
240
|
+
type ClipboardReadFunction = typeof clipboardRead;
|
|
241
|
+
declare function clipboardRead(): Promise<{
|
|
242
|
+
html: string;
|
|
243
|
+
text: string;
|
|
244
|
+
}>;
|
|
245
|
+
|
|
240
246
|
interface AIOptions {
|
|
241
247
|
defaultSelectProvider?: string;
|
|
242
248
|
supportProviderInfosMap: Record<string, {
|
|
@@ -389,6 +395,7 @@ type ExtensionsOptions = {
|
|
|
389
395
|
ai?: AIOptions;
|
|
390
396
|
customCopyFunction?: CustomCopyFunction;
|
|
391
397
|
overrideShortcutMap?: Record<string, string>;
|
|
398
|
+
clipboardReadFunction?: ClipboardReadFunction;
|
|
392
399
|
};
|
|
393
400
|
declare function extensions(options: ExtensionsOptions): any[];
|
|
394
401
|
|
package/dist/index.mjs
CHANGED
|
@@ -3433,6 +3433,33 @@ import { CountExtension } from "@rme-sdk/extension-count";
|
|
|
3433
3433
|
import { corePreset } from "@rme-sdk/preset-core";
|
|
3434
3434
|
import { ReactComponentExtension } from "@rme-sdk/react";
|
|
3435
3435
|
|
|
3436
|
+
// src/editor/utils/clipboard-read.ts
|
|
3437
|
+
function clipboardRead() {
|
|
3438
|
+
return navigator.clipboard.read().then(async (data) => {
|
|
3439
|
+
let html2 = "";
|
|
3440
|
+
let text = "";
|
|
3441
|
+
const htmlData = data.find((item) => item.types.includes("text/html"));
|
|
3442
|
+
const textData = data.find((item) => item.types.includes("text/plain"));
|
|
3443
|
+
const getHtml = async () => {
|
|
3444
|
+
if (htmlData) {
|
|
3445
|
+
const blob = await htmlData.getType("text/html");
|
|
3446
|
+
html2 = await blob.text();
|
|
3447
|
+
}
|
|
3448
|
+
};
|
|
3449
|
+
const getText = async () => {
|
|
3450
|
+
if (textData) {
|
|
3451
|
+
const blob = await textData.getType("text/plain");
|
|
3452
|
+
text = await blob.text();
|
|
3453
|
+
}
|
|
3454
|
+
};
|
|
3455
|
+
await Promise.all([getHtml(), getText()]);
|
|
3456
|
+
return {
|
|
3457
|
+
html: html2,
|
|
3458
|
+
text
|
|
3459
|
+
};
|
|
3460
|
+
});
|
|
3461
|
+
}
|
|
3462
|
+
|
|
3436
3463
|
// src/editor/extensions/Ai/ai-extension.tsx
|
|
3437
3464
|
import { extension, ExtensionTag, NodeExtension } from "@rme-sdk/core";
|
|
3438
3465
|
import { TextSelection as TextSelection3 } from "@rme-sdk/pm/state";
|
|
@@ -3827,6 +3854,71 @@ function isTextOnlySlice(slice) {
|
|
|
3827
3854
|
return false;
|
|
3828
3855
|
}
|
|
3829
3856
|
var ClipboardExtension = class extends PlainExtension2 {
|
|
3857
|
+
constructor() {
|
|
3858
|
+
super(...arguments);
|
|
3859
|
+
this.handleClipboardData = async ({
|
|
3860
|
+
html: html2 = "",
|
|
3861
|
+
text = "",
|
|
3862
|
+
view
|
|
3863
|
+
}) => {
|
|
3864
|
+
const editable = view.props.editable?.(view.state);
|
|
3865
|
+
if (!editable) return false;
|
|
3866
|
+
const currentNode = view.state.selection.$from.node();
|
|
3867
|
+
if (currentNode.type.spec.code) return false;
|
|
3868
|
+
if (html2.length === 0 && text.length === 0) return false;
|
|
3869
|
+
console.log("html", html2);
|
|
3870
|
+
console.log("text", text);
|
|
3871
|
+
const transformer = getTransformerByView(view);
|
|
3872
|
+
const parser = transformer.stringToDoc;
|
|
3873
|
+
const schema = view.state.schema;
|
|
3874
|
+
const domParser = DOMParser2.fromSchema(schema);
|
|
3875
|
+
let dom;
|
|
3876
|
+
if (html2.length === 0) {
|
|
3877
|
+
const slice2 = parser?.(text);
|
|
3878
|
+
if (!slice2 || typeof slice2 === "string") return false;
|
|
3879
|
+
const res = [];
|
|
3880
|
+
slice2.content.forEach((node2, index) => {
|
|
3881
|
+
if (node2.type.name === "paragraph" && index === 0) {
|
|
3882
|
+
node2.content.forEach((child) => {
|
|
3883
|
+
res.push(child);
|
|
3884
|
+
});
|
|
3885
|
+
} else {
|
|
3886
|
+
res.push(node2);
|
|
3887
|
+
}
|
|
3888
|
+
});
|
|
3889
|
+
this.processImagesInNodesAsync(res, view);
|
|
3890
|
+
if (res.length === 1) {
|
|
3891
|
+
view.dispatch(view.state.tr.replaceSelectionWith(res[0], false));
|
|
3892
|
+
} else {
|
|
3893
|
+
const fragment = Fragment3.from(res);
|
|
3894
|
+
view.dispatch(view.state.tr.replaceSelection(new Slice(fragment, 0, 0)));
|
|
3895
|
+
}
|
|
3896
|
+
return true;
|
|
3897
|
+
} else {
|
|
3898
|
+
const template = document.createElement("template");
|
|
3899
|
+
template.innerHTML = html2;
|
|
3900
|
+
dom = template.content.cloneNode(true);
|
|
3901
|
+
template.remove();
|
|
3902
|
+
}
|
|
3903
|
+
const slice = domParser.parseSlice(dom);
|
|
3904
|
+
const node = isTextOnlySlice(slice);
|
|
3905
|
+
console.log("slice", slice, node);
|
|
3906
|
+
if (node) {
|
|
3907
|
+
if ((node.type.name === "html_image" || node.type.name === "md_image") && node.attrs.src) {
|
|
3908
|
+
this.processImageNode(node, view);
|
|
3909
|
+
view.dispatch(view.state.tr.replaceSelectionWith(node, true));
|
|
3910
|
+
} else {
|
|
3911
|
+
this.processMarkdownImageSyntax(node, view).then(() => {
|
|
3912
|
+
view.dispatch(view.state.tr.replaceSelectionWith(node, true));
|
|
3913
|
+
});
|
|
3914
|
+
}
|
|
3915
|
+
return true;
|
|
3916
|
+
}
|
|
3917
|
+
this.processImagesInSliceAsync(slice, view);
|
|
3918
|
+
view.dispatch(view.state.tr.replaceSelection(slice));
|
|
3919
|
+
return true;
|
|
3920
|
+
};
|
|
3921
|
+
}
|
|
3830
3922
|
get name() {
|
|
3831
3923
|
return "clipboard";
|
|
3832
3924
|
}
|
|
@@ -3834,62 +3926,13 @@ var ClipboardExtension = class extends PlainExtension2 {
|
|
|
3834
3926
|
return {
|
|
3835
3927
|
props: {
|
|
3836
3928
|
handlePaste: (view, event) => {
|
|
3837
|
-
console.log("handlePaste", event);
|
|
3838
|
-
const transformer = getTransformerByView(view);
|
|
3839
|
-
const parser = transformer.stringToDoc;
|
|
3840
|
-
const schema = view.state.schema;
|
|
3841
|
-
const editable = view.props.editable?.(view.state);
|
|
3842
3929
|
const { clipboardData } = event;
|
|
3843
|
-
if (!
|
|
3930
|
+
if (!clipboardData) return false;
|
|
3844
3931
|
const currentNode = view.state.selection.$from.node();
|
|
3845
3932
|
if (currentNode.type.spec.code) return false;
|
|
3846
3933
|
const text = clipboardData.getData("text/plain");
|
|
3847
3934
|
const html2 = clipboardData.getData("text/html");
|
|
3848
|
-
|
|
3849
|
-
const domParser = DOMParser2.fromSchema(schema);
|
|
3850
|
-
let dom;
|
|
3851
|
-
if (html2.length === 0) {
|
|
3852
|
-
const slice2 = parser?.(text);
|
|
3853
|
-
if (!slice2 || typeof slice2 === "string") return false;
|
|
3854
|
-
const res = [];
|
|
3855
|
-
slice2.content.forEach((node2, index) => {
|
|
3856
|
-
if (node2.type.name === "paragraph" && index === 0) {
|
|
3857
|
-
node2.content.forEach((child) => {
|
|
3858
|
-
res.push(child);
|
|
3859
|
-
});
|
|
3860
|
-
} else {
|
|
3861
|
-
res.push(node2);
|
|
3862
|
-
}
|
|
3863
|
-
});
|
|
3864
|
-
this.processImagesInNodesAsync(res, view);
|
|
3865
|
-
if (res.length === 1) {
|
|
3866
|
-
view.dispatch(view.state.tr.replaceSelectionWith(res[0], false));
|
|
3867
|
-
} else {
|
|
3868
|
-
const fragment = Fragment3.from(res);
|
|
3869
|
-
view.dispatch(view.state.tr.replaceSelection(new Slice(fragment, 0, 0)));
|
|
3870
|
-
}
|
|
3871
|
-
return true;
|
|
3872
|
-
} else {
|
|
3873
|
-
const template = document.createElement("template");
|
|
3874
|
-
template.innerHTML = html2;
|
|
3875
|
-
dom = template.content.cloneNode(true);
|
|
3876
|
-
template.remove();
|
|
3877
|
-
}
|
|
3878
|
-
const slice = domParser.parseSlice(dom);
|
|
3879
|
-
const node = isTextOnlySlice(slice);
|
|
3880
|
-
if (node) {
|
|
3881
|
-
if ((node.type.name === "html_image" || node.type.name === "md_image") && node.attrs.src) {
|
|
3882
|
-
this.processImageNode(node, view);
|
|
3883
|
-
view.dispatch(view.state.tr.replaceSelectionWith(node, true));
|
|
3884
|
-
} else {
|
|
3885
|
-
this.processMarkdownImageSyntax(node, view).then(() => {
|
|
3886
|
-
view.dispatch(view.state.tr.replaceSelectionWith(node, true));
|
|
3887
|
-
});
|
|
3888
|
-
}
|
|
3889
|
-
return true;
|
|
3890
|
-
}
|
|
3891
|
-
this.processImagesInSliceAsync(slice, view);
|
|
3892
|
-
view.dispatch(view.state.tr.replaceSelection(slice));
|
|
3935
|
+
this.handleClipboardData({ text, html: html2, view });
|
|
3893
3936
|
return true;
|
|
3894
3937
|
},
|
|
3895
3938
|
clipboardTextSerializer: (slice, view) => {
|
|
@@ -3922,13 +3965,16 @@ var ClipboardExtension = class extends PlainExtension2 {
|
|
|
3922
3965
|
},
|
|
3923
3966
|
paste: () => {
|
|
3924
3967
|
return (params) => {
|
|
3925
|
-
|
|
3968
|
+
const { view } = params;
|
|
3969
|
+
if (!view) return false;
|
|
3970
|
+
if (!this.options.clipboardReadFunction) {
|
|
3926
3971
|
return false;
|
|
3927
3972
|
}
|
|
3928
|
-
|
|
3929
|
-
|
|
3930
|
-
|
|
3931
|
-
|
|
3973
|
+
this.options.clipboardReadFunction().then(async (data) => {
|
|
3974
|
+
let { html: html2, text } = data;
|
|
3975
|
+
if (!html2 || !text) return false;
|
|
3976
|
+
return await this.handleClipboardData({ html: html2, text, view });
|
|
3977
|
+
});
|
|
3932
3978
|
return true;
|
|
3933
3979
|
};
|
|
3934
3980
|
},
|
|
@@ -3984,13 +4030,13 @@ var ClipboardExtension = class extends PlainExtension2 {
|
|
|
3984
4030
|
imageCopyHandler(node.attrs.src).then((newSrc) => {
|
|
3985
4031
|
if (newSrc && newSrc !== node.attrs.src) {
|
|
3986
4032
|
this.updateImageNodeSrc(view, node, newSrc);
|
|
3987
|
-
} else {
|
|
3988
|
-
const { state, dispatch } = view;
|
|
3989
|
-
node.attrs["data-rme-loading"] = null;
|
|
3990
|
-
dispatch(state.tr);
|
|
3991
4033
|
}
|
|
3992
4034
|
}).catch((error) => {
|
|
3993
4035
|
console.warn("imageCopyHandler failed:", error);
|
|
4036
|
+
}).finally(() => {
|
|
4037
|
+
const { state, dispatch } = view;
|
|
4038
|
+
node.attrs["data-rme-loading"] = null;
|
|
4039
|
+
dispatch(state.tr);
|
|
3994
4040
|
});
|
|
3995
4041
|
}
|
|
3996
4042
|
/**
|
|
@@ -6771,8 +6817,8 @@ import { jsx as jsx14 } from "react/jsx-runtime";
|
|
|
6771
6817
|
var warningFallBack = "";
|
|
6772
6818
|
function ImageNodeView(props) {
|
|
6773
6819
|
const { node, selected, updateAttributes, handleViewImgSrcUrl, imageHostingHandler } = props;
|
|
6774
|
-
const initRef = useRef7();
|
|
6775
|
-
const popoverStore = useRef7();
|
|
6820
|
+
const initRef = useRef7(null);
|
|
6821
|
+
const popoverStore = useRef7(null);
|
|
6776
6822
|
const popoverRef = useRef7(null);
|
|
6777
6823
|
const handleStoreChange = (store) => {
|
|
6778
6824
|
popoverStore.current = store;
|
|
@@ -6831,10 +6877,10 @@ function ImageNodeView(props) {
|
|
|
6831
6877
|
});
|
|
6832
6878
|
},
|
|
6833
6879
|
...node.attrs
|
|
6834
|
-
}
|
|
6880
|
+
},
|
|
6881
|
+
`${node.attrs.src}_${node.attrs["data-rme-loading"]}`
|
|
6835
6882
|
)
|
|
6836
|
-
}
|
|
6837
|
-
`${node.attrs.src}_${node.attrs["data-rme-loading"]}`
|
|
6883
|
+
}
|
|
6838
6884
|
);
|
|
6839
6885
|
return /* @__PURE__ */ jsx14("div", { ref: popoverRef, style: { position: "relative", zIndex: selected ? 10 : "auto" }, children: /* @__PURE__ */ jsx14(
|
|
6840
6886
|
Popover2,
|
|
@@ -8956,7 +9002,6 @@ var MathInlineView = class {
|
|
|
8956
9002
|
}
|
|
8957
9003
|
this._renderElt.replaceWith(newRenderEl);
|
|
8958
9004
|
this._renderElt = newRenderEl;
|
|
8959
|
-
console.log("this.renderElt", this._renderElt.outerHTML);
|
|
8960
9005
|
this.dom.appendChild(this._renderElt);
|
|
8961
9006
|
if (preview) {
|
|
8962
9007
|
this._renderElt.classList.add("inline-input-preview");
|
|
@@ -10211,7 +10256,8 @@ function extensions(options) {
|
|
|
10211
10256
|
handleViewImgSrcUrl,
|
|
10212
10257
|
imageHostingHandler,
|
|
10213
10258
|
imageCopyHandler,
|
|
10214
|
-
customCopyFunction = defaultCopyFunction
|
|
10259
|
+
customCopyFunction = defaultCopyFunction,
|
|
10260
|
+
clipboardReadFunction = clipboardRead
|
|
10215
10261
|
} = options;
|
|
10216
10262
|
const res = [
|
|
10217
10263
|
...corePreset({ excludeExtensions: ["paragraph", "text"] }),
|
|
@@ -10266,7 +10312,8 @@ function extensions(options) {
|
|
|
10266
10312
|
handleViewImgSrcUrl
|
|
10267
10313
|
}),
|
|
10268
10314
|
new ClipboardExtension({
|
|
10269
|
-
imageCopyHandler
|
|
10315
|
+
imageCopyHandler,
|
|
10316
|
+
clipboardReadFunction
|
|
10270
10317
|
}),
|
|
10271
10318
|
new ReactComponentExtension({}),
|
|
10272
10319
|
new DropCursorExtension({
|