REFACTOR: Ripple effect

TODO: Segmented buttons styles
This commit is contained in:
2024-02-09 21:18:20 +04:00
committed by doryan
parent 9c7f163af9
commit 22d75a2952
17 changed files with 249 additions and 279 deletions

View File

@@ -0,0 +1,30 @@
'use client';
import useRippleBuilder from './hooks/useRippleBuilder';
import React, { forwardRef, useId, useRef } from 'react';
import { RippleAreaProps, RippleContainer } from './ripple.types';
const rippleAreaContext = React.createContext(false);
const RippleEffect = forwardRef<RippleContainer, RippleAreaProps>(
({ central = false, ...props }, ref) => {
const uniqueId = useId(),
rippleDomain = useRef<HTMLSpanElement>(null),
clicked = useRef<boolean>(false),
ripples = useRippleBuilder(clicked, rippleDomain, central, ref);
return (
<span
className={`m3 m3-ripple-domain ${props.className ?? ''}`.trimEnd()}
id={uniqueId}
ref={rippleDomain}
>
<rippleAreaContext.Provider value={clicked.current}>
{Object.values(ripples)}
</rippleAreaContext.Provider>
</span>
);
},
);
export { rippleAreaContext, RippleEffect };