1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

replace icons with Checkbox component (#8830)

in both permission flows the checkboxes were using the fa-check icon, and in the case
of the connected accounts popover the color of the icon was wrong. It occurred to me
while simply fixing that color would have been easier, we will be adding permissions
at some point in the future that a user will be able to 'uncheck'. This PR replaces
the usages of those icons with the Checkbox component that is equipped to handle the
interactivity of checking/unchecking.
This commit is contained in:
Brad Decker 2020-06-23 09:26:33 -05:00 committed by GitHub
parent 3673d69816
commit 41c8e486af
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 26 additions and 19 deletions

View File

@ -1,6 +1,7 @@
import classnames from 'classnames' import classnames from 'classnames'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import React, { PureComponent } from 'react' import React, { PureComponent } from 'react'
import CheckBox from '../../ui/check-box'
export default class ConnectedAccountsPermissions extends PureComponent { export default class ConnectedAccountsPermissions extends PureComponent {
static contextTypes = { static contextTypes = {
@ -57,7 +58,8 @@ export default class ConnectedAccountsPermissions extends PureComponent {
<ul className="connected-accounts-permissions__list"> <ul className="connected-accounts-permissions__list">
{permissions.map(({ key: permissionName }) => ( {permissions.map(({ key: permissionName }) => (
<li key={permissionName} className="connected-accounts-permissions__list-item"> <li key={permissionName} className="connected-accounts-permissions__list-item">
<i className="fas fa-check-square" />{t(permissionName)} <CheckBox checked disabled id={permissionName} className="connected-accounts-permissions__checkbox" />
<label htmlFor={permissionName}>{t(permissionName)}</label>
</li> </li>
))} ))}
</ul> </ul>

View File

@ -41,13 +41,11 @@
&__list-item { &__list-item {
display: flex; display: flex;
i {
display: block;
padding-right: 8px;
font-size: 18px;
color: $Grey-800;
} }
& &__checkbox {
margin: 0 8px 0 0;
font-size: 18px;
} }
&__list-container { &__list-container {

View File

@ -62,11 +62,6 @@
display: flex; display: flex;
align-items: center; align-items: center;
i {
font-size: 1.4rem;
color: $Grey-200;
}
label { label {
font-size: 14px; font-size: 14px;
margin-left: 16px; margin-left: 16px;
@ -75,6 +70,11 @@
} }
} }
& &__checkbox {
font-size: 1.4rem;
margin: 0;
}
&__content-container { &__content-container {
display: flex; display: flex;
flex-direction: column; flex-direction: column;

View File

@ -2,6 +2,7 @@ import PropTypes from 'prop-types'
import React, { PureComponent } from 'react' import React, { PureComponent } from 'react'
import PermissionsConnectHeader from '../../permissions-connect-header' import PermissionsConnectHeader from '../../permissions-connect-header'
import Tooltip from '../../../ui/tooltip-v2' import Tooltip from '../../../ui/tooltip-v2'
import CheckBox from '../../../ui/check-box'
export default class PermissionPageContainerContent extends PureComponent { export default class PermissionPageContainerContent extends PureComponent {
@ -33,6 +34,8 @@ export default class PermissionPageContainerContent extends PureComponent {
const description = t(permissionName) const description = t(permissionName)
// don't allow deselecting eth_accounts // don't allow deselecting eth_accounts
const isDisabled = permissionName === 'eth_accounts' const isDisabled = permissionName === 'eth_accounts'
const isChecked = Boolean(selectedPermissions[permissionName])
const title = isChecked ? t('permissionCheckedIconDescription') : t('permissionUncheckedIconDescription')
return ( return (
<div <div
@ -44,11 +47,14 @@ export default class PermissionPageContainerContent extends PureComponent {
} }
}} }}
> >
{ selectedPermissions[permissionName] <CheckBox
? <i title={t('permissionCheckedIconDescription')} className="fa fa-check-square" /> disabled={isDisabled}
: <i title={t('permissionUncheckedIconDescription')} className="fa fa-square" /> id={permissionName}
} className="permission-approval-container__checkbox"
<label>{description}</label> checked={isChecked}
title={title}
/>
<label htmlFor={permissionName}>{description}</label>
</div> </div>
) )
}) })

View File

@ -10,7 +10,7 @@ const CHECKBOX_STATE = {
export const { CHECKED, INDETERMINATE, UNCHECKED } = CHECKBOX_STATE export const { CHECKED, INDETERMINATE, UNCHECKED } = CHECKBOX_STATE
const CheckBox = ({ className, disabled, id, onClick, checked }) => { const CheckBox = ({ className, disabled, id, onClick, checked, title }) => {
if (typeof checked === 'boolean') { if (typeof checked === 'boolean') {
checked = checked checked = checked
? CHECKBOX_STATE.CHECKED ? CHECKBOX_STATE.CHECKED
@ -41,6 +41,7 @@ const CheckBox = ({ className, disabled, id, onClick, checked }) => {
} }
readOnly readOnly
ref={ref} ref={ref}
title={title}
type="checkbox" type="checkbox"
/> />
) )
@ -52,6 +53,7 @@ CheckBox.propTypes = {
id: PropTypes.string, id: PropTypes.string,
onClick: PropTypes.func, onClick: PropTypes.func,
checked: PropTypes.oneOf([...Object.keys(CHECKBOX_STATE), true, false]).isRequired, checked: PropTypes.oneOf([...Object.keys(CHECKBOX_STATE), true, false]).isRequired,
title: PropTypes.string,
} }
CheckBox.defaultProps = { CheckBox.defaultProps = {

View File

@ -18,6 +18,5 @@
&:disabled { &:disabled {
color: $Grey-100; color: $Grey-100;
cursor: not-allowed; cursor: not-allowed;
opacity: 0.5;
} }
} }