utils

Previous
Docs
react-arialib

Preview

Loading preview…
lib/react-aria-utils.ts
import { composeRenderProps } from 'react-aria-components';
import { twMerge } from 'tailwind-merge';
import { tv } from 'tailwind-variants';

export const focusRing = tv({
  base: 'outline outline-blue-600 dark:outline-blue-500 forced-colors:outline-[Highlight] outline-offset-2',
  variants: {
    isFocusVisible: {
      false: 'outline-0',
      true: 'outline-2'
    }
  }
});

export function composeTailwindRenderProps<T>(className: string | ((v: T) => string) | undefined, tw: string): string | ((v: T) => string) {
  return composeRenderProps(className, (className) => twMerge(tw, className));
}

Installation

npx shadcn@latest add @react-aria/tailwind-utils

Usage

import { TailwindUtils } from "@/lib/tailwind-utils"
TailwindUtils()