Skip to content

Commit

Permalink
Merge pull request #1674 from oasisprotocol/mz/contactNameModal
Browse files Browse the repository at this point in the history
Show contact name in tx confirmation dialog
  • Loading branch information
buberdds authored Sep 25, 2023
2 parents ee78d0d + ddff4e0 commit c8bf08c
Show file tree
Hide file tree
Showing 4 changed files with 166 additions and 16 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,105 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`<ResponsiveGridAddressRow /> should match snapshot 1`] = `
.c0 {
font-family: Rubik;
font-size: 18px;
line-height: 24px;
background-color: #ffffff;
color: #16213E;
box-sizing: border-box;
-webkit-text-size-adjust: 100%;
-ms-text-size-adjust: 100%;
-moz-osx-font-smoothing: grayscale;
-webkit-font-smoothing: antialiased;
}
.c1 {
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
box-sizing: border-box;
max-width: 100%;
min-width: 0;
min-height: 0;
-webkit-flex-direction: column;
-ms-flex-direction: column;
flex-direction: column;
}
.c3 {
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
box-sizing: border-box;
max-width: 100%;
min-width: 0;
min-height: 0;
-webkit-flex-direction: row;
-ms-flex-direction: row;
flex-direction: row;
}
.c2 {
font-size: 18px;
line-height: 24px;
font-weight: bold;
}
.c4 {
font-size: 18px;
line-height: 24px;
}
<div
class="c0"
style="min-height: 100vh;"
>
<div
class="c1"
>
<span
class="c2"
>
To
</span>
</div>
<div
class="c3"
>
<span
class="c2"
>
My Contact
</span>
</div>
<div
class="c1"
>
<span
class="c2"
/>
</div>
<div
class="c3"
>
<span
class="c4"
style="font-family: Roboto mono; letter-spacing: 0;"
>
<span
class="notranslate"
translate="no"
>
oasis1 qq2v zcvx n0js 5uns ch5m e2xz 4kr4 3vca sv0d 5eq4
</span>
</span>
</div>
</div>
`;

exports[`<ResponsiveGridRow /> should render component 1`] = `
.c0 {
display: -webkit-box;
Expand Down
44 changes: 40 additions & 4 deletions src/app/components/ResponsiveGridRow/__tests__/index.test.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import * as React from 'react'
import { render } from '@testing-library/react'

import { ResponsiveGridRow } from '..'
import { render, screen } from '@testing-library/react'
import { Provider } from 'react-redux'
import { configureAppStore } from 'store/configureStore'
import { ThemeProvider } from 'styles/theme/ThemeProvider'
import { ResponsiveGridRow, ResponsiveGridAddressRow } from '..'

describe('<ResponsiveGridRow />', () => {
it('should render component', () => {
Expand All @@ -10,3 +11,38 @@ describe('<ResponsiveGridRow />', () => {
expect(container).toMatchSnapshot()
})
})

const address = 'oasis1qq2vzcvxn0js5unsch5me2xz4kr43vcasv0d5eq4'
const renderComponent = (store: any, address: string) =>
render(
<Provider store={store}>
<ThemeProvider>
<ResponsiveGridAddressRow label="To" value={address} />
</ThemeProvider>
</Provider>,
)

describe('<ResponsiveGridAddressRow />', () => {
let store: ReturnType<typeof configureAppStore>

beforeEach(() => {
store = configureAppStore({
contacts: {
[address]: {
address: address,
name: 'My Contact',
},
},
})
})

it('should match snapshot', () => {
const { container } = renderComponent(store, address)
expect(container.firstChild).toMatchSnapshot()
})

it('should render without a name', () => {
renderComponent(store, 'oasis1qqurxkgavtcjjytneumeclx59ds3avjaqg7ftqph')
expect(screen.queryByText('My Contact')).not.toBeInTheDocument()
})
})
21 changes: 21 additions & 0 deletions src/app/components/ResponsiveGridRow/index.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
import { useSelector } from 'react-redux'
import { Box } from 'grommet/es6/components/Box'
import { Text } from 'grommet/es6/components/Text'
import React, { memo } from 'react'
import { selectContact } from 'app/state/contacts/selectors'
import { PrettyAddress } from '../PrettyAddress'

interface ResponsiveGridRowProps {
label: React.ReactNode
Expand All @@ -17,3 +20,21 @@ export const ResponsiveGridRow = memo(({ label, value }: ResponsiveGridRowProps)
</>
)
})

interface ResponsiveGridAddressRowProps {
label: string
value: string
}

export const ResponsiveGridAddressRow = ({ label, value }: ResponsiveGridAddressRowProps) => {
const contactAddress = useSelector(selectContact(value))

return (
<>
{contactAddress && (
<ResponsiveGridRow label={label} value={<Text weight="bold">{contactAddress.name}</Text>} />
)}
<ResponsiveGridRow label={contactAddress ? '' : label} value={<PrettyAddress address={value} />} />
</>
)
}
17 changes: 5 additions & 12 deletions src/app/components/TransactionPreview/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,7 @@ import { ResponsiveContext } from 'grommet/es6/contexts/ResponsiveContext'
import React, { memo, useContext } from 'react'

import { AmountFormatter } from '../AmountFormatter'
import { PrettyAddress } from '../PrettyAddress'
import { ResponsiveGridRow } from '../ResponsiveGridRow'
import { ResponsiveGridRow, ResponsiveGridAddressRow } from '../ResponsiveGridRow'
import { TransactionPreview as Preview } from 'app/state/transaction/types'
import { useTranslation } from 'react-i18next'
import { TransactionTypeFormatter } from '../TransactionTypeFormatter'
Expand All @@ -32,20 +31,14 @@ export const TransactionPreview = memo((props: Props) => {
label={t('transaction.preview.type', 'Type')}
value={<TransactionTypeFormatter type={preview.transaction.type} />}
/>
<ResponsiveGridRow
label={t('transaction.preview.from', 'From')}
value={<PrettyAddress address={walletAddress} />}
/>
<ResponsiveGridAddressRow label={t('transaction.preview.from', 'From')} value={walletAddress} />
{preview.transaction.type === 'transfer' && (
<ResponsiveGridRow
label={t('transaction.preview.to', 'To')}
value={<PrettyAddress address={preview.transaction.to} />}
/>
<ResponsiveGridAddressRow label={t('transaction.preview.to', 'To')} value={preview.transaction.to} />
)}
{(preview.transaction.type === 'addEscrow' || preview.transaction.type === 'reclaimEscrow') && (
<ResponsiveGridRow
<ResponsiveGridAddressRow
label={t('transaction.preview.validator', 'Validator')}
value={<PrettyAddress address={preview.transaction.validator} />}
value={preview.transaction.validator}
/>
)}
<ResponsiveGridRow
Expand Down

0 comments on commit c8bf08c

Please sign in to comment.