* wip: Add gridstack board * wip: Centralize board pages, Add board settings page * fix: remove cyclic dependency and rename widget-sort to kind * improve: Add header actions as parallel route * feat: add item select modal, add category edit modal, * feat: add edit item modal * feat: add remove item modal * wip: add category actions * feat: add saving of board, wip: add app widget * Merge branch 'main' into add-board * chore: update turbo dependencies * chore: update mantine dependencies * chore: fix typescript errors, lint and format * feat: add confirm modal to category removal, move items of removed category to above wrapper * feat: remove app widget to continue in another branch * feat: add loading spinner until board is initialized * fix: issue with cellheight of gridstack items * feat: add translations for board * fix: issue with translation for settings page * chore: address pull request feedback
48 lines
1.1 KiB
TypeScript
48 lines
1.1 KiB
TypeScript
import type { ForwardedRef, ReactNode } from "react";
|
|
import { forwardRef } from "react";
|
|
import Link from "next/link";
|
|
|
|
import type { ActionIconProps } from "@homarr/ui";
|
|
import { ActionIcon } from "@homarr/ui";
|
|
|
|
type HeaderButtonProps = (
|
|
| {
|
|
onClick?: () => void;
|
|
}
|
|
| {
|
|
href: string;
|
|
}
|
|
) & {
|
|
children: ReactNode;
|
|
} & Partial<ActionIconProps>;
|
|
|
|
const headerButtonActionIconProps: ActionIconProps = {
|
|
variant: "subtle",
|
|
style: { border: "none" },
|
|
color: "gray",
|
|
size: "lg",
|
|
};
|
|
|
|
// eslint-disable-next-line react/display-name
|
|
export const HeaderButton = forwardRef<HTMLButtonElement, HeaderButtonProps>(
|
|
(props, ref) => {
|
|
if ("href" in props) {
|
|
return (
|
|
<ActionIcon
|
|
ref={ref as ForwardedRef<HTMLAnchorElement>}
|
|
component={Link}
|
|
{...props}
|
|
{...headerButtonActionIconProps}
|
|
>
|
|
{props.children}
|
|
</ActionIcon>
|
|
);
|
|
}
|
|
return (
|
|
<ActionIcon ref={ref} {...props} {...headerButtonActionIconProps}>
|
|
{props.children}
|
|
</ActionIcon>
|
|
);
|
|
},
|
|
);
|