25 lines
583 B
TypeScript
25 lines
583 B
TypeScript
import { JSX } from 'preact/jsx-runtime'
|
|
|
|
interface IconButtonProps {
|
|
active?: boolean
|
|
text?: string
|
|
icon?: JSX.Element
|
|
}
|
|
|
|
export function IconButton(
|
|
{ icon, children, active, ...props }:
|
|
& IconButtonProps
|
|
& JSX.HTMLAttributes<HTMLButtonElement>,
|
|
) {
|
|
return (
|
|
<button
|
|
class={'p-2 sm:px-4 flex flex-col sm:flex-row flex-1 sm:flex-none bg-mantle justify-center items-center sm:justify-start text-center sm:text-left rounded' +
|
|
(active ? ' text-primary' : '')}
|
|
{...props}
|
|
>
|
|
<div class='sm:mr-2'>{icon}</div>
|
|
<div class=''>{children}</div>
|
|
</button>
|
|
)
|
|
}
|