Portal/rsconcept/frontend/src/components/ui/ValueLabeled.tsx

32 lines
666 B
TypeScript
Raw Normal View History

2024-06-07 20:17:03 +03:00
import clsx from 'clsx';
import { CProps } from '../props';
2024-08-23 12:35:05 +03:00
interface ValueLabeledProps extends CProps.Styling {
/** Id of the component. */
2024-06-07 20:17:03 +03:00
id?: string;
/** Label to display. */
2024-06-07 20:17:03 +03:00
label: string;
/** Value to display. */
2024-06-07 20:17:03 +03:00
text: string | number;
/** Tooltip for the component. */
2024-06-07 20:17:03 +03:00
title?: string;
}
/**
* Displays a labeled value.
*/
2024-08-23 12:35:05 +03:00
function ValueLabeled({ id, label, text, title, className, ...restProps }: ValueLabeledProps) {
2024-06-07 20:17:03 +03:00
return (
<div className={clsx('flex justify-between gap-6', className)} {...restProps}>
<span title={title}>{label}</span>
<span id={id}>{text}</span>
</div>
);
}
2024-08-23 12:35:05 +03:00
export default ValueLabeled;