fix: Handle base64 and remote images when creating a file (#5740)
This commit is contained in:
@@ -1,20 +0,0 @@
|
||||
import dataURItoBuffer from "./dataURItoBuffer";
|
||||
|
||||
it("should parse value data URI", () => {
|
||||
const response = dataURItoBuffer(
|
||||
``
|
||||
);
|
||||
expect(response.buffer).toBeTruthy();
|
||||
expect(response.type).toBe("image/png");
|
||||
});
|
||||
it("should throw an error with junk input", () => {
|
||||
let err;
|
||||
|
||||
try {
|
||||
dataURItoBuffer("what");
|
||||
} catch (error) {
|
||||
err = error;
|
||||
}
|
||||
|
||||
expect(err).toBeTruthy();
|
||||
});
|
||||
@@ -1,16 +0,0 @@
|
||||
export default function dataURItoBuffer(dataURI: string) {
|
||||
const split = dataURI.split(",");
|
||||
|
||||
if (!dataURI.startsWith("data") || split.length <= 1) {
|
||||
throw new Error("Not a dataURI");
|
||||
}
|
||||
|
||||
// separate out the mime component
|
||||
const type = split[0].split(":")[1].split(";")[0];
|
||||
// convert base64 to buffer
|
||||
const buffer = Buffer.from(split[1], "base64");
|
||||
return {
|
||||
buffer,
|
||||
type,
|
||||
};
|
||||
}
|
||||
@@ -10,7 +10,8 @@ it("should return an array of images", () => {
|
||||

|
||||
`);
|
||||
expect(result.length).toBe(1);
|
||||
expect(result[0]).toBe("/attachments/image.png");
|
||||
expect(result[0].alt).toBe("internal");
|
||||
expect(result[0].src).toBe("/attachments/image.png");
|
||||
});
|
||||
|
||||
it("should return deeply nested images", () => {
|
||||
@@ -18,10 +19,11 @@ it("should return deeply nested images", () => {
|
||||
|
||||
- one
|
||||
- two
|
||||
- three 
|
||||
- three 
|
||||
`);
|
||||
expect(result.length).toBe(1);
|
||||
expect(result[0]).toBe("/attachments/image.png");
|
||||
expect(result[0].alt).toBe("oh my");
|
||||
expect(result[0].src).toBe("/attachments/image.png");
|
||||
});
|
||||
|
||||
it("should not return non document links", () => {
|
||||
|
||||
@@ -1,17 +1,29 @@
|
||||
import { Node } from "prosemirror-model";
|
||||
import { parser } from "@server/editor";
|
||||
|
||||
export default function parseImages(text: string): string[] {
|
||||
type ImageProps = { src: string; alt: string };
|
||||
|
||||
/**
|
||||
* Parses a string of markdown and returns a list of images.
|
||||
*
|
||||
* @param text The markdown to parse
|
||||
* @returns A unique list of images
|
||||
*/
|
||||
export default function parseImages(text: string): ImageProps[] {
|
||||
const doc = parser.parse(text);
|
||||
const images: string[] = [];
|
||||
const images = new Map<string, ImageProps>();
|
||||
|
||||
if (!doc) {
|
||||
return images;
|
||||
return [];
|
||||
}
|
||||
|
||||
doc.descendants((node: Node) => {
|
||||
if (node.type.name === "image") {
|
||||
if (!images.includes(node.attrs.src)) {
|
||||
images.push(node.attrs.src);
|
||||
if (!images.has(node.attrs.src)) {
|
||||
images.set(node.attrs.src, {
|
||||
src: node.attrs.src,
|
||||
alt: node.attrs.alt,
|
||||
});
|
||||
}
|
||||
|
||||
return false;
|
||||
@@ -24,5 +36,5 @@ export default function parseImages(text: string): string[] {
|
||||
return true;
|
||||
});
|
||||
|
||||
return images;
|
||||
return Array.from(images.values());
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user