mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-26 17:26:23 +02:00
33 lines
770 B
TypeScript
33 lines
770 B
TypeScript
|
|
'use client';
|
||
|
|
|
||
|
|
import * as React from 'react';
|
||
|
|
|
||
|
|
import type { TLinkElement } from 'platejs';
|
||
|
|
import type { PlateElementProps } from 'platejs/react';
|
||
|
|
|
||
|
|
import { getLinkAttributes } from '@platejs/link';
|
||
|
|
import { PlateElement } from 'platejs/react';
|
||
|
|
|
||
|
|
import { cn } from '@/lib/utils';
|
||
|
|
|
||
|
|
export function LinkElement(props: PlateElementProps<TLinkElement>) {
|
||
|
|
return (
|
||
|
|
<PlateElement
|
||
|
|
{...props}
|
||
|
|
as="a"
|
||
|
|
className={cn(
|
||
|
|
'font-medium text-primary underline decoration-primary underline-offset-4'
|
||
|
|
)}
|
||
|
|
attributes={{
|
||
|
|
...props.attributes,
|
||
|
|
...getLinkAttributes(props.editor, props.element),
|
||
|
|
onMouseOver: (e) => {
|
||
|
|
e.stopPropagation();
|
||
|
|
},
|
||
|
|
}}
|
||
|
|
>
|
||
|
|
{props.children}
|
||
|
|
</PlateElement>
|
||
|
|
);
|
||
|
|
}
|