mirror of
https://github.com/dergigi/boris.git
synced 2025-12-17 14:44:26 +01:00
feat(ui): add reusable IconButton component with square styling
This commit is contained in:
37
src/components/IconButton.tsx
Normal file
37
src/components/IconButton.tsx
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
import React from 'react'
|
||||||
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
|
||||||
|
import type { IconDefinition } from '@fortawesome/fontawesome-svg-core'
|
||||||
|
|
||||||
|
interface IconButtonProps {
|
||||||
|
icon: IconDefinition
|
||||||
|
onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void
|
||||||
|
title?: string
|
||||||
|
ariaLabel?: string
|
||||||
|
variant?: 'primary' | 'success' | 'ghost'
|
||||||
|
size?: number
|
||||||
|
}
|
||||||
|
|
||||||
|
const IconButton: React.FC<IconButtonProps> = ({
|
||||||
|
icon,
|
||||||
|
onClick,
|
||||||
|
title,
|
||||||
|
ariaLabel,
|
||||||
|
variant = 'ghost',
|
||||||
|
size = 28
|
||||||
|
}) => {
|
||||||
|
return (
|
||||||
|
<button
|
||||||
|
className={`icon-button ${variant}`}
|
||||||
|
onClick={onClick}
|
||||||
|
title={title}
|
||||||
|
aria-label={ariaLabel || title}
|
||||||
|
style={{ width: size, height: size }}
|
||||||
|
>
|
||||||
|
<FontAwesomeIcon icon={icon} />
|
||||||
|
</button>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
export default IconButton
|
||||||
|
|
||||||
|
|
||||||
@@ -169,6 +169,29 @@ body {
|
|||||||
background: #218838;
|
background: #218838;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Generic IconButton styling */
|
||||||
|
.icon-button {
|
||||||
|
display: inline-flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
border: 1px solid #444;
|
||||||
|
border-radius: 6px;
|
||||||
|
background: #2a2a2a;
|
||||||
|
color: #ddd;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.icon-button:hover { background: #333; }
|
||||||
|
.icon-button:active { transform: translateY(1px); }
|
||||||
|
|
||||||
|
.icon-button.primary { background: #646cff; color: white; border-color: #646cff; }
|
||||||
|
.icon-button.primary:hover { filter: brightness(1.05); }
|
||||||
|
|
||||||
|
.icon-button.success { background: #28a745; color: white; border-color: #28a745; }
|
||||||
|
.icon-button.success:hover { filter: brightness(1.05); }
|
||||||
|
|
||||||
|
.icon-button.ghost { background: #2a2a2a; }
|
||||||
|
|
||||||
.bookmark-events {
|
.bookmark-events {
|
||||||
margin: 1rem 0;
|
margin: 1rem 0;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user