Browse Source

Add copy hash on OperationDetail

master
meriadec 7 years ago
parent
commit
7c01304f91
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 42
      src/components/modals/OperationDetails.js
  2. 2
      src/components/modals/Receive/index.js

42
src/components/modals/OperationDetails.js

@ -16,6 +16,7 @@ import { MODAL_OPERATION_DETAILS } from 'config/constants'
import { getMarketColor } from 'styles/helpers' import { getMarketColor } from 'styles/helpers'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import CopyToClipboard from 'components/base/CopyToClipboard'
import GradientBox from 'components/GradientBox' import GradientBox from 'components/GradientBox'
import GrowScroll from 'components/base/GrowScroll' import GrowScroll from 'components/base/GrowScroll'
import Button from 'components/base/Button' import Button from 'components/base/Button'
@ -28,6 +29,7 @@ import { createStructuredSelector, createSelector } from 'reselect'
import { accountSelector } from 'reducers/accounts' import { accountSelector } from 'reducers/accounts'
import { currencySettingsForAccountSelector, marketIndicatorSelector } from 'reducers/settings' import { currencySettingsForAccountSelector, marketIndicatorSelector } from 'reducers/settings'
import IconCopy from 'icons/Copy'
import IconChevronRight from 'icons/ChevronRight' import IconChevronRight from 'icons/ChevronRight'
import CounterValue from 'components/CounterValue' import CounterValue from 'components/CounterValue'
import ConfirmationCheck from 'components/OperationsList/ConfirmationCheck' import ConfirmationCheck from 'components/OperationsList/ConfirmationCheck'
@ -43,11 +45,37 @@ const OpDetailsTitle = styled(Box).attrs({
letter-spacing: 2px; letter-spacing: 2px;
` `
const CopyBtn = styled(Box).attrs({
horizontal: true,
flow: 1,
align: 'center',
color: 'wallet',
cursor: 'pointer',
ff: 'Open Sans|SemiBold',
})`
background: white;
position: absolute;
top: 0;
right: 0;
bottom: 0;
padding-left: 20px;
background: linear-gradient(to right, rgba(255, 255, 255, 0), #ffffff 20%);
`
const OpDetailsData = styled(Box).attrs({ const OpDetailsData = styled(Box).attrs({
ff: 'Open Sans', ff: 'Open Sans',
color: 'smoke', color: 'smoke',
fontSize: 4, fontSize: 4,
})`` relative: true,
})`
${CopyBtn} {
display: none;
}
&:hover ${CopyBtn} {
display: flex;
}
`
const CanSelect = styled.div` const CanSelect = styled.div`
user-select: text; user-select: text;
@ -170,7 +198,7 @@ const OperationDetails = connect(mapStateToProps)((props: Props) => {
</Box> </Box>
<Box flex={1}> <Box flex={1}>
<OpDetailsTitle>{t('app:operationDetails.status')}</OpDetailsTitle> <OpDetailsTitle>{t('app:operationDetails.status')}</OpDetailsTitle>
<OpDetailsData color={isConfirmed ? 'positiveGreen' : null} horizontal> <OpDetailsData color={isConfirmed ? 'positiveGreen' : null} horizontal flow={1}>
<Box> <Box>
{isConfirmed {isConfirmed
? t('app:operationDetails.confirmed') ? t('app:operationDetails.confirmed')
@ -185,6 +213,16 @@ const OperationDetails = connect(mapStateToProps)((props: Props) => {
<OpDetailsTitle>{t('app:operationDetails.identifier')}</OpDetailsTitle> <OpDetailsTitle>{t('app:operationDetails.identifier')}</OpDetailsTitle>
<OpDetailsData> <OpDetailsData>
<Ellipsis canSelect>{hash}</Ellipsis> <Ellipsis canSelect>{hash}</Ellipsis>
<CopyToClipboard
data={hash}
render={copy => (
<CopyBtn onClick={copy}>
<IconCopy size={16} />
<span>{t('app:common.copy')}</span>
</CopyBtn>
)}
/>
</OpDetailsData> </OpDetailsData>
</Box> </Box>
<B /> <B />

2
src/components/modals/Receive/index.js

@ -54,7 +54,7 @@ export type StepProps = DefaultStepProps & {
onResetSkip: void => void, onResetSkip: void => void,
onChangeAccount: (?Account) => void, onChangeAccount: (?Account) => void,
onChangeAppOpened: boolean => void, onChangeAppOpened: boolean => void,
onChangeAddressVerified: ?boolean => void, onChangeAddressVerified: (?boolean) => void,
} }
const createSteps = ({ t }: { t: T }) => [ const createSteps = ({ t }: { t: T }) => [

Loading…
Cancel
Save