/* * QQQ - Low-code Application Framework for Engineers. * Copyright (C) 2021-2022. Kingsrook, LLC * 651 N Broad St Ste 205 # 6917 | Middletown DE 19709 | United States * contact@kingsrook.com * https://github.com/Kingsrook/ * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ import Card from "@mui/material/Card"; import Grid from "@mui/material/Grid"; import Icon from "@mui/material/Icon"; import {ReactNode} from "react"; import {useMaterialUIController} from "context"; import MDBox from "qqq/components/Temporary/MDBox"; import MDTypography from "qqq/components/Temporary/MDTypography"; // Decalaring props types for MiniStatisticsCard interface Props { bgColor?: "white" | "primary" | "secondary" | "info" | "success" | "warning" | "error" | "dark"; title?: { fontWeight?: "light" | "regular" | "medium" | "bold"; text?: string; }; count: string | number; percentage?: { color: "primary" | "secondary" | "info" | "success" | "warning" | "error" | "dark" | "white"; text: string | number; }; icon: { color: "primary" | "secondary" | "info" | "success" | "warning" | "error" | "dark"; component: ReactNode; }; direction?: "right" | "left"; [key: string]: any; } function MiniStatisticsCard({ bgColor, title, count, percentage, icon, direction, }: Props): JSX.Element { const [controller] = useMaterialUIController(); const {darkMode} = controller; return ( ({ background: darkMode && background.card, })} > {direction === "left" ? ( {icon.component} ) : null} {title.text} {count}{" "} {percentage.text} {direction === "right" ? ( {icon.component} ) : null} ); } // Declaring default props for MiniStatisticsCard MiniStatisticsCard.defaultProps = { bgColor: "white", title: { fontWeight: "light", text: "", }, percentage: { color: "success", text: "", }, direction: "right", }; export default MiniStatisticsCard;