summaryrefslogtreecommitdiffstats
path: root/src/components/atoms/icons/plus-minus.tsx
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-04-04 18:46:05 +0200
committerArmand Philippot <git@armandphilippot.com>2022-04-04 18:46:05 +0200
commite8bac61a7f0be6c60624b00e06ab8d00efc932f8 (patch)
tree7b8920512e79edb006f3ff85c290f5ef0a9b1c3b /src/components/atoms/icons/plus-minus.tsx
parent8a4fbf91b0ffdcb0ec38105f918ce6f90e6ec161 (diff)
chore: add a PlusMinus icon component
Diffstat (limited to 'src/components/atoms/icons/plus-minus.tsx')
-rw-r--r--src/components/atoms/icons/plus-minus.tsx45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/components/atoms/icons/plus-minus.tsx b/src/components/atoms/icons/plus-minus.tsx
new file mode 100644
index 0000000..1a6f7b0
--- /dev/null
+++ b/src/components/atoms/icons/plus-minus.tsx
@@ -0,0 +1,45 @@
+import { FC } from 'react';
+import styles from './plus-minus.module.scss';
+
+type PlusMinusProps = {
+ /**
+ * Adds additional classes.
+ */
+ additionalClasses?: string;
+ /**
+ * An accessible name.
+ */
+ ariaLabel?: string;
+ /**
+ * Should be hidden for accessibility. Default: true.
+ */
+ ariaHidden?: boolean;
+ /**
+ * Which state should be displayed.
+ */
+ state: 'plus' | 'minus';
+};
+
+/**
+ * PlusMinus component
+ *
+ * Render a plus or a minus icon.
+ */
+const PlusMinus: FC<PlusMinusProps> = ({
+ additionalClasses,
+ ariaHidden = true,
+ ariaLabel,
+ state,
+}) => {
+ const stateClass = `icon--${state}`;
+
+ return (
+ <div
+ className={`${styles.icon} ${styles[stateClass]} ${additionalClasses}`}
+ aria-label={ariaLabel}
+ aria-hidden={ariaHidden}
+ ></div>
+ );
+};
+
+export default PlusMinus;