Add checkbox component
Signed-off-by: Ajay Bura <ajbura@gmail.com>
This commit is contained in:
parent
fd9f734de1
commit
d3dcb320f4
2 changed files with 67 additions and 0 deletions
30
src/app/atoms/button/Checkbox.jsx
Normal file
30
src/app/atoms/button/Checkbox.jsx
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
import React from 'react';
|
||||||
|
import PropTypes from 'prop-types';
|
||||||
|
import './Checkbox.scss';
|
||||||
|
|
||||||
|
function Checkbox({ variant, isActive, onToggle }) {
|
||||||
|
const className = `checkbox checkbox-${variant}${isActive ? ' checkbox--active' : ''}`;
|
||||||
|
if (onToggle === null) return <span className={className} />;
|
||||||
|
return (
|
||||||
|
// eslint-disable-next-line jsx-a11y/control-has-associated-label
|
||||||
|
<button
|
||||||
|
onClick={() => onToggle(!isActive)}
|
||||||
|
className={className}
|
||||||
|
type="button"
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
Checkbox.defaultProps = {
|
||||||
|
variant: 'primary',
|
||||||
|
isActive: false,
|
||||||
|
onToggle: null,
|
||||||
|
};
|
||||||
|
|
||||||
|
Checkbox.propTypes = {
|
||||||
|
variant: PropTypes.oneOf(['primary', 'positive', 'caution', 'danger']),
|
||||||
|
isActive: PropTypes.bool,
|
||||||
|
onToggle: PropTypes.func,
|
||||||
|
};
|
||||||
|
|
||||||
|
export default Checkbox;
|
37
src/app/atoms/button/Checkbox.scss
Normal file
37
src/app/atoms/button/Checkbox.scss
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
@use '../../partials/flex';
|
||||||
|
|
||||||
|
.checkbox {
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
|
||||||
|
border-radius: calc(var(--bo-radius) / 2);
|
||||||
|
background-color: var(--bg-surface-border);
|
||||||
|
box-shadow: var(--bs-surface-border);
|
||||||
|
cursor: pointer;
|
||||||
|
@extend .cp-fx__row--c-c;
|
||||||
|
|
||||||
|
&--active {
|
||||||
|
background-color: black;
|
||||||
|
&::before {
|
||||||
|
content: "";
|
||||||
|
display: inline-block;
|
||||||
|
width: 12px;
|
||||||
|
height: 6px;
|
||||||
|
border: 6px solid white;
|
||||||
|
border-width: 0 0 3px 3px;
|
||||||
|
transform: rotateZ(-45deg) translate(1px, -1px);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.checkbox-primary.checkbox--active {
|
||||||
|
background-color: var(--bg-primary);
|
||||||
|
}
|
||||||
|
.checkbox-positive.checkbox--active {
|
||||||
|
background-color: var(--bg-positive);
|
||||||
|
}
|
||||||
|
.checkbox-caution.checkbox--active {
|
||||||
|
background-color: var(--bg-caution);
|
||||||
|
}
|
||||||
|
.checkbox-danger.checkbox--active {
|
||||||
|
background-color: var(--bg-danger);
|
||||||
|
}
|
Loading…
Reference in a new issue