memos/web/src/components/MemoContent/EmbeddedContent/EmbeddedResource.tsx
2024-07-11 23:43:44 +08:00

62 lines
1.7 KiB
TypeScript

import clsx from "clsx";
import { useEffect } from "react";
import MemoResourceListView from "@/components/MemoResourceListView";
import useLoading from "@/hooks/useLoading";
import { useResourceStore } from "@/store/v1";
import Error from "./Error";
interface Props {
resourceId: string;
params: string;
}
const getAdditionalClassNameWithParams = (params: URLSearchParams) => {
const additionalClassNames = [];
if (params.has("align")) {
const align = params.get("align");
if (align === "center") {
additionalClassNames.push("mx-auto");
}
}
if (params.has("size")) {
const size = params.get("size");
if (size === "lg") {
additionalClassNames.push("w-full");
} else if (size === "md") {
additionalClassNames.push("w-2/3");
} else if (size === "sm") {
additionalClassNames.push("w-1/3");
}
}
if (params.has("width")) {
const width = params.get("width");
additionalClassNames.push(`w-[${width}]`);
}
return additionalClassNames.join(" ");
};
const EmbeddedResource = ({ resourceId: uid, params: paramsStr }: Props) => {
const loadingState = useLoading();
const resourceStore = useResourceStore();
const resource = resourceStore.getResourceByName(uid);
const params = new URLSearchParams(paramsStr);
useEffect(() => {
resourceStore.fetchResourceByUID(uid).finally(() => loadingState.setFinish());
}, [uid]);
if (loadingState.isLoading) {
return null;
}
if (!resource) {
return <Error message={`Resource not found: ${uid}`} />;
}
return (
<div className={clsx("max-w-full", getAdditionalClassNameWithParams(params))}>
<MemoResourceListView resources={[resource]} />
</div>
);
};
export default EmbeddedResource;