3v324v23's picture
lfs
1e3b872
import { getResolver } from "./shared_utils.js";
// @ts-ignore
import { getPngMetadata, getWebpMetadata } from "../../scripts/pnginfo.js";
import type { SerializedGraph } from "typings/index.js";
import type { ComfyApiFormat } from "typings/comfy.js";
export async function tryToGetWorkflowDataFromEvent(
e: DragEvent,
): Promise<{ workflow: SerializedGraph | null; prompt: ComfyApiFormat | null }> {
let work;
for (const file of e.dataTransfer?.files || []) {
const data = await tryToGetWorkflowDataFromFile(file);
if (data.workflow || data.prompt) {
return data;
}
}
const validTypes = ["text/uri-list", "text/x-moz-url"];
const match = (e.dataTransfer?.types || []).find((t) => validTypes.find((v) => t === v));
if (match) {
const uri = e.dataTransfer!.getData(match)?.split("\n")?.[0];
if (uri) {
return tryToGetWorkflowDataFromFile(await (await fetch(uri)).blob());
}
}
return { workflow: null, prompt: null };
}
export async function tryToGetWorkflowDataFromFile(
file: File | Blob,
): Promise<{ workflow: SerializedGraph | null; prompt: ComfyApiFormat | null }> {
if (file.type === "image/png") {
const pngInfo = await getPngMetadata(file);
return {
workflow: JSON.parse(pngInfo?.workflow ?? "null"),
prompt: JSON.parse(pngInfo?.prompt ?? "null"),
};
}
if (file.type === "image/webp") {
const pngInfo = await getWebpMetadata(file);
// Support loading workflows from that webp custom node.
const workflow = JSON.parse(pngInfo?.workflow || pngInfo?.Workflow || "null");
const prompt = JSON.parse(pngInfo?.prompt || pngInfo?.Prompt || "null");
return { workflow, prompt };
}
if (file.type === "application/json" || (file as File).name?.endsWith(".json")) {
const resolver = getResolver<{ workflow: any; prompt: any }>();
const reader = new FileReader();
reader.onload = async () => {
const json = JSON.parse(reader.result as string);
const isApiJson = Object.values(json).every((v: any) => v.class_type);
const prompt = isApiJson ? json : null;
const workflow = !isApiJson && !json?.templates ? json : null;
return { workflow, prompt };
};
return resolver.promise;
}
return { workflow: null, prompt: null };
}