feat(Settings): Add toggle button
This commit is contained in:
49
common/app/routes/Settings/Toggle-Button/Toggle-Button.jsx
Normal file
49
common/app/routes/Settings/Toggle-Button/Toggle-Button.jsx
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import PropTypes from 'prop-types';
|
||||||
|
import { ToggleButtonGroup as BSBG, ToggleButton as TB } from 'react-bootstrap';
|
||||||
|
|
||||||
|
import ns from './ns.json';
|
||||||
|
|
||||||
|
const propTypes = {
|
||||||
|
onChange: PropTypes.func.isRequired,
|
||||||
|
value: PropTypes.bool.isRequired
|
||||||
|
};
|
||||||
|
|
||||||
|
export default function ToggleButton({
|
||||||
|
onChange,
|
||||||
|
value
|
||||||
|
}) {
|
||||||
|
return (
|
||||||
|
<div className={ `${ns}-container` }>
|
||||||
|
<BSBG
|
||||||
|
name='monthly-email'
|
||||||
|
onChange={ onChange }
|
||||||
|
type='radio'
|
||||||
|
>
|
||||||
|
<TB
|
||||||
|
bsSize='lg'
|
||||||
|
bsStyle='primary'
|
||||||
|
className={ value && 'active' }
|
||||||
|
disabled={ value }
|
||||||
|
type='radio'
|
||||||
|
value={ 1 }
|
||||||
|
>
|
||||||
|
On
|
||||||
|
</TB>
|
||||||
|
<TB
|
||||||
|
bsSize='lg'
|
||||||
|
bsStyle='primary'
|
||||||
|
className={ !value && 'active' }
|
||||||
|
disabled={ !value }
|
||||||
|
type='radio'
|
||||||
|
value={ 2 }
|
||||||
|
>
|
||||||
|
Off
|
||||||
|
</TB>
|
||||||
|
</BSBG>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
ToggleButton.displayName = 'ToggleButton';
|
||||||
|
ToggleButton.propTypes = propTypes;
|
1
common/app/routes/Settings/Toggle-Button/index.js
Normal file
1
common/app/routes/Settings/Toggle-Button/index.js
Normal file
@ -0,0 +1 @@
|
|||||||
|
export { default } from './Toggle-Button.jsx';
|
1
common/app/routes/Settings/Toggle-Button/ns.json
Normal file
1
common/app/routes/Settings/Toggle-Button/ns.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
"toggle"
|
20
common/app/routes/Settings/Toggle-Button/toggle.less
Normal file
20
common/app/routes/Settings/Toggle-Button/toggle.less
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
@ns: toggle;
|
||||||
|
|
||||||
|
.@{ns}-container > .btn-group {
|
||||||
|
float: right;
|
||||||
|
.btn {
|
||||||
|
margin-top: 20px;
|
||||||
|
}
|
||||||
|
.btn[disabled] {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
float: none;
|
||||||
|
.btn {
|
||||||
|
margin-top: 10px;
|
||||||
|
margin-bottom: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
2
common/app/routes/Settings/index.less
Normal file
2
common/app/routes/Settings/index.less
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
&{ @import "./settings.less"; }
|
||||||
|
&{ @import "./Toggle-Button/toggle.less"; }
|
@ -1,2 +1,2 @@
|
|||||||
&{ @import "./Challenges/challenges.less"; }
|
&{ @import "./Challenges/challenges.less"; }
|
||||||
&{ @import "./Settings/settings.less"; }
|
&{ @import "./Settings/index.less"; }
|
||||||
|
Reference in New Issue
Block a user