@ -11,6 +11,7 @@ import TrackPage from 'analytics/TrackPage'
import Button from 'components/base/Button'
import Button from 'components/base/Button'
import Box from 'components/base/Box'
import Box from 'components/base/Box'
import Text from 'components/base/Text'
import Text from 'components/base/Text'
import Select from 'components/base/Select'
import ProgressCircle from 'components/ProgressCircle'
import ProgressCircle from 'components/ProgressCircle'
import TranslatedError from 'components/TranslatedError'
import TranslatedError from 'components/TranslatedError'
import ExclamationCircleThin from 'icons/ExclamationCircleThin'
import ExclamationCircleThin from 'icons/ExclamationCircleThin'
@ -129,7 +130,7 @@ type Props = {
confirmText ? : string ,
confirmText ? : string ,
cancelText ? : string ,
cancelText ? : string ,
onReject : Function ,
onReject : Function ,
repair : ? string => * ,
repair : ( ? string ) => * ,
t : T ,
t : T ,
isLoading ? : boolean ,
isLoading ? : boolean ,
analyticsName : string ,
analyticsName : string ,
@ -138,7 +139,22 @@ type Props = {
error ? : Error ,
error ? : Error ,
}
}
class RepairModal extends PureComponent < Props > {
const options = [ { value : 'generic' } , { value : '0_8' } , { value : '0_9' } ]
class RepairModal extends PureComponent < Props , * > {
state = {
selectedOption : options [ 0 ] ,
}
onChange = selectedOption => {
this . setState ( { selectedOption } )
}
renderOption = option => ( option && this . props . t ( ` settings.repairDevice. ${ option . value } ` ) ) || null
renderValue = option =>
( option && this . props . t ( ` settings.repairDevice. ${ option . data . value } ` ) ) || null
render ( ) {
render ( ) {
const {
const {
cancellable ,
cancellable ,
@ -157,6 +173,7 @@ class RepairModal extends PureComponent<Props> {
error ,
error ,
... props
... props
} = this . props
} = this . props
const { selectedOption } = this . state
return (
return (
< Modal
< Modal
@ -175,37 +192,36 @@ class RepairModal extends PureComponent<Props> {
< DisclaimerStep desc = { desc } / >
< DisclaimerStep desc = { desc } / >
) }
) }
{ ! isLoading && ! error ? (
< Box py = { 2 } px = { 4 } >
< Select
value = { selectedOption }
onChange = { this . onChange }
autoFocus
options = { options }
renderOption = { this . renderOption }
renderValue = { this . renderValue }
/ >
< / B o x >
) : null }
{ ! isLoading ? (
{ ! isLoading ? (
< ModalFooter horizontal align = "center" justify = "space-between" flow = { 2 } >
< ModalFooter horizontal align = "center" justify = "flex-end " flow = { 2 } >
{ error ? < Button onClick = { onReject } > { t ( ` common.close ` ) } < / B u t t o n > : n u l l }
{ error ? < Button onClick = { onReject } > { t ( ` common.close ` ) } < / B u t t o n > : n u l l }
{ error ? null : (
{ error ? null : (
< >
< >
< Button
< Button
onClick = { ( ) => repair ( ) }
onClick = { ( ) =>
primary = { ! isDanger }
repair (
danger = { isDanger }
selectedOption . value === 'generic' ? undefined : selectedOption . value ,
isLoading = { isLoading }
)
disabled = { isLoading }
}
>
{ t ( 'settings.repairDevice.generic' ) }
< / B u t t o n >
< Button
onClick = { ( ) => repair ( "0.8" ) }
primary = { ! isDanger }
danger = { isDanger }
isLoading = { isLoading }
disabled = { isLoading }
>
{ t ( 'settings.repairDevice.0_8' ) }
< / B u t t o n >
< Button
onClick = { ( ) => repair ( "0.9" ) }
primary = { ! isDanger }
primary = { ! isDanger }
danger = { isDanger }
danger = { isDanger }
isLoading = { isLoading }
isLoading = { isLoading }
disabled = { isLoading }
disabled = { isLoading }
>
>
{ t ( 'settings.repairDevice.0_9 ' ) }
{ t ( 'settings.repairDevice.button' ) }
< / B u t t o n >
< / B u t t o n >
< / >
< / >
) }
) }