diff --git a/web/components/checkbox.css b/web/components/checkbox.css
new file mode 100644
index 000000000..c9444e5ff
--- /dev/null
+++ b/web/components/checkbox.css
@@ -0,0 +1,25 @@
+.checkbox {
+ appearance: none;
+ background-color: transparent;
+ width: 24px;
+ height: 24px;
+ border: 1px solid var(--radio-border);
+ border-radius: 3.6px;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+}
+
+.checkbox::before {
+ content: '';
+ width: 16px;
+ height: 16px;
+ border-radius: 2.4px;
+ transform: scale(0);
+ transition: 120ms transform ease-in-out;
+ background-color: var(--radio-color);
+}
+
+.checkbox:checked::before {
+ transform: scale(1);
+}
diff --git a/web/components/checkbox.react.js b/web/components/checkbox.react.js
new file mode 100644
index 000000000..ed4f55e7f
--- /dev/null
+++ b/web/components/checkbox.react.js
@@ -0,0 +1,23 @@
+// @flow
+import * as React from 'react';
+
+import css from './checkbox.css';
+
+type Props = {
+ +checked: boolean,
+ +readOnly?: boolean,
+};
+
+function Checkbox(props: Props): React.Node {
+ const { checked, readOnly = true } = props;
+ return (
+
+ );
+}
+
+export default Checkbox;
diff --git a/web/components/enum-settings-option.css b/web/components/enum-settings-option.css
index 9e07c678e..740ee0270 100644
--- a/web/components/enum-settings-option.css
+++ b/web/components/enum-settings-option.css
@@ -1,36 +1,49 @@
div.optionContainer {
display: flex;
padding: 16px 32px 16px 16px;
align-items: center;
border-radius: 8px;
+ cursor: pointer;
}
div.optionContainerSelected {
background: var(--notification-settings-option-selected-bg);
}
div.optionIcon {
margin-right: 24px;
}
+div.optionIconTop {
+ align-self: flex-start;
+}
+
+div.optionIconCenter {
+ align-self: center;
+}
+
+div.optionIconBottom {
+ align-self: flex-end;
+}
+
div.optionContent {
display: flex;
flex-direction: column;
flex: 1;
line-height: var(--line-height-text);
}
div.optionTitle {
font-size: var(--m-font-16);
font-weight: var(--semi-bold);
color: var(--notification-settings-option-title-color);
margin-bottom: 4px;
}
div.optionDescription {
font-size: var(--xs-font-12);
color: var(--notification-settings-option-color);
display: flex;
flex-direction: column;
row-gap: 4px;
}
diff --git a/web/components/enum-settings-option.react.js b/web/components/enum-settings-option.react.js
index bfa270cf5..3e99ddd1d 100644
--- a/web/components/enum-settings-option.react.js
+++ b/web/components/enum-settings-option.react.js
@@ -1,61 +1,97 @@
// @flow
import classnames from 'classnames';
import * as React from 'react';
+import Checkbox from './checkbox.react';
import EnumSettingsOptionInfo from './enum-settings-option-info.react.js';
import css from './enum-settings-option.css';
import Radio from './radio.react';
+const iconPositionClassnames = {
+ top: css.optionIconTop,
+ center: css.optionIconCenter,
+ bottom: css.optionIconBottom,
+};
+
+type InputType = 'radio' | 'checkbox';
+type IconPosition = $Keys;
+
type Props = {
+selected: boolean,
+onSelect: () => void,
+icon: React.Node,
+title: string,
+ +type?: InputType,
+ +iconPosition?: IconPosition,
+statements: $ReadOnlyArray<{
+statement: string,
+isStatementValid: boolean,
+styleStatementBasedOnValidity: boolean,
}>,
};
function EnumSettingsOption(props: Props): React.Node {
- const { icon, title, statements, selected, onSelect } = props;
+ const {
+ icon,
+ title,
+ statements,
+ selected,
+ onSelect,
+ type = 'radio',
+ iconPosition = 'center',
+ } = props;
const descriptionItems = React.useMemo(
() =>
statements.map(
({ statement, isStatementValid, styleStatementBasedOnValidity }) => (
{statement}
),
),
[selected, statements],
);
+ const inputIcon = React.useMemo(
+ () =>
+ type === 'checkbox' ? (
+
+ ) : (
+
+ ),
+ [type, selected],
+ );
+
const optionContainerClasses = React.useMemo(
() =>
classnames(css.optionContainer, {
[css.optionContainerSelected]: selected,
}),
[selected],
);
+
+ const optionIconClasses = React.useMemo(
+ () => classnames(css.optionIcon, iconPositionClassnames[iconPosition]),
+ [iconPosition],
+ );
+
return (
-
{icon}
+
{icon}
{title}
{descriptionItems}
-
+ {inputIcon}
);
}
export default EnumSettingsOption;