mirror of
https://github.com/ente-io/ente.git
synced 2025-07-03 22:16:08 +00:00
51 lines
1.3 KiB
TypeScript
51 lines
1.3 KiB
TypeScript
import { CenteredFlex } from "@/base/components/containers";
|
|
import { ActivityIndicator } from "@/base/components/mui/ActivityIndicator";
|
|
import CopyButton from "@ente/shared/components/CopyButton";
|
|
import { Box } from "@mui/material";
|
|
import React from "react";
|
|
|
|
interface CodeBlockProps {
|
|
/**
|
|
* The code (an arbitrary string) to show.
|
|
*
|
|
* If not present, then an activity indicator will be shown.
|
|
*/
|
|
code: string | undefined;
|
|
}
|
|
|
|
/**
|
|
* A component that shows a "code" (e.g. the user's recovery key, or a 2FA setup
|
|
* code), alongwith a button to copy it.
|
|
*/
|
|
export const CodeBlock: React.FC<CodeBlockProps> = ({ code }) => {
|
|
if (!code) {
|
|
return (
|
|
<CenteredFlex sx={{ minHeight: "80px" }}>
|
|
<ActivityIndicator />
|
|
</CenteredFlex>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Box
|
|
sx={{
|
|
position: "relative",
|
|
bgcolor: "accent.dark",
|
|
borderRadius: 1,
|
|
}}
|
|
>
|
|
<Box
|
|
sx={{
|
|
padding: "16px 36px 16px 16px",
|
|
wordBreak: "break-word",
|
|
}}
|
|
>
|
|
{code}
|
|
</Box>
|
|
<Box sx={{ position: "absolute", top: 0, right: 0, mt: 1 }}>
|
|
<CopyButton code={code} />
|
|
</Box>
|
|
</Box>
|
|
);
|
|
};
|