teableio/teable

View on GitHub
packages/sdk/src/components/comment/comment-editor/plate-ui/resizable.tsx

Summary

Maintainability
A
0 mins
Test Coverage
'use client';

import { cn, withRef, withVariants } from '@udecode/cn';
import {
  Resizable as ResizablePrimitive,
  ResizeHandle as ResizeHandlePrimitive,
} from '@udecode/plate-resizable';
import { cva } from 'class-variance-authority';
import React from 'react';

export const mediaResizeHandleVariants = cva(
  cn(
    'top-0 flex w-6 select-none flex-col justify-center',
    'after:flex after:h-16 after:w-[3px] after:rounded-[6px] after:bg-slate-950 after:opacity-0 after:content-[_] group-hover:after:opacity-100 dark:after:bg-slate-300'
  ),
  {
    variants: {
      direction: {
        left: '-left-3 -ml-3 pl-3',
        right: '-right-3 -mr-3 items-end pr-3',
      },
    },
  }
);

const resizeHandleVariants = cva(cn('absolute z-40'), {
  variants: {
    direction: {
      bottom: 'w-full cursor-row-resize',
      left: 'h-full cursor-col-resize',
      right: 'h-full cursor-col-resize',
      top: 'w-full cursor-row-resize',
    },
  },
});

const ResizeHandleVariants = withVariants(ResizeHandlePrimitive, resizeHandleVariants, [
  'direction',
]);

export const ResizeHandle = withRef<typeof ResizeHandlePrimitive>((props, ref) => (
  <ResizeHandleVariants direction={props.options?.direction} ref={ref} {...props} />
));

const resizableVariants = cva('', {
  variants: {
    align: {
      center: 'mx-auto',
      left: 'mr-auto',
      right: 'ml-auto',
    },
  },
});

export const Resizable = withVariants(ResizablePrimitive, resizableVariants, ['align']);