Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feature(resolver): multiresolution new features #3004

Merged
merged 2 commits into from
Jan 16, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
import React from 'react'
import {StyleSheet, Text, TouchableOpacity, View, ViewProps} from 'react-native'
import LinearGradient from 'react-native-linear-gradient'

import {Spacer} from '../../../../components/Spacer/Spacer'
import {COLORS} from '../../../../theme'

type ButtonGroupProps<T> = {
labels: T[]
Expand All @@ -25,15 +25,22 @@ export const ButtonGroup = <T extends string>({
<>
{index > 0 && <Spacer width={8} />}

<TouchableOpacity
onPress={() => {
setSelected(index)
onSelect(index, label)
}}
style={[styles.button, index === selected && styles.selected]}
<LinearGradient
style={{borderRadius: 8, padding: 3}}
start={{x: 0, y: 0}}
end={{x: 1, y: 1}}
colors={['#C6F7ED', '#E4E8F7']}
>
<Text style={styles.label}>{label}</Text>
</TouchableOpacity>
<TouchableOpacity
onPress={() => {
setSelected(index)
onSelect(index, label)
}}
style={[styles.button, index !== selected && styles.selected]}
>
<Text style={styles.label}>{label}</Text>
</TouchableOpacity>
</LinearGradient>
</>
))}
</View>
Expand All @@ -47,13 +54,13 @@ const styles = StyleSheet.create({
button: {
paddingHorizontal: 8,
paddingVertical: 8,
borderRadius: 8,
borderRadius: 6,
},
selected: {
backgroundColor: COLORS.BORDER_GRAY,
backgroundColor: 'white',
},
label: {
color: COLORS.BLACK,
color: '#3154CB',
fontFamily: 'Rubik-Medium',
fontWeight: '500',
lineHeight: 24,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -185,7 +185,7 @@ const targetsReducer = (state: SendState, action: TargetAction) => {
if (index === selectedTargetIndex) {
if (addressRecords !== undefined) {
const keys = Object.keys(addressRecords).filter(isNameServer)
const nameServer = keys[0]
const nameServer = keys.length === 1 ? keys[0] : undefined
target.receiver.selectedNameServer = nameServer
if (nameServer !== undefined) {
target.entry.address = addressRecords[nameServer] ?? ''
Expand Down
5 changes: 0 additions & 5 deletions apps/wallet-mobile/src/features/Send/common/strings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,6 @@ export const useStrings = () => {
helperMemoErrorTooLong: intl.formatMessage(messages.helperMemoErrorTooLong),
helperMemoInstructions: intl.formatMessage(messages.helperMemoInstructions),
helperResolverErrorDomainNotFound: intl.formatMessage(messages.helperResolverErrorDomainNotFound),
manyNameServersWarning: intl.formatMessage(messages.manyNameServersWarning),
max: intl.formatMessage(globalMessages.max),
memoLabel: intl.formatMessage(messages.memoLabel),
minPrimaryBalanceForTokens: intl.formatMessage(amountInputErrorMessages.minPrimaryBalanceForTokens),
Expand Down Expand Up @@ -288,10 +287,6 @@ export const messages = defineMessages({
defaultMessage:
'!!!Yoroi offers a unique chance to use custom and lightning-fast alternatives to the traditional wallet address, such as',
},
manyNameServersWarning: {
id: 'send.warning.resolver.manyNameServers',
defaultMessage: '!!!Multiple name servers found. Please select one.',
},
helperAddressErrorInvalid: {
id: 'send.helper.addressError.invalid',
defaultMessage: '!!!Please enter a valid receiver address, ADA Handle or domain',
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
import {isNameServer, nameServerName} from '@yoroi/resolver'
import {Resolver} from '@yoroi/types'
import * as React from 'react'
import {Animated, StyleSheet, Text, View} from 'react-native'
import {defineMessages, useIntl} from 'react-intl'
import {Animated, StyleSheet, Text as RNText, View} from 'react-native'

import {Icon} from '../../../../../components/Icon'
import {Spacer} from '../../../../../components/Spacer/Spacer'
import {Text} from '../../../../../components/Text'
import {ButtonGroup} from '../../../common/ButtonGroup/ButtonGroup'
import {useSend} from '../../../common/SendContext'
import {useStrings} from '../../../common/strings'

export const SelectNameServer = () => {
const {targets, selectedTargetIndex, nameServerSelectedChanged} = useSend()
Expand All @@ -20,6 +21,7 @@ export const SelectNameServer = () => {

const [animatedValue] = React.useState(new Animated.Value(0))
const [waitAnimation, setWaitAnimation] = React.useState(false)

React.useEffect(() => {
animatedValue.stopAnimation()
if (shouldShow) {
Expand All @@ -43,35 +45,37 @@ export const SelectNameServer = () => {
nameServerSelectedChanged(nameServer)
}

const initial = receiver.selectedNameServer ? labels.indexOf(nameServerName[receiver.selectedNameServer]) : 0

return (
<Animated.View style={{opacity: animatedValue}}>
{shouldShow && <Spacer height={16} />}

{(waitAnimation || shouldShow) && (
<>
<ShowManyAddressWarning />
<ButtonGroup labels={labels} onSelect={handleOnSelectNameServer} />

<Spacer height={16} />
{!receiver.selectedNameServer && shouldShow && (
<>
<Spacer height={16} />

<ButtonGroup initial={initial} labels={labels} onSelect={handleOnSelectNameServer} />

<Spacer height={16} />
<ShowManyAddressWarning />
stackchain marked this conversation as resolved.
Show resolved Hide resolved
</>
)}
</>
)}
</Animated.View>
)
}

export const ShowManyAddressWarning = () => {
const strings = useStrings()
const localStrings = useLocalStrings()

return (
<View style={styles.notice}>
<Icon.Info size={30} color="#ECBA09" />

<Spacer height={8} />

<Text style={styles.text}>{strings.manyNameServersWarning}</Text>
<RNText style={styles.text}>{localStrings.manyNameServersWarning}</RNText>
</View>
)
}
Expand All @@ -90,9 +94,24 @@ const styles = StyleSheet.create({
padding: 12,
},
text: {
fontFamily: 'Rubik-Medium',
fontSize: 14,
fontWeight: '500',
lineHeight: 22,
},
})

const bold = {b: (text) => <Text bold>{text}</Text>}

export const useLocalStrings = () => {
const intl = useIntl()

return {
manyNameServersWarning: intl.formatMessage(messages.manyNameServersWarning, bold),
banklesss marked this conversation as resolved.
Show resolved Hide resolved
}
}

export const messages = defineMessages({
manyNameServersWarning: {
id: 'send.warning.resolver.manyNameServers',
defaultMessage: '!!!There are <b>two addresses</b> for this domain. Please SELECT the desired domain.',
},
})
Original file line number Diff line number Diff line change
Expand Up @@ -79,8 +79,6 @@ export const StartMultiTokenTxScreen = () => {

<NotifySupportedNameServers />

<SelectNameServer />

<InputReceiver
value={receiver.resolve}
onChangeText={handleOnChangeReceiver}
Expand All @@ -90,6 +88,8 @@ export const StartMultiTokenTxScreen = () => {
errorText={receiverErrorMessage}
/>

<SelectNameServer />

<Spacer height={16} />

<InputMemo value={memo} onChangeText={handleOnChangeMemo} isValid={!hasMemoError} />
Expand Down
2 changes: 1 addition & 1 deletion apps/wallet-mobile/src/i18n/locales/en-US.json
Original file line number Diff line number Diff line change
Expand Up @@ -773,7 +773,7 @@
"send.helper.addressError.wrongNetwork": "Please enter an address for the current wallet network",
"send.helper.resolver.resolvedAddress": "Resolved address",
"send.helper.resolverError.domainNotFound": "Receiver address, ADA Handle or domain you entered doesn't exist. Please double-check it and try again",
"send.warning.resolver.manyNameServers": "There are more than one address for this domain. Please choose the desired name server.",
"send.warning.resolver.manyNameServers": "There are <b>two addresses</b> for this domain. Please SELECT the desired domain.",
"swap.listOrders.card.buttonText": "Cancel order",
"swap.listOrders.completed": "completed orders",
"swap.listOrders.emptyCompletedOrders": "No orders completed yet",
Expand Down
Loading
Loading