index.tsx 836 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import React from 'react';
  2. import {
  3. IconWrapper,
  4. ClickZone,
  5. } from './styled';
  6. import data from './data';
  7. type Props = {
  8. id?: string;
  9. glyph: string;
  10. onClick?: () => void;
  11. onBlur?: () => void;
  12. style?: {};
  13. isActive? : boolean;
  14. };
  15. const Icon: React.FunctionComponent<Props> = ({
  16. glyph,
  17. id = '',
  18. onClick,
  19. onBlur,
  20. style,
  21. isActive = false,
  22. }: Props) => {
  23. const {
  24. Normal,
  25. Hover,
  26. } = data[glyph];
  27. return (
  28. <IconWrapper
  29. isHover={!!Hover}
  30. style={style}
  31. >
  32. {Normal && <Normal data-status="normal" />}
  33. {Hover && <Hover data-status="hover" />}
  34. {isActive && Hover ? <Hover data-status="active" /> : null}
  35. <ClickZone
  36. id={id}
  37. tabIndex={0}
  38. onClick={onClick}
  39. onBlur={onBlur}
  40. />
  41. </IconWrapper>
  42. );
  43. };
  44. export default Icon;