mirror of
https://github.com/alexmickelson/canvasManagement.git
synced 2026-03-25 23:28:33 -06:00
58 lines
1.6 KiB
TypeScript
58 lines
1.6 KiB
TypeScript
"use client";
|
|
import { marked } from "marked";
|
|
import DOMPurify from "isomorphic-dompurify";
|
|
import { LocalCourseSettings } from "@/models/local/localCourseSettings";
|
|
import markedKatex from "marked-katex-extension";
|
|
|
|
marked.use(markedKatex({
|
|
throwOnError: false,
|
|
output: "mathml"
|
|
}));
|
|
|
|
export function extractImageSources(htmlString: string) {
|
|
const srcUrls = [];
|
|
const regex = /<img[^>]+src=["']?([^"'>]+)["']?/g;
|
|
let match;
|
|
|
|
while ((match = regex.exec(htmlString)) !== null) {
|
|
srcUrls.push(match[1]);
|
|
}
|
|
|
|
return srcUrls;
|
|
}
|
|
export function convertImagesToCanvasImages(
|
|
html: string,
|
|
settings: LocalCourseSettings
|
|
) {
|
|
const imageSources = extractImageSources(html);
|
|
let mutableHtml = html;
|
|
// console.log(imageSources);
|
|
|
|
const imageLookup = settings.assets.reduce((acc, asset) => {
|
|
return { ...acc, [asset.sourceUrl]: asset.canvasUrl };
|
|
}, {} as { [key: string]: string });
|
|
|
|
for (const imageSrc of imageSources) {
|
|
const destinationUrl = imageLookup[imageSrc];
|
|
if (typeof destinationUrl === "undefined") {
|
|
throw `cannot convert to html, no canvas url for ${imageSrc} in settings`;
|
|
}
|
|
mutableHtml = mutableHtml.replaceAll(imageSrc, destinationUrl);
|
|
}
|
|
return mutableHtml;
|
|
}
|
|
|
|
export function markdownToHTMLSafe(
|
|
markdownString: string,
|
|
settings: LocalCourseSettings
|
|
) {
|
|
return markdownToHtmlNoImages(markdownString);
|
|
}
|
|
|
|
export function markdownToHtmlNoImages(markdownString: string) {
|
|
const clean = DOMPurify.sanitize(
|
|
marked.parse(markdownString, { async: false, pedantic: false, gfm: true })
|
|
).replaceAll(/>[^<>]*<\/math>/g, "></math>");
|
|
return clean;
|
|
}
|