Skip to content

Commit

Permalink
Updates
Browse files Browse the repository at this point in the history
  • Loading branch information
joshwooding committed Dec 18, 2024
1 parent 650c3d8 commit 4ac1224
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 24 deletions.
2 changes: 1 addition & 1 deletion .changeset/silent-dots-run.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
"@salt-ds/core": minor
---

Added `render` prop to `Link`.
Added `render` prop to `Link`. The `render` prop enables the substitution of the default anchor tag with an alternate link, such as React Router, facilitating integration with routing libraries.
28 changes: 17 additions & 11 deletions packages/core/src/link/Link.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,15 @@ import type { IconProps } from "@salt-ds/icons";
import { useComponentCssInjection } from "@salt-ds/styles";
import { useWindow } from "@salt-ds/window";
import { clsx } from "clsx";
import { type ComponentType, type ReactElement, forwardRef } from "react";
import {
type ComponentPropsWithoutRef,
type ComponentType,
type ReactElement,
forwardRef,
} from "react";
import { useIcon } from "../semantic-icon-provider";
import type { TextProps } from "../text";
import { makePrefixer } from "../utils";
import type { RenderPropsType } from "../utils";
import { Text, type TextProps } from "../text";
import { type RenderPropsType, makePrefixer } from "../utils";
import linkCss from "./Link.css";
import { LinkAction } from "./LinkAction";

Expand All @@ -18,10 +22,12 @@ const withBaseName = makePrefixer("saltLink");
* @example
* <LinkExample to="#link">Action</LinkExample>
*/
export interface LinkProps extends Omit<TextProps<"a">, "as" | "disabled"> {
export interface LinkProps
extends Omit<ComponentPropsWithoutRef<"a">, "color">,
Pick<TextProps<"a">, "maxRows" | "styleAs" | "color" | "variant"> {
IconComponent?: ComponentType<IconProps> | null;
/**
* Render prop to enable customisation of link element.
* Render prop to enable customisation of anchor element.
*/
render?: RenderPropsType["render"];
}
Expand All @@ -35,7 +41,8 @@ export const Link = forwardRef<HTMLAnchorElement, LinkProps>(function Link(
color: colorProp,
variant,
target = "_self",
render,
styleAs,
maxRows,
...rest
},
ref,
Expand All @@ -54,16 +61,15 @@ export const Link = forwardRef<HTMLAnchorElement, LinkProps>(function Link(

return (
<LinkAction
as="a"
className={clsx(withBaseName(), className)}
href={href}
ref={ref}
target={target}
color={color}
render={render}
{...rest}
>
{children}
<Text as="span" color={color} styleAs={styleAs} maxRows={maxRows}>
{children}
</Text>
{target === "_blank" && (
<>
{LinkIconComponent && (
Expand Down
19 changes: 7 additions & 12 deletions packages/core/src/link/LinkAction.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,10 @@
import type { ComponentPropsWithoutRef } from "react";
import { Text } from "../text";
import { type ComponentPropsWithoutRef, forwardRef } from "react";
import { renderProps } from "../utils";

interface LinkActionProps extends ComponentPropsWithoutRef<any> {}
interface LinkActionProps extends ComponentPropsWithoutRef<"a"> {}

export function LinkAction(props: LinkActionProps) {
const { render, ...rest } = props;

if (render) {
return renderProps("a", props);
}

return <Text {...rest} />;
}
export const LinkAction = forwardRef<HTMLAnchorElement, LinkActionProps>(
function LinkAction(props, ref) {
return renderProps("a", { ...props, ref });
},
);

0 comments on commit 4ac1224

Please sign in to comment.