REFACTOR: Ripple effect
TODO: Segmented buttons styles
This commit is contained in:
30
src/primitive-components/ripple/ripple-effect.tsx
Normal file
30
src/primitive-components/ripple/ripple-effect.tsx
Normal 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 };
|
||||
Reference in New Issue
Block a user