Skip to content

Commit

Permalink
Merge branch 'master' into fix-long-recipient-name
Browse files Browse the repository at this point in the history
  • Loading branch information
LuizAsFight authored Jan 7, 2025
2 parents 609fb91 + 28628cb commit 999a099
Show file tree
Hide file tree
Showing 8 changed files with 253 additions and 160 deletions.
5 changes: 5 additions & 0 deletions .changeset/hip-beds-do.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"fuels-wallet": patch
---

Allow editing network name when adding.
Original file line number Diff line number Diff line change
Expand Up @@ -40,10 +40,17 @@ export function NetworkForm({
}: NetworkFormProps) {
const [isFirstShownTestConnectionBtn, setIsFirstShownTestConnectionBtn] =
useState(false);
const { control, formState } = form;
const { control, formState, setValue } = form;

const url = useWatch({ control, name: 'url' });
const chainId = useWatch({ control, name: 'chainId' });
const customName = useWatch({ control, name: 'name' });

useEffect(() => {
if (isReviewing && chainName) {
setValue('name', chainName);
}
}, [isReviewing, chainName, setValue]);

useEffect(() => {
if (isValid && chainId) {
Expand All @@ -54,12 +61,40 @@ export function NetworkForm({
return (
<Box.Stack css={{ width: '100%' }} gap="$4">
{isReviewing && (
<NetworkReviewCard
headerText="You're adding this network"
name={chainName || ''}
chainId={chainId}
url={url}
/>
<>
<NetworkReviewCard
headerText="You're adding this network"
name={customName || chainName || ''}
chainId={chainId}
url={url}
/>
<ControlledField
control={control}
name="name"
label={
<HelperIcon message="Customize the network name to avoid conflicts">
Network Name
</HelperIcon>
}
isRequired
isInvalid={Boolean(formState.errors?.name)}
render={({ field }) => (
<MotionInput {...animations.slideInTop()}>
<Input.Field
{...field}
id="network-name"
aria-label="Network name"
placeholder={chainName || 'Enter network name'}
/>
</MotionInput>
)}
/>
{formState.errors?.name && (
<Form.ErrorMessage>
{formState.errors.name.message}
</Form.ErrorMessage>
)}
</>
)}
{!isReviewing && (
<>
Expand Down
35 changes: 25 additions & 10 deletions packages/app/src/systems/Network/hooks/useNetworkForm.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import type { NetworkData } from '@fuel-wallet/types';
import { yupResolver } from '@hookform/resolvers/yup';
import { useEffect } from 'react';
import { useForm } from 'react-hook-form';
Expand All @@ -12,11 +13,13 @@ const schema = yup
.object({
name: yup
.string()
.default('')
.test('is-required', 'Name is required', function (value) {
return !this.options?.context?.isEditing || !!value;
}),
url: yup
.string()
.default('')
.test('is-url-valid', 'URL is not valid', isValidNetworkUrl)
.test('is-network-valid', 'Network is not valid', function (url) {
return (
Expand All @@ -26,17 +29,16 @@ const schema = yup
.required('URL is required'),
explorerUrl: yup
.string()
.default('')
.test(
'is-url-valid',
'Explorer URL is not valid',
(url) => !url || isValidNetworkUrl(url)
)
.optional(),
chainId: yup
.mixed<string | number>()
.transform((value) =>
value != null && value !== '' ? Number(value) : undefined
)
.string()
.default('')
.required('Chain ID is required')
.test(
'chainId-match',
Expand All @@ -51,22 +53,26 @@ const schema = yup
.test(
'is-numbers-only',
'Chain ID must contain only numbers',
(value) => value == null || Number.isInteger(value)
(value) => {
if (!value) return true;
const num = Number(value);
return !Number.isNaN(num) && Number.isInteger(num);
}
),
})
.required();

const DEFAULT_VALUES = {
const DEFAULT_VALUES: NetworkFormValues = {
name: '',
url: '',
explorerUrl: '',
chainId: undefined,
chainId: '',
};

export type UseNetworkFormReturn = ReturnType<typeof useNetworkForm>;

export type UseAddNetworkOpts = {
defaultValues?: Maybe<NetworkFormValues>;
defaultValues?: Maybe<Partial<NetworkData>>;
context?: {
providerChainId?: number;
isEditing?: boolean;
Expand All @@ -82,13 +88,22 @@ export function useNetworkForm({ defaultValues, context }: UseAddNetworkOpts) {
resetOptions: {
keepValues: true,
},
defaultValues: defaultValues || DEFAULT_VALUES,
defaultValues: defaultValues
? {
...DEFAULT_VALUES,
...defaultValues,
chainId: defaultValues.chainId?.toString() || '',
}
: DEFAULT_VALUES,
context,
});

useEffect(() => {
if (defaultValues) {
form.reset(defaultValues);
form.reset({
...defaultValues,
chainId: defaultValues.chainId?.toString() || '',
});
}
}, [defaultValues, form]);

Expand Down
5 changes: 4 additions & 1 deletion packages/app/src/systems/Network/machines/networksMachine.ts
Original file line number Diff line number Diff line change
Expand Up @@ -146,8 +146,11 @@ export const networksMachine = createMachine(
},
onDone: [
{
target: 'idle',
target: 'waitingAddNetwork',
cond: FetchMachine.hasError,
actions: assign({
error: (_, ev) => ev.data,
}),
},
{
actions: [
Expand Down
30 changes: 20 additions & 10 deletions packages/app/src/systems/Network/pages/AddNetwork/AddNetwork.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ export function AddNetwork() {
const form = useNetworkForm({ context });
const url = useWatch({ control: form.control, name: 'url' });
const chainId = useWatch({ control: form.control, name: 'chainId' });
const name = useWatch({ control: form.control, name: 'name' });
const isValid =
form.formState.isDirty &&
form.formState.isValid &&
Expand Down Expand Up @@ -61,15 +62,24 @@ export function AddNetwork() {
});
}

function onAddNetwork() {
const name = chainInfoToAdd?.name || '';
handlers.addNetwork({
data: {
chainId: Number(chainId),
name,
url,
},
});
async function onAddNetwork() {
if (!name) return;
try {
await handlers.addNetwork({
data: {
chainId: Number(chainId),
name,
url,
},
});
} catch (error) {
if (error instanceof Error && error.message.includes('already exists')) {
form.setError('name', {
type: 'manual',
message: 'A network with this name already exists',
});
}
}
}

return (
Expand Down Expand Up @@ -101,7 +111,7 @@ export function AddNetwork() {
<Button
onPress={onAddNetwork}
intent="primary"
isDisabled={!isReviewingAddNetwork}
isDisabled={!isReviewingAddNetwork || !name}
isLoading={isLoading}
leftIcon={<Icon icon="Plus" />}
aria-label="Add new network"
Expand Down
8 changes: 6 additions & 2 deletions packages/app/src/systems/Network/services/network.ts
Original file line number Diff line number Diff line change
Expand Up @@ -353,8 +353,12 @@ export class NetworkService {
name,
url,
});
if (network) {
throw new Error('Network with Name or URL already exists');

if (network?.url === url) {
throw new Error('Network with same URL already exists');
}
if (network?.name === name) {
throw new Error('Network with same Name already exists');
}
}

Expand Down
2 changes: 1 addition & 1 deletion packages/docs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@
"gray-matter": "^4.0.3",
"hast-util-heading-rank": "^3.0.0",
"hast-util-to-string": "^3.0.0",
"next": "14.2.15",
"next": "14.2.22",
"next-mdx-remote": "4.4.1",
"plyr-react": "^5.3.0",
"react": "18.3.1",
Expand Down
Loading

0 comments on commit 999a099

Please sign in to comment.