Emails
1 month ago
EngagementChart
1 month ago
MediaHub
1 month ago
Onboarding
1 month ago
Popup
1 month ago
Skeletons
1 week ago
WhatsNew
1 month ago
charts
1 month ago
test
1 month ago
AdminMenuSync.js
1 month ago
ChartEmptyState.js
1 month ago
ChooseDate.js
1 month ago
ColorPicker.js
1 month ago
ExtendPlugins.js
1 month ago
Filters.js
1 month ago
Link.js
1 month ago
Navbar.js
1 week ago
NoFound.js
1 month ago
PageHeader.js
1 month ago
PluginRecommendations.js
1 month ago
PostScheduleField.js
1 month ago
PrestoPlayerIcon.js
1 month ago
ProGateOverlay.js
1 month ago
QuickAccess.js
1 month ago
RankedTable.js
1 month ago
StatCard.js
1 month ago
TopMedia.js
1 month ago
TopPerformingMedia.js
1 month ago
TopUsers.js
1 month ago
TruncatedTitle.js
1 month ago
UpgradeNotice.js
1 month ago
UpgradeToPro.js
1 month ago
VideoModal.js
1 month ago
WelcomeBanner.js
1 month ago
StatCard.js
40 lines
| 1 | import { Text } from "@bsf/force-ui"; |
| 2 | |
| 3 | /** |
| 4 | * Reusable stat card component. |
| 5 | * Renders a white card with a label and either a large stat value or custom children. |
| 6 | * |
| 7 | * @param {string} label - The stat label text |
| 8 | * @param {string} value - The stat value (used when children not provided) |
| 9 | * @param {string} sublabel - Optional secondary label below the value (e.g., "seconds") |
| 10 | * @param {React.ReactNode} children - Optional custom content (e.g., a chart) |
| 11 | * @param {string} className - Optional extra classes appended to the outer card (e.g., flex-1 to grow) |
| 12 | */ |
| 13 | const StatCard = ({ label, value, sublabel, children, className = "" }) => ( |
| 14 | <div className={`bg-background-primary border border-solid border-border-subtle rounded-xl shadow-sm p-5 flex flex-col gap-1 ${className}`}> |
| 15 | <div className="px-1 py-1"> |
| 16 | <Text size={14} weight={400} color="tertiary"> |
| 17 | {label} |
| 18 | </Text> |
| 19 | </div> |
| 20 | {children ? ( |
| 21 | <div className="px-1 py-1 flex-1 min-h-0 overflow-hidden">{children}</div> |
| 22 | ) : ( |
| 23 | <div className="px-1 py-1"> |
| 24 | <Text size={30} weight={600} color="primary"> |
| 25 | {value} |
| 26 | </Text> |
| 27 | </div> |
| 28 | )} |
| 29 | {sublabel && ( |
| 30 | <div className="px-1"> |
| 31 | <Text size={12} weight={400} color="tertiary"> |
| 32 | {sublabel} |
| 33 | </Text> |
| 34 | </div> |
| 35 | )} |
| 36 | </div> |
| 37 | ); |
| 38 | |
| 39 | export default StatCard; |
| 40 |