Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Embedded base64 images are not working after update from 3.26.5 to 4.0.1 #607

Open
TobiasMorell opened this issue Dec 20, 2023 · 9 comments

Comments

@TobiasMorell
Copy link

TobiasMorell commented Dec 20, 2023

I'm facing an issue where images are no longer displayed after updating from react-md-editor v. 3.26.5 to v 4.0.1. We're embedding the images in the markdown string and displaying them using references. This used to work, but now renders an img tag with an empty source string.

Repro:

<MDEditor.Markdown source="This is my example:\n\n![][example.png]\n\n[example.png]: " />

Edit: I have found a link to a Markdown Syntax Guide that describes this implementation. They call it "Reference Links": Link to article.

@jaywcjlove
Copy link
Member

@TobiasMorell This feature does not support base64. Maybe you can customize it via rehype-plugins

https://codesandbox.io/p/sandbox/uiwjs-react-md-editor-issues-607-cvrsld

import MDEditor from "@uiw/react-md-editor";

const code = `
This is my example:


![Open-Source Software][1]
![Open-Source Software][2]

[1]: https://jaywcjlove.github.io/sb/ico/min-oss.svg "Open Source Software"
[2]: ""
`;

export default function App() {
  return (
    <div className="App">
      <MDEditor.Markdown source={code} style={{ whiteSpace: "pre-wrap" }} />
    </div>
  );
}

@TobiasMorell
Copy link
Author

Thank you for your quick response. The example you provided correctly shows the issue I'm facing. I've allowed myself to elaborate a bit more:

  1. Example using reference links in v 3.26.5: As you may notice, the base64 encoded image shows correctly here.
  2. Example using reference links in v 4.0.1: Here the base64 image is shown using the fallback value "Open-Source Software".

Given that the example using v 3.26.5 renders the image correctly, I would argue this is a regression - unless you've decided to drop the support for showing base64 encoded images as reference links?

@jaywcjlove
Copy link
Member

@TobiasMorell This is a problem caused by update dependency and I will try to troubleshoot the problem

It looks like rehype-raw is causing the bug.

@jaywcjlove
Copy link
Member

@TobiasMorell https://codesandbox.io/p/sandbox/uiwjs-react-md-editor-issues-607-forked-5kd6ps?file=%2Fsrc%2FApp.js%3A11%2C1-11%2C9185

import MDEditor from "@uiw/react-md-editor";

const code = `
This is my example:


![Open-Source Software][1]
![Open-Source Software][2]

[1]: https://jaywcjlove.github.io/sb/ico/min-oss.svg "Open Source Software"
[2]: 
`;

export default function App() {
  return (
    <div className="App">
      <MDEditor.Markdown
        urlTransform={(url) => {
          return url;
        }}
        source={code}
        style={{ whiteSpace: "pre-wrap" }}
      />
    </div>
  );
}

@TobiasMorell
Copy link
Author

Thank for the help! I can confirm this solves my issue.

jaywcjlove added a commit to uiwjs/react-markdown-preview that referenced this issue Dec 24, 2023
github-actions bot added a commit to uiwjs/react-markdown-preview that referenced this issue Dec 24, 2023
jaywcjlove added a commit to uiwjs/react-markdown-preview that referenced this issue Dec 24, 2023
@jaywcjlove
Copy link
Member

@TobiasMorell Integrated by default, now you don’t need to pass urlTransform props

github-actions bot added a commit to uiwjs/react-markdown-preview that referenced this issue Dec 24, 2023
@zengzilu
Copy link

zengzilu commented Dec 26, 2023

@TobiasMorell https://codesandbox.io/p/sandbox/uiwjs-react-md-editor-issues-607-forked-5kd6ps?file=%2Fsrc%2FApp.js%3A11%2C1-11%2C9185

import MDEditor from "@uiw/react-md-editor";

const code = `
This is my example:


![Open-Source Software][1]
![Open-Source Software][2]

[1]: https://jaywcjlove.github.io/sb/ico/min-oss.svg "Open Source Software"
[2]: 
`;

export default function App() {
  return (
    <div className="App">
      <MDEditor.Markdown
        urlTransform={(url) => {
          return url;
        }}
        source={code}
        style={{ whiteSpace: "pre-wrap" }}
      />
    </div>
  );
}

works fine with <MDEditor.Markdown />
is there a way works with <MDEditor /> ?

@jaywcjlove
Copy link
Member

@TobiasMorell I tested it and it worked fine

https://codesandbox.io/p/sandbox/uiwjs-react-md-editor-issues-607-forked-d7dxhj?file=%2Fsrc%2FApp.js%3A25%2C13

import React from "react";
import MDEditor from "@uiw/react-md-editor";

// No import is required in the WebPack.
import "@uiw/react-md-editor/markdown-editor.css";
// No import is required in the WebPack.
import "@uiw/react-markdown-preview/markdown.css";

const code = `
This is my example:


![Open-Source Software][1]
![Fallback][2]

[1]: https://jaywcjlove.github.io/sb/ico/min-oss.svg "Open Source Software"
[2]: 
`;

export default function App() {
  const [value, setValue] = React.useState(code);
  return (
    <div className="App">
      <MDEditor value={value} onChange={setValue} />
      <hr />
      <MDEditor.Markdown source={code} style={{ whiteSpace: "pre-wrap" }} />
    </div>
  );
}

@zengzilu
Copy link

@TobiasMorell I tested it and it worked fine

https://codesandbox.io/p/sandbox/uiwjs-react-md-editor-issues-607-forked-d7dxhj?file=%2Fsrc%2FApp.js%3A25%2C13

import React from "react";
import MDEditor from "@uiw/react-md-editor";

// No import is required in the WebPack.
import "@uiw/react-md-editor/markdown-editor.css";
// No import is required in the WebPack.
import "@uiw/react-markdown-preview/markdown.css";

const code = `
This is my example:


![Open-Source Software][1]
![Fallback][2]

[1]: https://jaywcjlove.github.io/sb/ico/min-oss.svg "Open Source Software"
[2]: 
`;

export default function App() {
  const [value, setValue] = React.useState(code);
  return (
    <div className="App">
      <MDEditor value={value} onChange={setValue} />
      <hr />
      <MDEditor.Markdown source={code} style={{ whiteSpace: "pre-wrap" }} />
    </div>
  );
}

thanks,
i'm using "@uiw/react-md-editor": "^4.0.1", while set "@uiw/react-markdown-preview": "^5.0.6" both and <MDEditor.Markdown /> work fine

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants