import classNames from 'classnames';
import React from 'react';
import { defineMessages, useIntl } from 'react-intl';
import { Link } from 'react-router-dom';
import { Text } from 'soapbox/components/ui';
import SvgIcon from 'soapbox/components/ui/icon/svg-icon';
const sizes = {
md: 'p-4 sm:rounded-xl',
lg: 'p-4 sm:p-6 sm:rounded-xl',
xl: 'p-4 sm:p-10 sm:rounded-3xl',
};
const messages = defineMessages({
back: { id: 'card.back.label', defaultMessage: 'Back' },
});
interface ICard {
/** The type of card. */
variant?: 'rounded',
/** Card size preset. */
size?: 'md' | 'lg' | 'xl',
/** Extra classnames for the
element. */
className?: string,
/** Elements inside the card. */
children: React.ReactNode,
}
/** An opaque backdrop to hold a collection of related elements. */
const Card = React.forwardRef
(({ children, variant, size = 'md', className, ...filteredProps }, ref): JSX.Element => (
{children}
));
interface ICardHeader {
backHref?: string,
onBackClick?: (event: React.MouseEvent) => void
}
/** Typically holds a CardTitle. */
const CardHeader: React.FC = ({ children, backHref, onBackClick }): JSX.Element => {
const intl = useIntl();
const renderBackButton = () => {
if (!backHref && !onBackClick) {
return null;
}
const Comp: React.ElementType = backHref ? Link : 'button';
const backAttributes = backHref ? { to: backHref } : { onClick: onBackClick };
return (
Back
);
};
return (
{renderBackButton()}
{children}
);
};
interface ICardTitle {
title: string | React.ReactNode
}
/** A card's title. */
const CardTitle = ({ title }: ICardTitle): JSX.Element => (
{title}
);
/** A card's body. */
const CardBody: React.FC = ({ children }): JSX.Element => (
{children}
);
export { Card, CardHeader, CardTitle, CardBody };