rme 0.3.0-beta.5 → 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.mjs CHANGED
@@ -3854,6 +3854,71 @@ function isTextOnlySlice(slice) {
3854
3854
  return false;
3855
3855
  }
3856
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
+ }
3857
3922
  get name() {
3858
3923
  return "clipboard";
3859
3924
  }
@@ -3861,61 +3926,13 @@ var ClipboardExtension = class extends PlainExtension2 {
3861
3926
  return {
3862
3927
  props: {
3863
3928
  handlePaste: (view, event) => {
3864
- const transformer = getTransformerByView(view);
3865
- const parser = transformer.stringToDoc;
3866
- const schema = view.state.schema;
3867
- const editable = view.props.editable?.(view.state);
3868
3929
  const { clipboardData } = event;
3869
- if (!editable || !clipboardData) return false;
3930
+ if (!clipboardData) return false;
3870
3931
  const currentNode = view.state.selection.$from.node();
3871
3932
  if (currentNode.type.spec.code) return false;
3872
3933
  const text = clipboardData.getData("text/plain");
3873
3934
  const html2 = clipboardData.getData("text/html");
3874
- if (html2.length === 0 && text.length === 0) return false;
3875
- const domParser = DOMParser2.fromSchema(schema);
3876
- let dom;
3877
- if (html2.length === 0) {
3878
- const slice2 = parser?.(text);
3879
- if (!slice2 || typeof slice2 === "string") return false;
3880
- const res = [];
3881
- slice2.content.forEach((node2, index) => {
3882
- if (node2.type.name === "paragraph" && index === 0) {
3883
- node2.content.forEach((child) => {
3884
- res.push(child);
3885
- });
3886
- } else {
3887
- res.push(node2);
3888
- }
3889
- });
3890
- this.processImagesInNodesAsync(res, view);
3891
- if (res.length === 1) {
3892
- view.dispatch(view.state.tr.replaceSelectionWith(res[0], false));
3893
- } else {
3894
- const fragment = Fragment3.from(res);
3895
- view.dispatch(view.state.tr.replaceSelection(new Slice(fragment, 0, 0)));
3896
- }
3897
- return true;
3898
- } else {
3899
- const template = document.createElement("template");
3900
- template.innerHTML = html2;
3901
- dom = template.content.cloneNode(true);
3902
- template.remove();
3903
- }
3904
- const slice = domParser.parseSlice(dom);
3905
- const node = isTextOnlySlice(slice);
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));
3935
+ this.handleClipboardData({ text, html: html2, view });
3919
3936
  return true;
3920
3937
  },
3921
3938
  clipboardTextSerializer: (slice, view) => {
@@ -3950,66 +3967,13 @@ var ClipboardExtension = class extends PlainExtension2 {
3950
3967
  return (params) => {
3951
3968
  const { view } = params;
3952
3969
  if (!view) return false;
3953
- const transformer = getTransformerByView(view);
3954
- const parser = transformer.stringToDoc;
3955
- const schema = view.state.schema;
3956
- const editable = view.props.editable?.(view.state);
3957
3970
  if (!this.options.clipboardReadFunction) {
3958
3971
  return false;
3959
3972
  }
3960
3973
  this.options.clipboardReadFunction().then(async (data) => {
3961
3974
  let { html: html2, text } = data;
3962
- if (!editable || !html2 || !text) return false;
3963
- const currentNode = view.state.selection.$from.node();
3964
- if (currentNode.type.spec.code) return false;
3965
- if (html2.length === 0 && text.length === 0) return false;
3966
- console.log("html", html2);
3967
- console.log("text", text);
3968
- const domParser = DOMParser2.fromSchema(schema);
3969
- let dom;
3970
- if (html2.length === 0) {
3971
- const slice2 = parser?.(text);
3972
- if (!slice2 || typeof slice2 === "string") return false;
3973
- const res = [];
3974
- slice2.content.forEach((node2, index) => {
3975
- if (node2.type.name === "paragraph" && index === 0) {
3976
- node2.content.forEach((child) => {
3977
- res.push(child);
3978
- });
3979
- } else {
3980
- res.push(node2);
3981
- }
3982
- });
3983
- this.processImagesInNodesAsync(res, view);
3984
- if (res.length === 1) {
3985
- view.dispatch(view.state.tr.replaceSelectionWith(res[0], false));
3986
- } else {
3987
- const fragment = Fragment3.from(res);
3988
- view.dispatch(view.state.tr.replaceSelection(new Slice(fragment, 0, 0)));
3989
- }
3990
- return true;
3991
- } else {
3992
- const template = document.createElement("template");
3993
- template.innerHTML = html2;
3994
- dom = template.content.cloneNode(true);
3995
- template.remove();
3996
- }
3997
- const slice = domParser.parseSlice(dom);
3998
- const node = isTextOnlySlice(slice);
3999
- console.log("slice", slice, node);
4000
- if (node) {
4001
- if ((node.type.name === "html_image" || node.type.name === "md_image") && node.attrs.src) {
4002
- this.processImageNode(node, view);
4003
- view.dispatch(view.state.tr.replaceSelectionWith(node, true));
4004
- } else {
4005
- this.processMarkdownImageSyntax(node, view).then(() => {
4006
- view.dispatch(view.state.tr.replaceSelectionWith(node, true));
4007
- });
4008
- }
4009
- return true;
4010
- }
4011
- this.processImagesInSliceAsync(slice, view);
4012
- view.dispatch(view.state.tr.replaceSelection(slice));
3975
+ if (!html2 || !text) return false;
3976
+ return await this.handleClipboardData({ html: html2, text, view });
4013
3977
  });
4014
3978
  return true;
4015
3979
  };
@@ -4066,13 +4030,13 @@ var ClipboardExtension = class extends PlainExtension2 {
4066
4030
  imageCopyHandler(node.attrs.src).then((newSrc) => {
4067
4031
  if (newSrc && newSrc !== node.attrs.src) {
4068
4032
  this.updateImageNodeSrc(view, node, newSrc);
4069
- } else {
4070
- const { state, dispatch } = view;
4071
- node.attrs["data-rme-loading"] = null;
4072
- dispatch(state.tr);
4073
4033
  }
4074
4034
  }).catch((error) => {
4075
4035
  console.warn("imageCopyHandler failed:", error);
4036
+ }).finally(() => {
4037
+ const { state, dispatch } = view;
4038
+ node.attrs["data-rme-loading"] = null;
4039
+ dispatch(state.tr);
4076
4040
  });
4077
4041
  }
4078
4042
  /**
@@ -6853,8 +6817,8 @@ import { jsx as jsx14 } from "react/jsx-runtime";
6853
6817
  var warningFallBack = "";
6854
6818
  function ImageNodeView(props) {
6855
6819
  const { node, selected, updateAttributes, handleViewImgSrcUrl, imageHostingHandler } = props;
6856
- const initRef = useRef7();
6857
- const popoverStore = useRef7();
6820
+ const initRef = useRef7(null);
6821
+ const popoverStore = useRef7(null);
6858
6822
  const popoverRef = useRef7(null);
6859
6823
  const handleStoreChange = (store) => {
6860
6824
  popoverStore.current = store;
@@ -6913,10 +6877,10 @@ function ImageNodeView(props) {
6913
6877
  });
6914
6878
  },
6915
6879
  ...node.attrs
6916
- }
6880
+ },
6881
+ `${node.attrs.src}_${node.attrs["data-rme-loading"]}`
6917
6882
  )
6918
- },
6919
- `${node.attrs.src}_${node.attrs["data-rme-loading"]}`
6883
+ }
6920
6884
  );
6921
6885
  return /* @__PURE__ */ jsx14("div", { ref: popoverRef, style: { position: "relative", zIndex: selected ? 10 : "auto" }, children: /* @__PURE__ */ jsx14(
6922
6886
  Popover2,
@@ -9038,7 +9002,6 @@ var MathInlineView = class {
9038
9002
  }
9039
9003
  this._renderElt.replaceWith(newRenderEl);
9040
9004
  this._renderElt = newRenderEl;
9041
- console.log("this.renderElt", this._renderElt.outerHTML);
9042
9005
  this.dom.appendChild(this._renderElt);
9043
9006
  if (preview) {
9044
9007
  this._renderElt.classList.add("inline-input-preview");