mirror of
https://github.com/clash-verge-rev/clash-verge-rev
synced 2025-05-04 23:43:44 +08:00
52 lines
1.4 KiB
TypeScript
52 lines
1.4 KiB
TypeScript
import React, { ReactNode } from "react";
|
|
import { Typography } from "@mui/material";
|
|
import { BaseErrorBoundary } from "./base-error-boundary";
|
|
import { useTheme } from "@mui/material/styles";
|
|
|
|
interface Props {
|
|
title?: React.ReactNode; // the page title
|
|
header?: React.ReactNode; // something behind title
|
|
contentStyle?: React.CSSProperties;
|
|
children?: ReactNode;
|
|
full?: boolean;
|
|
}
|
|
|
|
export const BasePage: React.FC<Props> = (props) => {
|
|
const { title, header, contentStyle, full, children } = props;
|
|
const theme = useTheme();
|
|
|
|
const isDark = theme.palette.mode === "dark";
|
|
|
|
return (
|
|
<BaseErrorBoundary>
|
|
<div className="base-page">
|
|
<header data-tauri-drag-region="true" style={{ userSelect: "none" }}>
|
|
<Typography
|
|
sx={{ fontSize: "20px", fontWeight: "700 " }}
|
|
data-tauri-drag-region="true"
|
|
>
|
|
{title}
|
|
</Typography>
|
|
|
|
{header}
|
|
</header>
|
|
|
|
<div
|
|
className={full ? "base-container no-padding" : "base-container"}
|
|
style={{ backgroundColor: isDark ? "#1e1f27" : "#ffffff" }}
|
|
>
|
|
<section
|
|
style={{
|
|
backgroundColor: isDark ? "#1e1f27" : "var(--background-color)",
|
|
}}
|
|
>
|
|
<div className="base-content" style={contentStyle}>
|
|
{children}
|
|
</div>
|
|
</section>
|
|
</div>
|
|
</div>
|
|
</BaseErrorBoundary>
|
|
);
|
|
};
|