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;