mirror of
https://github.com/fleetdm/fleet
synced 2026-04-22 05:57:36 +00:00
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
|
|
import React from "react";
|
||
|
|
|
||
|
|
import { SetupSoftwareStatus } from "interfaces/software";
|
||
|
|
|
||
|
|
import Icon from "components/Icon";
|
||
|
|
import { IconNames } from "components/icons";
|
||
|
|
import Spinner from "components/Spinner";
|
||
|
|
|
||
|
|
const baseClass = "setup-software-status-cell";
|
||
|
|
|
||
|
|
interface ISetupSoftwareStatusCell {
|
||
|
|
status: SetupSoftwareStatus;
|
||
|
|
}
|
||
|
|
|
||
|
|
const serverToUiStatus = (
|
||
|
|
status: SetupSoftwareStatus
|
||
|
|
): { label: string; icon: IconNames | "spinner" } => {
|
||
|
|
switch (status) {
|
||
|
|
case "pending":
|
||
|
|
return { label: "Pending", icon: "pending-outline" };
|
||
|
|
case "running":
|
||
|
|
return { label: "Installing", icon: "spinner" };
|
||
|
|
case "success":
|
||
|
|
return { label: "Installed", icon: "success" };
|
||
|
|
case "failure":
|
||
|
|
case "cancelled":
|
||
|
|
return { label: "Failed", icon: "error" };
|
||
|
|
default:
|
||
|
|
return { label: "Pending", icon: "pending-outline" };
|
||
|
|
}
|
||
|
|
};
|
||
|
|
|
||
|
|
const SetupSoftwareStatusCell = ({ status }: ISetupSoftwareStatusCell) => {
|
||
|
|
const { label, icon } = serverToUiStatus(status);
|
||
|
|
return (
|
||
|
|
<div className={baseClass}>
|
||
|
|
{icon === "spinner" ? <Spinner size="x-small" /> : <Icon name={icon} />}
|
||
|
|
{label}
|
||
|
|
</div>
|
||
|
|
);
|
||
|
|
};
|
||
|
|
|
||
|
|
export default SetupSoftwareStatusCell;
|