mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
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.
66 lines
1.6 KiB
JavaScript
66 lines
1.6 KiB
JavaScript
import React, { useLayoutEffect, useRef } from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import classnames from 'classnames'
|
|
|
|
const CHECKBOX_STATE = {
|
|
CHECKED: 'CHECKED',
|
|
INDETERMINATE: 'INDETERMINATE',
|
|
UNCHECKED: 'UNCHECKED',
|
|
}
|
|
|
|
export const { CHECKED, INDETERMINATE, UNCHECKED } = CHECKBOX_STATE
|
|
|
|
const CheckBox = ({ className, disabled, id, onClick, checked, title }) => {
|
|
if (typeof checked === 'boolean') {
|
|
checked = checked
|
|
? CHECKBOX_STATE.CHECKED
|
|
: CHECKBOX_STATE.UNCHECKED
|
|
}
|
|
const ref = useRef(null)
|
|
useLayoutEffect(() => {
|
|
ref.current.indeterminate = checked === CHECKBOX_STATE.INDETERMINATE
|
|
}, [checked])
|
|
|
|
return (
|
|
<input
|
|
checked={checked === CHECKBOX_STATE.CHECKED}
|
|
className={classnames('check-box', className, {
|
|
'far fa-square': checked === CHECKBOX_STATE.UNCHECKED,
|
|
'fa fa-check-square check-box__checked': checked === CHECKBOX_STATE.CHECKED,
|
|
'fa fa-minus-square check-box__indeterminate': checked === CHECKBOX_STATE.INDETERMINATE,
|
|
})}
|
|
disabled={disabled}
|
|
id={id}
|
|
onClick={
|
|
onClick
|
|
? (event) => {
|
|
event.preventDefault()
|
|
onClick()
|
|
}
|
|
: null
|
|
}
|
|
readOnly
|
|
ref={ref}
|
|
title={title}
|
|
type="checkbox"
|
|
/>
|
|
)
|
|
}
|
|
|
|
CheckBox.propTypes = {
|
|
className: PropTypes.string,
|
|
disabled: PropTypes.bool,
|
|
id: PropTypes.string,
|
|
onClick: PropTypes.func,
|
|
checked: PropTypes.oneOf([...Object.keys(CHECKBOX_STATE), true, false]).isRequired,
|
|
title: PropTypes.string,
|
|
}
|
|
|
|
CheckBox.defaultProps = {
|
|
className: undefined,
|
|
disabled: false,
|
|
id: undefined,
|
|
}
|
|
|
|
export default CheckBox
|