web/components/Box.tsx
2025-11-01 23:46:32 -03:00

22 lines
577 B
TypeScript

/**
* Copyright (c) 2025 xwra
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
import { ComponentChildren, h } from "preact";
import { LinkIcon } from "./Icon.tsx";
interface PolygonBoxProps {
as?: keyof HTMLElementTagNameMap;
children?: ComponentChildren;
[key: string]: any;
}
export default function Box(
{ as: Tag = "span", class: className, children, ...props }: PolygonBoxProps,
) {
const content = Tag === "a"
? [children, h(LinkIcon, { size: 16, class: "link-icon" })]
: children;
return h(Tag, { class: `box ${className || ""}`, ...props }, content);
}