otterscan/src/components/AddressHighlighter.tsx

41 lines
1.0 KiB
TypeScript
Raw Normal View History

2021-10-22 18:50:31 +00:00
import React, { useMemo } from "react";
import { useSelectionContext } from "../useSelection";
2021-07-14 19:17:27 +00:00
type AddressHighlighterProps = React.PropsWithChildren<{
address: string;
2021-07-14 19:17:27 +00:00
}>;
const AddressHighlighter: React.FC<AddressHighlighterProps> = ({
address,
children,
}) => {
const [selection, setSelection] = useSelectionContext();
2021-10-22 18:50:31 +00:00
const [select, deselect] = useMemo(() => {
const _select = () => {
setSelection({ type: "address", content: address });
};
const _deselect = () => {
setSelection(null);
};
return [_select, _deselect];
}, [setSelection, address]);
return (
<div
className={`border border-dashed rounded hover:bg-transparent hover:border-transparent px-1 truncate ${
selection !== null &&
selection.type === "address" &&
selection.content === address
? "border-orange-400 bg-yellow-100"
: "border-transparent"
}`}
onMouseEnter={select}
onMouseLeave={deselect}
>
{children}
</div>
);
};
2021-07-14 19:17:27 +00:00
export default React.memo(AddressHighlighter);