33 lines
1.1 KiB
TypeScript
33 lines
1.1 KiB
TypeScript
import { FunctionComponent } from 'preact';
|
|
|
|
export const Title: FunctionComponent = ({ children }) => (
|
|
<h2 className="text-base m-0 mb-1">{children}</h2>
|
|
);
|
|
|
|
export const Subtitle: FunctionComponent<{ className?: string }> = ({ children, className = "" }) => (
|
|
<h4 className={`font-medium text-sm m-0 mb-1 ${className}`}>{children}</h4>
|
|
);
|
|
|
|
export const SubtitleLight: FunctionComponent<{ className?: string }> = ({ children, className = "" }) => (
|
|
<h4 className={`font-normal text-sm m-0 mb-1 ${className}`}>{children}</h4>
|
|
);
|
|
|
|
export const Text: FunctionComponent<{ className?: string }> = ({
|
|
children,
|
|
className = '',
|
|
}) => <p className={`${className} text-xs`}>{children}</p>;
|
|
|
|
const buttonClasses = `block bg-default color-text rounded border-solid \
|
|
border-1 px-4 py-1.75 font-bold text-sm fit-content \
|
|
focus:bg-contrast hover:bg-contrast border-neutral`;
|
|
|
|
export const LinkButton: FunctionComponent<{
|
|
label: string;
|
|
link: string;
|
|
className?: string;
|
|
}> = ({ label, link, className }) => (
|
|
<a target="_blank" className={`${className} ${buttonClasses}`} href={link}>
|
|
{label}
|
|
</a>
|
|
);
|