Centralize rights management
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
This commit is contained in:
@ -1,47 +1,13 @@
|
||||
import React from "react";
|
||||
import { SysInfoApi, SysInfoConfig, SysInfoStatus } from "../api/SysInfoApi";
|
||||
import { AsyncWidget } from "./AsyncWidget";
|
||||
import { SectionContainer } from "./SectionContainer";
|
||||
import { Field, ProgressBar } from "@fluentui/react-components";
|
||||
import { filesize } from "filesize";
|
||||
import { format_duration } from "../utils/time_utils";
|
||||
import React from "react";
|
||||
import { SysInfoApi, SysInfoStatus } from "../api/SysInfoApi";
|
||||
import { useToast } from "../hooks/providers/ToastProvider";
|
||||
import { format_duration } from "../utils/time_utils";
|
||||
import { AsyncWidget } from "./AsyncWidget";
|
||||
import { SectionContainer } from "./SectionContainer";
|
||||
|
||||
export function SystemInfoWidget(): React.ReactElement {
|
||||
const [config, setConfig] = React.useState<SysInfoConfig | undefined>();
|
||||
|
||||
const load = async () => {
|
||||
setConfig(await SysInfoApi.GetConfig());
|
||||
};
|
||||
|
||||
return (
|
||||
<SectionContainer>
|
||||
<AsyncWidget
|
||||
loadKey={1}
|
||||
load={load}
|
||||
errMsg="Failed to check system configuration!"
|
||||
loadingMessage="Checking server configuration..."
|
||||
build={() =>
|
||||
config?.allowed ? (
|
||||
<SystemInfoWidgetInner />
|
||||
) : (
|
||||
<SystemInfoWidgetUnavailable />
|
||||
)
|
||||
}
|
||||
/>
|
||||
</SectionContainer>
|
||||
);
|
||||
}
|
||||
|
||||
function SystemInfoWidgetUnavailable(): React.ReactElement {
|
||||
return (
|
||||
<p style={{ textAlign: "center" }}>
|
||||
Unfortunatley, system information is available. (not enough privileges)
|
||||
</p>
|
||||
);
|
||||
}
|
||||
|
||||
function SystemInfoWidgetInner(): React.ReactElement {
|
||||
const toast = useToast();
|
||||
|
||||
const [status, setStatus] = React.useState<SysInfoStatus | undefined>();
|
||||
@ -63,49 +29,51 @@ function SystemInfoWidgetInner(): React.ReactElement {
|
||||
});
|
||||
|
||||
return (
|
||||
<AsyncWidget
|
||||
loadKey={1}
|
||||
load={load}
|
||||
loadingMessage="Loading system status..."
|
||||
errMsg="Failed to load system status!"
|
||||
build={() => (
|
||||
<div
|
||||
style={{
|
||||
display: "flex",
|
||||
flexDirection: "row",
|
||||
alignItems: "center",
|
||||
justifyContent: "center",
|
||||
}}
|
||||
>
|
||||
<Field
|
||||
validationMessage={`${filesize(
|
||||
status!.system.used_memory
|
||||
)} of memory used out of ${filesize(
|
||||
status!.system.available_memory + status!.system.used_memory
|
||||
)}`}
|
||||
validationState="none"
|
||||
style={{ flex: 2 }}
|
||||
<SectionContainer>
|
||||
<AsyncWidget
|
||||
loadKey={1}
|
||||
load={load}
|
||||
loadingMessage="Loading system status..."
|
||||
errMsg="Failed to load system status!"
|
||||
build={() => (
|
||||
<div
|
||||
style={{
|
||||
display: "flex",
|
||||
flexDirection: "row",
|
||||
alignItems: "center",
|
||||
justifyContent: "center",
|
||||
}}
|
||||
>
|
||||
<ProgressBar
|
||||
value={
|
||||
status!.system.used_memory /
|
||||
(status!.system.available_memory + status!.system.used_memory)
|
||||
}
|
||||
/>
|
||||
</Field>
|
||||
<div style={{ width: "20px" }}></div>
|
||||
<div style={{ flex: 1 }}>
|
||||
<p>
|
||||
Load average: {status!.system.load_average.one}{" "}
|
||||
{status!.system.load_average.five}{" "}
|
||||
{status!.system.load_average.fifteen}
|
||||
</p>
|
||||
<UptimeWidget uptime={status!.system.uptime} />
|
||||
Number physical cores: {status!.system.physical_core_count}
|
||||
<Field
|
||||
validationMessage={`${filesize(
|
||||
status!.system.used_memory
|
||||
)} of memory used out of ${filesize(
|
||||
status!.system.available_memory + status!.system.used_memory
|
||||
)}`}
|
||||
validationState="none"
|
||||
style={{ flex: 2 }}
|
||||
>
|
||||
<ProgressBar
|
||||
value={
|
||||
status!.system.used_memory /
|
||||
(status!.system.available_memory + status!.system.used_memory)
|
||||
}
|
||||
/>
|
||||
</Field>
|
||||
<div style={{ width: "20px" }}></div>
|
||||
<div style={{ flex: 1 }}>
|
||||
<p>
|
||||
Load average: {status!.system.load_average.one}{" "}
|
||||
{status!.system.load_average.five}{" "}
|
||||
{status!.system.load_average.fifteen}
|
||||
</p>
|
||||
<UptimeWidget uptime={status!.system.uptime} />
|
||||
Number physical cores: {status!.system.physical_core_count}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
)}
|
||||
/>
|
||||
)}
|
||||
/>
|
||||
</SectionContainer>
|
||||
);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user