From 56fb817b61474989f433590932eacdfefc4a3835 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Fri, 13 Sep 2024 19:26:36 +0700 Subject: [PATCH 01/75] Update react-query refetchOnMount option to always --- .../profile/[name]/registration/useMoonpayRegistration.ts | 2 +- src/hooks/chain/useBlockTimestamp.ts | 2 +- src/utils/query/reactQuery.ts | 6 +++--- 3 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts b/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts index 769876eae..0329264ad 100644 --- a/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts +++ b/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts @@ -81,7 +81,7 @@ export const useMoonpayRegistration = ( return result || {} }, refetchOnWindowFocus: true, - refetchOnMount: true, + refetchOnMount: 'always', refetchInterval: 1000, refetchIntervalInBackground: true, enabled: !!currentExternalTransactionId && !isCompleted, diff --git a/src/hooks/chain/useBlockTimestamp.ts b/src/hooks/chain/useBlockTimestamp.ts index db8bd192e..865dde78d 100644 --- a/src/hooks/chain/useBlockTimestamp.ts +++ b/src/hooks/chain/useBlockTimestamp.ts @@ -12,7 +12,7 @@ export const useBlockTimestamp = ({ enabled = true }: UseBlockTimestampParameter blockTag: 'latest', query: { enabled, - refetchOnMount: true, + refetchOnMount: 'always', refetchInterval: 1000 * 60 * 5 /* 5 minutes */, staleTime: 1000 * 60 /* 1 minute */, select: (b) => b.timestamp * 1000n, diff --git a/src/utils/query/reactQuery.ts b/src/utils/query/reactQuery.ts index d297288c2..7dd6fef80 100644 --- a/src/utils/query/reactQuery.ts +++ b/src/utils/query/reactQuery.ts @@ -4,8 +4,8 @@ import { hashFn } from 'wagmi/query' export const queryClient = new QueryClient({ defaultOptions: { queries: { - refetchOnWindowFocus: false, - refetchOnMount: true, + refetchOnWindowFocus: true, + refetchOnMount: 'always', staleTime: 1_000 * 12, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: hashFn, @@ -21,7 +21,7 @@ export const refetchOptions: DefaultOptions = { meta: { isRefetchQuery: true, }, - refetchOnMount: true, + refetchOnMount: 'always', queryKeyHashFn: hashFn, }, } From 61ba6ce7091de9f89e22ca9842f07b963d4093fd Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 16 Sep 2024 13:30:29 +0800 Subject: [PATCH 02/75] add ens credentials check --- e2e/specs/stateless/verifications.spec.ts | 73 +++++++++++++ .../pages/profile/[name]/tabs/ProfileTab.tsx | 2 + .../useVerifiedRecords.test.ts | 6 +- .../useVerifiedRecords/useVerifiedRecords.ts | 9 +- .../parseVerificationData.ts | 24 +++-- .../parseDentityVerifiablePresentation.ts | 27 +++++ .../parseOpenIdVerifiablePresentation.test.ts | 4 +- .../parseOpenIdVerifiablePresentation.ts | 23 ++-- .../utils/parseVerifiedCredential.test.ts | 28 +++-- .../utils/parseVerifiedCredential.ts | 101 ++++++++++-------- 10 files changed, 220 insertions(+), 77 deletions(-) create mode 100644 src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts diff --git a/e2e/specs/stateless/verifications.spec.ts b/e2e/specs/stateless/verifications.spec.ts index 706bb1848..1ca030b7d 100644 --- a/e2e/specs/stateless/verifications.spec.ts +++ b/e2e/specs/stateless/verifications.spec.ts @@ -194,6 +194,79 @@ test.describe('Verified records', () => { await expect(profilePage.record('verification', 'dentity')).toBeVisible() await expect(profilePage.record('verification', 'dentity')).toBeVisible() }) + + test('Should not show badges if records match but ens credential fails', async ({ + page, + accounts, + makePageObject, + makeName, + }) => { + const name = await makeName({ + label: 'dentity', + type: 'wrapped', + owner: 'user', + records: { + texts: [ + { + key: 'com.twitter', + value: '@name2', + }, + { + key: 'org.telegram', + value: 'name2', + }, + { + key: 'com.discord', + value: 'name2', + }, + { + key: 'com.github', + value: 'name2', + }, + { + key: VERIFICATION_RECORD_KEY, + value: JSON.stringify([ + `${DENTITY_VPTOKEN_ENDPOINT}?name=name.eth&federated_token=federated_token`, + ]), + }, + { + key: 'com.twitter', + value: '@name2', + }, + ], + }, + }) + + const profilePage = makePageObject('ProfilePage') + + await page.route(`${DENTITY_VPTOKEN_ENDPOINT}*`, async (route) => { + await route.fulfill({ + status: 200, + contentType: 'application/json', + body: JSON.stringify({ + ens_name: name, + eth_address: accounts.getAddress('user2'), + vp_token: makeMockVPToken(['com.twitter', 'com.github', 'com.discord', 'org.telegram']), + }), + }) + }) + + await page.goto(`/${name}`) + + await page.pause() + + await expect(page.getByTestId('profile-section-verifications')).toBeVisible() + + await profilePage.isRecordVerified('text', 'com.twitter', false) + await profilePage.isRecordVerified('text', 'org.telegram', false) + await profilePage.isRecordVerified('text', 'com.github', false) + await profilePage.isRecordVerified('text', 'com.discord', false) + await profilePage.isRecordVerified('verification', 'dentity', false) + await profilePage.isPersonhoodVerified(false) + + await expect(profilePage.record('verification', 'dentity')).toBeVisible() + await expect(profilePage.record('verification', 'dentity')).toBeVisible() + }) }) test.describe('Verify profile', () => { diff --git a/src/components/pages/profile/[name]/tabs/ProfileTab.tsx b/src/components/pages/profile/[name]/tabs/ProfileTab.tsx index 0f75b4be3..67e98b23f 100644 --- a/src/components/pages/profile/[name]/tabs/ProfileTab.tsx +++ b/src/components/pages/profile/[name]/tabs/ProfileTab.tsx @@ -79,6 +79,8 @@ const ProfileTab = ({ nameDetails, name }: Props) => { const { data: verifiedData, appendVerificationProps } = useVerifiedRecords({ verificationsRecord: profile?.texts?.find(({ key }) => key === VERIFICATION_RECORD_KEY)?.value, + ownerAddress: ownerData?.registrant || ownerData?.owner, + name: normalisedName, }) const isOffchainImport = useIsOffchainName({ diff --git a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts index d4f7224fa..d1a2b69c9 100644 --- a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts +++ b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts @@ -1,6 +1,6 @@ import { match } from 'ts-pattern'; import { getVerifiedRecords, parseVerificationRecord } from './useVerifiedRecords'; -import { describe, it, vi, expect, afterAll } from 'vitest'; +import { describe, it, vi, expect } from 'vitest'; import { makeMockVerifiablePresentationData } from '@root/test/mock/makeMockVerifiablePresentationData'; describe('parseVerificationRecord', () => { @@ -23,12 +23,12 @@ describe('parseVerificationRecord', () => { -describe('getVerifiedRecords', () => { +describe.only('getVerifiedRecords', () => { const mockFetch = vi.fn().mockImplementation(async (uri) => match(uri).with('error', () => Promise.reject('error')).otherwise(() => Promise.resolve({ json: () => Promise.resolve(makeMockVerifiablePresentationData('openid'))}))) vi.stubGlobal('fetch', mockFetch) it('should exclude fetches that error from results ', async () => { - const result = await getVerifiedRecords({ queryKey: [{ verificationsRecord: '["error", "regular", "error"]'}]} as any) + const result = await getVerifiedRecords({ queryKey: [{ verificationsRecord: '["error", "regular", "error"]'}, '0x123']} as any) expect(result).toHaveLength(6) }) diff --git a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts index 5caac58ac..2e785db36 100644 --- a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts +++ b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts @@ -1,4 +1,5 @@ import { QueryFunctionContext } from '@tanstack/react-query' +import { Hash } from 'viem' import { useQueryOptions } from '@app/hooks/useQueryOptions' import { CreateQueryKey, QueryConfig } from '@app/types' @@ -14,6 +15,8 @@ import { type UseVerifiedRecordsParameters = { verificationsRecord?: string + ownerAddress?: Hash + name?: string } export type UseVerifiedRecordsReturnType = VerifiedRecord[] @@ -41,7 +44,7 @@ export const parseVerificationRecord = (verificationRecord?: string): string[] = } export const getVerifiedRecords = async ({ - queryKey: [{ verificationsRecord }], + queryKey: [{ verificationsRecord, ownerAddress }], }: QueryFunctionContext>): Promise => { const verifiablePresentationUris = parseVerificationRecord(verificationsRecord) const responses = await Promise.allSettled( @@ -53,7 +56,7 @@ export const getVerifiedRecords = async => response.status === 'fulfilled', ) .map(({ value }) => value) - .map(parseVerificationData), + .map(parseVerificationData({ ownerAddress })), ).then((records) => records.flat()) } @@ -74,7 +77,7 @@ export const useVerifiedRecords = const preparedOptions = prepareQueryOptions({ queryKey: initialOptions.queryKey, queryFn: initialOptions.queryFn, - enabled: enabled && !!params.verificationsRecord, + enabled: enabled && !!params.verificationsRecord && !!params.ownerAddress && !!params.name, gcTime, staleTime, }) diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts index 11a36fdb3..2b17fcc79 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts @@ -1,7 +1,13 @@ +import { Hash } from 'viem' + import { - isOpenIdVerifiablePresentation, - parseOpenIdVerifiablePresentation, -} from './utils/parseOpenIdVerifiablePresentation' + isDentityVerifiablePresentation, + parseDentityVerifiablePresentation, +} from './utils/parseDentityVerifiablePresentation' + +export type ParseVerificationDataDependencies = { + ownerAddress?: Hash +} export type VerifiedRecord = { verified: boolean @@ -11,7 +17,11 @@ export type VerifiedRecord = { } // TODO: Add more formats here -export const parseVerificationData = async (data: unknown): Promise => { - if (isOpenIdVerifiablePresentation(data)) return parseOpenIdVerifiablePresentation(data) - return [] -} +export const parseVerificationData = + (dependencies: ParseVerificationDataDependencies) => + async (data: unknown): Promise => { + console.log('data', data) + if (isDentityVerifiablePresentation(data)) + return parseDentityVerifiablePresentation(dependencies)(data) + return [] + } diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts new file mode 100644 index 000000000..2279b0a1a --- /dev/null +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts @@ -0,0 +1,27 @@ +import { type ParseVerificationDataDependencies } from '../parseVerificationData' +import { + isOpenIdVerifiablePresentation, + OpenIdVerifiablePresentation, + parseOpenIdVerifiablePresentation, +} from './parseOpenIdVerifiablePresentation' + +export const isDentityVerifiablePresentation = ( + data: unknown, +): data is OpenIdVerifiablePresentation => { + if (!isOpenIdVerifiablePresentation(data)) return false + const credentials = Array.isArray(data.vp_token) ? data.vp_token : [data.vp_token] + return credentials.some((credential) => credential?.type.includes('VerifiedENS')) +} + +export const parseDentityVerifiablePresentation = + ({ ownerAddress }: ParseVerificationDataDependencies) => + async (data: OpenIdVerifiablePresentation) => { + const credentials = Array.isArray(data.vp_token) ? data.vp_token : [data.vp_token] + const ownershipVerified = credentials.some( + (credential) => + !!credential && + credential.type.includes('VerifiedENS') && + credential.credentialSubject?.ethAddress?.toLowerCase() === ownerAddress?.toLowerCase(), + ) + return parseOpenIdVerifiablePresentation({ ownershipVerified })(data) + } diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.test.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.test.ts index 3a9537e63..a199ba522 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.test.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.test.ts @@ -4,7 +4,7 @@ import { makeMockVerifiablePresentationData } from '@root/test/mock/makeMockVeri import { match } from 'ts-pattern'; vi.mock('../../parseVerifiedCredential', () => ({ - parseVerifiableCredential: async (type: string) => match(type).with('error', () => null).with('twitter', () => ({ + parseVerifiableCredential: () => async (type: string) => match(type).with('error', () => null).with('twitter', () => ({ issuer: 'dentity', key: 'com.twitter', value: 'name', @@ -37,7 +37,7 @@ describe('isOpenIdVerifiablePresentation', () => { describe('parseOpenIdVerifiablePresentation', () => { it('should return an array of verified credentials an exclude any null values', async () => { - const result = await parseOpenIdVerifiablePresentation({ vp_token: ['twitter', 'error', 'other'] as any}) + const result = await parseOpenIdVerifiablePresentation({ ownershipVerified: true })({ vp_token: ['twitter', 'error', 'other'] as any}) expect(result).toEqual([{ issuer: 'dentity', key: 'com.twitter', value: 'name', verified: true}]) }) }) \ No newline at end of file diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.ts index 46de4525b..c8c5d92ea 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseOpenIdVerifiablePresentation.ts @@ -1,11 +1,14 @@ /* eslint-disable @typescript-eslint/naming-convention */ import type { VerifiableCredential } from '@app/types/verification' -import { parseVerifiableCredential } from '../../parseVerifiedCredential' +import { + parseVerifiableCredential, + ParseVerifiedCredentialDependencies, +} from '../../parseVerifiedCredential' import type { VerifiedRecord } from '../parseVerificationData' export type OpenIdVerifiablePresentation = { - vp_token: VerifiableCredential | VerifiableCredential[] + vp_token: VerifiableCredential | VerifiableCredential[] | undefined } export const isOpenIdVerifiablePresentation = ( @@ -20,9 +23,13 @@ export const isOpenIdVerifiablePresentation = ( ) } -export const parseOpenIdVerifiablePresentation = async (data: OpenIdVerifiablePresentation) => { - const { vp_token } = data - const credentials = Array.isArray(vp_token) ? vp_token : [vp_token] - const verifiedRecords = await Promise.all(credentials.map(parseVerifiableCredential)) - return verifiedRecords.filter((records): records is VerifiedRecord => !!records) -} +export const parseOpenIdVerifiablePresentation = + (dependencies: ParseVerifiedCredentialDependencies) => + async (data: OpenIdVerifiablePresentation) => { + const { vp_token } = data + const credentials = Array.isArray(vp_token) ? vp_token : [vp_token] + const verifiedRecords = await Promise.all( + credentials.map(parseVerifiableCredential(dependencies)), + ) + return verifiedRecords.filter((records): records is VerifiedRecord => !!records) + } diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.test.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.test.ts index 9084593cf..96ef21563 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.test.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.test.ts @@ -5,7 +5,7 @@ import { parseVerifiableCredential } from './parseVerifiedCredential' describe('parseVerifiedCredential', () => { it('should parse x account verified credential', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedXAccount'], credentialSubject: { username: 'name' }, } as any), @@ -19,7 +19,7 @@ describe('parseVerifiedCredential', () => { it('should parse twitter account verified credential', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedTwitterAccount'], credentialSubject: { username: 'name' }, } as any), @@ -33,7 +33,7 @@ describe('parseVerifiedCredential', () => { it('should parse discord account verified credential', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedDiscordAccount'], credentialSubject: { name: 'name' }, } as any), @@ -47,7 +47,7 @@ describe('parseVerifiedCredential', () => { it('should parse telegram account verified credential', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedTelegramAccount'], credentialSubject: { name: 'name' }, } as any), @@ -61,7 +61,7 @@ describe('parseVerifiedCredential', () => { it('should parse github account verified credential', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedGithubAccount'], credentialSubject: { name: 'name' }, } as any), @@ -75,7 +75,7 @@ describe('parseVerifiedCredential', () => { it('should parse personhood verified credential', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedPersonhood'], credentialSubject: { name: 'name' }, } as any), @@ -89,10 +89,24 @@ describe('parseVerifiedCredential', () => { it('should return null otherwise', async () => { expect( - await parseVerifiableCredential({ + await parseVerifiableCredential({ ownershipVerified: true })({ type: ['VerifiedIddentity'], credentialSubject: { name: 'name' }, } as any), ).toEqual(null) }) + + it('should return verified = false for verified credential if ownershipVerified is false', async () => { + expect( + await parseVerifiableCredential({ ownershipVerified: false })({ + type: ['VerifiedPersonhood'], + credentialSubject: { name: 'name' }, + } as any), + ).toEqual({ + issuer: 'dentity', + key: 'personhood', + value: '', + verified: false, + }) + }) }) diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts index ff3236036..84aeced23 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts @@ -8,53 +8,60 @@ import { tryVerifyVerifiableCredentials } from './parseVerificationData/utils/tr // TODO: parse issuer from verifiableCredential when dentity fixes their verifiable credentials -export const parseVerifiableCredential = async ( - verifiableCredential: VerifiableCredential, -): Promise => { - const verified = await tryVerifyVerifiableCredentials(verifiableCredential) - const baseResult = match(verifiableCredential) - .with( - { - type: P.when( - (type) => type?.includes('VerifiedTwitterAccount') || type?.includes('VerifiedXAccount'), - ), - }, - (vc) => ({ +export type ParseVerifiedCredentialDependencies = { + ownershipVerified: boolean +} + +export const parseVerifiableCredential = + ({ ownershipVerified }: ParseVerifiedCredentialDependencies) => + async (verifiableCredential?: VerifiableCredential): Promise => { + if (!verifiableCredential) return null + + const verified = await tryVerifyVerifiableCredentials(verifiableCredential) + const baseResult = match(verifiableCredential) + .with( + { + type: P.when( + (type) => + type?.includes('VerifiedTwitterAccount') || type?.includes('VerifiedXAccount'), + ), + }, + (vc) => ({ + issuer: 'dentity', + key: 'com.twitter', + value: normaliseTwitterRecordValue(vc?.credentialSubject?.username), + }), + ) + .with({ type: P.when((type) => type?.includes('VerifiedDiscordAccount')) }, (vc) => ({ + issuer: 'dentity', + key: 'com.discord', + value: vc?.credentialSubject?.name || '', + })) + .with({ type: P.when((type) => type?.includes('VerifiedGithubAccount')) }, (vc) => ({ issuer: 'dentity', - key: 'com.twitter', - value: normaliseTwitterRecordValue(vc?.credentialSubject?.username), - }), - ) - .with({ type: P.when((type) => type?.includes('VerifiedDiscordAccount')) }, (vc) => ({ - issuer: 'dentity', - key: 'com.discord', - value: vc?.credentialSubject?.name || '', - })) - .with({ type: P.when((type) => type?.includes('VerifiedGithubAccount')) }, (vc) => ({ - issuer: 'dentity', - key: 'com.github', - value: vc?.credentialSubject?.name || '', - })) - .with({ type: P.when((type) => type?.includes('VerifiedPersonhood')) }, () => ({ - issuer: 'dentity', - key: 'personhood', - value: '', - })) - .with({ type: P.when((type) => type?.includes('VerifiedTelegramAccount')) }, (vc) => ({ - issuer: 'dentity', - key: 'org.telegram', - value: vc?.credentialSubject?.name || '', - })) - .with({ type: P.when((type) => type?.includes('VerifiedEmail')) }, (vc) => ({ - issuer: 'dentity', - key: 'email', - value: vc?.credentialSubject?.verifiedEmail || '', - })) - .otherwise(() => null) + key: 'com.github', + value: vc?.credentialSubject?.name || '', + })) + .with({ type: P.when((type) => type?.includes('VerifiedPersonhood')) }, () => ({ + issuer: 'dentity', + key: 'personhood', + value: '', + })) + .with({ type: P.when((type) => type?.includes('VerifiedTelegramAccount')) }, (vc) => ({ + issuer: 'dentity', + key: 'org.telegram', + value: vc?.credentialSubject?.name || '', + })) + .with({ type: P.when((type) => type?.includes('VerifiedEmail')) }, (vc) => ({ + issuer: 'dentity', + key: 'email', + value: vc?.credentialSubject?.verifiedEmail || '', + })) + .otherwise(() => null) - if (!baseResult) return null - return { - verified, - ...baseResult, + if (!baseResult) return null + return { + verified: ownershipVerified && verified, + ...baseResult, + } } -} From 2091dbeedb42495bd83bb2b83be9ec2c1da8f7f4 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Mon, 16 Sep 2024 19:06:29 +0700 Subject: [PATCH 03/75] Apply unit test for reactQuery client configuration --- src/utils/query/reactQuery.test.tsx | 83 +++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 src/utils/query/reactQuery.test.tsx diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx new file mode 100644 index 000000000..30985f70c --- /dev/null +++ b/src/utils/query/reactQuery.test.tsx @@ -0,0 +1,83 @@ +import { render, waitFor } from '@app/test-utils' + +import { QueryClientProvider, useQuery } from '@tanstack/react-query' +import { ReactNode } from 'react' +import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest' +import { WagmiProvider } from 'wagmi' + +import { queryClient } from './reactQuery' +import { wagmiConfig } from './wagmi' + +const mockFetchData = vi.fn().mockResolvedValue('Test data') + +const TestComponentWrapper = ({ children }: { children: ReactNode }) => { + console.log('queryClient', queryClient.getDefaultOptions()) + return ( + + {children} + + ) +} + +const TestComponentWithHook = () => { + const { data, isFetching } = useQuery({ + queryKey: ['test-hook'], + queryFn: mockFetchData, + enabled: true, + }) + + return ( +
{isFetching ? Loading... : Data: {data}}
+ ) +} + +describe('reactQuery', () => { + beforeEach(() => { + vi.clearAllMocks() + queryClient.clear() + }) + + afterEach(() => { + queryClient.clear() + }) + + it('should create a query client with default options', () => { + expect(queryClient.getDefaultOptions()).toEqual({ + queries: { + refetchOnWindowFocus: true, + refetchOnMount: 'always', + staleTime: 1_000 * 12, + gcTime: 1_000 * 60 * 60 * 24, + queryKeyHashFn: expect.any(Function), + }, + }) + }) + + it('should refetch queries on mount', async () => { + const { getByTestId, unmount } = render( + + + , + ) + + await waitFor(() => { + expect(mockFetchData).toHaveBeenCalledTimes(1) + expect(getByTestId('test')).toHaveTextContent('Test data') + }) + + unmount() + const { getByTestId: getByTestId2 } = render( + + + , + ) + + await waitFor( + () => { + expect(mockFetchData).toHaveBeenCalledTimes(2) + expect(getByTestId2('test')).toHaveTextContent('Test data') + }, + { timeout: 2000 }, + ) + }) +}) From f2f1beecb9ca4b926a05399d3f7743594aaf349c Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Mon, 16 Sep 2024 19:12:31 +0700 Subject: [PATCH 04/75] Remove debug log --- src/utils/query/reactQuery.test.tsx | 1 - 1 file changed, 1 deletion(-) diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx index 30985f70c..4ab83d9f3 100644 --- a/src/utils/query/reactQuery.test.tsx +++ b/src/utils/query/reactQuery.test.tsx @@ -11,7 +11,6 @@ import { wagmiConfig } from './wagmi' const mockFetchData = vi.fn().mockResolvedValue('Test data') const TestComponentWrapper = ({ children }: { children: ReactNode }) => { - console.log('queryClient', queryClient.getDefaultOptions()) return ( {children} From 740a615d626b7412a33610a434a0c09e15177590 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 16 Sep 2024 22:11:39 +0800 Subject: [PATCH 05/75] update verification tests and add check for address and name in verification parsers --- e2e/specs/stateless/verifications.spec.ts | 269 +++++++++++++++--- playwright/pageObjects/profilePage.ts | 5 + .../useVerifiedRecords/useVerifiedRecords.ts | 4 +- .../parseVerificationData.ts | 2 +- .../parseDentityVerifiablePresentation.ts | 5 +- .../VerifyProfile/VerifyProfile-flow.tsx | 2 + 6 files changed, 239 insertions(+), 48 deletions(-) diff --git a/e2e/specs/stateless/verifications.spec.ts b/e2e/specs/stateless/verifications.spec.ts index 1ca030b7d..244cf8fa2 100644 --- a/e2e/specs/stateless/verifications.spec.ts +++ b/e2e/specs/stateless/verifications.spec.ts @@ -16,12 +16,19 @@ import { import { createAccounts } from '../../../playwright/fixtures/accounts' import { testClient } from '../../../playwright/fixtures/contracts/utils/addTestContracts' +type MakeMockVPTokenRecordKey = + | 'com.twitter' + | 'com.github' + | 'com.discord' + | 'org.telegram' + | 'personhood' + | 'email' + | 'ens' + const makeMockVPToken = ( - records: Array< - 'com.twitter' | 'com.github' | 'com.discord' | 'org.telegram' | 'personhood' | 'email' - >, + records: Array<{ key: MakeMockVPTokenRecordKey; value?: string; name?: string }>, ) => { - return records.map((record) => ({ + return records.map(({ key, value, name }) => ({ type: [ 'VerifiableCredential', { @@ -31,15 +38,22 @@ const makeMockVPToken = ( 'org.telegram': 'VerifiedTelegramAccount', personhood: 'VerifiedPersonhood', email: 'VerifiedEmail', - }[record], + ens: 'VerifiedENS', + }[key], ], credentialSubject: { credentialIssuer: 'Dentity', - ...(record === 'com.twitter' ? { username: '@name' } : {}), - ...(['com.twitter', 'com.github', 'com.discord', 'org.telegram'].includes(record) - ? { name: 'name' } + ...(key === 'com.twitter' ? { username: value ?? '@name' } : {}), + ...(['com.twitter', 'com.github', 'com.discord', 'org.telegram'].includes(key) + ? { name: value ?? 'name' } + : {}), + ...(key === 'email' ? { verifiedEmail: value ?? 'name@email.com' } : {}), + ...(key === 'ens' + ? { + ensName: name ?? 'name.eth', + ethAddress: value ?? (createAccounts().getAddress('user') as Hash), + } : {}), - ...(record === 'email' ? { verifiedEmail: 'name@email.com' } : {}), }, })) } @@ -94,12 +108,13 @@ test.describe('Verified records', () => { contentType: 'application/json', body: JSON.stringify({ vp_token: makeMockVPToken([ - 'com.twitter', - 'com.github', - 'com.discord', - 'org.telegram', - 'personhood', - 'email', + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'personhood' }, + { key: 'email' }, + { key: 'ens', name }, ]), }), }) @@ -173,7 +188,13 @@ test.describe('Verified records', () => { body: JSON.stringify({ ens_name: name, eth_address: accounts.getAddress('user2'), - vp_token: makeMockVPToken(['com.twitter', 'com.github', 'com.discord', 'org.telegram']), + vp_token: makeMockVPToken([ + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'ens', name }, + ]), }), }) }) @@ -195,7 +216,7 @@ test.describe('Verified records', () => { await expect(profilePage.record('verification', 'dentity')).toBeVisible() }) - test('Should not show badges if records match but ens credential fails', async ({ + test('Should not show badges if records match but ens credential address does not match', async ({ page, accounts, makePageObject, @@ -209,19 +230,19 @@ test.describe('Verified records', () => { texts: [ { key: 'com.twitter', - value: '@name2', + value: '@name', }, { key: 'org.telegram', - value: 'name2', + value: 'name', }, { key: 'com.discord', - value: 'name2', + value: 'name', }, { key: 'com.github', - value: 'name2', + value: 'name', }, { key: VERIFICATION_RECORD_KEY, @@ -229,9 +250,80 @@ test.describe('Verified records', () => { `${DENTITY_VPTOKEN_ENDPOINT}?name=name.eth&federated_token=federated_token`, ]), }, + ], + }, + }) + + const profilePage = makePageObject('ProfilePage') + + await page.route(`${DENTITY_VPTOKEN_ENDPOINT}*`, async (route) => { + await route.fulfill({ + status: 200, + contentType: 'application/json', + body: JSON.stringify({ + ens_name: name, + eth_address: accounts.getAddress('user2'), + vp_token: makeMockVPToken([ + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'ens', name, value: accounts.getAddress('user2') }, + ]), + }), + }) + }) + + await page.goto(`/${name}`) + + await page.pause() + + await expect(page.getByTestId('profile-section-verifications')).toBeVisible() + + await profilePage.isRecordVerified('text', 'com.twitter', false) + await profilePage.isRecordVerified('text', 'org.telegram', false) + await profilePage.isRecordVerified('text', 'com.github', false) + await profilePage.isRecordVerified('text', 'com.discord', false) + await profilePage.isRecordVerified('verification', 'dentity', false) + await profilePage.isPersonhoodVerified(false) + + await expect(profilePage.record('verification', 'dentity')).toBeVisible() + await expect(profilePage.record('verification', 'dentity')).toBeVisible() + }) + + test('Should not show badges if records match but ens credential name does not match', async ({ + page, + accounts, + makePageObject, + makeName, + }) => { + const name = await makeName({ + label: 'dentity', + type: 'wrapped', + owner: 'user', + records: { + texts: [ { key: 'com.twitter', - value: '@name2', + value: '@name', + }, + { + key: 'org.telegram', + value: 'name', + }, + { + key: 'com.discord', + value: 'name', + }, + { + key: 'com.github', + value: 'name', + }, + { + key: VERIFICATION_RECORD_KEY, + value: JSON.stringify([ + `${DENTITY_VPTOKEN_ENDPOINT}?name=name.eth&federated_token=federated_token`, + ]), }, ], }, @@ -246,7 +338,13 @@ test.describe('Verified records', () => { body: JSON.stringify({ ens_name: name, eth_address: accounts.getAddress('user2'), - vp_token: makeMockVPToken(['com.twitter', 'com.github', 'com.discord', 'org.telegram']), + vp_token: makeMockVPToken([ + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'ens', name: 'differentName.eth' }, + ]), }), }) }) @@ -267,6 +365,89 @@ test.describe('Verified records', () => { await expect(profilePage.record('verification', 'dentity')).toBeVisible() await expect(profilePage.record('verification', 'dentity')).toBeVisible() }) + + test('Should show error icon on verication button if VerifiedENS credential is not validated', async ({ + page, + login, + makePageObject, + makeName, + }) => { + const name = await makeName({ + label: 'dentity', + type: 'wrapped', + owner: 'user', + records: { + texts: [ + { + key: 'com.twitter', + value: '@name', + }, + { + key: 'org.telegram', + value: 'name', + }, + { + key: 'com.discord', + value: 'name', + }, + { + key: 'com.github', + value: 'name', + }, + { + key: 'email', + value: 'name@email.com', + }, + { + key: VERIFICATION_RECORD_KEY, + value: JSON.stringify([ + `${DENTITY_VPTOKEN_ENDPOINT}?name=name.eth&federated_token=federated_token`, + ]), + }, + { + key: 'com.twitter', + value: '@name', + }, + ], + }, + }) + + const profilePage = makePageObject('ProfilePage') + + await page.route(`${DENTITY_VPTOKEN_ENDPOINT}*`, async (route) => { + await route.fulfill({ + status: 200, + contentType: 'application/json', + body: JSON.stringify({ + vp_token: makeMockVPToken([ + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'personhood' }, + { key: 'email' }, + { key: 'ens', name: 'othername.eth' }, + ]), + }), + }) + }) + + await page.goto(`/${name}`) + await login.connect() + + await page.pause() + + await expect(page.getByTestId('profile-section-verifications')).toBeVisible() + + await profilePage.isRecordVerified('text', 'com.twitter', false) + await profilePage.isRecordVerified('text', 'org.telegram', false) + await profilePage.isRecordVerified('text', 'com.github', false) + await profilePage.isRecordVerified('text', 'com.discord', false) + await profilePage.isRecordVerified('verification', 'dentity', false) + await profilePage.isPersonhoodErrored() + + await expect(profilePage.record('verification', 'dentity')).toBeVisible() + }) }) test.describe('Verify profile', () => { @@ -292,11 +473,11 @@ test.describe('Verify profile', () => { contentType: 'application/json', body: JSON.stringify({ vp_token: makeMockVPToken([ - 'personhood', - 'com.twitter', - 'com.github', - 'com.discord', - 'org.telegram', + { key: 'personhood' }, + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, ]), }), }) @@ -336,11 +517,11 @@ test.describe('Verify profile', () => { contentType: 'application/json', body: JSON.stringify({ vp_token: makeMockVPToken([ - 'personhood', - 'com.twitter', - 'com.github', - 'com.discord', - 'org.telegram', + { key: 'personhood' }, + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, ]), }), }) @@ -405,11 +586,12 @@ test.describe('Verify profile', () => { contentType: 'application/json', body: JSON.stringify({ vp_token: makeMockVPToken([ - 'personhood', - 'com.twitter', - 'com.github', - 'com.discord', - 'org.telegram', + { key: 'personhood' }, + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'ens', name, value: createAccounts().getAddress('user2') }, ]), }), }) @@ -505,11 +687,12 @@ test.describe('OAuth flow', () => { contentType: 'application/json', body: JSON.stringify({ vp_token: makeMockVPToken([ - 'personhood', - 'com.twitter', - 'com.github', - 'com.discord', - 'org.telegram', + { key: 'personhood' }, + { key: 'com.twitter' }, + { key: 'com.github' }, + { key: 'com.discord' }, + { key: 'org.telegram' }, + { key: 'ens', name, value: createAccounts().getAddress('user2') }, ]), }), }) diff --git a/playwright/pageObjects/profilePage.ts b/playwright/pageObjects/profilePage.ts index e14abfdba..dcc179fb9 100644 --- a/playwright/pageObjects/profilePage.ts +++ b/playwright/pageObjects/profilePage.ts @@ -83,6 +83,11 @@ export class ProfilePage { return expect(this.page.getByTestId("profile-snippet-person-icon")).toHaveCount(count) } + isPersonhoodErrored(errored = true) { + const count = errored ? 1 : 0 + return expect(this.page.getByTestId("verification-badge-error-icon")).toHaveCount(count) + } + contentHash(): Locator { return this.page.getByTestId('other-profile-button-contenthash') } diff --git a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts index 2e785db36..6c6de02b3 100644 --- a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts +++ b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.ts @@ -44,7 +44,7 @@ export const parseVerificationRecord = (verificationRecord?: string): string[] = } export const getVerifiedRecords = async ({ - queryKey: [{ verificationsRecord, ownerAddress }], + queryKey: [{ verificationsRecord, ownerAddress, name }], }: QueryFunctionContext>): Promise => { const verifiablePresentationUris = parseVerificationRecord(verificationsRecord) const responses = await Promise.allSettled( @@ -56,7 +56,7 @@ export const getVerifiedRecords = async => response.status === 'fulfilled', ) .map(({ value }) => value) - .map(parseVerificationData({ ownerAddress })), + .map(parseVerificationData({ ownerAddress, name })), ).then((records) => records.flat()) } diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts index 2b17fcc79..0f34c4ae4 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/parseVerificationData.ts @@ -7,6 +7,7 @@ import { export type ParseVerificationDataDependencies = { ownerAddress?: Hash + name?: string } export type VerifiedRecord = { @@ -20,7 +21,6 @@ export type VerifiedRecord = { export const parseVerificationData = (dependencies: ParseVerificationDataDependencies) => async (data: unknown): Promise => { - console.log('data', data) if (isDentityVerifiablePresentation(data)) return parseDentityVerifiablePresentation(dependencies)(data) return [] diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts index 2279b0a1a..e4c4db5fd 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts @@ -14,14 +14,15 @@ export const isDentityVerifiablePresentation = ( } export const parseDentityVerifiablePresentation = - ({ ownerAddress }: ParseVerificationDataDependencies) => + ({ ownerAddress, name }: ParseVerificationDataDependencies) => async (data: OpenIdVerifiablePresentation) => { const credentials = Array.isArray(data.vp_token) ? data.vp_token : [data.vp_token] const ownershipVerified = credentials.some( (credential) => !!credential && credential.type.includes('VerifiedENS') && - credential.credentialSubject?.ethAddress?.toLowerCase() === ownerAddress?.toLowerCase(), + credential.credentialSubject?.ethAddress?.toLowerCase() === ownerAddress?.toLowerCase() && + credential.credentialSubject?.ensName?.toLowerCase() === name.toLowerCase(), ) return parseOpenIdVerifiablePresentation({ ownershipVerified })(data) } diff --git a/src/transaction-flow/input/VerifyProfile/VerifyProfile-flow.tsx b/src/transaction-flow/input/VerifyProfile/VerifyProfile-flow.tsx index a3fd6eedc..e0f7057e4 100644 --- a/src/transaction-flow/input/VerifyProfile/VerifyProfile-flow.tsx +++ b/src/transaction-flow/input/VerifyProfile/VerifyProfile-flow.tsx @@ -32,6 +32,8 @@ const VerifyProfile = ({ data: { name }, dispatch, onDismiss }: Props) => { const { data: verificationData, isLoading: isVerificationLoading } = useVerifiedRecords({ verificationsRecord: profile?.texts?.find(({ key }) => key === VERIFICATION_RECORD_KEY)?.value, + ownerAddress, + name, }) const isLoading = isProfileLoading || isVerificationLoading || isOwnerLoading From 445c25aad7ac5b35eddfb77baa3ddbad68311166 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 16 Sep 2024 22:41:49 +0800 Subject: [PATCH 06/75] fix some test errors --- .../useVerifiedRecords/useVerifiedRecords.test.ts | 2 +- .../utils/parseDentityVerifiablePresentation.ts | 4 +++- .../useVerifiedRecords/utils/parseVerifiedCredential.ts | 5 +++++ 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts index d1a2b69c9..e8af7a3ee 100644 --- a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts +++ b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts @@ -23,7 +23,7 @@ describe('parseVerificationRecord', () => { -describe.only('getVerifiedRecords', () => { +describe('getVerifiedRecords', () => { const mockFetch = vi.fn().mockImplementation(async (uri) => match(uri).with('error', () => Promise.reject('error')).otherwise(() => Promise.resolve({ json: () => Promise.resolve(makeMockVerifiablePresentationData('openid'))}))) vi.stubGlobal('fetch', mockFetch) diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts index e4c4db5fd..6e9060235 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerificationData/utils/parseDentityVerifiablePresentation.ts @@ -21,8 +21,10 @@ export const parseDentityVerifiablePresentation = (credential) => !!credential && credential.type.includes('VerifiedENS') && + !!credential.credentialSubject.ethAddress && + !!credential.credentialSubject.ensName && credential.credentialSubject?.ethAddress?.toLowerCase() === ownerAddress?.toLowerCase() && - credential.credentialSubject?.ensName?.toLowerCase() === name.toLowerCase(), + credential.credentialSubject?.ensName?.toLowerCase() === name?.toLowerCase(), ) return parseOpenIdVerifiablePresentation({ ownershipVerified })(data) } diff --git a/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts b/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts index 84aeced23..a6dcb2046 100644 --- a/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts +++ b/src/hooks/verification/useVerifiedRecords/utils/parseVerifiedCredential.ts @@ -57,6 +57,11 @@ export const parseVerifiableCredential = key: 'email', value: vc?.credentialSubject?.verifiedEmail || '', })) + .with({ type: P.when((type) => type?.includes('VerifiedENS')) }, () => ({ + issuer: 'dentity', + key: 'ens', + value: '', + })) .otherwise(() => null) if (!baseResult) return null From 00b4efa3a735cecaa3b1d890c6ae7bdcb41b18b2 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 16 Sep 2024 23:48:23 +0800 Subject: [PATCH 07/75] fix unit test --- .../useVerifiedRecords/useVerifiedRecords.test.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts index e8af7a3ee..e87264342 100644 --- a/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts +++ b/src/hooks/verification/useVerifiedRecords/useVerifiedRecords.test.ts @@ -29,12 +29,12 @@ describe('getVerifiedRecords', () => { it('should exclude fetches that error from results ', async () => { const result = await getVerifiedRecords({ queryKey: [{ verificationsRecord: '["error", "regular", "error"]'}, '0x123']} as any) - expect(result).toHaveLength(6) + expect(result).toHaveLength(7) }) it('should return a flat array of verified credentials', async () => { const result = await getVerifiedRecords({ queryKey: [{ verificationsRecord: '["one", "two", "error", "three"]'}]} as any) - expect(result).toHaveLength(18) + expect(result).toHaveLength(21) expect(result.every((item) => !Array.isArray(item))).toBe(true) }) }) \ No newline at end of file From 47363e34aafffb5cc53db9388f092df356332cc6 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Tue, 17 Sep 2024 19:46:25 +0700 Subject: [PATCH 08/75] Revert refetchOnMount to true for refetchOptions and useMoonpayRegistration --- .../pages/profile/[name]/registration/useMoonpayRegistration.ts | 2 +- src/utils/query/reactQuery.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts b/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts index 0329264ad..769876eae 100644 --- a/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts +++ b/src/components/pages/profile/[name]/registration/useMoonpayRegistration.ts @@ -81,7 +81,7 @@ export const useMoonpayRegistration = ( return result || {} }, refetchOnWindowFocus: true, - refetchOnMount: 'always', + refetchOnMount: true, refetchInterval: 1000, refetchIntervalInBackground: true, enabled: !!currentExternalTransactionId && !isCompleted, diff --git a/src/utils/query/reactQuery.ts b/src/utils/query/reactQuery.ts index 7dd6fef80..c93241bb2 100644 --- a/src/utils/query/reactQuery.ts +++ b/src/utils/query/reactQuery.ts @@ -21,7 +21,7 @@ export const refetchOptions: DefaultOptions = { meta: { isRefetchQuery: true, }, - refetchOnMount: 'always', + refetchOnMount: true, queryKeyHashFn: hashFn, }, } From 2efca82fa2d2d6df9cc7ead278640947f60a8b47 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 18 Sep 2024 11:21:12 +0700 Subject: [PATCH 09/75] Apply queryClient.invalidateQueries on PersistQueryClientProvider. Revert refetchOnMount=true for useBlockTimestamp and reactQuery --- src/hooks/chain/useBlockTimestamp.ts | 2 +- src/utils/query/providers.tsx | 6 ++++++ src/utils/query/reactQuery.ts | 2 +- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/src/hooks/chain/useBlockTimestamp.ts b/src/hooks/chain/useBlockTimestamp.ts index 865dde78d..db8bd192e 100644 --- a/src/hooks/chain/useBlockTimestamp.ts +++ b/src/hooks/chain/useBlockTimestamp.ts @@ -12,7 +12,7 @@ export const useBlockTimestamp = ({ enabled = true }: UseBlockTimestampParameter blockTag: 'latest', query: { enabled, - refetchOnMount: 'always', + refetchOnMount: true, refetchInterval: 1000 * 60 * 5 /* 5 minutes */, staleTime: 1000 * 60 /* 1 minute */, select: (b) => b.timestamp * 1000n, diff --git a/src/utils/query/providers.tsx b/src/utils/query/providers.tsx index 9227d1217..0eca8ebf2 100644 --- a/src/utils/query/providers.tsx +++ b/src/utils/query/providers.tsx @@ -1,3 +1,4 @@ +import { ReactQueryDevtoolsPanel } from '@tanstack/react-query-devtools' import { PersistQueryClientProvider } from '@tanstack/react-query-persist-client' import type { ReactNode } from 'react' import { WagmiProvider } from 'wagmi' @@ -16,8 +17,13 @@ export function QueryProviders({ children }: Props) { { + return queryClient.invalidateQueries() + }} > {children} + + ) diff --git a/src/utils/query/reactQuery.ts b/src/utils/query/reactQuery.ts index c93241bb2..81047d639 100644 --- a/src/utils/query/reactQuery.ts +++ b/src/utils/query/reactQuery.ts @@ -5,7 +5,7 @@ export const queryClient = new QueryClient({ defaultOptions: { queries: { refetchOnWindowFocus: true, - refetchOnMount: 'always', + refetchOnMount: true, staleTime: 1_000 * 12, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: hashFn, From 20069e4a040687115dc7ebbf8452924e2167dcdf Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 18 Sep 2024 11:22:22 +0700 Subject: [PATCH 10/75] Remove ReactQueryDevtoolsPanel --- src/utils/query/providers.tsx | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/utils/query/providers.tsx b/src/utils/query/providers.tsx index 0eca8ebf2..1ad065a2d 100644 --- a/src/utils/query/providers.tsx +++ b/src/utils/query/providers.tsx @@ -1,4 +1,3 @@ -import { ReactQueryDevtoolsPanel } from '@tanstack/react-query-devtools' import { PersistQueryClientProvider } from '@tanstack/react-query-persist-client' import type { ReactNode } from 'react' import { WagmiProvider } from 'wagmi' @@ -22,8 +21,6 @@ export function QueryProviders({ children }: Props) { }} > {children} - - ) From 61be95f0fb2b6628293c5157850882bbb8c91bf4 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 18 Sep 2024 14:15:22 +0700 Subject: [PATCH 11/75] Update unit test for reactQuery --- src/utils/query/reactQuery.test.tsx | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx index 4ab83d9f3..c27fd3e71 100644 --- a/src/utils/query/reactQuery.test.tsx +++ b/src/utils/query/reactQuery.test.tsx @@ -44,7 +44,7 @@ describe('reactQuery', () => { expect(queryClient.getDefaultOptions()).toEqual({ queries: { refetchOnWindowFocus: true, - refetchOnMount: 'always', + refetchOnMount: true, staleTime: 1_000 * 12, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: expect.any(Function), @@ -70,13 +70,11 @@ describe('reactQuery', () => { , ) + await queryClient.invalidateQueries() - await waitFor( - () => { - expect(mockFetchData).toHaveBeenCalledTimes(2) - expect(getByTestId2('test')).toHaveTextContent('Test data') - }, - { timeout: 2000 }, - ) + await waitFor(() => { + expect(mockFetchData).toHaveBeenCalledTimes(2) + expect(getByTestId2('test')).toHaveTextContent('Test data') + }) }) }) From 7b6b949a1f68af82f2f2e6e808b68fb8f7ec583c Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Mon, 23 Sep 2024 09:50:35 +0700 Subject: [PATCH 12/75] Track DNS import flow events --- .../@molecules/SearchInput/SearchInput.tsx | 28 +++++++---- .../stage/TransactionStageModal.tsx | 30 ++++++++++-- .../import/[name]/steps/SelectImportType.tsx | 7 +++ .../steps/onchain/ImportTransaction.tsx | 11 ++++- src/hooks/useEventTracker.ts | 48 +++++++++++++++++-- 5 files changed, 107 insertions(+), 17 deletions(-) diff --git a/src/components/@molecules/SearchInput/SearchInput.tsx b/src/components/@molecules/SearchInput/SearchInput.tsx index 770dd55d1..534f7eb4c 100644 --- a/src/components/@molecules/SearchInput/SearchInput.tsx +++ b/src/components/@molecules/SearchInput/SearchInput.tsx @@ -13,6 +13,7 @@ import { import { TFunction, useTranslation } from 'react-i18next' import useTransition, { TransitionState } from 'react-transition-state' import styled, { css } from 'styled-components' +import { match } from 'ts-pattern' import { Address, isAddress } from 'viem' import { useAccount, useChainId } from 'wagmi' @@ -343,17 +344,26 @@ const createSearchHandler = const path = getRouteForSearchItem({ address, chainId, queryClient, selectedItem }) - if (path === `/register/${text}`) { - trackEvent({ - eventName: 'search_selected_eth', - customProperties: { name: text }, + match(path) + .with(`/register/${text}`, () => { + trackEvent({ + eventName: 'search_selected_eth', + customProperties: { name: text }, + }) }) - } else if (path === `/dotbox/${text}`) { - trackEvent({ - eventName: 'search_selected_box', - customProperties: { name: text }, + .with(`/dotbox/${text}`, () => { + trackEvent({ + eventName: 'search_selected_box', + customProperties: { name: text }, + }) }) - } + .with(`/import/${text}`, () => { + trackEvent({ + eventName: 'search_selected_dns', + customProperties: { name: text }, + }) + }) + .otherwise(() => {}) setInputVal('') searchInputRef.current?.blur() diff --git a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx index b76d86d68..b1730ad24 100644 --- a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx +++ b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx @@ -411,6 +411,15 @@ export const TransactionStageModal = ({ }, [helper]) const ActionButton = useMemo(() => { + const handleClickActionButton = () => { + dispatch({ name: 'incrementTransaction' }) + + if (actionName === 'approveDnsRegistrar') { + trackEvent({ + eventName: 'register_started_dns', + }) + } + } if (stage === 'complete') { const final = currentStep + 1 === stepCount @@ -428,7 +437,7 @@ export const TransactionStageModal = ({ return ( @@ -480,10 +489,25 @@ export const TransactionStageModal = ({ onClick={() => { sendTransaction(request!) + console.log(actionName) + if (['commitName', 'registerName'].includes(actionName)) { trackEvent({ - eventName: - actionName === 'commitName' ? 'commit_wallet_opened' : 'register_wallet_opened', + eventName: ['commitName'].includes(actionName) + ? 'commit_wallet_opened' + : 'register_wallet_opened', + }) + } + + if (actionName === 'approveDnsRegistrar') { + trackEvent({ + eventName: 'commit_wallet_opened_dns', + }) + } + + if (actionName === 'claimDnsName') { + trackEvent({ + eventName: 'register_wallet_opened_dns', }) } }} diff --git a/src/components/pages/import/[name]/steps/SelectImportType.tsx b/src/components/pages/import/[name]/steps/SelectImportType.tsx index 97ddbee25..55b44e0c7 100644 --- a/src/components/pages/import/[name]/steps/SelectImportType.tsx +++ b/src/components/pages/import/[name]/steps/SelectImportType.tsx @@ -12,6 +12,7 @@ import { useDnsOffchainStatus } from '@app/hooks/dns/useDnsOffchainStatus' import { useDnsSecEnabled } from '@app/hooks/dns/useDnsSecEnabled' import { useDnsOwner } from '@app/hooks/ensjs/dns/useDnsOwner' import { useResolver } from '@app/hooks/ensjs/public/useResolver' +import { useEventTracker } from '@app/hooks/useEventTracker' import { CenteredTypography } from '@app/transaction-flow/input/ProfileEditor/components/CenteredTypography' import { getSupportLink } from '@app/utils/supportLinks' @@ -155,6 +156,7 @@ export const SelectImportType = ({ }) => { const { t } = useTranslation('dnssec', { keyPrefix: 'steps.selectType' }) const { t: tc } = useTranslation('common') + const { trackEvent } = useEventTracker() const { address } = useAccount() const chainId = useChainId() @@ -191,6 +193,11 @@ export const SelectImportType = ({ }) dispatch({ name: 'setSteps', selected, payload: steps }) dispatch({ name: 'increaseStep', selected }) + + trackEvent({ + eventName: 'import_type_selected_dns', + customProperties: { name: selected.name, importType: item.type }, + }) } return ( diff --git a/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx b/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx index d27f5715a..b9a20c671 100644 --- a/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx +++ b/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx @@ -15,6 +15,7 @@ import { useDnsImportData } from '@app/hooks/ensjs/dns/useDnsImportData' import { useDnsOwner } from '@app/hooks/ensjs/dns/useDnsOwner' import { usePrimaryName } from '@app/hooks/ensjs/public/usePrimaryName' import { useApprovedForAll } from '@app/hooks/useApprovedForAll' +import { useEventTracker } from '@app/hooks/useEventTracker' import { useTransactionFlow } from '@app/transaction-flow/TransactionFlowProvider' import { UpdateCallback, useCallbackOnTransaction } from '@app/utils/SyncProvider/SyncProvider' import useUserConfig from '@app/utils/useUserConfig' @@ -105,6 +106,7 @@ export const ImportTransaction = ({ const { t } = useTranslation('dnssec', { keyPrefix: 'steps.transaction' }) const { t: tc } = useTranslation('common') + const { trackEvent } = useEventTracker() const { data: gasPrice } = useGasPrice() const { userConfig, setCurrency } = useUserConfig() const currencyDisplay = userConfig.currency === 'fiat' ? userConfig.fiat : 'eth' @@ -180,7 +182,13 @@ export const ImportTransaction = ({ const startOrResumeFlow = () => { if (!item.started) dispatch({ name: 'setStarted', selected }) - if (resumable) return resumeTransactionFlow(key) + if (resumable) { + trackEvent({ + eventName: 'claim_domain_started_dns', + }) + return resumeTransactionFlow(key) + } + return createTransactionFlow(key, { transactions, resumable: true, @@ -189,7 +197,6 @@ export const ImportTransaction = ({ resumeLink: `/import/${selected.name}`, }) } - const txCallback: UpdateCallback = useCallback( ({ action, status, key: cbKey }) => { if (action !== 'claimDnsName' && action !== 'importDnsName') return diff --git a/src/hooks/useEventTracker.ts b/src/hooks/useEventTracker.ts index 0759ee144..6e73a8784 100644 --- a/src/hooks/useEventTracker.ts +++ b/src/hooks/useEventTracker.ts @@ -8,7 +8,7 @@ import useUserConfig from '@app/utils/useUserConfig' import { useChainName } from './chain/useChainName' type SearchSelectEvent = { - eventName: 'search_selected_eth' | 'search_selected_box' + eventName: 'search_selected_eth' | 'search_selected_box' | 'search_selected_dns' customProperties: { name: string } } @@ -22,6 +22,14 @@ type PaymentEvent = { } } +type DNSImportTypeEvent = { + eventName: 'import_type_selected_dns' + customProperties: { + importType: 'onchain' | 'offchain' | null + name: string + } +} + type DefaultEvent = { eventName: | 'commit_started' @@ -29,10 +37,19 @@ type DefaultEvent = { | 'register_started' | 'register_started_box' | 'register_wallet_opened' + | 'verify_ownership_started_dns' + | 'claim_domain_started_dns' + | 'commit_wallet_opened_dns' + | 'register_started_dns' + | 'register_wallet_opened_dns' customProperties?: never } -export type TrackEventParameters = SearchSelectEvent | PaymentEvent | DefaultEvent +export type TrackEventParameters = + | SearchSelectEvent + | PaymentEvent + | DefaultEvent + | DNSImportTypeEvent export const useEventTracker = () => { const chain = useChainName() @@ -41,7 +58,9 @@ export const useEventTracker = () => { const trackEvent = (props: TrackEventParameters) => { match(props) .with( - { eventName: P.union('search_selected_eth', 'search_selected_box') }, + { + eventName: P.union('search_selected_eth', 'search_selected_box', 'search_selected_dns'), + }, ({ eventName, customProperties }) => { const { name } = customProperties sendTrackEvent(eventName, chain, { name }) @@ -72,6 +91,29 @@ export const useEventTracker = () => { paymentAmount, }) }) + .with( + { + eventName: P.union('import_type_selected_dns'), + }, + ({ eventName, customProperties }) => { + const { importType, name } = customProperties + sendTrackEvent(eventName, chain, { name, importType }) + }, + ) + .with( + { + eventName: P.union( + 'verify_ownership_started_dns', + 'claim_domain_started_dns', + 'commit_wallet_opened_dns', + 'register_started_dns', + 'register_wallet_opened_dns', + ), + }, + ({ eventName }) => { + sendTrackEvent(eventName, chain) + }, + ) .exhaustive() } From 8454e10bb70cbb90f1c0a4be04cae86ad56c12eb Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Tue, 24 Sep 2024 17:16:21 +0700 Subject: [PATCH 13/75] Update refetchOnMount to always for defaultOptions, update unit test for reactQuery --- src/utils/query/providers.tsx | 3 --- src/utils/query/reactQuery.test.tsx | 28 +++++++++++++++++++++++++--- src/utils/query/reactQuery.ts | 2 +- 3 files changed, 26 insertions(+), 7 deletions(-) diff --git a/src/utils/query/providers.tsx b/src/utils/query/providers.tsx index 1ad065a2d..9227d1217 100644 --- a/src/utils/query/providers.tsx +++ b/src/utils/query/providers.tsx @@ -16,9 +16,6 @@ export function QueryProviders({ children }: Props) { { - return queryClient.invalidateQueries() - }} > {children} diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx index c27fd3e71..f97c9f337 100644 --- a/src/utils/query/reactQuery.test.tsx +++ b/src/utils/query/reactQuery.test.tsx @@ -44,7 +44,7 @@ describe('reactQuery', () => { expect(queryClient.getDefaultOptions()).toEqual({ queries: { refetchOnWindowFocus: true, - refetchOnMount: true, + refetchOnMount: 'always', staleTime: 1_000 * 12, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: expect.any(Function), @@ -52,7 +52,30 @@ describe('reactQuery', () => { }) }) - it('should refetch queries on mount', async () => { + it('should not refetch query on rerender', async () => { + const { getByTestId, rerender } = render( + + + , + ) + + await waitFor(() => { + expect(mockFetchData).toHaveBeenCalledTimes(1) + expect(getByTestId('test')).toHaveTextContent('Test data') + }) + + rerender( + + + , + ) + + await waitFor(() => { + expect(mockFetchData).toHaveBeenCalledTimes(1) + }) + }) + + it('should refetch query on mount', async () => { const { getByTestId, unmount } = render( @@ -70,7 +93,6 @@ describe('reactQuery', () => { , ) - await queryClient.invalidateQueries() await waitFor(() => { expect(mockFetchData).toHaveBeenCalledTimes(2) diff --git a/src/utils/query/reactQuery.ts b/src/utils/query/reactQuery.ts index 81047d639..c93241bb2 100644 --- a/src/utils/query/reactQuery.ts +++ b/src/utils/query/reactQuery.ts @@ -5,7 +5,7 @@ export const queryClient = new QueryClient({ defaultOptions: { queries: { refetchOnWindowFocus: true, - refetchOnMount: true, + refetchOnMount: 'always', staleTime: 1_000 * 12, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: hashFn, From 3be33542c013b987b47fd72393f02d6026c457b9 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Tue, 24 Sep 2024 19:22:49 +0700 Subject: [PATCH 14/75] Add e2e test for DNS import flow --- e2e/specs/stateless/_importName.spec.ts | 118 ++++++++++++++++++ .../stage/TransactionStageModal.tsx | 2 - .../steps/onchain/ImportTransaction.tsx | 8 +- .../steps/onchain/VerifyOnchainOwnership.tsx | 14 ++- 4 files changed, 137 insertions(+), 5 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index 55e9d7172..109710bf1 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -1,9 +1,24 @@ import { expect } from '@playwright/test' import { test } from '../../../playwright' +import { trackConsoleEvents } from '../../../playwright/fixtures/consoleListener' + +const chain = 'localhost' +const validEventTypes = [ + 'search_selected_dns', + 'import_type_selected_dns', + 'verify_ownership_started_dns', + 'claim_domain_started_dns', + 'commit_wallet_opened_dns', + 'register_started_dns', + 'register_wallet_opened_dns', +] + +const validEthRegistrationEventRegex = new RegExp(`"type":"(${validEventTypes.join('|')})"`) test('should allow claim (owned by user)', async ({ page, login, accounts, makePageObject }) => { const name = 'swagabc.xyz' + const consoleEvents = trackConsoleEvents(page, validEthRegistrationEventRegex) const homePage = makePageObject('HomePage') const importPage = makePageObject('ImportPage') @@ -14,7 +29,19 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP // should redirect to registration page await homePage.searchInput.fill(name) + await page.locator(`[data-testid="search-result-name"]`, { hasText: name }).waitFor() + await page.locator(`[data-testid="search-result-name"]`, { hasText: 'Not Imported' }).waitFor() await homePage.searchInput.press('Enter') + + await test.step('should fire DNS tracking event: search_selected_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ type: 'search_selected_dns', chain, props: { name, referrer: null } }), + ) + consoleEvents.length = 0 + }) + await expect(importPage.heading).toHaveText(`Claim ${name}`) // no type should be checked yet @@ -31,6 +58,19 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP // should jump straight to transaction step await expect(importPage.heading).toHaveText('Claim your domain') + await test.step('should fire DNS tracking event: import_type_selected_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ + type: 'import_type_selected_dns', + chain, + props: { name, importType: 'onchain', referrer: null }, + }), + ) + consoleEvents.length = 0 + }) + // should show cost value above 0 await expect(importPage.getCost()).resolves.toBeGreaterThan(0) @@ -39,10 +79,29 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await importPage.nextButton.click() + await test.step('should fire DNS tracking event: claim_domain_started_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ type: 'claim_domain_started_dns', chain, props: { referrer: null } }), + ) + consoleEvents.length = 0 + }) + // should be two steps: approve and claim await expect(transactionModal.getStepCount()).resolves.toEqual(2) await transactionModal.confirm() + + await test.step('should fire DNS tracking event: commit_wallet_opened_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ type: 'commit_wallet_opened_dns', chain, props: { referrer: null } }), + ) + consoleEvents.length = 0 + }) + await transactionModal.complete() // should save transaction status on refresh @@ -50,15 +109,46 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await expect(importPage.heading).toHaveText('Claim your domain') await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) + await test.step('should fire DNS tracking event: import_type_selected_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ + type: 'import_type_selected_dns', + chain, + props: { name, importType: 'onchain', referrer: null }, + }), + ) + consoleEvents.length = 0 + }) + // should allow finalising await importPage.nextButton.click() + await test.step('should fire DNS tracking event: register_started_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ type: 'register_started_dns', chain, props: { referrer: null } }), + ) + consoleEvents.length = 0 + }) + // transaction modal should still have 2 steps await expect(transactionModal.getStepCount()).resolves.toEqual(2) await expect(page.getByText('Open Wallet')).toBeVisible() await transactionModal.confirm() + await test.step('should fire DNS tracking event: register_wallet_opened_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ type: 'register_wallet_opened_dns', chain, props: { referrer: null } }), + ) + consoleEvents.length = 0 + }) + // should show complete step await expect(page.getByText('Congratulations!')).toBeVisible() await expect(page.getByText(`You are now the owner of ${name}`)).toBeVisible() @@ -71,6 +161,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP test('should allow import (not owned by user)', async ({ page, login, makePageObject }) => { const name = 'taytems.xyz' + const consoleEvents = trackConsoleEvents(page, validEthRegistrationEventRegex) const homePage = makePageObject('HomePage') const importPage = makePageObject('ImportPage') @@ -81,7 +172,21 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb // should redirect to registration page await homePage.searchInput.fill(name) + await page.locator(`[data-testid="search-result-name"]`, { hasText: name }).waitFor() + await page.locator(`[data-testid="search-result-name"]`, { hasText: 'Not Imported' }).waitFor() await homePage.searchInput.press('Enter') + + await page.pause() + + await test.step('should fire DNS tracking event: search_selected_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ type: 'search_selected_dns', chain, props: { name, referrer: null } }), + ) + consoleEvents.length = 0 + }) + await expect(importPage.heading).toHaveText(`Claim ${name}`) // no type should be checked yet @@ -95,6 +200,19 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) await importPage.nextButton.click() + await test.step('should fire DNS tracking event: import_type_selected_dns', async () => { + await expect(consoleEvents).toHaveLength(1) + + await expect(consoleEvents[0]).toContain( + JSON.stringify({ + type: 'import_type_selected_dns', + chain, + props: { name, importType: 'onchain', referrer: null }, + }), + ) + consoleEvents.length = 0 + }) + // should show verify ownership step with error message await expect(importPage.heading).toHaveText('Verify Ownership') await expect( diff --git a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx index b1730ad24..1d2082a18 100644 --- a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx +++ b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx @@ -489,8 +489,6 @@ export const TransactionStageModal = ({ onClick={() => { sendTransaction(request!) - console.log(actionName) - if (['commitName', 'registerName'].includes(actionName)) { trackEvent({ eventName: ['commitName'].includes(actionName) diff --git a/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx b/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx index b9a20c671..4e8b424ad 100644 --- a/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx +++ b/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx @@ -181,11 +181,15 @@ export const ImportTransaction = ({ const resumable = getResumable(key) const startOrResumeFlow = () => { - if (!item.started) dispatch({ name: 'setStarted', selected }) - if (resumable) { + if (!item.started) { trackEvent({ eventName: 'claim_domain_started_dns', }) + + dispatch({ name: 'setStarted', selected }) + } + + if (resumable) { return resumeTransactionFlow(key) } diff --git a/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx b/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx index 17bfba790..50950e021 100644 --- a/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx +++ b/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx @@ -8,6 +8,7 @@ import { CheckCircleSVG, Helper, Typography } from '@ensdomains/thorin' import RecordItem from '@app/components/RecordItem' import { DNS_TXT_RECORD_HELPER_LINKS } from '@app/constants/dnsLinks' import { useDnsOwner } from '@app/hooks/ensjs/dns/useDnsOwner' +import { useEventTracker } from '@app/hooks/useEventTracker' import { shortenAddress } from '@app/utils/utils' import { @@ -68,6 +69,7 @@ export const VerifyOnchainOwnership = ({ }) => { const { t } = useTranslation('dnssec', { keyPrefix: 'steps.verifyOwnership' }) const { t: tc } = useTranslation('common') + const { trackEvent } = useEventTracker() const { data: dnsOwner, @@ -96,6 +98,16 @@ export const VerifyOnchainOwnership = ({ return tc(`error.${errorKey}`, { ns: 'dnssec' }) }, [tc, error, isLoading]) + const handleDNSButtonClick = () => { + dispatch({ name: 'increaseStep', selected }) + + if (dnsOwnerStatus === 'mismatching') { + trackEvent({ + eventName: 'verify_ownership_started_dns', + }) + } + } + return ( {t('title')} @@ -160,7 +172,7 @@ export const VerifyOnchainOwnership = ({ {isConnected ? ( dispatch({ name: 'increaseStep', selected })} + onClick={handleDNSButtonClick} data-testid="import-next-button" {...(dnsOwnerStatus === 'mismatching' ? { From 1dd642e2e74dba0d3ff906beb529e5765b30b91d Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 25 Sep 2024 09:23:34 +0700 Subject: [PATCH 15/75] Add tracker DNS follow to event open wallet and verify offchain owner ship --- .../stage/TransactionStageModal.tsx | 2 +- .../import/[name]/steps/VerifyOffchainOwnership.tsx | 11 ++++++++++- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx index 1d2082a18..3ba31a94f 100644 --- a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx +++ b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx @@ -497,7 +497,7 @@ export const TransactionStageModal = ({ }) } - if (actionName === 'approveDnsRegistrar') { + if (['approveDnsRegistrar', 'importDnsName'].includes(actionName)) { trackEvent({ eventName: 'commit_wallet_opened_dns', }) diff --git a/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx b/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx index e72dbc4ad..0a2a7b19e 100644 --- a/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx +++ b/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx @@ -9,6 +9,7 @@ import RecordItem from '@app/components/RecordItem' import { DNS_TXT_RECORD_HELPER_LINKS } from '@app/constants/dnsLinks' import { EXTENDED_DNS_RESOLVER_MAP } from '@app/constants/resolverAddressData' import { useDnsOffchainStatus } from '@app/hooks/dns/useDnsOffchainStatus' +import { useEventTracker } from '@app/hooks/useEventTracker' import { shortenAddress } from '@app/utils/utils' import { @@ -73,6 +74,7 @@ export const VerifyOffchainOwnership = ({ }) => { const { t } = useTranslation('dnssec', { keyPrefix: 'steps.verifyOwnership' }) const { t: tc } = useTranslation('common') + const { trackEvent } = useEventTracker() const { address, chainId } = selected const isConnected = !!address @@ -97,6 +99,13 @@ export const VerifyOffchainOwnership = ({ return null }, [tc, error]) + const handleCompleteOffChainProcess = () => { + dispatch({ name: 'increaseStep', selected }) + if (dnsOffchainStatus?.address?.status === 'mismatching') { + trackEvent({ eventName: 'register_started_dns' }) + } + } + return ( {t('title')} @@ -165,7 +174,7 @@ export const VerifyOffchainOwnership = ({ {isConnected ? ( dispatch({ name: 'increaseStep', selected })} + onClick={handleCompleteOffChainProcess} {...(dnsOffchainStatus?.address?.status === 'mismatching' ? { colorStyle: 'redPrimary', From 87b55b3c8aefde2511225fb793abba8e12c02082 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 25 Sep 2024 10:25:33 +0700 Subject: [PATCH 16/75] Fix e2e test failed on import_type_selected_dns event --- e2e/specs/stateless/_importName.spec.ts | 15 --------------- 1 file changed, 15 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index 109710bf1..b34b9c501 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -109,19 +109,6 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await expect(importPage.heading).toHaveText('Claim your domain') await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) - await test.step('should fire DNS tracking event: import_type_selected_dns', async () => { - await expect(consoleEvents).toHaveLength(1) - - await expect(consoleEvents[0]).toContain( - JSON.stringify({ - type: 'import_type_selected_dns', - chain, - props: { name, importType: 'onchain', referrer: null }, - }), - ) - consoleEvents.length = 0 - }) - // should allow finalising await importPage.nextButton.click() @@ -176,8 +163,6 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb await page.locator(`[data-testid="search-result-name"]`, { hasText: 'Not Imported' }).waitFor() await homePage.searchInput.press('Enter') - await page.pause() - await test.step('should fire DNS tracking event: search_selected_dns', async () => { await expect(consoleEvents).toHaveLength(1) From d3d68ffb201ee2215a3fb8610290bf847e32fa24 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 25 Sep 2024 15:54:56 +0700 Subject: [PATCH 17/75] Change logic function complete off chain process and function verify owner ship --- .../pages/import/[name]/steps/VerifyOffchainOwnership.tsx | 6 +++--- .../[name]/steps/onchain/VerifyOnchainOwnership.tsx | 8 +++----- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx b/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx index 0a2a7b19e..7b65f1156 100644 --- a/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx +++ b/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx @@ -99,9 +99,9 @@ export const VerifyOffchainOwnership = ({ return null }, [tc, error]) - const handleCompleteOffChainProcess = () => { + const handleCompleteOffchainProcess = () => { dispatch({ name: 'increaseStep', selected }) - if (dnsOffchainStatus?.address?.status === 'mismatching') { + if (dnsOffchainStatus?.address?.status !== 'mismatching') { trackEvent({ eventName: 'register_started_dns' }) } } @@ -174,7 +174,7 @@ export const VerifyOffchainOwnership = ({ {isConnected ? ( { dispatch({ name: 'increaseStep', selected }) - if (dnsOwnerStatus === 'mismatching') { - trackEvent({ - eventName: 'verify_ownership_started_dns', - }) - } + trackEvent({ + eventName: 'verify_ownership_started_dns', + }) } return ( From 112a529fb856a5338b9d204c8c280500e4779ec5 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 25 Sep 2024 16:42:20 +0700 Subject: [PATCH 18/75] Update message test, change name function start dns import and reduce case tracker event in useEventTracker --- e2e/specs/stateless/_importName.spec.ts | 16 ++++++++-------- .../steps/onchain/VerifyOnchainOwnership.tsx | 4 ++-- src/hooks/useEventTracker.ts | 19 +++++-------------- 3 files changed, 15 insertions(+), 24 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index b34b9c501..2f0832138 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -33,7 +33,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await page.locator(`[data-testid="search-result-name"]`, { hasText: 'Not Imported' }).waitFor() await homePage.searchInput.press('Enter') - await test.step('should fire DNS tracking event: search_selected_dns', async () => { + await test.step('should fire DNS import tracking event: search_selected_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -58,7 +58,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP // should jump straight to transaction step await expect(importPage.heading).toHaveText('Claim your domain') - await test.step('should fire DNS tracking event: import_type_selected_dns', async () => { + await test.step('should fire DNS import tracking event: import_type_selected_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -79,7 +79,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await importPage.nextButton.click() - await test.step('should fire DNS tracking event: claim_domain_started_dns', async () => { + await test.step('should fire DNS import tracking event: claim_domain_started_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -93,7 +93,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await transactionModal.confirm() - await test.step('should fire DNS tracking event: commit_wallet_opened_dns', async () => { + await test.step('should fire DNS import tracking event: commit_wallet_opened_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -112,7 +112,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP // should allow finalising await importPage.nextButton.click() - await test.step('should fire DNS tracking event: register_started_dns', async () => { + await test.step('should fire DNS import tracking event: register_started_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -127,7 +127,7 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await expect(page.getByText('Open Wallet')).toBeVisible() await transactionModal.confirm() - await test.step('should fire DNS tracking event: register_wallet_opened_dns', async () => { + await test.step('should fire DNS import tracking event: register_wallet_opened_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -163,7 +163,7 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb await page.locator(`[data-testid="search-result-name"]`, { hasText: 'Not Imported' }).waitFor() await homePage.searchInput.press('Enter') - await test.step('should fire DNS tracking event: search_selected_dns', async () => { + await test.step('should fire DNS import tracking event: search_selected_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( @@ -185,7 +185,7 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) await importPage.nextButton.click() - await test.step('should fire DNS tracking event: import_type_selected_dns', async () => { + await test.step('should fire DNS import tracking event: import_type_selected_dns', async () => { await expect(consoleEvents).toHaveLength(1) await expect(consoleEvents[0]).toContain( diff --git a/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx b/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx index a768acb56..149ede542 100644 --- a/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx +++ b/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx @@ -98,7 +98,7 @@ export const VerifyOnchainOwnership = ({ return tc(`error.${errorKey}`, { ns: 'dnssec' }) }, [tc, error, isLoading]) - const handleDNSButtonClick = () => { + const handleStartDNSImport = () => { dispatch({ name: 'increaseStep', selected }) trackEvent({ @@ -170,7 +170,7 @@ export const VerifyOnchainOwnership = ({ {isConnected ? ( { 'register_started', 'register_started_box', 'register_wallet_opened', + 'verify_ownership_started_dns', + 'claim_domain_started_dns', + 'commit_wallet_opened_dns', + 'register_started_dns', + 'register_wallet_opened_dns', ), }, ({ eventName }) => sendTrackEvent(eventName, chain), @@ -100,20 +105,6 @@ export const useEventTracker = () => { sendTrackEvent(eventName, chain, { name, importType }) }, ) - .with( - { - eventName: P.union( - 'verify_ownership_started_dns', - 'claim_domain_started_dns', - 'commit_wallet_opened_dns', - 'register_started_dns', - 'register_wallet_opened_dns', - ), - }, - ({ eventName }) => { - sendTrackEvent(eventName, chain) - }, - ) .exhaustive() } From 98fc8437a73566f6ddd814a3a88189d5bca006b9 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Wed, 25 Sep 2024 17:04:59 +0700 Subject: [PATCH 19/75] Update function name complete transaction DNS import and update type DNS import select event --- .../TransactionDialogManager/stage/TransactionStageModal.tsx | 4 ++-- src/hooks/useEventTracker.ts | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx index 3ba31a94f..ddaa5b7c4 100644 --- a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx +++ b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx @@ -411,7 +411,7 @@ export const TransactionStageModal = ({ }, [helper]) const ActionButton = useMemo(() => { - const handleClickActionButton = () => { + const handleCompleteTransaction = () => { dispatch({ name: 'incrementTransaction' }) if (actionName === 'approveDnsRegistrar') { @@ -437,7 +437,7 @@ export const TransactionStageModal = ({ return ( diff --git a/src/hooks/useEventTracker.ts b/src/hooks/useEventTracker.ts index dc26c4f7e..859b2fc4f 100644 --- a/src/hooks/useEventTracker.ts +++ b/src/hooks/useEventTracker.ts @@ -22,7 +22,7 @@ type PaymentEvent = { } } -type DNSImportTypeEvent = { +type DNSImportTypeSelectedEvent = { eventName: 'import_type_selected_dns' customProperties: { importType: 'onchain' | 'offchain' | null @@ -49,7 +49,7 @@ export type TrackEventParameters = | SearchSelectEvent | PaymentEvent | DefaultEvent - | DNSImportTypeEvent + | DNSImportTypeSelectedEvent export const useEventTracker = () => { const chain = useChainName() From 91267adc9edb47498db454319c651b534c674383 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Thu, 26 Sep 2024 17:53:51 +0700 Subject: [PATCH 20/75] Update console listener event DNS tracker follow --- e2e/specs/stateless/_importName.spec.ts | 118 ++++++++++++++++-------- 1 file changed, 80 insertions(+), 38 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index 2f0832138..d3f10294c 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -1,7 +1,6 @@ import { expect } from '@playwright/test' import { test } from '../../../playwright' -import { trackConsoleEvents } from '../../../playwright/fixtures/consoleListener' const chain = 'localhost' const validEventTypes = [ @@ -16,9 +15,27 @@ const validEventTypes = [ const validEthRegistrationEventRegex = new RegExp(`"type":"(${validEventTypes.join('|')})"`) -test('should allow claim (owned by user)', async ({ page, login, accounts, makePageObject }) => { +test('should allow claim (owned by user)', async ({ + page, + login, + accounts, + makePageObject, + consoleListener, +}) => { const name = 'swagabc.xyz' - const consoleEvents = trackConsoleEvents(page, validEthRegistrationEventRegex) + await consoleListener.initialize({ + regex: new RegExp( + `Event triggered on local development.*?(${[ + 'search_selected_dns', + 'import_type_selected_dns', + 'verify_ownership_started_dns', + 'claim_domain_started_dns', + 'commit_wallet_opened_dns', + 'register_started_dns', + 'register_wallet_opened_dns', + ].join('|')})`, + ), + }) const homePage = makePageObject('HomePage') const importPage = makePageObject('ImportPage') @@ -34,13 +51,14 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await homePage.searchInput.press('Enter') await test.step('should fire DNS import tracking event: search_selected_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( - JSON.stringify({ type: 'search_selected_dns', chain, props: { name, referrer: null } }), + await expect(consoleListener.getMessages().toString()).toMatch( + new RegExp(`search_selected_dns`), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) + await page.pause() await expect(importPage.heading).toHaveText(`Claim ${name}`) @@ -59,16 +77,18 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await expect(importPage.heading).toHaveText('Claim your domain') await test.step('should fire DNS import tracking event: import_type_selected_dns', async () => { - await expect(consoleEvents).toHaveLength(1) - - await expect(consoleEvents[0]).toContain( - JSON.stringify({ - type: 'import_type_selected_dns', - chain, - props: { name, importType: 'onchain', referrer: null }, - }), + await expect(consoleListener.getMessages()).toHaveLength(1) + + await expect(consoleListener.getMessages().toString()).toMatch( + new RegExp( + JSON.stringify({ + type: 'import_type_selected_dns', + chain, + props: { name, importType: 'onchain', referrer: null }, + }), + ), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) // should show cost value above 0 @@ -80,12 +100,14 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await importPage.nextButton.click() await test.step('should fire DNS import tracking event: claim_domain_started_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( - JSON.stringify({ type: 'claim_domain_started_dns', chain, props: { referrer: null } }), + await expect(consoleListener.getMessages().toString()).toMatch( + new RegExp( + JSON.stringify({ type: 'claim_domain_started_dns', chain, props: { referrer: null } }), + ), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) // should be two steps: approve and claim @@ -94,12 +116,14 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await transactionModal.confirm() await test.step('should fire DNS import tracking event: commit_wallet_opened_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( - JSON.stringify({ type: 'commit_wallet_opened_dns', chain, props: { referrer: null } }), + await expect(consoleListener.getMessages().toString()).toMatch( + new RegExp( + JSON.stringify({ type: 'commit_wallet_opened_dns', chain, props: { referrer: null } }), + ), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) await transactionModal.complete() @@ -113,12 +137,12 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await importPage.nextButton.click() await test.step('should fire DNS import tracking event: register_started_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( + await expect(consoleListener.getMessages().toString()).toMatch( JSON.stringify({ type: 'register_started_dns', chain, props: { referrer: null } }), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) // transaction modal should still have 2 steps @@ -128,12 +152,12 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP await transactionModal.confirm() await test.step('should fire DNS import tracking event: register_wallet_opened_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( + await expect(consoleListener.getMessages().toString()).toMatch( JSON.stringify({ type: 'register_wallet_opened_dns', chain, props: { referrer: null } }), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) // should show complete step @@ -146,9 +170,27 @@ test('should allow claim (owned by user)', async ({ page, login, accounts, makeP ) }) -test('should allow import (not owned by user)', async ({ page, login, makePageObject }) => { +test('should allow import (not owned by user)', async ({ + page, + login, + makePageObject, + consoleListener, +}) => { const name = 'taytems.xyz' - const consoleEvents = trackConsoleEvents(page, validEthRegistrationEventRegex) + + await consoleListener.initialize({ + regex: new RegExp( + `Event triggered on local development.*?(${[ + 'search_selected_dns', + 'import_type_selected_dns', + 'verify_ownership_started_dns', + 'claim_domain_started_dns', + 'commit_wallet_opened_dns', + 'register_started_dns', + 'register_wallet_opened_dns', + ].join('|')})`, + ), + }) const homePage = makePageObject('HomePage') const importPage = makePageObject('ImportPage') @@ -164,12 +206,12 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb await homePage.searchInput.press('Enter') await test.step('should fire DNS import tracking event: search_selected_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( + await expect(consoleListener.getMessages().toString()).toMatch( JSON.stringify({ type: 'search_selected_dns', chain, props: { name, referrer: null } }), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) await expect(importPage.heading).toHaveText(`Claim ${name}`) @@ -186,16 +228,16 @@ test('should allow import (not owned by user)', async ({ page, login, makePageOb await importPage.nextButton.click() await test.step('should fire DNS import tracking event: import_type_selected_dns', async () => { - await expect(consoleEvents).toHaveLength(1) + await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleEvents[0]).toContain( + await expect(consoleListener.getMessages().toString()).toMatch( JSON.stringify({ type: 'import_type_selected_dns', chain, props: { name, importType: 'onchain', referrer: null }, }), ) - consoleEvents.length = 0 + consoleListener.clearMessages() }) // should show verify ownership step with error message From e197f27345da15b42352d0273e6a4db66f030789 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Thu, 26 Sep 2024 18:24:24 +0700 Subject: [PATCH 21/75] Remove variable unused and change method match to contain --- e2e/specs/stateless/_importName.spec.ts | 61 ++++++------------------- 1 file changed, 14 insertions(+), 47 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index d3f10294c..5cf18fdb3 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -2,19 +2,6 @@ import { expect } from '@playwright/test' import { test } from '../../../playwright' -const chain = 'localhost' -const validEventTypes = [ - 'search_selected_dns', - 'import_type_selected_dns', - 'verify_ownership_started_dns', - 'claim_domain_started_dns', - 'commit_wallet_opened_dns', - 'register_started_dns', - 'register_wallet_opened_dns', -] - -const validEthRegistrationEventRegex = new RegExp(`"type":"(${validEventTypes.join('|')})"`) - test('should allow claim (owned by user)', async ({ page, login, @@ -58,7 +45,6 @@ test('should allow claim (owned by user)', async ({ ) consoleListener.clearMessages() }) - await page.pause() await expect(importPage.heading).toHaveText(`Claim ${name}`) @@ -80,13 +66,7 @@ test('should allow claim (owned by user)', async ({ await expect(consoleListener.getMessages()).toHaveLength(1) await expect(consoleListener.getMessages().toString()).toMatch( - new RegExp( - JSON.stringify({ - type: 'import_type_selected_dns', - chain, - props: { name, importType: 'onchain', referrer: null }, - }), - ), + new RegExp(`import_type_selected_dns.*?${name}`), ) consoleListener.clearMessages() }) @@ -102,11 +82,7 @@ test('should allow claim (owned by user)', async ({ await test.step('should fire DNS import tracking event: claim_domain_started_dns', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleListener.getMessages().toString()).toMatch( - new RegExp( - JSON.stringify({ type: 'claim_domain_started_dns', chain, props: { referrer: null } }), - ), - ) + await expect(consoleListener.getMessages().toString()).toContain('claim_domain_started_dns') consoleListener.clearMessages() }) @@ -118,11 +94,7 @@ test('should allow claim (owned by user)', async ({ await test.step('should fire DNS import tracking event: commit_wallet_opened_dns', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleListener.getMessages().toString()).toMatch( - new RegExp( - JSON.stringify({ type: 'commit_wallet_opened_dns', chain, props: { referrer: null } }), - ), - ) + await expect(consoleListener.getMessages().toString()).toContain('commit_wallet_opened_dns') consoleListener.clearMessages() }) @@ -139,9 +111,7 @@ test('should allow claim (owned by user)', async ({ await test.step('should fire DNS import tracking event: register_started_dns', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleListener.getMessages().toString()).toMatch( - JSON.stringify({ type: 'register_started_dns', chain, props: { referrer: null } }), - ) + await expect(consoleListener.getMessages().toString()).toContain('register_started_dns') consoleListener.clearMessages() }) @@ -154,9 +124,7 @@ test('should allow claim (owned by user)', async ({ await test.step('should fire DNS import tracking event: register_wallet_opened_dns', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleListener.getMessages().toString()).toMatch( - JSON.stringify({ type: 'register_wallet_opened_dns', chain, props: { referrer: null } }), - ) + await expect(consoleListener.getMessages().toString()).toContain('register_wallet_opened_dns') consoleListener.clearMessages() }) @@ -184,10 +152,6 @@ test('should allow import (not owned by user)', async ({ 'search_selected_dns', 'import_type_selected_dns', 'verify_ownership_started_dns', - 'claim_domain_started_dns', - 'commit_wallet_opened_dns', - 'register_started_dns', - 'register_wallet_opened_dns', ].join('|')})`, ), }) @@ -209,7 +173,7 @@ test('should allow import (not owned by user)', async ({ await expect(consoleListener.getMessages()).toHaveLength(1) await expect(consoleListener.getMessages().toString()).toMatch( - JSON.stringify({ type: 'search_selected_dns', chain, props: { name, referrer: null } }), + new RegExp(`search_selected_dns.*?${name}`), ) consoleListener.clearMessages() }) @@ -231,11 +195,7 @@ test('should allow import (not owned by user)', async ({ await expect(consoleListener.getMessages()).toHaveLength(1) await expect(consoleListener.getMessages().toString()).toMatch( - JSON.stringify({ - type: 'import_type_selected_dns', - chain, - props: { name, importType: 'onchain', referrer: null }, - }), + new RegExp(`import_type_selected_dns.*?${name}`), ) consoleListener.clearMessages() }) @@ -252,6 +212,13 @@ test('should allow import (not owned by user)', async ({ await importPage.nextButton.click() + await test.step('should fire DNS import tracking event: verify_ownership_started_dns', async () => { + await expect(consoleListener.getMessages()).toHaveLength(1) + + await expect(consoleListener.getMessages().toString()).toContain('verify_ownership_started_dns') + consoleListener.clearMessages() + }) + // should go to transaction step await expect(importPage.heading).toHaveText('Import this domain') From ee21c1d9d114a5ef6527e6f8c491087567e92c42 Mon Sep 17 00:00:00 2001 From: Nho Huynh Date: Thu, 26 Sep 2024 18:30:41 +0700 Subject: [PATCH 22/75] Use a regular expression literal instead of the 'RegExp' for search_selected_dns event --- e2e/specs/stateless/_importName.spec.ts | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index 5cf18fdb3..c029836f3 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -40,9 +40,7 @@ test('should allow claim (owned by user)', async ({ await test.step('should fire DNS import tracking event: search_selected_dns', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleListener.getMessages().toString()).toMatch( - new RegExp(`search_selected_dns`), - ) + await expect(consoleListener.getMessages().toString()).toContain('search_selected_dns') consoleListener.clearMessages() }) From b965851bf8b735de0062ec79c3fc03af4a7a85aa Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Wed, 9 Oct 2024 13:22:42 +0800 Subject: [PATCH 23/75] add react-query-dev-tools --- package.json | 1 + pnpm-lock.yaml | 20 +++++++++ src/hooks/ensjs/public/useRecords.ts | 1 + src/utils/query/providers.tsx | 2 + src/utils/query/reactQuery.test.tsx | 64 +++++++++++++++++++++++----- 5 files changed, 77 insertions(+), 11 deletions(-) diff --git a/package.json b/package.json index 17cb30b03..ec3f01af5 100644 --- a/package.json +++ b/package.json @@ -65,6 +65,7 @@ "@tanstack/query-persist-client-core": "5.22.2", "@tanstack/query-sync-storage-persister": "5.22.2", "@tanstack/react-query": "5.22.2", + "@tanstack/react-query-devtools": "^5.59.0", "@tanstack/react-query-persist-client": "5.22.2", "@wagmi/core": "2.13.3", "@walletconnect/ethereum-provider": "^2.11.1", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 96fc7eb4e..a7e2a8274 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -68,6 +68,9 @@ importers: '@tanstack/react-query': specifier: 5.22.2 version: 5.22.2(react@18.3.1) + '@tanstack/react-query-devtools': + specifier: ^5.59.0 + version: 5.59.0(@tanstack/react-query@5.22.2(react@18.3.1))(react@18.3.1) '@tanstack/react-query-persist-client': specifier: 5.22.2 version: 5.22.2(@tanstack/react-query@5.22.2(react@18.3.1))(react@18.3.1) @@ -3093,12 +3096,21 @@ packages: '@tanstack/query-core@5.22.2': resolution: {integrity: sha512-z3PwKFUFACMUqe1eyesCIKg3Jv1mysSrYfrEW5ww5DCDUD4zlpTKBvUDaEjsfZzL3ULrFLDM9yVUxI/fega1Qg==} + '@tanstack/query-devtools@5.58.0': + resolution: {integrity: sha512-iFdQEFXaYYxqgrv63ots+65FGI+tNp5ZS5PdMU1DWisxk3fez5HG3FyVlbUva+RdYS5hSLbxZ9aw3yEs97GNTw==} + '@tanstack/query-persist-client-core@5.22.2': resolution: {integrity: sha512-sFDgWoN54uclIDIoImPmDzxTq8HhZEt9pO0JbVHjI6LPZqunMMF9yAq9zFKrpH//jD5f+rBCQsdGyhdpUo9e8Q==} '@tanstack/query-sync-storage-persister@5.22.2': resolution: {integrity: sha512-mDxXURiMPzWXVc+FwDu94VfIt/uHk5+9EgcxJRYtj8Vsx18T0DiiKk1VgVOBLd97C+Sa7z7ujP2D6Y5lphW+hQ==} + '@tanstack/react-query-devtools@5.59.0': + resolution: {integrity: sha512-Kz7577FQGU8qmJxROIT/aOwmkTcxfBqgTP6r1AIvuJxVMVHPkp8eQxWQ7BnfBsy/KTJHiV9vMtRVo1+R1tB3vg==} + peerDependencies: + '@tanstack/react-query': ^5.59.0 + react: ^18.2.0 + '@tanstack/react-query-persist-client@5.22.2': resolution: {integrity: sha512-osAaQn2PDTaa2ApTLOAus7g8Y96LHfS2+Pgu/RoDlEJUEkX7xdEn0YuurxbnJaDJDESMfr+CH/eAX2y+lx02Fg==} peerDependencies: @@ -13816,6 +13828,8 @@ snapshots: '@tanstack/query-core@5.22.2': {} + '@tanstack/query-devtools@5.58.0': {} + '@tanstack/query-persist-client-core@5.22.2': dependencies: '@tanstack/query-core': 5.22.2 @@ -13825,6 +13839,12 @@ snapshots: '@tanstack/query-core': 5.22.2 '@tanstack/query-persist-client-core': 5.22.2 + '@tanstack/react-query-devtools@5.59.0(@tanstack/react-query@5.22.2(react@18.3.1))(react@18.3.1)': + dependencies: + '@tanstack/query-devtools': 5.58.0 + '@tanstack/react-query': 5.22.2(react@18.3.1) + react: 18.3.1 + '@tanstack/react-query-persist-client@5.22.2(@tanstack/react-query@5.22.2(react@18.3.1))(react@18.3.1)': dependencies: '@tanstack/query-persist-client-core': 5.22.2 diff --git a/src/hooks/ensjs/public/useRecords.ts b/src/hooks/ensjs/public/useRecords.ts index 6e95d1e10..dafbf538b 100644 --- a/src/hooks/ensjs/public/useRecords.ts +++ b/src/hooks/ensjs/public/useRecords.ts @@ -86,6 +86,7 @@ export const getRecordsQueryFn = > => { if (!name) throw new Error('name is required') + console.log('getRecordsQueryFn', name) const client = config.getClient({ chainId }) const res = await getRecords(client, { name, diff --git a/src/utils/query/providers.tsx b/src/utils/query/providers.tsx index 9227d1217..8224a50d0 100644 --- a/src/utils/query/providers.tsx +++ b/src/utils/query/providers.tsx @@ -1,3 +1,4 @@ +import { ReactQueryDevtools } from '@tanstack/react-query-devtools' import { PersistQueryClientProvider } from '@tanstack/react-query-persist-client' import type { ReactNode } from 'react' import { WagmiProvider } from 'wagmi' @@ -18,6 +19,7 @@ export function QueryProviders({ children }: Props) { persistOptions={createPersistConfig({ queryClient })} > {children} + ) diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx index f97c9f337..aac560125 100644 --- a/src/utils/query/reactQuery.test.tsx +++ b/src/utils/query/reactQuery.test.tsx @@ -1,7 +1,8 @@ import { render, waitFor } from '@app/test-utils' -import { QueryClientProvider, useQuery } from '@tanstack/react-query' -import { ReactNode } from 'react' +import { QueryClientProvider } from '@tanstack/react-query' +import { useQuery } from './useQuery' +import { PropsWithChildren, ReactNode } from 'react' import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest' import { WagmiProvider } from 'wagmi' @@ -18,15 +19,24 @@ const TestComponentWrapper = ({ children }: { children: ReactNode }) => { ) } -const TestComponentWithHook = () => { - const { data, isFetching } = useQuery({ +const TestComponentWithHook = ({ children, ...props }: PropsWithChildren<{}>) => { + const { data, isFetching, isLoading } = useQuery({ queryKey: ['test-hook'], queryFn: mockFetchData, enabled: true, }) return ( -
{isFetching ? Loading... : Data: {data}}
+
+ {isLoading ? ( + Loading... + ) : ( + + Data: {data} + {children} + + )} +
) } @@ -44,8 +54,8 @@ describe('reactQuery', () => { expect(queryClient.getDefaultOptions()).toEqual({ queries: { refetchOnWindowFocus: true, - refetchOnMount: 'always', - staleTime: 1_000 * 12, + refetchOnMount: true, + staleTime: 0, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: expect.any(Function), }, @@ -55,7 +65,7 @@ describe('reactQuery', () => { it('should not refetch query on rerender', async () => { const { getByTestId, rerender } = render( - + , ) @@ -66,11 +76,12 @@ describe('reactQuery', () => { rerender( - + , ) await waitFor(() => { + expect(getByTestId('test')).toHaveTextContent('Test data') expect(mockFetchData).toHaveBeenCalledTimes(1) }) }) @@ -78,7 +89,7 @@ describe('reactQuery', () => { it('should refetch query on mount', async () => { const { getByTestId, unmount } = render( - + , ) @@ -90,13 +101,44 @@ describe('reactQuery', () => { unmount() const { getByTestId: getByTestId2 } = render( - + , ) await waitFor(() => { + expect(getByTestId2('test')).toHaveTextContent('Test data') expect(mockFetchData).toHaveBeenCalledTimes(2) + }) + }) + + it('should not fetch twice on nested query', async () => { + const { getByTestId, unmount } = render( + + + + + , + ) + + await waitFor(() => { + expect(getByTestId('test')).toHaveTextContent('Test data') + expect(getByTestId('nested')).toHaveTextContent('Test data') + expect(mockFetchData).toHaveBeenCalledTimes(1) + }) + + unmount() + const { getByTestId: getByTestId2 } = render( + + + + + , + ) + + await waitFor(() => { expect(getByTestId2('test')).toHaveTextContent('Test data') + expect(getByTestId2('nested')).toHaveTextContent('Test data') + expect(mockFetchData).toHaveBeenCalledTimes(2) }) }) }) From 3c19154b34a5e2ed13198799f71704c402745b1e Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Wed, 9 Oct 2024 15:36:54 +0800 Subject: [PATCH 24/75] update react query defaults and react query test --- src/utils/query/providers.tsx | 2 +- src/utils/query/reactQuery.test.tsx | 6 +++--- src/utils/query/reactQuery.ts | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/utils/query/providers.tsx b/src/utils/query/providers.tsx index 8224a50d0..387a4e1ce 100644 --- a/src/utils/query/providers.tsx +++ b/src/utils/query/providers.tsx @@ -19,7 +19,7 @@ export function QueryProviders({ children }: Props) { persistOptions={createPersistConfig({ queryClient })} > {children} - + ) diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx index aac560125..f89d42bc1 100644 --- a/src/utils/query/reactQuery.test.tsx +++ b/src/utils/query/reactQuery.test.tsx @@ -111,7 +111,7 @@ describe('reactQuery', () => { }) }) - it('should not fetch twice on nested query', async () => { + it('should fetch twice on nested query with no cache and once with cache', async () => { const { getByTestId, unmount } = render( @@ -123,7 +123,7 @@ describe('reactQuery', () => { await waitFor(() => { expect(getByTestId('test')).toHaveTextContent('Test data') expect(getByTestId('nested')).toHaveTextContent('Test data') - expect(mockFetchData).toHaveBeenCalledTimes(1) + expect(mockFetchData).toHaveBeenCalledTimes(2) }) unmount() @@ -138,7 +138,7 @@ describe('reactQuery', () => { await waitFor(() => { expect(getByTestId2('test')).toHaveTextContent('Test data') expect(getByTestId2('nested')).toHaveTextContent('Test data') - expect(mockFetchData).toHaveBeenCalledTimes(2) + expect(mockFetchData).toHaveBeenCalledTimes(3) }) }) }) diff --git a/src/utils/query/reactQuery.ts b/src/utils/query/reactQuery.ts index c93241bb2..80ba1fb8c 100644 --- a/src/utils/query/reactQuery.ts +++ b/src/utils/query/reactQuery.ts @@ -5,8 +5,8 @@ export const queryClient = new QueryClient({ defaultOptions: { queries: { refetchOnWindowFocus: true, - refetchOnMount: 'always', - staleTime: 1_000 * 12, + refetchOnMount: true, + staleTime: 0, gcTime: 1_000 * 60 * 60 * 24, queryKeyHashFn: hashFn, }, From 161447b28714b83dbf5656f4ad90efc55116c7ec Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Wed, 9 Oct 2024 16:05:25 +0800 Subject: [PATCH 25/75] clean up console logs --- .../pages/profile/[name]/registration/steps/Transactions.tsx | 2 -- src/hooks/ensjs/public/useRecords.ts | 1 - 2 files changed, 3 deletions(-) diff --git a/src/components/pages/profile/[name]/registration/steps/Transactions.tsx b/src/components/pages/profile/[name]/registration/steps/Transactions.tsx index 4e245ea57..f934e8ef2 100644 --- a/src/components/pages/profile/[name]/registration/steps/Transactions.tsx +++ b/src/components/pages/profile/[name]/registration/steps/Transactions.tsx @@ -336,8 +336,6 @@ const Transactions = ({ registrationData, name, callback, onStart }: Props) => { endDate: commitTimestamp ? new Date(commitTimestamp + ONE_DAY * 1000) : undefined, }) - console.log('duration', duration, commitTimestamp) - return ( setResetOpen(false)}> diff --git a/src/hooks/ensjs/public/useRecords.ts b/src/hooks/ensjs/public/useRecords.ts index dafbf538b..6e95d1e10 100644 --- a/src/hooks/ensjs/public/useRecords.ts +++ b/src/hooks/ensjs/public/useRecords.ts @@ -86,7 +86,6 @@ export const getRecordsQueryFn = > => { if (!name) throw new Error('name is required') - console.log('getRecordsQueryFn', name) const client = config.getClient({ chainId }) const res = await getRecords(client, { name, From 3f27a767a2a137bbd7d55a22e746a65e4fad25bf Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Wed, 9 Oct 2024 19:38:19 +0800 Subject: [PATCH 26/75] clean up extendNames test --- e2e/specs/stateless/extendNames.spec.ts | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index ae14d1346..f16352fbb 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -77,6 +77,7 @@ test('should be able to register multiple names on the address page', async ({ // increment and save await page.getByTestId('plus-minus-control-plus').click() await page.getByTestId('plus-minus-control-plus').click() + await page.waitForTimeout(500) await page.getByTestId('extend-names-confirm').click() await transactionModal.autoComplete() @@ -88,13 +89,11 @@ test('should be able to register multiple names on the address page', async ({ // Should be able to remove this after useQuery is fixed. Using to force a refetch. await time.increaseTime({ seconds: 15 }) - await page.pause() await page.reload() for (const name of extendableNameItems) { const label = name.replace('.eth', '') await addresPage.search(label) await expect(addresPage.getNameRow(name)).toBeVisible({ timeout: 5000 }) - await page.pause() await expect(await addresPage.getTimestamp(name)).not.toBe(timestampDict[name]) await expect(await addresPage.getTimestamp(name)).toBe(timestampDict[name] + 31536000000 * 3) } @@ -194,7 +193,6 @@ test('should be able to extend a single unwrapped name in grace period from prof const timestamp = await profilePage.getExpiryTimestamp() - await page.pause() await profilePage.getExtendButton.click() const extendNamesModal = makePageObject('ExtendNamesModal') @@ -353,7 +351,6 @@ test('should be able to extend a name by a month', async ({ await profilePage.goto(name) await login.connect() - await page.pause() const timestamp = await profilePage.getExpiryTimestamp() await profilePage.getExtendButton.click() @@ -418,7 +415,6 @@ test('should be able to extend a name by a day', async ({ await profilePage.goto(name) await login.connect() - await page.pause() const timestamp = await profilePage.getExpiryTimestamp() await profilePage.getExtendButton.click() @@ -485,7 +481,6 @@ test('should be able to extend a name in grace period by a month', async ({ const timestamp = await profilePage.getExpiryTimestamp() - await page.pause() await profilePage.getExtendButton.click() const extendNamesModal = makePageObject('ExtendNamesModal') @@ -568,7 +563,6 @@ test('should be able to extend a name in grace period by 1 day', async ({ const timestamp = await profilePage.getExpiryTimestamp() - await page.pause() await profilePage.getExtendButton.click() const extendNamesModal = makePageObject('ExtendNamesModal') From 887de3f65ca16fe336ebba57d49a639c90ea3cfa Mon Sep 17 00:00:00 2001 From: v1rtl Date: Thu, 17 Oct 2024 14:38:31 +0300 Subject: [PATCH 27/75] socket optimize + remove unused deps --- deploy/00_deploy_bulk_renewal.ts | 6 +- package.json | 111 ++++++- pnpm-lock.yaml | 512 +------------------------------ 3 files changed, 115 insertions(+), 514 deletions(-) diff --git a/deploy/00_deploy_bulk_renewal.ts b/deploy/00_deploy_bulk_renewal.ts index 8e5749703..c1018638c 100644 --- a/deploy/00_deploy_bulk_renewal.ts +++ b/deploy/00_deploy_bulk_renewal.ts @@ -1,5 +1,5 @@ /* eslint-disable import/no-extraneous-dependencies */ -import { Interface } from '@ethersproject/abi' +import { utils } from 'ethers' import { ethers } from 'hardhat' import { DeployFunction } from 'hardhat-deploy/types' import { HardhatRuntimeEnvironment } from 'hardhat/types' @@ -49,7 +49,7 @@ const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) { console.log('Set interface implementor of eth tld for bulk renewal') const tx2 = await resolver.setInterface( ethers.utils.namehash('eth'), - computeInterfaceId(new Interface(bulkRenewal.abi)), + computeInterfaceId(new utils.Interface(bulkRenewal.abi)), bulkRenewal.address, ) await tx2.wait() @@ -57,7 +57,7 @@ const func: DeployFunction = async function (hre: HardhatRuntimeEnvironment) { console.log('Set interface implementor of eth tld for registrar controller') const tx3 = await resolver.setInterface( ethers.utils.namehash('eth'), - computeInterfaceId(new Interface(controllerArtifact.abi)), + computeInterfaceId(new utils.Interface(controllerArtifact.abi)), controller.address, ) await tx3.wait() diff --git a/package.json b/package.json index 17cb30b03..e9626f104 100644 --- a/package.json +++ b/package.json @@ -83,12 +83,11 @@ "markdown-to-jsx": "^7.1.7", "next": "13.5.6", "node-fetch": "^3.3.2", - "react": "^18.2.0", + "react": "*", "react-confetti": "^6.1.0", - "react-dom": "^18.2.0", + "react-dom": "*", "react-hook-form": "7.51.0", "react-i18next": "^11.18.5", - "react-is": "^17.0.2", "react-transition-state": "^1.1.5", "react-use": "^17.4.0", "react-use-error-boundary": "^3.0.0", @@ -109,7 +108,6 @@ "@ensdomains/buffer": "^0.1.1", "@ensdomains/ens-test-env": "0.5.0-beta.2", "@ensdomains/headless-web3-provider": "^1.0.8", - "@ethersproject/abi": "^5.4.0", "@ianvs/prettier-plugin-sort-imports": "^4.1.0", "@next/bundle-analyzer": "^13.4.19", "@nomiclabs/hardhat-ethers": "npm:hardhat-deploy-ethers@^0.3.0-beta.13", @@ -124,10 +122,8 @@ "@types/node": "^18.7.13", "@types/pako": "^2.0.0", "@types/prettier": "^2.7.0", - "@types/puppeteer-core": "^5.4.0", "@types/react": "18.2.21", "@types/react-dom": "^18.2.7", - "@types/react-is": "^17.0.3", "@types/styled-components": "5.1.23", "@types/ws": "^8.5.10", "@typescript-eslint/eslint-plugin": "^6.7.4", @@ -158,7 +154,7 @@ "hardhat-deploy": "^0.11.12", "husky": "^7.0.4", "isows": "^1.0.3", - "jsdom": "^24.0.0", + "jsdom": "^24.1.0", "knip": "^5.27.2", "lokijs": "^1.5.12", "msw": "^1.2.3", @@ -166,7 +162,6 @@ "next-compose-plugins": "^2.2.1", "next-dev-https": "^0.1.2", "next-router-mock": "^0.9.10", - "next-transpile-modules": "^9.1.0", "pako": "^2.1.0", "postcss-scss": "^4.0.4", "prettier": "3.0.3", @@ -205,5 +200,101 @@ "next-dev-https@0.1.2": "patches/next-dev-https@0.1.2.patch" } }, - "packageManager": "pnpm@9.3.0" -} \ No newline at end of file + "packageManager": "pnpm@9.3.0", + "overrides": { + "@nomiclabs/hardhat-ethers": "npm:hardhat-deploy-ethers@0.3.0-beta.13", + "@wagmi/core": "2.13.3", + "@walletconnect/ethereum-provider": "2.11.1", + "@walletconnect/modal": "2.6.2", + "aggregate-error": "npm:@socketregistry/aggregate-error@^1", + "array-buffer-byte-length": "npm:@socketregistry/array-buffer-byte-length@^1", + "array-flatten": "npm:@socketregistry/array-flatten@^1", + "array-includes": "npm:@socketregistry/array-includes@^1", + "array.prototype.findlast": "npm:@socketregistry/array.prototype.findlast@^1", + "array.prototype.findlastindex": "npm:@socketregistry/array.prototype.findlastindex@^1", + "array.prototype.flat": "npm:@socketregistry/array.prototype.flat@^1", + "array.prototype.flatmap": "npm:@socketregistry/array.prototype.flatmap@^1", + "array.prototype.toreversed": "npm:@socketregistry/array.prototype.toreversed@^1", + "array.prototype.tosorted": "npm:@socketregistry/array.prototype.tosorted@^1", + "arraybuffer.prototype.slice": "npm:@socketregistry/arraybuffer.prototype.slice@^1", + "available-typed-arrays": "npm:@socketregistry/available-typed-arrays@^1", + "bn.js": "npm:bn.js@^5.2.0", + "deep-equal": "npm:@socketregistry/deep-equal@^1", + "define-properties": "npm:@socketregistry/define-properties@^1", + "es-define-property": "npm:@socketregistry/es-define-property@^1", + "es-get-iterator": "npm:@socketregistry/es-get-iterator@^1", + "es-iterator-helpers": "npm:@socketregistry/es-iterator-helpers@^1", + "es-set-tostringtag": "npm:@socketregistry/es-set-tostringtag@^1", + "es6-symbol": "npm:@socketregistry/es6-symbol@^1", + "for-each": "npm:@socketregistry/for-each@^1", + "function-bind": "npm:@socketregistry/function-bind@^1", + "function.prototype.name": "npm:@socketregistry/function.prototype.name@^1", + "functions-have-names": "npm:@socketregistry/functions-have-names@^1", + "get-symbol-description": "npm:@socketregistry/get-symbol-description@^1", + "globalthis": "npm:@socketregistry/globalthis@^1", + "gopd": "npm:@socketregistry/gopd@^1", + "has-property-descriptors": "npm:@socketregistry/has-property-descriptors@^1", + "has-proto": "npm:@socketregistry/has-proto@^1", + "has-symbols": "npm:@socketregistry/has-symbols@^1", + "has-tostringtag": "npm:@socketregistry/has-tostringtag@^1", + "hasown": "npm:@socketregistry/hasown@^1", + "indent-string": "npm:@socketregistry/indent-string@^1", + "internal-slot": "npm:@socketregistry/internal-slot@^1", + "is-arguments": "npm:@socketregistry/is-arguments@^1", + "is-array-buffer": "npm:@socketregistry/is-array-buffer@^1", + "is-bigint": "npm:@socketregistry/is-bigint@^1", + "is-boolean-object": "npm:@socketregistry/is-boolean-object@^1", + "is-core-module": "npm:@socketregistry/is-core-module@^1", + "is-date-object": "npm:@socketregistry/is-date-object@^1", + "is-generator-function": "npm:@socketregistry/is-generator-function@^1", + "is-map": "npm:@socketregistry/is-map@^1", + "is-negative-zero": "npm:@socketregistry/is-negative-zero@^1", + "is-number-object": "npm:@socketregistry/is-number-object@^1", + "is-regex": "npm:@socketregistry/is-regex@^1", + "is-set": "npm:@socketregistry/is-set@^1", + "is-shared-array-buffer": "npm:@socketregistry/is-shared-array-buffer@^1", + "is-string": "npm:@socketregistry/is-string@^1", + "is-symbol": "npm:@socketregistry/is-symbol@^1", + "is-typed-array": "npm:@socketregistry/is-typed-array@^1", + "is-weakmap": "npm:@socketregistry/is-weakmap@^1", + "is-weakref": "npm:@socketregistry/is-weakref@^1", + "is-weakset": "npm:@socketregistry/is-weakset@^1", + "isarray": "npm:@socketregistry/isarray@^1", + "iterator.prototype": "npm:@socketregistry/iterator.prototype@^1", + "number-is-nan": "npm:@socketregistry/number-is-nan@^1", + "object-assign": "npm:@socketregistry/object-assign@^1", + "object-is": "npm:@socketregistry/object-is@^1", + "object-keys": "npm:@socketregistry/object-keys@^1", + "object.assign": "npm:@socketregistry/object.assign@^1", + "object.entries": "npm:@socketregistry/object.entries@^1", + "object.fromentries": "npm:@socketregistry/object.fromentries@^1", + "object.groupby": "npm:@socketregistry/object.groupby@^1", + "object.hasown": "npm:@socketregistry/object.hasown@^1", + "object.values": "npm:@socketregistry/object.values@^1", + "path-parse": "npm:@socketregistry/path-parse@^1", + "querystringify": "npm:@socketregistry/querystringify@^1", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "reflect.getprototypeof": "npm:@socketregistry/reflect.getprototypeof@^1", + "regexp.prototype.flags": "npm:@socketregistry/regexp.prototype.flags@^1", + "safe-array-concat": "npm:@socketregistry/safe-array-concat@^1", + "safe-buffer": "npm:@socketregistry/safe-buffer@^1", + "safe-regex-test": "npm:@socketregistry/safe-regex-test@^1", + "safer-buffer": "npm:@socketregistry/safer-buffer@^1", + "set-function-length": "npm:@socketregistry/set-function-length@^1", + "side-channel": "npm:@socketregistry/side-channel@^1", + "string.prototype.matchall": "npm:@socketregistry/string.prototype.matchall@^1", + "string.prototype.trim": "npm:@socketregistry/string.prototype.trim@^1", + "string.prototype.trimend": "npm:@socketregistry/string.prototype.trimend@^1", + "string.prototype.trimstart": "npm:@socketregistry/string.prototype.trimstart@^1", + "typed-array-buffer": "npm:@socketregistry/typed-array-buffer@^1", + "typed-array-byte-length": "npm:@socketregistry/typed-array-byte-length@^1", + "typed-array-byte-offset": "npm:@socketregistry/typed-array-byte-offset@^1", + "typed-array-length": "npm:@socketregistry/typed-array-length@^1", + "unbox-primitive": "npm:@socketregistry/unbox-primitive@^1", + "which-boxed-primitive": "npm:@socketregistry/which-boxed-primitive@^1", + "which-collection": "npm:@socketregistry/which-collection@^1", + "which-typed-array": "npm:@socketregistry/which-typed-array@^1", + "wrtc": "https://registry.npmjs.org/@koush/wrtc/-/wrtc-0.5.2.tgz" + } +} diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 96fc7eb4e..dd959e88b 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -40,7 +40,7 @@ importers: version: 4.0.0(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8) '@ensdomains/thorin': specifier: 0.6.50 - version: 0.6.50(react-dom@18.3.1(react@18.3.1))(react-transition-state@1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1)) + version: 0.6.50(react-dom@18.3.1(react@18.3.1))(react-transition-state@1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1)) '@metamask/post-message-stream': specifier: ^6.1.2 version: 6.2.0 @@ -137,9 +137,6 @@ importers: react-i18next: specifier: ^11.18.5 version: 11.18.6(i18next@21.10.0)(react-dom@18.3.1(react@18.3.1))(react-native@0.74.1(@babel/core@7.24.6)(@babel/preset-env@7.24.6(@babel/core@7.24.6))(@types/react@18.2.21)(bufferutil@4.0.8)(encoding@0.1.13)(react@18.3.1)(utf-8-validate@5.0.10))(react@18.3.1) - react-is: - specifier: ^17.0.2 - version: 17.0.2 react-transition-state: specifier: ^1.1.5 version: 1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1) @@ -154,7 +151,7 @@ importers: version: 5.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) styled-components: specifier: ^5.3.5 - version: 5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1) + version: 5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1) tinyglobby: specifier: ^0.2.6 version: 0.2.6 @@ -183,9 +180,6 @@ importers: '@ensdomains/headless-web3-provider': specifier: ^1.0.8 version: 1.0.8(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8)) - '@ethersproject/abi': - specifier: ^5.4.0 - version: 5.7.0 '@ianvs/prettier-plugin-sort-imports': specifier: ^4.1.0 version: 4.2.1(prettier@3.0.3) @@ -228,18 +222,12 @@ importers: '@types/prettier': specifier: ^2.7.0 version: 2.7.3 - '@types/puppeteer-core': - specifier: ^5.4.0 - version: 5.4.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10) '@types/react': specifier: 18.2.21 version: 18.2.21 '@types/react-dom': specifier: ^18.2.7 version: 18.3.0 - '@types/react-is': - specifier: ^17.0.3 - version: 17.0.7 '@types/styled-components': specifier: 5.1.23 version: 5.1.23 @@ -331,7 +319,7 @@ importers: specifier: ^1.0.3 version: 1.0.4(ws@8.17.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)) jsdom: - specifier: ^24.0.0 + specifier: ^24.1.0 version: 24.1.0(bufferutil@4.0.8)(canvas@2.11.2(encoding@0.1.13))(utf-8-validate@5.0.10) knip: specifier: ^5.27.2 @@ -354,9 +342,6 @@ importers: next-router-mock: specifier: ^0.9.10 version: 0.9.13(next@13.5.6(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1) - next-transpile-modules: - specifier: ^9.1.0 - version: 9.1.0 pako: specifier: ^2.1.0 version: 2.1.0 @@ -2582,11 +2567,6 @@ packages: '@polka/url@1.0.0-next.25': resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==} - '@puppeteer/browsers@2.2.3': - resolution: {integrity: sha512-bJ0UBsk0ESOs6RFcLXOt99a3yTDcOKlzfjad+rhFwdaG1Lu/Wzq58GHYCDTlZ9z6mldf4g+NTb+TXEfe0PpnsQ==} - engines: {node: '>=18'} - hasBin: true - '@rainbow-me/rainbowkit@2.1.2': resolution: {integrity: sha512-nzhS4p7rtE9bAkOKSq+J761+gn6UseVxMdDpRBAr+0+ct/Hv1STErq9TT3GEXNrnAeSldtbxBVIkepa4uGykDA==} engines: {node: '>=12.4'} @@ -3164,9 +3144,6 @@ packages: peerDependencies: '@testing-library/dom': '>=7.21.4' - '@tootallnate/quickjs-emscripten@0.23.0': - resolution: {integrity: sha512-C5Mc6rdnsaJDjO3UpGW/CQTHtCKaYlScZTly4JIu97Jxo/odCiH0ITnDXSJPTOrEKk/ycSZ0AOgTmkDtkOsvIA==} - '@truffle/abi-utils@1.0.3': resolution: {integrity: sha512-AWhs01HCShaVKjml7Z4AbVREr/u4oiWxCcoR7Cktm0mEvtT04pvnxW5xB/cI4znRkrbPdFQlFt67kgrAjesYkw==} engines: {node: ^16.20 || ^18.16 || >=20} @@ -3351,25 +3328,12 @@ packages: '@types/prop-types@15.7.12': resolution: {integrity: sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q==} - '@types/puppeteer-core@5.4.0': - resolution: {integrity: sha512-yqRPuv4EFcSkTyin6Yy17pN6Qz2vwVwTCJIDYMXbE3j8vTPhv0nCQlZOl5xfi0WHUkqvQsjAR8hAfjeMCoetwg==} - - '@types/puppeteer@7.0.4': - resolution: {integrity: sha512-ja78vquZc8y+GM2al07GZqWDKQskQXygCDiu0e3uO0DMRKqE0MjrFBFmTulfPYzLB6WnL7Kl2tFPy0WXSpPomg==} - deprecated: This is a stub types definition. puppeteer provides its own type definitions, so you do not need this installed. - '@types/qs@6.9.15': resolution: {integrity: sha512-uXHQKES6DQKKCLh441Xv/dwxOq1TVS3JPUMlEqoEglvlhR6Mxnlew/Xq/LRVHpLyk7iK3zODe1qYHIMltO7XGg==} '@types/react-dom@18.3.0': resolution: {integrity: sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg==} - '@types/react-is@17.0.7': - resolution: {integrity: sha512-WrTEiT+c6rgq36QApoy0063uAOdltCrhF0QMXLIgYPaTvIdQhAB8hPb5oGGqX18xToElNILS9UprwU6GyINcJg==} - - '@types/react@17.0.80': - resolution: {integrity: sha512-LrgHIu2lEtIo8M7d1FcI3BdwXWoRQwMoXOZ7+dPTW0lYREjmlHl3P0U1VD0i/9tppOuv8/sam7sOjx34TxSFbA==} - '@types/react@18.2.21': resolution: {integrity: sha512-neFKG/sBAwGxHgXiIxnbm3/AAVQ/cMRS93hvBpg8xYRbeQSPVABp9U2bRnPf0iI4+Ucdv3plSxKK+3CW2ENJxA==} @@ -3379,9 +3343,6 @@ packages: '@types/sax@1.2.7': resolution: {integrity: sha512-rO73L89PJxeYM3s3pPPjiPgVVcymqU490g0YO5n5By0k2Erzj6tay/4lr1CHAAU4JyOWd1rpQ8bCf6cZfHU96A==} - '@types/scheduler@0.16.8': - resolution: {integrity: sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==} - '@types/scheduler@0.23.0': resolution: {integrity: sha512-YIoDCTH3Af6XM5VuwGG/QL/CJqga1Zm3NkU3HZ4ZHK2fRMPYP1VczsTUqtsf43PH/iJNVlPHAo2oWX7BSdB2Hw==} @@ -3415,9 +3376,6 @@ packages: '@types/yargs@17.0.32': resolution: {integrity: sha512-xQ67Yc/laOG5uMfX/093MRlGGCIBzZMarVa+gfNKJxWAIgykYpVGkBdbqEzGDDfCrVUj6Hiff4mTZ5BA6TmAog==} - '@types/yauzl@2.10.3': - resolution: {integrity: sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==} - '@typescript-eslint/eslint-plugin@6.21.0': resolution: {integrity: sha512-oy9+hTPCUFpngkEZUSzbf9MxI65wbKFoQYsgPdILTfbUldp5ovUuphZVe4i30emU9M/kP+T64Di0mxl7dSw3MA==} engines: {node: ^16.0.0 || >=18.0.0} @@ -3996,10 +3954,6 @@ packages: ast-types-flow@0.0.8: resolution: {integrity: sha512-OH/2E5Fg20h2aPrbe+QL8JZQFko0YZaF+j4mnQ7BGhfavO7OpSLa8a0y9sBwomHdSbkhTS8TQNayBfnW5DwbvQ==} - ast-types@0.13.4: - resolution: {integrity: sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==} - engines: {node: '>=4'} - ast-types@0.15.2: resolution: {integrity: sha512-c27loCv9QkZinsa5ProX751khO9DJl/AcB5c2KNtA6NRvHKS0PgLfcftz72KVq504vB0Gku5s2kUZzDBvQWvHg==} engines: {node: '>=4'} @@ -4048,9 +4002,6 @@ packages: axobject-query@3.2.1: resolution: {integrity: sha512-jsyHu61e6N4Vbz/v18DHwWYKK0bSWLqn47eeDSKPB7m8tqMHF9YJ+mhIk2lVteyZrY8tnSj/jHOv4YiTCuCJgg==} - b4a@1.6.6: - resolution: {integrity: sha512-5Tk1HLk6b6ctmjIkAcU/Ujv/1WqiDl0F0JdRCR80VsOcUlHcu7pWeWRlOqQLHfDEsVx9YH/aif5AG4ehoCtTmg==} - babel-core@7.0.0-bridge.0: resolution: {integrity: sha512-poPX9mZH/5CSanm50Q+1toVci6pv5KSRv/5TWCwtzQS5XEwn40BcCrgIeMFWP9CKKIniKXNxoIOnOq4VVlGXhg==} peerDependencies: @@ -4090,31 +4041,12 @@ packages: balanced-match@2.0.0: resolution: {integrity: sha512-1ugUSr8BHXRnK23KfuYS+gVMC3LB8QGH9W1iGtDPsNWoQbgtXSExkBu2aDR4epiGWZOjZsj6lDl/N/AqqTC3UA==} - bare-events@2.2.2: - resolution: {integrity: sha512-h7z00dWdG0PYOQEvChhOSWvOfkIKsdZGkWr083FgN/HyoQuebSew/cgirYqh9SCuy/hRvxc5Vy6Fw8xAmYHLkQ==} - - bare-fs@2.3.0: - resolution: {integrity: sha512-TNFqa1B4N99pds2a5NYHR15o0ZpdNKbAeKTE/+G6ED/UeOavv8RY3dr/Fu99HW3zU3pXpo2kDNO8Sjsm2esfOw==} - - bare-os@2.3.0: - resolution: {integrity: sha512-oPb8oMM1xZbhRQBngTgpcQ5gXw6kjOaRsSWsIeNyRxGed2w/ARyP7ScBYpWR1qfX2E5rS3gBw6OWcSQo+s+kUg==} - - bare-path@2.1.3: - resolution: {integrity: sha512-lh/eITfU8hrj9Ru5quUp0Io1kJWIk1bTjzo7JH1P5dWmQ2EL4hFUlfI8FonAhSlgIfhn63p84CDY/x+PisgcXA==} - - bare-stream@1.0.0: - resolution: {integrity: sha512-KhNUoDL40iP4gFaLSsoGE479t0jHijfYdIcxRn/XtezA2BaUD0NRf/JGRpsMq6dMNM+SrCrB0YSSo/5wBY4rOQ==} - base-x@3.0.9: resolution: {integrity: sha512-H7JU6iBHTal1gp56aKoaa//YUxEaAOUiydvrV/pILqIHXTtqxSkATOnDA2u+jZ/61sD+L/412+7kzXRtWukhpQ==} base64-js@1.5.1: resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==} - basic-ftp@5.0.5: - resolution: {integrity: sha512-4Bcg1P8xhUuqcii/S0Z9wiHIrQVPMermM1any+MX5GeGD7faD3/msQUDGLol9wOcz4/jbg/WJnGqoJF6LiBdtg==} - engines: {node: '>=10.0.0'} - bcrypt-pbkdf@1.0.2: resolution: {integrity: sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w==} @@ -4205,9 +4137,6 @@ packages: bser@2.1.1: resolution: {integrity: sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==} - buffer-crc32@0.2.13: - resolution: {integrity: sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==} - buffer-from@1.1.2: resolution: {integrity: sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==} @@ -4398,11 +4327,6 @@ packages: resolution: {integrity: sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==} engines: {node: '>=6.0'} - chromium-bidi@0.5.19: - resolution: {integrity: sha512-UA6zL77b7RYCjJkZBsZ0wlvCTD+jTjllZ8f6wdO4buevXgTZYjV+XLB9CiEa2OuuTGGTLnI7eN9I60YxuALGQg==} - peerDependencies: - devtools-protocol: '*' - ci-info@2.0.0: resolution: {integrity: sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==} @@ -4650,15 +4574,6 @@ packages: typescript: optional: true - cosmiconfig@9.0.0: - resolution: {integrity: sha512-itvL5h8RETACmOTFc4UfIyB2RfEHi71Ax6E/PivVxq9NseKbOWpeyHEOIbmAw1rs8Ak0VursQNww7lf7YtUwzg==} - engines: {node: '>=14'} - peerDependencies: - typescript: '>=4.9.5' - peerDependenciesMeta: - typescript: - optional: true - crc-32@1.2.2: resolution: {integrity: sha512-ROmzCKrTnOwybPcJApAA6WBWij23HVfGVNKqqrZpuyZOHqK2CwHSvpGuyt/UNNvaIjEd8X5IFGp4Mh+Ie1IHJQ==} engines: {node: '>=0.8'} @@ -4773,10 +4688,6 @@ packages: resolution: {integrity: sha512-0R9ikRb668HB7QDxT1vkpuUBtqc53YyAwMwGeUFKRojY/NWKvdZ+9UYtRfGmhqNbRkTSVpMbmyhXipFFv2cb/A==} engines: {node: '>= 12'} - data-uri-to-buffer@6.0.2: - resolution: {integrity: sha512-7hvf7/GW8e86rW0ptuwS3OcBGDjIi6SZva7hCyWC0yYry2cOPmLIjXAUHI6DK2HsnwJd9ifmt57i8eV2n4YNpw==} - engines: {node: '>= 14'} - data-urls@5.0.0: resolution: {integrity: sha512-ZYP5VBHshaDAiVZxjbRVcFJpc+4xGgT0bK3vzy1HLN8jTO975HEbuYzZJcHoQEY5K1a0z8YayJkyVETa08eNTg==} engines: {node: '>=18'} @@ -4912,10 +4823,6 @@ packages: defu@6.1.4: resolution: {integrity: sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg==} - degenerator@5.0.1: - resolution: {integrity: sha512-TllpMR/t0M5sqCXfj85i4XaAzxmS5tVA16dqvdkMwGmzI+dXLXnw3J+3Vdv7VKw+ThlTMboK6i9rnZ6Nntj5CQ==} - engines: {node: '>= 14'} - delayed-stream@1.0.0: resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==} engines: {node: '>=0.4.0'} @@ -4964,9 +4871,6 @@ packages: detect-node-es@1.1.0: resolution: {integrity: sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ==} - devtools-protocol@0.0.1286932: - resolution: {integrity: sha512-wu58HMQll9voDjR4NlPyoDEw1syfzaBNHymMMZ/QOXiHRNluOnDgu9hp1yHOKYoMlxCh4lSSiugLITe6Fvu1eA==} - diff-sequences@29.6.3: resolution: {integrity: sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} @@ -5214,11 +5118,6 @@ packages: resolution: {integrity: sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==} engines: {node: '>=10'} - escodegen@2.1.0: - resolution: {integrity: sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==} - engines: {node: '>=6.0'} - hasBin: true - eslint-config-airbnb-base@15.0.0: resolution: {integrity: sha512-xaX3z4ZZIcFLvh2oUNvcX5oEofXda7giYmuplVxoOg5A7EXJMrUyqRgR+mhDhPK8LZ4PttFOBvCYDbX3sUoUig==} engines: {node: ^10.12.0 || >=12.0.0} @@ -5541,11 +5440,6 @@ packages: resolution: {integrity: sha512-CvdFfHkC95B4bBBk36hcEmvdR2awOdhhVUYH6S/zrVj3477zven/fJMYg7121h4T1xHZC+tetUpubpAhxwI7hQ==} engines: {node: ^10.17.0 || ^12.0.0 || >= 13.7.0} - extract-zip@2.0.1: - resolution: {integrity: sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==} - engines: {node: '>= 10.17.0'} - hasBin: true - extsprintf@1.3.0: resolution: {integrity: sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g==} engines: {'0': node >=0.6.0} @@ -5560,9 +5454,6 @@ packages: fast-diff@1.3.0: resolution: {integrity: sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==} - fast-fifo@1.3.2: - resolution: {integrity: sha512-/d9sfos4yxzpwkDkuN7k2SqFKtYNmCTzgfEpz82x34IM9/zc8KGxQoXg1liNC/izpRM/MBdt44Nmx41ZWqk+FQ==} - fast-glob@3.3.2: resolution: {integrity: sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==} engines: {node: '>=8.6.0'} @@ -5606,9 +5497,6 @@ packages: fb-watchman@2.0.2: resolution: {integrity: sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==} - fd-slicer@1.1.0: - resolution: {integrity: sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==} - fdir@6.3.0: resolution: {integrity: sha512-QOnuT+BOtivR77wYvCWHfGt9s4Pz1VIMbD463vegT5MLqNXy8rYFT/lPVEqf/bhYeT6qmqrNHhsX+rWwe3rOCQ==} peerDependencies: @@ -5752,10 +5640,6 @@ packages: resolution: {integrity: sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==} engines: {node: '>=12'} - fs-extra@11.2.0: - resolution: {integrity: sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==} - engines: {node: '>=14.14'} - fs-extra@4.0.3: resolution: {integrity: sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg==} @@ -5853,10 +5737,6 @@ packages: get-tsconfig@4.7.5: resolution: {integrity: sha512-ZCuZCnlqNzjb4QprAzXKdpp/gh6KTxSJuw3IBsPnV/7fV4NxC9ckB+vPTt8w7fJA0TaSD7c55BR47JD6MEDyDw==} - get-uri@6.0.3: - resolution: {integrity: sha512-BzUrJBS9EcUb4cFol8r4W3v1cPsSyajLSthNkz5BxbpDcHN5tIrM10E2eNvfnvBn3DaT3DUgx0OpsBKkaOpanw==} - engines: {node: '>= 14'} - getpass@0.1.7: resolution: {integrity: sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==} @@ -6281,10 +6161,6 @@ packages: io-ts@1.10.4: resolution: {integrity: sha512-b23PteSnYXSONJ6JQXRAlvJhuw8KOtkqa87W4wDtvMrud/DTJd5X+NpOOI+O/zZwVq6v0VLAaJ+1EDViKEuN9g==} - ip-address@9.0.5: - resolution: {integrity: sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==} - engines: {node: '>= 12'} - ipaddr.js@1.9.1: resolution: {integrity: sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==} engines: {node: '>= 0.10'} @@ -6648,9 +6524,6 @@ packages: jsbn@0.1.1: resolution: {integrity: sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg==} - jsbn@1.1.0: - resolution: {integrity: sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==} - jsc-android@250231.0.0: resolution: {integrity: sha512-rS46PvsjYmdmuz1OAWXY/1kCYG7pnf1TBqeTiOJr1iDz7s5DLxxC9n/ZMknLDxzYzNVfI7R95MH10emSSG1Wuw==} @@ -6918,10 +6791,6 @@ packages: resolution: {integrity: sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==} engines: {node: '>=10'} - lru-cache@7.18.3: - resolution: {integrity: sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==} - engines: {node: '>=12'} - lru_map@0.3.3: resolution: {integrity: sha512-Pn9cox5CsMYngeDbmChANltQl+5pi6XmTrraMSzhPmMBbmgcxmqWry0U3PGapCU1yB4/LqCcom7qhHZiF/jGfQ==} @@ -7217,9 +7086,6 @@ packages: typescript: optional: true - mitt@3.0.1: - resolution: {integrity: sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==} - mkdirp-classic@0.5.3: resolution: {integrity: sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==} @@ -7358,10 +7224,6 @@ packages: neo-async@2.6.2: resolution: {integrity: sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==} - netmask@2.0.2: - resolution: {integrity: sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==} - engines: {node: '>= 0.4.0'} - next-compose-plugins@2.2.1: resolution: {integrity: sha512-OjJ+fV15FXO2uQXQagLD4C0abYErBjyjE0I0FHpOEIB8upw0hg1ldFP6cqHTJBH1cZqy96OeR3u1dJ+Ez2D4Bg==} @@ -7381,9 +7243,6 @@ packages: next-tick@1.1.0: resolution: {integrity: sha512-CXdUiJembsNjuToQvxayPZF9Vqht7hewsvy2sOWafLvi2awflj9mOC6bHIg50orX8IJvWKY9wYQ/zB2kogPslQ==} - next-transpile-modules@9.1.0: - resolution: {integrity: sha512-yzJji65xDqcIqjvx5vPJcs1M+MYQTzLM1pXH/qf8Q88ohx+bwVGDc1AeV+HKr1NwvMCNTpwVPSFI7cA5WdyeWA==} - next@13.5.6: resolution: {integrity: sha512-Y2wTcTbO4WwEsVb4A8VSnOsG1I9ok+h74q0ZdxkwM3EODqrs4pasq7O0iUxbcS9VtWMicG7f3+HAj0r1+NtKSw==} engines: {node: '>=16.14.0'} @@ -7717,14 +7576,6 @@ packages: resolution: {integrity: sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==} engines: {node: '>=6'} - pac-proxy-agent@7.0.1: - resolution: {integrity: sha512-ASV8yU4LLKBAjqIPMbrgtaKIvxQri/yh2OpI+S6hVa9JRkUI3Y3NPFbfngDtY7oFtSMD3w31Xns89mDa3Feo5A==} - engines: {node: '>= 14'} - - pac-resolver@7.0.1: - resolution: {integrity: sha512-5NPgf87AT2STgwa2ntRMr45jTKrYBGkVU36yT0ig/n/GMAa3oPqhZfIQ2kMEimReg0+t9kZViDVZ83qfVUlckg==} - engines: {node: '>= 14'} - package-json-from-dist@1.0.0: resolution: {integrity: sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==} @@ -7832,9 +7683,6 @@ packages: resolution: {integrity: sha512-iuh7L6jA7JEGu2WxDwtQP1ddOpaJNC4KlDEFfdQajSGgGPNi4OyDc2R7QnbY2bR9QjBVGwgvTdNJZoE7RaxUMA==} engines: {node: '>=0.12'} - pend@1.2.0: - resolution: {integrity: sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==} - performance-now@2.1.0: resolution: {integrity: sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==} @@ -8028,10 +7876,6 @@ packages: resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==} engines: {node: '>= 0.10'} - proxy-agent@6.4.0: - resolution: {integrity: sha512-u0piLU+nCOHMgGjRbimiXmA9kM/L9EHh3zL81xCdp7m+Y2pHIsnmbdDoEDoAz5geaonNR6q6+yOPQs6n4T6sBQ==} - engines: {node: '>= 14'} - proxy-compare@2.5.1: resolution: {integrity: sha512-oyfc0Tx87Cpwva5ZXezSp5V9vht1c7dZBhvuV/y3ctkgMVUmiAGDVeeB0dKhGSyT0v1ZTEQYpe/RXlBVBNuCLA==} @@ -8052,15 +7896,6 @@ packages: resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==} engines: {node: '>=6'} - puppeteer-core@22.10.0: - resolution: {integrity: sha512-I54J4Vy4I07UHsgB1QSmuFoF7KNQjJWcvFBPhtY+ezMdBfwgGDr8dzYrJa11aPgP9kxIUHjhktcMmmfJkOAtTw==} - engines: {node: '>=18'} - - puppeteer@22.10.0: - resolution: {integrity: sha512-ZOkZd6a6t0BdKcWb0wAYHWQqCfdlN1PPnXOmg/XNrbo6gJhYWFX4qCNb6ahSn8TpAqBqLCoD4Q010F7GwOM7mA==} - engines: {node: '>=18'} - hasBin: true - pure-rand@5.0.5: resolution: {integrity: sha512-BwQpbqxSCBJVpamI6ydzcKqyFmnd5msMWUGvzXLm1aXvusbbgkbOto/EUPM00hjveJEaJtdbhUjKSzWRhQVkaw==} @@ -8118,9 +7953,6 @@ packages: queue-microtask@1.2.3: resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==} - queue-tick@1.0.1: - resolution: {integrity: sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag==} - queue@6.0.2: resolution: {integrity: sha512-iHZWu+q3IdFZFX36ro/lKBkSvfkztY5Y7HMiPlOUjhupPcG2JMfst2KKEpu5XndviX/3UhFbRngUPNKtgvtZiA==} @@ -8587,11 +8419,6 @@ packages: resolution: {integrity: sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==} hasBin: true - semver@7.6.0: - resolution: {integrity: sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==} - engines: {node: '>=10'} - hasBin: true - semver@7.6.2: resolution: {integrity: sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==} engines: {node: '>=10'} @@ -8726,10 +8553,6 @@ packages: resolution: {integrity: sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==} engines: {node: '>=10'} - smart-buffer@4.2.0: - resolution: {integrity: sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==} - engines: {node: '>= 6.0.0', npm: '>= 3.0.0'} - smol-toml@1.3.0: resolution: {integrity: sha512-tWpi2TsODPScmi48b/OQZGi2lgUmBCHy6SZrhi/FdnnHiU1GwebbCfuQuxsC3nHaLwtYeJGPrDZDIeodDOc4pA==} engines: {node: '>= 18'} @@ -8748,14 +8571,6 @@ packages: resolution: {integrity: sha512-/GbIKmo8ioc+NIWIhwdecY0ge+qVBSMdgxGygevmdHj24bsfgtCmcUUcQ5ZzcylGFHsN3k4HB4Cgkl96KVnuew==} engines: {node: '>=10.0.0'} - socks-proxy-agent@8.0.3: - resolution: {integrity: sha512-VNegTZKhuGq5vSD6XNKlbqWhyt/40CgoEw8XxD6dhnm8Jq9IEa3nIa4HwnM8XOqU0CdB0BwWVXusqiFXfHB3+A==} - engines: {node: '>= 14'} - - socks@2.8.3: - resolution: {integrity: sha512-l5x7VUUWbjVFbafGLxPWkYsHIhEvmF85tbIeFZWc8ZPtoMyybuEhL7Jye/ooC4/d48FgOjSJXgsF/AJPYCW8Zw==} - engines: {node: '>= 10.0.0', npm: '>= 3.0.0'} - solc@0.4.26: resolution: {integrity: sha512-o+c6FpkiHd+HPjmjEVpQgH7fqZ14tJpXhho+/bQXlXbliLIS/xjXb42Vxh+qQY1WCSTMQ0+a5vR9vi0MfhU6mA==} hasBin: true @@ -8824,9 +8639,6 @@ packages: sprintf-js@1.0.3: resolution: {integrity: sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==} - sprintf-js@1.1.3: - resolution: {integrity: sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==} - sshpk@1.18.0: resolution: {integrity: sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ==} engines: {node: '>=0.10.0'} @@ -8896,9 +8708,6 @@ packages: resolution: {integrity: sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==} engines: {node: '>=10.0.0'} - streamx@2.16.1: - resolution: {integrity: sha512-m9QYj6WygWyWa3H1YY69amr4nVgy61xfjys7xO7kviL5rfIEc2naf+ewFiOA+aEJD7y0JO3h2GoiUv4TDwEGzQ==} - strict-event-emitter@0.2.8: resolution: {integrity: sha512-KDf/ujU8Zud3YaLtMCcTI4xkZlZVIYxTLr+XIULexP+77EEVWixeXroLUXQXiVtH4XH2W7jr/3PT1v3zBuvc3A==} @@ -9154,16 +8963,10 @@ packages: tar-fs@2.1.1: resolution: {integrity: sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng==} - tar-fs@3.0.5: - resolution: {integrity: sha512-JOgGAmZyMgbqpLwct7ZV8VzkEB6pxXFBVErLtb+XCOqzc6w1xiWKI9GVd6bwk68EX7eJ4DWmfXVmq8K2ziZTGg==} - tar-stream@2.2.0: resolution: {integrity: sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==} engines: {node: '>=6'} - tar-stream@3.1.7: - resolution: {integrity: sha512-qJj60CXt7IU1Ffyc3NJMjh6EkuCFej46zUqJ4J7pqYlThyd9bO0XBTmcOIhSzZJVWfsLks0+nle/j538YAW9RQ==} - tar@4.4.19: resolution: {integrity: sha512-a20gEsvHnWe0ygBY8JbxoM4w3SJdhc7ZAuxkLqh+nvNQN2IOt0B5lLgM490X5Hl8FF0dl0tOf2ewFYAlIFgzVA==} engines: {node: '>=4.5'} @@ -9457,9 +9260,6 @@ packages: unbox-primitive@1.0.2: resolution: {integrity: sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==} - unbzip2-stream@1.4.3: - resolution: {integrity: sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==} - uncrypto@0.1.3: resolution: {integrity: sha512-Ql87qFHB3s/De2ClA9e0gsnS6zXG27SkTiSJwjCc9MebbfapQfuPzumMIUMi38ezPZVNFcHI9sUIepeQfw8J8Q==} @@ -9586,9 +9386,6 @@ packages: url-set-query@1.0.0: resolution: {integrity: sha512-3AChu4NiXquPfeckE5R5cGdiHCMWJx1dwCWOmWIL4KHAziJNOFIYJlpGFeKDvwLPHovZRCxK3cYlwzqI9Vp+Gg==} - urlpattern-polyfill@10.0.0: - resolution: {integrity: sha512-H/A06tKD7sS1O1X2SshBVeA5FLycRpjqiBeqGKmBwBDBy28EnRjORxTNe269KSSr5un5qyWi1iL61wLxpd+ZOg==} - use-callback-ref@1.3.2: resolution: {integrity: sha512-elOQwe6Q8gqZgDA8mrh44qRTQqpIHDcZ3hXTLjBe1i4ph8XpNJnO+aQf3NaG+lriLopI4HMx9VjQLfPQ6vhnoA==} engines: {node: '>=10'} @@ -10356,9 +10153,6 @@ packages: yargs@4.8.1: resolution: {integrity: sha512-LqodLrnIDM3IFT+Hf/5sxBnEGECrfdC1uIbgZeJmESCSo4HoCAaKEus8MylXHAkdacGc0ye+Qa+dpkuom8uVYA==} - yauzl@2.10.0: - resolution: {integrity: sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==} - yn@3.1.1: resolution: {integrity: sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==} engines: {node: '>=6'} @@ -10382,9 +10176,6 @@ packages: peerDependencies: zod: ^3.18.0 - zod@3.22.4: - resolution: {integrity: sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==} - zod@3.23.8: resolution: {integrity: sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g==} @@ -11834,7 +11625,7 @@ snapshots: dependencies: hash-test-vectors: 1.3.2 - '@ensdomains/thorin@0.6.50(react-dom@18.3.1(react@18.3.1))(react-transition-state@1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1))': + '@ensdomains/thorin@0.6.50(react-dom@18.3.1(react@18.3.1))(react-transition-state@1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1))': dependencies: clsx: 1.2.1 focus-visible: 5.2.1 @@ -11842,7 +11633,7 @@ snapshots: react: 18.3.1 react-dom: 18.3.1(react@18.3.1) react-transition-state: 1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - styled-components: 5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1) + styled-components: 5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1) ts-pattern: 4.3.0 '@esbuild-plugins/node-globals-polyfill@0.2.3(esbuild@0.17.19)': @@ -12992,19 +12783,6 @@ snapshots: '@polka/url@1.0.0-next.25': {} - '@puppeteer/browsers@2.2.3': - dependencies: - debug: 4.3.4(supports-color@5.5.0) - extract-zip: 2.0.1 - progress: 2.0.3 - proxy-agent: 6.4.0 - semver: 7.6.0 - tar-fs: 3.0.5 - unbzip2-stream: 1.4.3 - yargs: 17.7.2 - transitivePeerDependencies: - - supports-color - '@rainbow-me/rainbowkit@2.1.2(@tanstack/react-query@5.22.2(react@18.3.1))(@types/react@18.2.21)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(wagmi@2.12.4(@tanstack/query-core@5.22.2)(@tanstack/react-query@5.22.2(react@18.3.1))(@types/react@18.2.21)(bufferutil@4.0.8)(encoding@0.1.13)(immer@9.0.21)(react-dom@18.3.1(react@18.3.1))(react-native@0.74.1(@babel/core@7.24.6)(@babel/preset-env@7.24.6(@babel/core@7.24.6))(@types/react@18.2.21)(bufferutil@4.0.8)(encoding@0.1.13)(react@18.3.1)(utf-8-validate@5.0.10))(react@18.3.1)(rollup@2.78.0)(typescript@5.4.5)(utf-8-validate@5.0.10)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8))': dependencies: '@tanstack/react-query': 5.22.2(react@18.3.1) @@ -13882,8 +13660,6 @@ snapshots: dependencies: '@testing-library/dom': 9.3.4 - '@tootallnate/quickjs-emscripten@0.23.0': {} - '@truffle/abi-utils@1.0.3': dependencies: change-case: 3.0.2 @@ -14117,40 +13893,12 @@ snapshots: '@types/prop-types@15.7.12': {} - '@types/puppeteer-core@5.4.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)': - dependencies: - '@types/puppeteer': 7.0.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10) - transitivePeerDependencies: - - bufferutil - - supports-color - - typescript - - utf-8-validate - - '@types/puppeteer@7.0.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)': - dependencies: - puppeteer: 22.10.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10) - transitivePeerDependencies: - - bufferutil - - supports-color - - typescript - - utf-8-validate - '@types/qs@6.9.15': {} '@types/react-dom@18.3.0': dependencies: '@types/react': 18.2.21 - '@types/react-is@17.0.7': - dependencies: - '@types/react': 17.0.80 - - '@types/react@17.0.80': - dependencies: - '@types/prop-types': 15.7.12 - '@types/scheduler': 0.16.8 - csstype: 3.1.3 - '@types/react@18.2.21': dependencies: '@types/prop-types': 15.7.12 @@ -14165,8 +13913,6 @@ snapshots: dependencies: '@types/node': 18.19.33 - '@types/scheduler@0.16.8': {} - '@types/scheduler@0.23.0': {} '@types/secp256k1@4.0.6': @@ -14203,11 +13949,6 @@ snapshots: dependencies: '@types/yargs-parser': 21.0.3 - '@types/yauzl@2.10.3': - dependencies: - '@types/node': 18.19.44 - optional: true - '@typescript-eslint/eslint-plugin@6.21.0(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0)(typescript@5.4.5)': dependencies: '@eslint-community/regexpp': 4.10.0 @@ -15180,10 +14921,6 @@ snapshots: ast-types-flow@0.0.8: {} - ast-types@0.13.4: - dependencies: - tslib: 2.6.3 - ast-types@0.15.2: dependencies: tslib: 2.6.3 @@ -15228,8 +14965,6 @@ snapshots: dependencies: dequal: 2.0.3 - b4a@1.6.6: {} - babel-core@7.0.0-bridge.0(@babel/core@7.24.6): dependencies: '@babel/core': 7.24.6 @@ -15266,14 +15001,14 @@ snapshots: transitivePeerDependencies: - supports-color - babel-plugin-styled-components@2.1.4(@babel/core@7.24.6)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1)): + babel-plugin-styled-components@2.1.4(@babel/core@7.24.6)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1)): dependencies: '@babel/helper-annotate-as-pure': 7.24.6 '@babel/helper-module-imports': 7.24.6 '@babel/plugin-syntax-jsx': 7.24.6(@babel/core@7.24.6) lodash: 4.17.21 picomatch: 2.3.1 - styled-components: 5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1) + styled-components: 5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1) transitivePeerDependencies: - '@babel/core' @@ -15287,37 +15022,12 @@ snapshots: balanced-match@2.0.0: {} - bare-events@2.2.2: - optional: true - - bare-fs@2.3.0: - dependencies: - bare-events: 2.2.2 - bare-path: 2.1.3 - bare-stream: 1.0.0 - optional: true - - bare-os@2.3.0: - optional: true - - bare-path@2.1.3: - dependencies: - bare-os: 2.3.0 - optional: true - - bare-stream@1.0.0: - dependencies: - streamx: 2.16.1 - optional: true - base-x@3.0.9: dependencies: safe-buffer: 5.2.1 base64-js@1.5.1: {} - basic-ftp@5.0.5: {} - bcrypt-pbkdf@1.0.2: dependencies: tweetnacl: 0.14.5 @@ -15434,8 +15144,6 @@ snapshots: dependencies: node-int64: 0.4.0 - buffer-crc32@0.2.13: {} - buffer-from@1.1.2: {} buffer-to-arraybuffer@0.0.5: {} @@ -15682,13 +15390,6 @@ snapshots: chrome-trace-event@1.0.4: {} - chromium-bidi@0.5.19(devtools-protocol@0.0.1286932): - dependencies: - devtools-protocol: 0.0.1286932 - mitt: 3.0.1 - urlpattern-polyfill: 10.0.0 - zod: 3.22.4 - ci-info@2.0.0: {} ci-info@3.9.0: {} @@ -15937,15 +15638,6 @@ snapshots: optionalDependencies: typescript: 5.4.5 - cosmiconfig@9.0.0(typescript@5.4.5): - dependencies: - env-paths: 2.2.1 - import-fresh: 3.3.0 - js-yaml: 4.1.0 - parse-json: 5.2.0 - optionalDependencies: - typescript: 5.4.5 - crc-32@1.2.2: {} create-hash@1.2.0: @@ -16075,8 +15767,6 @@ snapshots: data-uri-to-buffer@4.0.1: {} - data-uri-to-buffer@6.0.2: {} - data-urls@5.0.0: dependencies: whatwg-mimetype: 4.0.0 @@ -16212,12 +15902,6 @@ snapshots: defu@6.1.4: {} - degenerator@5.0.1: - dependencies: - ast-types: 0.13.4 - escodegen: 2.1.0 - esprima: 4.0.1 - delayed-stream@1.0.0: {} delegates@1.0.0: {} @@ -16244,8 +15928,6 @@ snapshots: detect-node-es@1.1.0: {} - devtools-protocol@0.0.1286932: {} - diff-sequences@29.6.3: optional: true @@ -16625,14 +16307,6 @@ snapshots: escape-string-regexp@4.0.0: {} - escodegen@2.1.0: - dependencies: - esprima: 4.0.1 - estraverse: 5.3.0 - esutils: 2.0.3 - optionalDependencies: - source-map: 0.6.1 - eslint-config-airbnb-base@15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0): dependencies: confusing-browser-globals: 1.0.11 @@ -17200,16 +16874,6 @@ snapshots: extract-files@9.0.0: {} - extract-zip@2.0.1: - dependencies: - debug: 4.3.6 - get-stream: 5.2.0 - yauzl: 2.10.0 - optionalDependencies: - '@types/yauzl': 2.10.3 - transitivePeerDependencies: - - supports-color - extsprintf@1.3.0: {} fast-check@3.1.1: @@ -17220,8 +16884,6 @@ snapshots: fast-diff@1.3.0: {} - fast-fifo@1.3.2: {} - fast-glob@3.3.2: dependencies: '@nodelib/fs.stat': 2.0.5 @@ -17260,10 +16922,6 @@ snapshots: dependencies: bser: 2.1.1 - fd-slicer@1.1.0: - dependencies: - pend: 1.2.0 - fdir@6.3.0(picomatch@4.0.2): optionalDependencies: picomatch: 4.0.2 @@ -17421,12 +17079,6 @@ snapshots: jsonfile: 6.1.0 universalify: 2.0.1 - fs-extra@11.2.0: - dependencies: - graceful-fs: 4.2.11 - jsonfile: 6.1.0 - universalify: 2.0.1 - fs-extra@4.0.3: dependencies: graceful-fs: 4.2.11 @@ -17529,15 +17181,6 @@ snapshots: dependencies: resolve-pkg-maps: 1.0.0 - get-uri@6.0.3: - dependencies: - basic-ftp: 5.0.5 - data-uri-to-buffer: 6.0.2 - debug: 4.3.6 - fs-extra: 11.2.0 - transitivePeerDependencies: - - supports-color - getpass@0.1.7: dependencies: assert-plus: 1.0.0 @@ -18106,11 +17749,6 @@ snapshots: dependencies: fp-ts: 1.19.3 - ip-address@9.0.5: - dependencies: - jsbn: 1.1.0 - sprintf-js: 1.1.3 - ipaddr.js@1.9.1: {} iron-webcrypto@1.2.1: {} @@ -18476,8 +18114,6 @@ snapshots: jsbn@0.1.1: {} - jsbn@1.1.0: {} - jsc-android@250231.0.0: {} jsc-safe-url@0.2.4: {} @@ -18818,8 +18454,6 @@ snapshots: dependencies: yallist: 4.0.0 - lru-cache@7.18.3: {} - lru_map@0.3.3: {} lz-string@1.5.0: {} @@ -19223,8 +18857,6 @@ snapshots: optionalDependencies: typescript: 5.4.5 - mitt@3.0.1: {} - mkdirp-classic@0.5.3: {} mkdirp-promise@5.0.1: @@ -19393,8 +19025,6 @@ snapshots: neo-async@2.6.2: {} - netmask@2.0.2: {} - next-compose-plugins@2.2.1: {} next-dev-https@0.1.2(patch_hash=q5l3x5627ujg3rak6l6v24c2cq)(next@13.5.6(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1): @@ -19412,11 +19042,6 @@ snapshots: next-tick@1.1.0: {} - next-transpile-modules@9.1.0: - dependencies: - enhanced-resolve: 5.16.1 - escalade: 3.1.2 - next@13.5.6(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react@18.3.1): dependencies: '@next/env': 13.5.6 @@ -19755,24 +19380,6 @@ snapshots: p-try@2.2.0: {} - pac-proxy-agent@7.0.1: - dependencies: - '@tootallnate/quickjs-emscripten': 0.23.0 - agent-base: 7.1.1 - debug: 4.3.6 - get-uri: 6.0.3 - http-proxy-agent: 7.0.2 - https-proxy-agent: 7.0.4 - pac-resolver: 7.0.1 - socks-proxy-agent: 8.0.3 - transitivePeerDependencies: - - supports-color - - pac-resolver@7.0.1: - dependencies: - degenerator: 5.0.1 - netmask: 2.0.2 - package-json-from-dist@1.0.0: {} pako@2.1.0: {} @@ -19872,8 +19479,6 @@ snapshots: safe-buffer: 5.2.1 sha.js: 2.4.11 - pend@1.2.0: {} - performance-now@2.1.0: {} picocolors@0.2.1: {} @@ -20053,19 +19658,6 @@ snapshots: forwarded: 0.2.0 ipaddr.js: 1.9.1 - proxy-agent@6.4.0: - dependencies: - agent-base: 7.1.1 - debug: 4.3.6 - http-proxy-agent: 7.0.2 - https-proxy-agent: 7.0.4 - lru-cache: 7.18.3 - pac-proxy-agent: 7.0.1 - proxy-from-env: 1.1.0 - socks-proxy-agent: 8.0.3 - transitivePeerDependencies: - - supports-color - proxy-compare@2.5.1: {} proxy-from-env@1.1.0: {} @@ -20081,30 +19673,6 @@ snapshots: punycode@2.3.1: {} - puppeteer-core@22.10.0(bufferutil@4.0.8)(utf-8-validate@5.0.10): - dependencies: - '@puppeteer/browsers': 2.2.3 - chromium-bidi: 0.5.19(devtools-protocol@0.0.1286932) - debug: 4.3.4(supports-color@5.5.0) - devtools-protocol: 0.0.1286932 - ws: 8.17.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) - transitivePeerDependencies: - - bufferutil - - supports-color - - utf-8-validate - - puppeteer@22.10.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10): - dependencies: - '@puppeteer/browsers': 2.2.3 - cosmiconfig: 9.0.0(typescript@5.4.5) - devtools-protocol: 0.0.1286932 - puppeteer-core: 22.10.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) - transitivePeerDependencies: - - bufferutil - - supports-color - - typescript - - utf-8-validate - pure-rand@5.0.5: {} qr-code-styling@1.6.0-rc.1: @@ -20160,8 +19728,6 @@ snapshots: queue-microtask@1.2.3: {} - queue-tick@1.0.1: {} - queue@6.0.2: dependencies: inherits: 2.0.4 @@ -20313,7 +19879,7 @@ snapshots: dependencies: object-assign: 4.1.1 react: 18.3.1 - react-is: 17.0.2 + react-is: 18.3.1 react-style-singleton@2.2.1(@types/react@18.2.21)(react@18.3.1): dependencies: @@ -20729,10 +20295,6 @@ snapshots: semver@6.3.1: {} - semver@7.6.0: - dependencies: - lru-cache: 6.0.0 - semver@7.6.2: {} semver@7.6.3: {} @@ -20896,8 +20458,6 @@ snapshots: astral-regex: 2.0.0 is-fullwidth-code-point: 3.0.0 - smart-buffer@4.2.0: {} - smol-toml@1.3.0: {} snake-case@2.1.0: @@ -20927,19 +20487,6 @@ snapshots: transitivePeerDependencies: - supports-color - socks-proxy-agent@8.0.3: - dependencies: - agent-base: 7.1.1 - debug: 4.3.6 - socks: 2.8.3 - transitivePeerDependencies: - - supports-color - - socks@2.8.3: - dependencies: - ip-address: 9.0.5 - smart-buffer: 4.2.0 - solc@0.4.26: dependencies: fs-extra: 0.30.0 @@ -21007,8 +20554,6 @@ snapshots: sprintf-js@1.0.3: {} - sprintf-js@1.1.3: {} - sshpk@1.18.0: dependencies: asn1: 0.2.6 @@ -21086,13 +20631,6 @@ snapshots: streamsearch@1.1.0: {} - streamx@2.16.1: - dependencies: - fast-fifo: 1.3.2 - queue-tick: 1.0.1 - optionalDependencies: - bare-events: 2.2.2 - strict-event-emitter@0.2.8: dependencies: events: 3.3.0 @@ -21215,19 +20753,19 @@ snapshots: style-search@0.1.0: {} - styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1): + styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1): dependencies: '@babel/helper-module-imports': 7.24.6 '@babel/traverse': 7.24.6(supports-color@5.5.0) '@emotion/is-prop-valid': 1.2.2 '@emotion/stylis': 0.8.5 '@emotion/unitless': 0.7.5 - babel-plugin-styled-components: 2.1.4(@babel/core@7.24.6)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1)) + babel-plugin-styled-components: 2.1.4(@babel/core@7.24.6)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@18.3.1)(react@18.3.1)) css-to-react-native: 3.2.0 hoist-non-react-statics: 3.3.2 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - react-is: 17.0.2 + react-is: 18.3.1 shallowequal: 1.1.0 supports-color: 5.5.0 transitivePeerDependencies: @@ -21432,14 +20970,6 @@ snapshots: pump: 3.0.0 tar-stream: 2.2.0 - tar-fs@3.0.5: - dependencies: - pump: 3.0.0 - tar-stream: 3.1.7 - optionalDependencies: - bare-fs: 2.3.0 - bare-path: 2.1.3 - tar-stream@2.2.0: dependencies: bl: 4.1.0 @@ -21448,12 +20978,6 @@ snapshots: inherits: 2.0.4 readable-stream: 3.6.2 - tar-stream@3.1.7: - dependencies: - b4a: 1.6.6 - fast-fifo: 1.3.2 - streamx: 2.16.1 - tar@4.4.19: dependencies: chownr: 1.1.4 @@ -21736,11 +21260,6 @@ snapshots: has-symbols: 1.0.3 which-boxed-primitive: 1.0.2 - unbzip2-stream@1.4.3: - dependencies: - buffer: 5.7.1 - through: 2.3.8 - uncrypto@0.1.3: {} undici-types@5.26.5: {} @@ -21832,8 +21351,6 @@ snapshots: url-set-query@1.0.0: {} - urlpattern-polyfill@10.0.0: {} - use-callback-ref@1.3.2(@types/react@18.2.21)(react@18.3.1): dependencies: react: 18.3.1 @@ -22937,11 +22454,6 @@ snapshots: y18n: 3.2.2 yargs-parser: 2.4.1 - yauzl@2.10.0: - dependencies: - buffer-crc32: 0.2.13 - fd-slicer: 1.1.0 - yn@3.1.1: {} yocto-queue@0.1.0: {} @@ -22960,8 +22472,6 @@ snapshots: dependencies: zod: 3.23.8 - zod@3.22.4: {} - zod@3.23.8: {} zustand@4.4.1(@types/react@18.2.21)(immer@9.0.21)(react@18.3.1): From 9bedcd653f54080d6e78b6b6d9b79c2f61cca296 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Sat, 19 Oct 2024 00:50:38 +0300 Subject: [PATCH 28/75] reapply socket optimize --- package.json | 102 ++- pnpm-lock.yaml | 1694 +++++++++++++++++++----------------------------- 2 files changed, 746 insertions(+), 1050 deletions(-) diff --git a/package.json b/package.json index e9626f104..1aca49552 100644 --- a/package.json +++ b/package.json @@ -186,14 +186,96 @@ }, "pnpm": { "overrides": { - "wrtc": "https://registry.npmjs.org/@koush/wrtc/-/wrtc-0.5.2.tgz", - "bn.js": "npm:bn.js@^5.2.0", "@nomiclabs/hardhat-ethers": "npm:hardhat-deploy-ethers@0.3.0-beta.13", + "@wagmi/core": "2.13.3", "@walletconnect/ethereum-provider": "2.11.1", "@walletconnect/modal": "2.6.2", + "aggregate-error": "npm:@socketregistry/aggregate-error@^1", + "array-buffer-byte-length": "npm:@socketregistry/array-buffer-byte-length@^1", + "array-flatten": "npm:@socketregistry/array-flatten@^1", + "array-includes": "npm:@socketregistry/array-includes@^1", + "array.prototype.findlast": "npm:@socketregistry/array.prototype.findlast@^1", + "array.prototype.findlastindex": "npm:@socketregistry/array.prototype.findlastindex@^1", + "array.prototype.flat": "npm:@socketregistry/array.prototype.flat@^1", + "array.prototype.flatmap": "npm:@socketregistry/array.prototype.flatmap@^1", + "arraybuffer.prototype.slice": "npm:@socketregistry/arraybuffer.prototype.slice@^1", + "available-typed-arrays": "npm:@socketregistry/available-typed-arrays@^1", + "bn.js": "npm:bn.js@^5.2.0", + "deep-equal": "npm:@socketregistry/deep-equal@^1", + "define-properties": "npm:@socketregistry/define-properties@^1", + "es-define-property": "npm:@socketregistry/es-define-property@^1", + "es-get-iterator": "npm:@socketregistry/es-get-iterator@^1", + "es-set-tostringtag": "npm:@socketregistry/es-set-tostringtag@^1", + "es6-symbol": "npm:@socketregistry/es6-symbol@^1", + "for-each": "npm:@socketregistry/for-each@^1", + "function-bind": "npm:@socketregistry/function-bind@^1", + "function.prototype.name": "npm:@socketregistry/function.prototype.name@^1", + "functions-have-names": "npm:@socketregistry/functions-have-names@^1", + "get-symbol-description": "npm:@socketregistry/get-symbol-description@^1", + "globalthis": "npm:@socketregistry/globalthis@^1", + "gopd": "npm:@socketregistry/gopd@^1", + "has-property-descriptors": "npm:@socketregistry/has-property-descriptors@^1", + "has-proto": "npm:@socketregistry/has-proto@^1", + "has-symbols": "npm:@socketregistry/has-symbols@^1", + "has-tostringtag": "npm:@socketregistry/has-tostringtag@^1", + "hasown": "npm:@socketregistry/hasown@^1", + "indent-string": "npm:@socketregistry/indent-string@^1", + "internal-slot": "npm:@socketregistry/internal-slot@^1", + "is-arguments": "npm:@socketregistry/is-arguments@^1", + "is-array-buffer": "npm:@socketregistry/is-array-buffer@^1", + "is-bigint": "npm:@socketregistry/is-bigint@^1", + "is-boolean-object": "npm:@socketregistry/is-boolean-object@^1", + "is-core-module": "npm:@socketregistry/is-core-module@^1", + "is-date-object": "npm:@socketregistry/is-date-object@^1", + "is-generator-function": "npm:@socketregistry/is-generator-function@^1", + "is-map": "npm:@socketregistry/is-map@^1", + "is-negative-zero": "npm:@socketregistry/is-negative-zero@^1", + "is-number-object": "npm:@socketregistry/is-number-object@^1", + "is-regex": "npm:@socketregistry/is-regex@^1", + "is-set": "npm:@socketregistry/is-set@^1", + "is-shared-array-buffer": "npm:@socketregistry/is-shared-array-buffer@^1", + "is-string": "npm:@socketregistry/is-string@^1", + "is-symbol": "npm:@socketregistry/is-symbol@^1", + "is-typed-array": "npm:@socketregistry/is-typed-array@^1", + "is-weakmap": "npm:@socketregistry/is-weakmap@^1", + "is-weakref": "npm:@socketregistry/is-weakref@^1", + "is-weakset": "npm:@socketregistry/is-weakset@^1", + "isarray": "npm:@socketregistry/isarray@^1", + "iterator.prototype": "npm:@socketregistry/iterator.prototype@^1", + "number-is-nan": "npm:@socketregistry/number-is-nan@^1", + "object-assign": "npm:@socketregistry/object-assign@^1", + "object-is": "npm:@socketregistry/object-is@^1", + "object-keys": "npm:@socketregistry/object-keys@^1", + "object.assign": "npm:@socketregistry/object.assign@^1", + "object.entries": "npm:@socketregistry/object.entries@^1", + "object.fromentries": "npm:@socketregistry/object.fromentries@^1", + "object.hasown": "npm:@socketregistry/object.hasown@^1", + "object.values": "npm:@socketregistry/object.values@^1", + "path-parse": "npm:@socketregistry/path-parse@^1", + "querystringify": "npm:@socketregistry/querystringify@^1", "react": "^18.2.0", "react-dom": "^18.2.0", - "@wagmi/core": "2.13.3" + "reflect.getprototypeof": "npm:@socketregistry/reflect.getprototypeof@^1", + "regexp.prototype.flags": "npm:@socketregistry/regexp.prototype.flags@^1", + "safe-array-concat": "npm:@socketregistry/safe-array-concat@^1", + "safe-buffer": "npm:@socketregistry/safe-buffer@^1", + "safe-regex-test": "npm:@socketregistry/safe-regex-test@^1", + "safer-buffer": "npm:@socketregistry/safer-buffer@^1", + "set-function-length": "npm:@socketregistry/set-function-length@^1", + "side-channel": "npm:@socketregistry/side-channel@^1", + "string.prototype.matchall": "npm:@socketregistry/string.prototype.matchall@^1", + "string.prototype.trim": "npm:@socketregistry/string.prototype.trim@^1", + "string.prototype.trimend": "npm:@socketregistry/string.prototype.trimend@^1", + "string.prototype.trimstart": "npm:@socketregistry/string.prototype.trimstart@^1", + "typed-array-buffer": "npm:@socketregistry/typed-array-buffer@^1", + "typed-array-byte-length": "npm:@socketregistry/typed-array-byte-length@^1", + "typed-array-byte-offset": "npm:@socketregistry/typed-array-byte-offset@^1", + "typed-array-length": "npm:@socketregistry/typed-array-length@^1", + "unbox-primitive": "npm:@socketregistry/unbox-primitive@^1", + "which-boxed-primitive": "npm:@socketregistry/which-boxed-primitive@^1", + "which-collection": "npm:@socketregistry/which-collection@^1", + "which-typed-array": "npm:@socketregistry/which-typed-array@^1", + "wrtc": "https://registry.npmjs.org/@koush/wrtc/-/wrtc-0.5.2.tgz" }, "patchedDependencies": { "react-confetti@6.1.0": "patches/react-confetti@6.1.0.patch", @@ -202,10 +284,6 @@ }, "packageManager": "pnpm@9.3.0", "overrides": { - "@nomiclabs/hardhat-ethers": "npm:hardhat-deploy-ethers@0.3.0-beta.13", - "@wagmi/core": "2.13.3", - "@walletconnect/ethereum-provider": "2.11.1", - "@walletconnect/modal": "2.6.2", "aggregate-error": "npm:@socketregistry/aggregate-error@^1", "array-buffer-byte-length": "npm:@socketregistry/array-buffer-byte-length@^1", "array-flatten": "npm:@socketregistry/array-flatten@^1", @@ -214,16 +292,12 @@ "array.prototype.findlastindex": "npm:@socketregistry/array.prototype.findlastindex@^1", "array.prototype.flat": "npm:@socketregistry/array.prototype.flat@^1", "array.prototype.flatmap": "npm:@socketregistry/array.prototype.flatmap@^1", - "array.prototype.toreversed": "npm:@socketregistry/array.prototype.toreversed@^1", - "array.prototype.tosorted": "npm:@socketregistry/array.prototype.tosorted@^1", "arraybuffer.prototype.slice": "npm:@socketregistry/arraybuffer.prototype.slice@^1", "available-typed-arrays": "npm:@socketregistry/available-typed-arrays@^1", - "bn.js": "npm:bn.js@^5.2.0", "deep-equal": "npm:@socketregistry/deep-equal@^1", "define-properties": "npm:@socketregistry/define-properties@^1", "es-define-property": "npm:@socketregistry/es-define-property@^1", "es-get-iterator": "npm:@socketregistry/es-get-iterator@^1", - "es-iterator-helpers": "npm:@socketregistry/es-iterator-helpers@^1", "es-set-tostringtag": "npm:@socketregistry/es-set-tostringtag@^1", "es6-symbol": "npm:@socketregistry/es6-symbol@^1", "for-each": "npm:@socketregistry/for-each@^1", @@ -268,13 +342,10 @@ "object.assign": "npm:@socketregistry/object.assign@^1", "object.entries": "npm:@socketregistry/object.entries@^1", "object.fromentries": "npm:@socketregistry/object.fromentries@^1", - "object.groupby": "npm:@socketregistry/object.groupby@^1", "object.hasown": "npm:@socketregistry/object.hasown@^1", "object.values": "npm:@socketregistry/object.values@^1", "path-parse": "npm:@socketregistry/path-parse@^1", "querystringify": "npm:@socketregistry/querystringify@^1", - "react": "^18.2.0", - "react-dom": "^18.2.0", "reflect.getprototypeof": "npm:@socketregistry/reflect.getprototypeof@^1", "regexp.prototype.flags": "npm:@socketregistry/regexp.prototype.flags@^1", "safe-array-concat": "npm:@socketregistry/safe-array-concat@^1", @@ -294,7 +365,6 @@ "unbox-primitive": "npm:@socketregistry/unbox-primitive@^1", "which-boxed-primitive": "npm:@socketregistry/which-boxed-primitive@^1", "which-collection": "npm:@socketregistry/which-collection@^1", - "which-typed-array": "npm:@socketregistry/which-typed-array@^1", - "wrtc": "https://registry.npmjs.org/@koush/wrtc/-/wrtc-0.5.2.tgz" + "which-typed-array": "npm:@socketregistry/which-typed-array@^1" } } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index dd959e88b..09cc190cc 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,14 +5,96 @@ settings: excludeLinksFromLockfile: false overrides: - wrtc: https://registry.npmjs.org/@koush/wrtc/-/wrtc-0.5.2.tgz - bn.js: npm:bn.js@^5.2.0 '@nomiclabs/hardhat-ethers': npm:hardhat-deploy-ethers@0.3.0-beta.13 + '@wagmi/core': 2.13.3 '@walletconnect/ethereum-provider': 2.11.1 '@walletconnect/modal': 2.6.2 + aggregate-error: npm:@socketregistry/aggregate-error@^1 + array-buffer-byte-length: npm:@socketregistry/array-buffer-byte-length@^1 + array-flatten: npm:@socketregistry/array-flatten@^1 + array-includes: npm:@socketregistry/array-includes@^1 + array.prototype.findlast: npm:@socketregistry/array.prototype.findlast@^1 + array.prototype.findlastindex: npm:@socketregistry/array.prototype.findlastindex@^1 + array.prototype.flat: npm:@socketregistry/array.prototype.flat@^1 + array.prototype.flatmap: npm:@socketregistry/array.prototype.flatmap@^1 + arraybuffer.prototype.slice: npm:@socketregistry/arraybuffer.prototype.slice@^1 + available-typed-arrays: npm:@socketregistry/available-typed-arrays@^1 + bn.js: npm:bn.js@^5.2.0 + deep-equal: npm:@socketregistry/deep-equal@^1 + define-properties: npm:@socketregistry/define-properties@^1 + es-define-property: npm:@socketregistry/es-define-property@^1 + es-get-iterator: npm:@socketregistry/es-get-iterator@^1 + es-set-tostringtag: npm:@socketregistry/es-set-tostringtag@^1 + es6-symbol: npm:@socketregistry/es6-symbol@^1 + for-each: npm:@socketregistry/for-each@^1 + function-bind: npm:@socketregistry/function-bind@^1 + function.prototype.name: npm:@socketregistry/function.prototype.name@^1 + functions-have-names: npm:@socketregistry/functions-have-names@^1 + get-symbol-description: npm:@socketregistry/get-symbol-description@^1 + globalthis: npm:@socketregistry/globalthis@^1 + gopd: npm:@socketregistry/gopd@^1 + has-property-descriptors: npm:@socketregistry/has-property-descriptors@^1 + has-proto: npm:@socketregistry/has-proto@^1 + has-symbols: npm:@socketregistry/has-symbols@^1 + has-tostringtag: npm:@socketregistry/has-tostringtag@^1 + hasown: npm:@socketregistry/hasown@^1 + indent-string: npm:@socketregistry/indent-string@^1 + internal-slot: npm:@socketregistry/internal-slot@^1 + is-arguments: npm:@socketregistry/is-arguments@^1 + is-array-buffer: npm:@socketregistry/is-array-buffer@^1 + is-bigint: npm:@socketregistry/is-bigint@^1 + is-boolean-object: npm:@socketregistry/is-boolean-object@^1 + is-core-module: npm:@socketregistry/is-core-module@^1 + is-date-object: npm:@socketregistry/is-date-object@^1 + is-generator-function: npm:@socketregistry/is-generator-function@^1 + is-map: npm:@socketregistry/is-map@^1 + is-negative-zero: npm:@socketregistry/is-negative-zero@^1 + is-number-object: npm:@socketregistry/is-number-object@^1 + is-regex: npm:@socketregistry/is-regex@^1 + is-set: npm:@socketregistry/is-set@^1 + is-shared-array-buffer: npm:@socketregistry/is-shared-array-buffer@^1 + is-string: npm:@socketregistry/is-string@^1 + is-symbol: npm:@socketregistry/is-symbol@^1 + is-typed-array: npm:@socketregistry/is-typed-array@^1 + is-weakmap: npm:@socketregistry/is-weakmap@^1 + is-weakref: npm:@socketregistry/is-weakref@^1 + is-weakset: npm:@socketregistry/is-weakset@^1 + isarray: npm:@socketregistry/isarray@^1 + iterator.prototype: npm:@socketregistry/iterator.prototype@^1 + number-is-nan: npm:@socketregistry/number-is-nan@^1 + object-assign: npm:@socketregistry/object-assign@^1 + object-is: npm:@socketregistry/object-is@^1 + object-keys: npm:@socketregistry/object-keys@^1 + object.assign: npm:@socketregistry/object.assign@^1 + object.entries: npm:@socketregistry/object.entries@^1 + object.fromentries: npm:@socketregistry/object.fromentries@^1 + object.hasown: npm:@socketregistry/object.hasown@^1 + object.values: npm:@socketregistry/object.values@^1 + path-parse: npm:@socketregistry/path-parse@^1 + querystringify: npm:@socketregistry/querystringify@^1 react: ^18.2.0 react-dom: ^18.2.0 - '@wagmi/core': 2.13.3 + reflect.getprototypeof: npm:@socketregistry/reflect.getprototypeof@^1 + regexp.prototype.flags: npm:@socketregistry/regexp.prototype.flags@^1 + safe-array-concat: npm:@socketregistry/safe-array-concat@^1 + safe-buffer: npm:@socketregistry/safe-buffer@^1 + safe-regex-test: npm:@socketregistry/safe-regex-test@^1 + safer-buffer: npm:@socketregistry/safer-buffer@^1 + set-function-length: npm:@socketregistry/set-function-length@^1 + side-channel: npm:@socketregistry/side-channel@^1 + string.prototype.matchall: npm:@socketregistry/string.prototype.matchall@^1 + string.prototype.trim: npm:@socketregistry/string.prototype.trim@^1 + string.prototype.trimend: npm:@socketregistry/string.prototype.trimend@^1 + string.prototype.trimstart: npm:@socketregistry/string.prototype.trimstart@^1 + typed-array-buffer: npm:@socketregistry/typed-array-buffer@^1 + typed-array-byte-length: npm:@socketregistry/typed-array-byte-length@^1 + typed-array-byte-offset: npm:@socketregistry/typed-array-byte-offset@^1 + typed-array-length: npm:@socketregistry/typed-array-length@^1 + unbox-primitive: npm:@socketregistry/unbox-primitive@^1 + which-boxed-primitive: npm:@socketregistry/which-boxed-primitive@^1 + which-collection: npm:@socketregistry/which-collection@^1 + which-typed-array: npm:@socketregistry/which-typed-array@^1 + wrtc: https://registry.npmjs.org/@koush/wrtc/-/wrtc-0.5.2.tgz patchedDependencies: next-dev-https@0.1.2: @@ -2927,6 +3009,274 @@ packages: '@socket.io/component-emitter@3.1.2': resolution: {integrity: sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==} + '@socketregistry/aggregate-error@1.0.2': + resolution: {integrity: sha512-t/pYgFe0Fu5Xxj/sxeZSN+R+zRJkCapIbbnMmnUaaYMFiGa7F4QEpzfco9SzDsLKCL5KiXPk7eNoq5u+Zb7omQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array-buffer-byte-length@1.0.2': + resolution: {integrity: sha512-NnEN2yy/+CLT4crAkmVe61TBxCgVvm2Waed592kQ60BkeMQJO/u6NIz5UxIc1doKoMoOtpWFC7BsshdQ8OygdA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array-flatten@1.0.2': + resolution: {integrity: sha512-PtSpo+Um8t89av01cbNN5wMNt2wwA4Z9iC+VAVTYM+IDJY4edDmvjbT7aLW8RyIX4+iyusrOKRTYArxUKY9tsg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array-includes@1.0.2': + resolution: {integrity: sha512-05kt9puYSisQAr5+d4HVKOb/pgC/6gKGxJGkmpPN6xG6x7ZL5hUur+37YKxgC68fdteeBwkfLrPeUM27qd77pg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array.prototype.findlast@1.0.2': + resolution: {integrity: sha512-Mx6n+Babc3/JW3GlyGTmef27W1hhGDc/vdxPpNB0N+5KqNgq2shKJtltQtVt3RNaipLQ+8in8c6ssIZOwUs9kg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array.prototype.findlastindex@1.0.2': + resolution: {integrity: sha512-tRT9zZXIzXTzIFCWSEoH9NEU8Q03CynFdwoJghuPHucNtfkZI1k/fUSTJm3D9L7L1lw9x6Sau+dCktRVSflknQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array.prototype.flat@1.0.2': + resolution: {integrity: sha512-wlDtbBiodslkhBUxK3Zm7Y0/4qhLXvz+KAES0I6PZjpplRDQl4ovBO+TsSgw2DG6J04R0sU4GXIk7T8hwq4f/Q==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array.prototype.flatmap@1.0.2': + resolution: {integrity: sha512-NSfLVhyrne3HQFDmVjFQA0efGw6ffXS89vlxd0MAKDwb69Pm04L9ptcJYpMk5KePy3xHlInLHBcSL0jwK0ivfQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/arraybuffer.prototype.slice@1.0.2': + resolution: {integrity: sha512-+UxX/TBcH/+2Ne3UrOX2PcHZTnKFVOrP4oeUcJlq6PwVcj7Urjwy4DYmledOQ2wnSE0yPZU1pp5U7JCwRe3F1A==} + engines: {node: '>=18.20.4'} + + '@socketregistry/available-typed-arrays@1.0.2': + resolution: {integrity: sha512-4vcuP9rNmvvtk8sFbaIqnz5ljTJNxH31hXqt5TBr7v7gzlKgEgY5CYQNXDwTaHih/YfXUKv56NwhQqKVHxPErQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/deep-equal@1.0.3': + resolution: {integrity: sha512-6Ux7SFCn6dFLkGk3CF+83IAU/rbhUrDDxPOGKDhHmIt0u0qpR/ouAEszIDNMrY2mJ086GzDQM+rC5iddk2ue3w==} + engines: {node: '>=18.20.4'} + + '@socketregistry/define-properties@1.0.2': + resolution: {integrity: sha512-5imraGrpdiVWsgbEuNCGeMAexOjquIV3fPWt0+dZnaP0cGG9NKhxz4F+UmcdsNQRhwyZcAijBRETW8rxePxbqw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/es-define-property@1.0.2': + resolution: {integrity: sha512-PNysoPksplPu4GeaC01R9rM2P10zzijYJPuqF8zbvvTrB8vvCFih0X3IxI2oz2iDWvCasV5upZ3reevR07mt2Q==} + engines: {node: '>=18.20.4'} + + '@socketregistry/es-set-tostringtag@1.0.2': + resolution: {integrity: sha512-w94rrdD38Op0U1jS2K7DJ7MAaOQAeDGqXVy7J0We7jTNgjtesgO5WQ7n8H9Bl4ApWZq+Egcua+0APore6WCcuQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/es6-symbol@1.0.2': + resolution: {integrity: sha512-GOGaWdzCLFqQ4SyJ+UrXbr2b1ScaVELme7YLtFdusomZVipwRIsl6xAKT1dy4lY0dbihSZjudxP8g/cIHafhbQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/function-bind@1.0.2': + resolution: {integrity: sha512-LmyqjHMykbzvwXjJmViM/f4hmrnqwUCYEO0FGGenidcxXgO+Yj/gGVAa1Q0x9MWSZTlU06djYeD0ILqynIUoVw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/function.prototype.name@1.0.2': + resolution: {integrity: sha512-/uHAJXDEQm0LPewU+9RcH9kK8mujh1I0zB6ll3iZ4WZxPYmKgDbUaEJMOL9v1Xv0gj/Awu64hHkGHFRmEkMdxA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/get-symbol-description@1.0.2': + resolution: {integrity: sha512-plNw/+RUd+yfrbb+WsiRE+hWiPFHg7Wf1FqInQcsUxk39YcNBrB5LdagzxqbXtooYMX8YcZJ0Tzph2o9LhBGsQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/globalthis@1.0.2': + resolution: {integrity: sha512-kuSBfiI8Kbp6oUFwWA5X0ZYfBJ3Oc3AG8fqqNCRRsMhJRP7rY8xynFDk5kv6jya+5g8UlKKMh3nBc7+YmEIDWA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/gopd@1.0.2': + resolution: {integrity: sha512-gURoTaVFHcBKOolgWQoy0XdNlAhE/SxgcaaxI9+T22vkaMrmu9IidREocDVjy3hpzjHLRCqT6C9e0p9J5iaq4g==} + engines: {node: '>=18.20.4'} + + '@socketregistry/has-property-descriptors@1.0.2': + resolution: {integrity: sha512-92093fF64g08pgiZCg8FC/jZuoIFeRIsCe89qlj/VFFx35AAzShr4ypOBGy3BoIMbv7z+ooZFiqipkfEYE3Gpw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/has-proto@1.0.2': + resolution: {integrity: sha512-xDqvx1G2q63IHfoalQUJsR3VlSfsn5VRmxV8GepJpPGBJ0qDBZVX9lScieeRFibdhHenGiMGWkg6byukD3puTA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/has-symbols@1.0.2': + resolution: {integrity: sha512-7AyOmPWvCzQEtRZqRCxKgTrNXusduRSdVfnRsxGYjEycgyhgZivIJU0UrYP6nLX4VMeNjjAYMJP6vdRNxp5IIQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/hasown@1.0.2': + resolution: {integrity: sha512-xlPs2JPAw3EK9QxY4cQD9clAR2yJvc9dSK4mVw6k0OXyTQMhrzMIJVIVl5swl1rr3AqWv/vEtI4d/y6jj3aXfQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/indent-string@1.0.2': + resolution: {integrity: sha512-BFTaibLNPHgdTZjqsO4smcfFYqMw30WbWHYCQcmKHK03QlJxrfy4PaAPifTH1ydtcM+216WjDJIlFviRPN7JBg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/internal-slot@1.0.2': + resolution: {integrity: sha512-mAbt01fjEs3dFdhIsBHSyvG2xaNMzdE7kUfHX4gbfMPl1myibzo9oVL5hI/OSC8KRfU5+7TE0QO54QRnQusrCw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-arguments@1.0.2': + resolution: {integrity: sha512-M2zZobk3HdadnnQjjWc9wI5/5ayX0tQ1abZKQFPJb0m+nPQI9pHl5G0sVIpiYTcgR7InSEP2r34/4E8El8y+uA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-array-buffer@1.0.2': + resolution: {integrity: sha512-6wo4RbTwTBS/moYm7JjX2nC7ogRk4AMKCrCGLbmU6W79ee7PjKAO8KrkwLRbgwDPCMoImVkSQMHq2T2aPisgAQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-core-module@1.0.2': + resolution: {integrity: sha512-uGkXWRY0qh5EMHOohm/wrNP0o3L5m6QjGYZ+gYFmH8gQaIrZTKCgBZKZVB4b0wpuq5mvibYQAW0h/dYsw+SiXg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-date-object@1.0.2': + resolution: {integrity: sha512-s7Yfgi4sRxM1PhgA6jgYBxzvO5Gw6NSuOaGnArlaJrXEURNQ4QX5i/8Pm6/9kVzjkD53xL0JxeHTVrwZBFELFQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-generator-function@1.0.2': + resolution: {integrity: sha512-yFErdGF19F/3IeJZPgK3njx8iwAS2+E9sngrfu4NkxodO6Zm0PBAOXg/OSvm5kF++dWDm2mYW4S1AWzDA0S5aQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-negative-zero@1.0.2': + resolution: {integrity: sha512-DDfyjg26fz5PWcot0ukUK/30vQYyaQwku7LZToVld3WolUla6Vl+peA55vL8TojoVl/lUGJh7C8MQ205UU92Aw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-regex@1.0.2': + resolution: {integrity: sha512-bJQynMk09SMnQYDR8VJotCZUoopVwHaiNS0loKvpQFnvMIRzkelvHolR4y0tlpZOb/arChoC7wEm27ddrXb0eg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-shared-array-buffer@1.0.2': + resolution: {integrity: sha512-HOcwnXcUZN8a5N0HmfpnLwnxEJbWMoLLil2A6HvKDQ12L7s3fvdkH7gv3Z8Do4qnpiS5I79WkF+372wOtB5uaw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-string@1.0.2': + resolution: {integrity: sha512-Yd10AEWSvW9ZUfNMlaDIpOBr8iP8VPE0vhUE0qZNszIzWnRB0Ups5cNgW+sP3Mt6YjUc213kyqycKxnZ6WoKGQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-symbol@1.0.2': + resolution: {integrity: sha512-a+K70WtAQjvu3c6eTUXQju70bkQqulfHVnzoBex44gzjEd5Uml+HzisrBGyfsYxAMQbJUh3EPXKaXaLD1172Mg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-typed-array@1.0.2': + resolution: {integrity: sha512-rEkGPV+3urLHAUQ9kvASIE0ZUaNLUJpJVxt77nxcN+2E4KpqTdKGPK0T4wfFMjIMpgEd8LlKnWDmwde5tttI4Q==} + engines: {node: '>=18.20.4'} + + '@socketregistry/is-weakref@1.0.2': + resolution: {integrity: sha512-MGJK/ROsfLy7c4l72fZ9Db3ptTjqpAo0OaIEG3Vo2BFjnranFFTFG0EAznmMyDh1fedytVAY143AJSo0Wmhsmg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/isarray@1.0.2': + resolution: {integrity: sha512-VmPr36LumrJeLtOcIUbKJWl1KFSEg5R/eAu/WyD43VLHFFwxf3zDXuBvT9e7if76S4UKKyEAKQhJkwHv56/XHA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/iterator.prototype@1.0.2': + resolution: {integrity: sha512-QPHai4jStUU5ruTx1sZ9cGDwAwEWMl9Svhb/syMDPv5r+vAxosIsmMDieXCFdc9YyP9+CjWHeO2cIHvRez9qsg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/number-is-nan@1.0.2': + resolution: {integrity: sha512-8tK8nfk5Q3mHdC+rrKC0Qgj3PBBbXcOFh9XdZ3PGYvHKwk6qI+bbKSzw2RO8llNnzWL2VIfJYolkA/g9L2iRdA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object-assign@1.0.1': + resolution: {integrity: sha512-XPbWgbq8G1EMh9f6/96tfVp4wKwUOTpLzFPjN/BaB+g3xpF8CzmDBSoTvP/ApNs2dbiK9GOUhQbHlzyW5R/TXw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object-keys@1.0.2': + resolution: {integrity: sha512-cnVFGu/6UQUJZG10PsEevBsnyj39iWe6mCWsBBAjbRAXn5LcUGdnV62jjbSbD/LgPmDJkl0FuT9+C8DPWAt01w==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object.assign@1.0.2': + resolution: {integrity: sha512-ipVCKh88fGA7xTzWcrz4Q9Lne2KeP3XeQ/KGVt7pzg8WTKBK/KdRRRs01uS4slQYFGAnWf8YBh9wdmBYeRB+XQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object.entries@1.0.2': + resolution: {integrity: sha512-i0UY/qE6skVPb6vTnapVFcJj7hzihDoLvjE1zBFUHCcC3cpqDpFSVxQyvNod3vC+Rk3RNYsGVU/ITqTh48KooA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object.fromentries@1.0.2': + resolution: {integrity: sha512-bETV+GbmvxnsIe7aLtyeXxe4acTrqgQc3P1d9Nmc5ukUbr0yeuPjmawwQMS4o/2YoSiQs/6WdrMJSZH23l3gpQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object.hasown@1.0.2': + resolution: {integrity: sha512-ntM41w23t9SLbB7sVk+gakO4ghyMhZqiJpXFxvgE9HYNce7LBPwGTtP+xGH90IrDcJd9eHRJ5m0Pwe5V5Yzwmw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/object.values@1.0.2': + resolution: {integrity: sha512-nmjm5+pglSz36PKAsxZBuqKpgMLvcPKLNNbn9FdQcdB4UuyDn82imk7tD0wLc3aZZTiAmKf6JjGEJINJnRYtew==} + engines: {node: '>=18.20.4'} + + '@socketregistry/path-parse@1.0.2': + resolution: {integrity: sha512-h0bpAZ06Fb5554kU/Wg31GXBxadfI6gnlprktUmoReJnnn7LactZd8QoxABKWEZf/IMo3/wJnX2iqEHW+8MzFQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/querystringify@1.0.2': + resolution: {integrity: sha512-eHRJGTEtq5uHdR/1FJTl4w5umu+Nd0iWrnENRM7iiGY5z823Bv7zZ+NNyfJJGqDfjAkxSsYQnTXR9/dgPAhKmw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/regexp.prototype.flags@1.0.2': + resolution: {integrity: sha512-iIF0omZAYD1Uy+oKJ2z/9qx7yvKGnMRGk333aNNweMpqHNxkrNdat/4h6x5Lr1dZ/j9+2R2ENOxKf2wLJyYSyg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/safe-array-concat@1.0.2': + resolution: {integrity: sha512-TLR/NdMydXmmTpzm4wfTBgOekn43PRg8Dve7g9zYp3qjLevAHkKehYJVy07S8CaVQ6Ro1yLSqadZdobvHb0LGg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/safe-buffer@1.0.2': + resolution: {integrity: sha512-gxk0KHN9Zze3+y96yCl5QiVXiu6PfIOUlCLTVXwMIEA2UR7E0ITmTwqwN+yTtFNd3LX3LRDmF4gNd6yn6YiYpw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/safe-regex-test@1.0.2': + resolution: {integrity: sha512-U0jxa+n9IS0C0JMlgJPZlEfN9+c1f8D+ezOkWJcu7rBVrkaZlZV2PpqP2IswMEhbuFOKzU0UuvgQDJywWuDGVA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/safer-buffer@1.0.2': + resolution: {integrity: sha512-Qvr8L0zr5fuyOZWWM9ABeJxYH99Wk/geBlRzmKPvK074ujLBK+Hn2O5SEbKLqexyIHvHoFKgkaRFZh+PQHAnnA==} + engines: {node: '>=18.20.4'} + + '@socketregistry/set-function-length@1.0.2': + resolution: {integrity: sha512-ndUGe7a81X+LEzDGSghiARiHM4kQzVrRntkqgllZfDUWQTPZ3CJ1XjnS4pIOf/g/je4GG54okbeeSVog/ffInw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/side-channel@1.0.2': + resolution: {integrity: sha512-hG6cCXIU5v5w4PAFrM6j5LWjC4Au3l22FQ7lDhFSRtx2tJv+n0ArhwOJ5YvsVTVAqriu+cV2n5sI6S+JeNg8Gg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/string.prototype.matchall@1.0.2': + resolution: {integrity: sha512-GvDqIcQCTAKEUpjpw0jOA3IHbp/Lczuy0z3JsVXRESb4Pg/PC9WLq5N3JmUj1TaMdgWxHpqe9S2Qfsv6rKgIgQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/string.prototype.trim@1.0.2': + resolution: {integrity: sha512-dOFc51euK9xvy6O/Ocsx9ToaxT86Op0PYT8wWn8ZbZvvxcPe8ml3Sv9Ly3f0BbrCIJ9GNhv/TYCTaPqrxeFz0Q==} + engines: {node: '>=18.20.4'} + + '@socketregistry/string.prototype.trimend@1.0.2': + resolution: {integrity: sha512-Itv37wv0f4jy+xrD/4YQxRqzFrrhAnGXhaF+ghmOC0emFAbQtYggijRdiLw1d/C9Uk8j2aSTUPawgh6QH8nCdg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/string.prototype.trimstart@1.0.2': + resolution: {integrity: sha512-YhCLd74AjJpIlssJ+xeYvBs73V8DieKEuP4g+nuZhIwgpiVGRd1P6lKEJEM1yoUUJfxWle+SflKPwN11Vwa+mQ==} + engines: {node: '>=18.20.4'} + + '@socketregistry/typed-array-buffer@1.0.2': + resolution: {integrity: sha512-3sCGL5captteofXw7NC7p9aGahsxMmIr8YNpa/6vGx6PDRdWwhGCWWGZ/pOZ0dAPSnaab4dTUeud2PnkTP8I7Q==} + engines: {node: '>=18.20.4'} + + '@socketregistry/typed-array-byte-length@1.0.2': + resolution: {integrity: sha512-nc+oaM1ADOr8WEKrs0Hstox4keBM5wUI8j0M5ABHiQeH3anQcklRD0VkMc5s4f2gmEEWgUYIMFNaunzYxrjx/w==} + engines: {node: '>=18.20.4'} + + '@socketregistry/typed-array-byte-offset@1.0.2': + resolution: {integrity: sha512-5HwmZxC/h9DhSJSYUma1gO+VAPi5zs5pxT7ryQMusOHUYTef2YoxJhqf1jKYWGmcnXWKD28iot1T9+uj2Lpqng==} + engines: {node: '>=18.20.4'} + + '@socketregistry/typed-array-length@1.0.2': + resolution: {integrity: sha512-97u+OMGh8Qg8i7aaYAhoPO4pWr22jNql9wZfGoPi0fURqoXxUoVSnsC2nkUW26VurXQAdNBGUoRCk8d7Z+3nMg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/unbox-primitive@1.0.2': + resolution: {integrity: sha512-dXm1PDzOz+RhmsCx9mgPSKiKYKda7iDMzro6N9JEQpsIDTBJgGeCN3OaWJc5M8hO2jSupyw0rFyAeuAj2d8/Kw==} + engines: {node: '>=18.20.4'} + + '@socketregistry/which-typed-array@1.0.2': + resolution: {integrity: sha512-QGW8dtkJplWq93Hj2ZJf+58RFWBMKG8jxLAScahEur7Sk2jOlb8M2ErjwrIpiop3Zrvqm/ko+42i0E3xlbOOuw==} + engines: {node: '>=18.20.4'} + '@stablelib/aead@1.0.1': resolution: {integrity: sha512-q39ik6sxGHewqtO0nP4BuSe3db5G1fEJE8ukvngS2gLkBXyy6E7pLubhbYgnkDFv6V8cWaxcE4Xn0t6LWcJkyg==} @@ -3764,10 +4114,6 @@ packages: resolution: {integrity: sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==} engines: {node: '>= 14'} - aggregate-error@3.1.0: - resolution: {integrity: sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==} - engines: {node: '>=8'} - ajv-formats@2.1.1: resolution: {integrity: sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==} peerDependencies: @@ -3886,47 +4232,16 @@ packages: aria-query@5.3.0: resolution: {integrity: sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==} - array-buffer-byte-length@1.0.1: - resolution: {integrity: sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==} - engines: {node: '>= 0.4'} - - array-flatten@1.1.1: - resolution: {integrity: sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==} - - array-includes@3.1.8: - resolution: {integrity: sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==} - engines: {node: '>= 0.4'} - array-union@2.1.0: resolution: {integrity: sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==} engines: {node: '>=8'} - array.prototype.findlast@1.2.5: - resolution: {integrity: sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==} - engines: {node: '>= 0.4'} - - array.prototype.findlastindex@1.2.5: - resolution: {integrity: sha512-zfETvRFA8o7EiNn++N5f/kaCw221hrpGsDmcpndVupkPzEc1Wuf3VgC0qby1BbHs7f5DVYjgtEU2LLh5bqeGfQ==} - engines: {node: '>= 0.4'} - - array.prototype.flat@1.3.2: - resolution: {integrity: sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==} - engines: {node: '>= 0.4'} - - array.prototype.flatmap@1.3.2: - resolution: {integrity: sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==} - engines: {node: '>= 0.4'} - array.prototype.toreversed@1.1.2: resolution: {integrity: sha512-wwDCoT4Ck4Cz7sLtgUmzR5UV3YF5mFHUlbChCzZBQZ+0m2cl/DH3tKgvphv1nKgFsJ48oCSg6p91q2Vm0I/ZMA==} array.prototype.tosorted@1.1.3: resolution: {integrity: sha512-/DdH4TiTmOKzyQbp/eadcCVexiCb36xJg7HshYOYJnNZFDj33GEv0P7GxsynpShhq4OLYJzbGcBDkLsDt7MnNg==} - arraybuffer.prototype.slice@1.0.3: - resolution: {integrity: sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==} - engines: {node: '>= 0.4'} - arrify@1.0.1: resolution: {integrity: sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==} engines: {node: '>=0.10.0'} @@ -3979,10 +4294,6 @@ packages: resolution: {integrity: sha512-kNOjDqAh7px0XWNI+4QbzoiR/nTkHAWNud2uvnJquD1/x5a7EQZMJT0AczqK0Qn67oY/TTQ1LbUKajZpp3I9tQ==} engines: {node: '>=8.0.0'} - available-typed-arrays@1.0.7: - resolution: {integrity: sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==} - engines: {node: '>= 0.4'} - aws-sign2@0.7.0: resolution: {integrity: sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==} @@ -4348,10 +4659,6 @@ packages: class-is@1.1.0: resolution: {integrity: sha512-rhjH9AG1fvabIDoGRVH587413LPjTZgmDF9fOFCbFJQV4yuocX1mHxxvXI4g3cGwbVY9wAYIoKlg1N79frJKQw==} - clean-stack@2.2.0: - resolution: {integrity: sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==} - engines: {node: '>=6'} - cli-boxes@2.2.1: resolution: {integrity: sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw==} engines: {node: '>=6'} @@ -4787,10 +5094,6 @@ packages: resolution: {integrity: sha512-h5k/5U50IJJFpzfL6nO9jaaumfjO/f2NjK/oYB2Djzm4p9L+3T9qWpZqZ2hAbLPuuYq9wrU08WQyBTL5GbPk5Q==} engines: {node: '>=6'} - deep-equal@2.2.3: - resolution: {integrity: sha512-ZIwpnevOurS8bpT4192sqAowWM76JDKSHYzMLty3BZGSswgq6pBaH3DhCSW5xVAZICZyKdOBPjwww5wfgT/6PA==} - engines: {node: '>= 0.4'} - deep-is@0.1.4: resolution: {integrity: sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==} @@ -4808,18 +5111,10 @@ packages: resolution: {integrity: sha512-4tvttepXG1VaYGrRibk5EwJd1t4udunSOVMdLSAL6mId1ix438oPwPZMALY41FCijukO1L0twNcGsdzS7dHgDg==} engines: {node: '>=10'} - define-data-property@1.1.4: - resolution: {integrity: sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==} - engines: {node: '>= 0.4'} - define-lazy-prop@2.0.0: resolution: {integrity: sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==} engines: {node: '>=8'} - define-properties@1.2.1: - resolution: {integrity: sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==} - engines: {node: '>= 0.4'} - defu@6.1.4: resolution: {integrity: sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg==} @@ -5042,17 +5337,10 @@ packages: resolution: {integrity: sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==} engines: {node: '>= 0.4'} - es-define-property@1.0.0: - resolution: {integrity: sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==} - engines: {node: '>= 0.4'} - es-errors@1.3.0: resolution: {integrity: sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==} engines: {node: '>= 0.4'} - es-get-iterator@1.1.3: - resolution: {integrity: sha512-sPZmqHBe6JIiTfN5q2pEi//TwxmAFHwj/XEuYjTuse78i8KxaqMTTzxPoFKuzRpDpTJ+0NAbpfenkmH2rePtuw==} - es-iterator-helpers@1.0.19: resolution: {integrity: sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==} engines: {node: '>= 0.4'} @@ -5064,10 +5352,6 @@ packages: resolution: {integrity: sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==} engines: {node: '>= 0.4'} - es-set-tostringtag@2.0.3: - resolution: {integrity: sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==} - engines: {node: '>= 0.4'} - es-shim-unscopables@1.0.2: resolution: {integrity: sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==} @@ -5085,10 +5369,6 @@ packages: es6-promise@4.2.8: resolution: {integrity: sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==} - es6-symbol@3.1.4: - resolution: {integrity: sha512-U9bFFjX8tFiATgtkJ1zg25+KviIXpgRvRHS8sau3GfhVzThRQrOeksPeT0BWW2MNZs1OEWJ1DPXOQMn0KKRkvg==} - engines: {node: '>=0.12'} - esbuild@0.17.19: resolution: {integrity: sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==} engines: {node: '>=12'} @@ -5422,9 +5702,6 @@ packages: resolution: {integrity: sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==} engines: {node: '>= 0.10.0'} - ext@1.7.0: - resolution: {integrity: sha512-6hxeJYaL110a9b5TEJSj0gojyHQAmA2ch5Os+ySCiA1QGdS697XWY1pzsrSjqA9LDEEgdB/KypIlR59RcLuHYw==} - extend@3.0.2: resolution: {integrity: sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==} @@ -5590,9 +5867,6 @@ packages: debug: optional: true - for-each@0.3.3: - resolution: {integrity: sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==} - foreground-child@3.3.0: resolution: {integrity: sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==} engines: {node: '>=14'} @@ -5671,16 +5945,6 @@ packages: engines: {node: ^8.16.0 || ^10.6.0 || >=11.0.0} os: [darwin] - function-bind@1.1.2: - resolution: {integrity: sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==} - - function.prototype.name@1.1.6: - resolution: {integrity: sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==} - engines: {node: '>= 0.4'} - - functions-have-names@1.2.3: - resolution: {integrity: sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==} - futoin-hkdf@1.5.3: resolution: {integrity: sha512-SewY5KdMpaoCeh7jachEWFsh1nNlaDjNHZXWqL5IGwtpEYHTgkr2+AMCgNwKWkcc0wpSYrZfR7he4WdmHFtDxQ==} engines: {node: '>=8'} @@ -5730,10 +5994,6 @@ packages: resolution: {integrity: sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==} engines: {node: '>=16'} - get-symbol-description@1.0.2: - resolution: {integrity: sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==} - engines: {node: '>= 0.4'} - get-tsconfig@4.7.5: resolution: {integrity: sha512-ZCuZCnlqNzjb4QprAzXKdpp/gh6KTxSJuw3IBsPnV/7fV4NxC9ckB+vPTt8w7fJA0TaSD7c55BR47JD6MEDyDw==} @@ -5791,10 +6051,6 @@ packages: resolution: {integrity: sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==} engines: {node: '>=8'} - globalthis@1.0.4: - resolution: {integrity: sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==} - engines: {node: '>= 0.4'} - globby@11.1.0: resolution: {integrity: sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==} engines: {node: '>=10'} @@ -5802,9 +6058,6 @@ packages: globjoin@0.1.4: resolution: {integrity: sha512-xYfnw62CKG8nLkZBfWbhWwDw02CHty86jfPcc2cr3ZfeuK9ysoVPPEUxf21bAD/rWAgk52SuBrLJlefNy8mvFg==} - gopd@1.0.1: - resolution: {integrity: sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==} - got@11.8.6: resolution: {integrity: sha512-6tfZ91bOr7bOXnK7PRDCGBLa1H4U080YHNaAQ2KsMGlLEzRbk44nsZF2E1IeRc3vtJHPVbKCYgdFbaGO2ljd8g==} engines: {node: '>=10.19.0'} @@ -5880,9 +6133,6 @@ packages: typescript: optional: true - has-bigints@1.0.2: - resolution: {integrity: sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==} - has-flag@3.0.0: resolution: {integrity: sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==} engines: {node: '>=4'} @@ -5891,21 +6141,6 @@ packages: resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==} engines: {node: '>=8'} - has-property-descriptors@1.0.2: - resolution: {integrity: sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==} - - has-proto@1.0.3: - resolution: {integrity: sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==} - engines: {node: '>= 0.4'} - - has-symbols@1.0.3: - resolution: {integrity: sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==} - engines: {node: '>= 0.4'} - - has-tostringtag@1.0.2: - resolution: {integrity: sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==} - engines: {node: '>= 0.4'} - has-unicode@2.0.1: resolution: {integrity: sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==} @@ -5922,10 +6157,6 @@ packages: hash.js@1.1.7: resolution: {integrity: sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==} - hasown@2.0.2: - resolution: {integrity: sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==} - engines: {node: '>= 0.4'} - he@1.2.0: resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} hasBin: true @@ -6119,10 +6350,6 @@ packages: resolution: {integrity: sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==} engines: {node: '>=0.8.19'} - indent-string@4.0.0: - resolution: {integrity: sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==} - engines: {node: '>=8'} - inflight@1.0.6: resolution: {integrity: sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==} deprecated: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful. @@ -6144,10 +6371,6 @@ packages: resolution: {integrity: sha512-M1WuAmb7pn9zdFRtQYk26ZBoY043Sse0wVDdk4Bppr+JOXyQYybdtvK+l9wUibhtjdjvtoiNy8tk+EgsYIUqKg==} engines: {node: '>=12.0.0'} - internal-slot@1.0.7: - resolution: {integrity: sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==} - engines: {node: '>= 0.4'} - intl-segmenter-polyfill@0.4.4: resolution: {integrity: sha512-dIOcmvH+Q1WYGkjMqxPfaCgHEwOegH5UPcd/LLeaeY8aguHadC46MzGb40q8C1LrsuyJxJGKeKqoVtIh9ADRXQ==} @@ -6168,47 +6391,21 @@ packages: iron-webcrypto@1.2.1: resolution: {integrity: sha512-feOM6FaSr6rEABp/eDfVseKyTMDt+KGpeB35SkVn9Tyn0CqvVsY3EwI0v5i8nMHyJnzCIQf7nsy3p41TPkJZhg==} - is-arguments@1.1.1: - resolution: {integrity: sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==} - engines: {node: '>= 0.4'} - - is-array-buffer@3.0.4: - resolution: {integrity: sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==} - engines: {node: '>= 0.4'} - is-arrayish@0.2.1: resolution: {integrity: sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==} - is-async-function@2.0.0: - resolution: {integrity: sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==} - engines: {node: '>= 0.4'} - - is-bigint@1.0.4: - resolution: {integrity: sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==} - is-binary-path@2.1.0: resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==} engines: {node: '>=8'} - is-boolean-object@1.1.2: - resolution: {integrity: sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==} - engines: {node: '>= 0.4'} - is-callable@1.2.7: resolution: {integrity: sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==} engines: {node: '>= 0.4'} - is-core-module@2.13.1: - resolution: {integrity: sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==} - is-data-view@1.0.1: resolution: {integrity: sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==} engines: {node: '>= 0.4'} - is-date-object@1.0.5: - resolution: {integrity: sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==} - engines: {node: '>= 0.4'} - is-directory@0.3.1: resolution: {integrity: sha512-yVChGzahRFvbkscn2MlwGismPO12i9+znNruC5gVEntG3qu0xQMzsGg/JFbrsqDOHtHFPci+V5aP5T9I+yeKqw==} engines: {node: '>=0.10.0'} @@ -6227,9 +6424,6 @@ packages: resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==} engines: {node: '>=0.10.0'} - is-finalizationregistry@1.0.2: - resolution: {integrity: sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==} - is-fullwidth-code-point@1.0.0: resolution: {integrity: sha512-1pqUqRjkhPJ9miNq9SwMfdvi6lBJcd6eFxvfaivQhaH3SgisfiuudvFntdKOmxuee/77l+FPjKrQjWvmPjWrRw==} engines: {node: '>=0.10.0'} @@ -6245,10 +6439,6 @@ packages: is-function@1.0.2: resolution: {integrity: sha512-lw7DUp0aWXYg+CBCN+JKkcE0Q2RayZnSvnZBlwgxHBQhqt5pZNVy4Ri7H9GmmXkdu7LUthszM+Tor1u/2iBcpQ==} - is-generator-function@1.0.10: - resolution: {integrity: sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==} - engines: {node: '>= 0.4'} - is-glob@4.0.3: resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==} engines: {node: '>=0.10.0'} @@ -6269,21 +6459,9 @@ packages: is-lower-case@1.1.3: resolution: {integrity: sha512-+5A1e/WJpLLXZEDlgz4G//WYSHyQBD32qa4Jd3Lw06qQlv3fJHnp3YIHjTQSGzHMgzmVKz2ZP3rBxTHkPw/lxA==} - is-map@2.0.3: - resolution: {integrity: sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==} - engines: {node: '>= 0.4'} - - is-negative-zero@2.0.3: - resolution: {integrity: sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==} - engines: {node: '>= 0.4'} - is-node-process@1.2.0: resolution: {integrity: sha512-Vg4o6/fqPxIjtxgUH5QLJhwZ7gW5diGCVlXpuUfELC62CuxM1iHcRe51f2W1FDy04Ai4KJkagKjx3XaqyfRKXw==} - is-number-object@1.0.7: - resolution: {integrity: sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==} - engines: {node: '>= 0.4'} - is-number@7.0.0: resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==} engines: {node: '>=0.12.0'} @@ -6314,18 +6492,6 @@ packages: is-reference@1.2.1: resolution: {integrity: sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==} - is-regex@1.1.4: - resolution: {integrity: sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==} - engines: {node: '>= 0.4'} - - is-set@2.0.3: - resolution: {integrity: sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==} - engines: {node: '>= 0.4'} - - is-shared-array-buffer@1.0.3: - resolution: {integrity: sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==} - engines: {node: '>= 0.4'} - is-stream@2.0.1: resolution: {integrity: sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==} engines: {node: '>=8'} @@ -6334,18 +6500,6 @@ packages: resolution: {integrity: sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - is-string@1.0.7: - resolution: {integrity: sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==} - engines: {node: '>= 0.4'} - - is-symbol@1.0.4: - resolution: {integrity: sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==} - engines: {node: '>= 0.4'} - - is-typed-array@1.1.13: - resolution: {integrity: sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==} - engines: {node: '>= 0.4'} - is-typedarray@1.0.0: resolution: {integrity: sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==} @@ -6359,17 +6513,6 @@ packages: is-utf8@0.2.1: resolution: {integrity: sha512-rMYPYvCzsXywIsldgLaSoPlw5PfoB/ssr7hY4pLfcodrA5M/eArza1a9VmTiNIBNMjOGr1Ow9mTyU2o69U6U9Q==} - is-weakmap@2.0.2: - resolution: {integrity: sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==} - engines: {node: '>= 0.4'} - - is-weakref@1.0.2: - resolution: {integrity: sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==} - - is-weakset@2.0.3: - resolution: {integrity: sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==} - engines: {node: '>= 0.4'} - is-wsl@1.1.0: resolution: {integrity: sha512-gfygJYZ2gLTDlmbWMI0CE2MwnFzSN/2SZfkMlItC4K/JBlsWVDB0bO6XhqcY13YXE7iMcAJnzTCJjPiTeJJ0Mw==} engines: {node: '>=4'} @@ -6386,12 +6529,6 @@ packages: resolution: {integrity: sha512-jv+8jaWCl0g2lSBkNSVXdzfBA0npK1HGC2KtWM9FumFRoGS94g3NbCCLVnCYHLjp4GrW2KZeeSTMo5ddtznmGw==} engines: {node: '>=18'} - isarray@1.0.0: - resolution: {integrity: sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==} - - isarray@2.0.5: - resolution: {integrity: sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==} - isexe@2.0.0: resolution: {integrity: sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==} @@ -6430,9 +6567,6 @@ packages: resolution: {integrity: sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==} engines: {node: '>=8'} - iterator.prototype@1.1.2: - resolution: {integrity: sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==} - jackspeak@3.4.3: resolution: {integrity: sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==} @@ -7392,10 +7526,6 @@ packages: nullthrows@1.1.1: resolution: {integrity: sha512-2vPPEi+Z7WqML2jZYddDIfy5Dqb0r2fze2zTxNNknZaFpVHU3mFB3R+DWeJWGVx0ecvttSGlJTI+WG+8Z4cDWw==} - number-is-nan@1.0.1: - resolution: {integrity: sha512-4jbtZXNAsfZbAHiiqjLPBiCl16dES1zI4Hpzzxw61Tk+loF+sBDBKx1ICKKKwIqQ7M0mFn1TmkN7euSncWgHiQ==} - engines: {node: '>=0.10.0'} - number-to-bn@1.7.0: resolution: {integrity: sha512-wsJ9gfSz1/s4ZsJN01lyonwuxA1tml6X1yBDnfpMglypcBRFZZkus26EdPSlqS5GJfYddVZa22p3VNb3z5m5Ig==} engines: {node: '>=6.5.0', npm: '>=3'} @@ -7413,45 +7543,13 @@ packages: obj-multiplex@1.0.0: resolution: {integrity: sha512-0GNJAOsHoBHeNTvl5Vt6IWnpUEcc3uSRxzBri7EDyIcMgYvnY2JL2qdeV5zTMjWQX5OHcD5amcW2HFfDh0gjIA==} - object-assign@4.1.1: - resolution: {integrity: sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==} - engines: {node: '>=0.10.0'} - object-inspect@1.13.1: resolution: {integrity: sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==} - object-is@1.1.6: - resolution: {integrity: sha512-F8cZ+KfGlSGi09lJT7/Nd6KJZ9ygtvYC0/UYYLI9nmQKLMnydpB9yvbv9K1uSkEu7FU9vYPmVwLg328tX+ot3Q==} - engines: {node: '>= 0.4'} - - object-keys@1.1.1: - resolution: {integrity: sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==} - engines: {node: '>= 0.4'} - - object.assign@4.1.5: - resolution: {integrity: sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==} - engines: {node: '>= 0.4'} - - object.entries@1.1.8: - resolution: {integrity: sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==} - engines: {node: '>= 0.4'} - - object.fromentries@2.0.8: - resolution: {integrity: sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==} - engines: {node: '>= 0.4'} - object.groupby@1.0.3: resolution: {integrity: sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ==} engines: {node: '>= 0.4'} - object.hasown@1.1.4: - resolution: {integrity: sha512-FZ9LZt9/RHzGySlBARE3VF+gE26TxR38SdmqOqliuTnl9wrKulaQs+4dee1V+Io8VfxqzAfHu6YuRgUy8OHoTg==} - engines: {node: '>= 0.4'} - - object.values@1.2.0: - resolution: {integrity: sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==} - engines: {node: '>= 0.4'} - obliterator@2.0.4: resolution: {integrity: sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==} @@ -7648,9 +7746,6 @@ packages: resolution: {integrity: sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==} engines: {node: '>=12'} - path-parse@1.0.7: - resolution: {integrity: sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==} - path-scurry@1.11.1: resolution: {integrity: sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==} engines: {node: '>=16 || 14 >=14.18'} @@ -7763,10 +7858,6 @@ packages: resolution: {integrity: sha512-M7LhCsdNbNgiLYiP4WjsfLUuFmCfnjdF6jKe2R9NKl4WFN+HZPGHJZ9lnLP7f9ZnKe3U9nuWD0szirmj+migUg==} engines: {node: '>=12.0.0'} - possible-typed-array-names@1.0.0: - resolution: {integrity: sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==} - engines: {node: '>= 0.4'} - postcss-media-query-parser@0.2.3: resolution: {integrity: sha512-3sOlxmbKcSHMjlUXQZKQ06jOswE7oVkXPxmZdoB1r5l0q6gTFTQSHxNxOrCccElbW7dxNytifNEo8qidX2Vsig==} @@ -7947,9 +8038,6 @@ packages: engines: {node: '>=0.4.x'} deprecated: The querystring API is considered Legacy. new code should use the URLSearchParams API instead. - querystringify@2.2.0: - resolution: {integrity: sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==} - queue-microtask@1.2.3: resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==} @@ -8167,10 +8255,6 @@ packages: resolution: {integrity: sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==} engines: {node: '>=8'} - reflect.getprototypeof@1.0.6: - resolution: {integrity: sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==} - engines: {node: '>= 0.4'} - regenerate-unicode-properties@10.1.1: resolution: {integrity: sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==} engines: {node: '>=4'} @@ -8187,10 +8271,6 @@ packages: regenerator-transform@0.15.2: resolution: {integrity: sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg==} - regexp.prototype.flags@1.5.2: - resolution: {integrity: sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==} - engines: {node: '>= 0.4'} - regexpu-core@5.3.2: resolution: {integrity: sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ==} engines: {node: '>=4'} @@ -8347,27 +8427,10 @@ packages: rxjs@7.8.1: resolution: {integrity: sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==} - safe-array-concat@1.1.2: - resolution: {integrity: sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==} - engines: {node: '>=0.4'} - - safe-buffer@5.1.2: - resolution: {integrity: sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==} - - safe-buffer@5.2.1: - resolution: {integrity: sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==} - - safe-regex-test@1.0.3: - resolution: {integrity: sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==} - engines: {node: '>= 0.4'} - safe-stable-stringify@2.4.3: resolution: {integrity: sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g==} engines: {node: '>=10'} - safer-buffer@2.1.2: - resolution: {integrity: sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==} - sax@1.3.0: resolution: {integrity: sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==} @@ -8460,14 +8523,6 @@ packages: set-cookie-parser@2.6.0: resolution: {integrity: sha512-RVnVQxTXuerk653XfuliOxBP81Sf0+qfQE73LIYKcyMYHG94AuH0kgrQpRDuTZnSmjpysHmzxJXKNfa6PjFhyQ==} - set-function-length@1.2.2: - resolution: {integrity: sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==} - engines: {node: '>= 0.4'} - - set-function-name@2.0.2: - resolution: {integrity: sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==} - engines: {node: '>= 0.4'} - set-harmonic-interval@1.0.1: resolution: {integrity: sha512-AhICkFV84tBP1aWqPwLZqFvAwqEoVA9kxNMniGEUvzOlm4vLmOFLiTT3UZ6bziJTy4bOVpzWGTfSCbmaayGx8g==} engines: {node: '>=6.9'} @@ -8506,10 +8561,6 @@ packages: shell-quote@1.8.1: resolution: {integrity: sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==} - side-channel@1.0.6: - resolution: {integrity: sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==} - engines: {node: '>= 0.4'} - siginfo@2.0.0: resolution: {integrity: sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g==} @@ -8693,10 +8744,6 @@ packages: std-env@3.7.0: resolution: {integrity: sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==} - stop-iteration-iterator@1.0.0: - resolution: {integrity: sha512-iCGQj+0l0HOdZ2AEeBADlsRC+vsnDsZsbdSiH1yNSjcfKM7fdpCMfqAL/dwF5BLiw/XhRft/Wax6zQbhq2BcjQ==} - engines: {node: '>= 0.4'} - stoppable@1.1.0: resolution: {integrity: sha512-KXDYZ9dszj6bzvnEMRYvxgeTHU74QBFL54XKtP3nyMuJ81CFYtABZ3bAzL2EdFUaEwJOBOgENyFj3R7oTzDyyw==} engines: {node: '>=4', npm: '>=6'} @@ -8734,21 +8781,6 @@ packages: resolution: {integrity: sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==} engines: {node: '>=12'} - string.prototype.matchall@4.0.11: - resolution: {integrity: sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==} - engines: {node: '>= 0.4'} - - string.prototype.trim@1.2.9: - resolution: {integrity: sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==} - engines: {node: '>= 0.4'} - - string.prototype.trimend@1.0.8: - resolution: {integrity: sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==} - - string.prototype.trimstart@1.0.8: - resolution: {integrity: sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==} - engines: {node: '>= 0.4'} - string_decoder@1.0.3: resolution: {integrity: sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==} @@ -9211,22 +9243,6 @@ packages: type@2.7.2: resolution: {integrity: sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw==} - typed-array-buffer@1.0.2: - resolution: {integrity: sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==} - engines: {node: '>= 0.4'} - - typed-array-byte-length@1.0.1: - resolution: {integrity: sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==} - engines: {node: '>= 0.4'} - - typed-array-byte-offset@1.0.2: - resolution: {integrity: sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==} - engines: {node: '>= 0.4'} - - typed-array-length@1.0.6: - resolution: {integrity: sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==} - engines: {node: '>= 0.4'} - typedarray-to-buffer@3.1.5: resolution: {integrity: sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==} @@ -9257,9 +9273,6 @@ packages: ultron@1.1.1: resolution: {integrity: sha512-UIEXBNeYmKptWH6z8ZnqTeS8fV74zG0/eRU9VGkpzz+LIJNs8W/zM/L+7ctCkRrgbNnnR0xxw4bKOr0cW0N0Og==} - unbox-primitive@1.0.2: - resolution: {integrity: sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==} - uncrypto@0.1.3: resolution: {integrity: sha512-Ql87qFHB3s/De2ClA9e0gsnS6zXG27SkTiSJwjCc9MebbfapQfuPzumMIUMi38ezPZVNFcHI9sUIepeQfw8J8Q==} @@ -9851,27 +9864,12 @@ packages: whatwg-url@5.0.0: resolution: {integrity: sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==} - which-boxed-primitive@1.0.2: - resolution: {integrity: sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==} - - which-builtin-type@1.1.3: - resolution: {integrity: sha512-YmjsSMDBYsM1CaFiayOVT06+KJeXf0o5M/CAd4o1lTadFAtacTUM49zoYxr/oroopFDfhvN6iEcBxUyc3gvKmw==} - engines: {node: '>= 0.4'} - - which-collection@1.0.2: - resolution: {integrity: sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==} - engines: {node: '>= 0.4'} - which-module@1.0.0: resolution: {integrity: sha512-F6+WgncZi/mJDrammbTuHe1q0R5hOXv/mBaiNA2TCNT/LTHusX0V+CJnj9XT8ki5ln2UZyyddDgHfCzyrOH7MQ==} which-module@2.0.1: resolution: {integrity: sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ==} - which-typed-array@1.1.15: - resolution: {integrity: sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==} - engines: {node: '>= 0.4'} - which@1.3.1: resolution: {integrity: sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==} hasBin: true @@ -13407,31 +13405,165 @@ snapshots: '@socket.io/component-emitter@3.1.2': {} - '@stablelib/aead@1.0.1': {} + '@socketregistry/aggregate-error@1.0.2': {} - '@stablelib/binary@1.0.1': - dependencies: - '@stablelib/int': 1.0.1 + '@socketregistry/array-buffer-byte-length@1.0.2': {} - '@stablelib/bytes@1.0.1': {} + '@socketregistry/array-flatten@1.0.2': {} - '@stablelib/chacha20poly1305@1.0.1': - dependencies: - '@stablelib/aead': 1.0.1 - '@stablelib/binary': 1.0.1 - '@stablelib/chacha': 1.0.1 - '@stablelib/constant-time': 1.0.1 - '@stablelib/poly1305': 1.0.1 - '@stablelib/wipe': 1.0.1 + '@socketregistry/array-includes@1.0.2': {} - '@stablelib/chacha@1.0.1': - dependencies: - '@stablelib/binary': 1.0.1 - '@stablelib/wipe': 1.0.1 + '@socketregistry/array.prototype.findlast@1.0.2': {} - '@stablelib/constant-time@1.0.1': {} + '@socketregistry/array.prototype.findlastindex@1.0.2': {} - '@stablelib/ed25519@1.0.3': + '@socketregistry/array.prototype.flat@1.0.2': {} + + '@socketregistry/array.prototype.flatmap@1.0.2': {} + + '@socketregistry/arraybuffer.prototype.slice@1.0.2': {} + + '@socketregistry/available-typed-arrays@1.0.2': {} + + '@socketregistry/deep-equal@1.0.3': {} + + '@socketregistry/define-properties@1.0.2': {} + + '@socketregistry/es-define-property@1.0.2': {} + + '@socketregistry/es-set-tostringtag@1.0.2': {} + + '@socketregistry/es6-symbol@1.0.2': {} + + '@socketregistry/function-bind@1.0.2': {} + + '@socketregistry/function.prototype.name@1.0.2': {} + + '@socketregistry/get-symbol-description@1.0.2': {} + + '@socketregistry/globalthis@1.0.2': {} + + '@socketregistry/gopd@1.0.2': {} + + '@socketregistry/has-property-descriptors@1.0.2': {} + + '@socketregistry/has-proto@1.0.2': {} + + '@socketregistry/has-symbols@1.0.2': {} + + '@socketregistry/hasown@1.0.2': {} + + '@socketregistry/indent-string@1.0.2': {} + + '@socketregistry/internal-slot@1.0.2': {} + + '@socketregistry/is-arguments@1.0.2': {} + + '@socketregistry/is-array-buffer@1.0.2': {} + + '@socketregistry/is-core-module@1.0.2': {} + + '@socketregistry/is-date-object@1.0.2': {} + + '@socketregistry/is-generator-function@1.0.2': {} + + '@socketregistry/is-negative-zero@1.0.2': {} + + '@socketregistry/is-regex@1.0.2': {} + + '@socketregistry/is-shared-array-buffer@1.0.2': {} + + '@socketregistry/is-string@1.0.2': {} + + '@socketregistry/is-symbol@1.0.2': {} + + '@socketregistry/is-typed-array@1.0.2': {} + + '@socketregistry/is-weakref@1.0.2': {} + + '@socketregistry/isarray@1.0.2': {} + + '@socketregistry/iterator.prototype@1.0.2': {} + + '@socketregistry/number-is-nan@1.0.2': {} + + '@socketregistry/object-assign@1.0.1': {} + + '@socketregistry/object-keys@1.0.2': {} + + '@socketregistry/object.assign@1.0.2': {} + + '@socketregistry/object.entries@1.0.2': {} + + '@socketregistry/object.fromentries@1.0.2': {} + + '@socketregistry/object.hasown@1.0.2': {} + + '@socketregistry/object.values@1.0.2': {} + + '@socketregistry/path-parse@1.0.2': {} + + '@socketregistry/querystringify@1.0.2': {} + + '@socketregistry/regexp.prototype.flags@1.0.2': {} + + '@socketregistry/safe-array-concat@1.0.2': {} + + '@socketregistry/safe-buffer@1.0.2': {} + + '@socketregistry/safe-regex-test@1.0.2': {} + + '@socketregistry/safer-buffer@1.0.2': {} + + '@socketregistry/set-function-length@1.0.2': {} + + '@socketregistry/side-channel@1.0.2': {} + + '@socketregistry/string.prototype.matchall@1.0.2': {} + + '@socketregistry/string.prototype.trim@1.0.2': {} + + '@socketregistry/string.prototype.trimend@1.0.2': {} + + '@socketregistry/string.prototype.trimstart@1.0.2': {} + + '@socketregistry/typed-array-buffer@1.0.2': {} + + '@socketregistry/typed-array-byte-length@1.0.2': {} + + '@socketregistry/typed-array-byte-offset@1.0.2': {} + + '@socketregistry/typed-array-length@1.0.2': {} + + '@socketregistry/unbox-primitive@1.0.2': {} + + '@socketregistry/which-typed-array@1.0.2': {} + + '@stablelib/aead@1.0.1': {} + + '@stablelib/binary@1.0.1': + dependencies: + '@stablelib/int': 1.0.1 + + '@stablelib/bytes@1.0.1': {} + + '@stablelib/chacha20poly1305@1.0.1': + dependencies: + '@stablelib/aead': 1.0.1 + '@stablelib/binary': 1.0.1 + '@stablelib/chacha': 1.0.1 + '@stablelib/constant-time': 1.0.1 + '@stablelib/poly1305': 1.0.1 + '@stablelib/wipe': 1.0.1 + + '@stablelib/chacha@1.0.1': + dependencies: + '@stablelib/binary': 1.0.1 + '@stablelib/wipe': 1.0.1 + + '@stablelib/constant-time@1.0.1': {} + + '@stablelib/ed25519@1.0.3': dependencies: '@stablelib/random': 1.0.2 '@stablelib/sha512': 1.0.1 @@ -14717,11 +14849,6 @@ snapshots: transitivePeerDependencies: - supports-color - aggregate-error@3.1.0: - dependencies: - clean-stack: 2.2.0 - indent-string: 4.0.0 - ajv-formats@2.1.1(ajv@8.14.0): optionalDependencies: ajv: 8.14.0 @@ -14819,88 +14946,29 @@ snapshots: aria-query@5.1.3: dependencies: - deep-equal: 2.2.3 + deep-equal: '@socketregistry/deep-equal@1.0.3' aria-query@5.3.0: dependencies: dequal: 2.0.3 - array-buffer-byte-length@1.0.1: - dependencies: - call-bind: 1.0.7 - is-array-buffer: 3.0.4 - - array-flatten@1.1.1: {} - - array-includes@3.1.8: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-object-atoms: 1.0.0 - get-intrinsic: 1.2.4 - is-string: 1.0.7 - array-union@2.1.0: {} - array.prototype.findlast@1.2.5: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-errors: 1.3.0 - es-object-atoms: 1.0.0 - es-shim-unscopables: 1.0.2 - - array.prototype.findlastindex@1.2.5: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-errors: 1.3.0 - es-object-atoms: 1.0.0 - es-shim-unscopables: 1.0.2 - - array.prototype.flat@1.3.2: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-shim-unscopables: 1.0.2 - - array.prototype.flatmap@1.3.2: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-shim-unscopables: 1.0.2 - array.prototype.toreversed@1.1.2: dependencies: call-bind: 1.0.7 - define-properties: 1.2.1 + define-properties: '@socketregistry/define-properties@1.0.2' es-abstract: 1.23.3 es-shim-unscopables: 1.0.2 array.prototype.tosorted@1.1.3: dependencies: call-bind: 1.0.7 - define-properties: 1.2.1 + define-properties: '@socketregistry/define-properties@1.0.2' es-abstract: 1.23.3 es-errors: 1.3.0 es-shim-unscopables: 1.0.2 - arraybuffer.prototype.slice@1.0.3: - dependencies: - array-buffer-byte-length: 1.0.1 - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-errors: 1.3.0 - get-intrinsic: 1.2.4 - is-array-buffer: 3.0.4 - is-shared-array-buffer: 1.0.3 - arrify@1.0.1: {} as-table@1.0.55: @@ -14911,7 +14979,7 @@ snapshots: asn1@0.2.6: dependencies: - safer-buffer: 2.1.2 + safer-buffer: '@socketregistry/safer-buffer@1.0.2' assert-plus@1.0.0: {} @@ -14939,10 +15007,6 @@ snapshots: atomic-sleep@1.0.0: {} - available-typed-arrays@1.0.7: - dependencies: - possible-typed-array-names: 1.0.0 - aws-sign2@0.7.0: {} aws4@1.13.0: {} @@ -15024,7 +15088,7 @@ snapshots: base-x@3.0.9: dependencies: - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' base64-js@1.5.1: {} @@ -15114,7 +15178,7 @@ snapshots: create-hash: 1.2.0 evp_bytestokey: 1.0.3 inherits: 2.0.4 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' browserslist@4.23.0: dependencies: @@ -15138,7 +15202,7 @@ snapshots: dependencies: bs58: 4.0.1 create-hash: 1.2.0 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' bser@2.1.1: dependencies: @@ -15195,11 +15259,11 @@ snapshots: call-bind@1.0.7: dependencies: - es-define-property: 1.0.0 + es-define-property: '@socketregistry/es-define-property@1.0.2' es-errors: 1.3.0 - function-bind: 1.1.2 + function-bind: '@socketregistry/function-bind@1.0.2' get-intrinsic: 1.2.4 - set-function-length: 1.2.2 + set-function-length: '@socketregistry/set-function-length@1.0.2' caller-callsite@2.0.0: dependencies: @@ -15250,7 +15314,7 @@ snapshots: capnp-ts@0.7.0: dependencies: debug: 4.3.6 - tslib: 2.6.2 + tslib: 2.6.3 transitivePeerDependencies: - supports-color @@ -15405,7 +15469,7 @@ snapshots: cipher-base@1.0.4: dependencies: inherits: 2.0.4 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' citty@0.1.6: dependencies: @@ -15413,8 +15477,6 @@ snapshots: class-is@1.1.0: {} - clean-stack@2.2.0: {} - cli-boxes@2.2.1: {} cli-cursor@3.1.0: @@ -15528,7 +15590,7 @@ snapshots: compressible: 2.0.18 debug: 2.6.9 on-headers: 1.0.2 - safe-buffer: 5.1.2 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' vary: 1.1.2 transitivePeerDependencies: - supports-color @@ -15571,7 +15633,7 @@ snapshots: content-disposition@0.5.4: dependencies: - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' content-hash@2.5.2: dependencies: @@ -15611,7 +15673,7 @@ snapshots: cors@2.8.5: dependencies: - object-assign: 4.1.1 + object-assign: '@socketregistry/object-assign@1.0.1' vary: 1.1.2 cosmiconfig@5.2.1: @@ -15654,7 +15716,7 @@ snapshots: create-hash: 1.2.0 inherits: 2.0.4 ripemd160: 2.0.2 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' sha.js: 2.4.11 create-require@1.1.1: {} @@ -15692,7 +15754,7 @@ snapshots: blakejs: 1.2.1 bs58: 4.0.1 ripemd160-min: 0.0.6 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' sha3: 2.1.4 css-color-keywords@1.0.0: {} @@ -15853,27 +15915,6 @@ snapshots: deep-eql@5.0.2: {} - deep-equal@2.2.3: - dependencies: - array-buffer-byte-length: 1.0.1 - call-bind: 1.0.7 - es-get-iterator: 1.1.3 - get-intrinsic: 1.2.4 - is-arguments: 1.1.1 - is-array-buffer: 3.0.4 - is-date-object: 1.0.5 - is-regex: 1.1.4 - is-shared-array-buffer: 1.0.3 - isarray: 2.0.5 - object-is: 1.1.6 - object-keys: 1.1.1 - object.assign: 4.1.5 - regexp.prototype.flags: 1.5.2 - side-channel: 1.0.6 - which-boxed-primitive: 1.0.2 - which-collection: 1.0.2 - which-typed-array: 1.1.15 - deep-is@0.1.4: {} deep-object-diff@1.1.9: {} @@ -15886,20 +15927,8 @@ snapshots: defer-to-connect@2.0.1: {} - define-data-property@1.1.4: - dependencies: - es-define-property: 1.0.0 - es-errors: 1.3.0 - gopd: 1.0.1 - define-lazy-prop@2.0.0: {} - define-properties@1.2.1: - dependencies: - define-data-property: 1.1.4 - has-property-descriptors: 1.0.2 - object-keys: 1.1.1 - defu@6.1.4: {} delayed-stream@1.0.0: {} @@ -15988,7 +16017,7 @@ snapshots: dot-case@3.0.4: dependencies: no-case: 3.0.4 - tslib: 2.6.2 + tslib: 2.6.3 dotenv@16.4.5: {} @@ -16012,7 +16041,7 @@ snapshots: ecc-jsbn@0.1.2: dependencies: jsbn: 0.1.1 - safer-buffer: 2.1.2 + safer-buffer: '@socketregistry/safer-buffer@1.0.2' eciesjs@0.3.18: dependencies: @@ -16122,87 +16151,71 @@ snapshots: es-abstract@1.23.3: dependencies: - array-buffer-byte-length: 1.0.1 - arraybuffer.prototype.slice: 1.0.3 - available-typed-arrays: 1.0.7 + array-buffer-byte-length: '@socketregistry/array-buffer-byte-length@1.0.2' + arraybuffer.prototype.slice: '@socketregistry/arraybuffer.prototype.slice@1.0.2' + available-typed-arrays: '@socketregistry/available-typed-arrays@1.0.2' call-bind: 1.0.7 data-view-buffer: 1.0.1 data-view-byte-length: 1.0.1 data-view-byte-offset: 1.0.0 - es-define-property: 1.0.0 + es-define-property: '@socketregistry/es-define-property@1.0.2' es-errors: 1.3.0 es-object-atoms: 1.0.0 - es-set-tostringtag: 2.0.3 + es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.2' es-to-primitive: 1.2.1 - function.prototype.name: 1.1.6 + function.prototype.name: '@socketregistry/function.prototype.name@1.0.2' get-intrinsic: 1.2.4 - get-symbol-description: 1.0.2 - globalthis: 1.0.4 - gopd: 1.0.1 - has-property-descriptors: 1.0.2 - has-proto: 1.0.3 - has-symbols: 1.0.3 - hasown: 2.0.2 - internal-slot: 1.0.7 - is-array-buffer: 3.0.4 + get-symbol-description: '@socketregistry/get-symbol-description@1.0.2' + globalthis: '@socketregistry/globalthis@1.0.2' + gopd: '@socketregistry/gopd@1.0.2' + has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.2' + has-proto: '@socketregistry/has-proto@1.0.2' + has-symbols: '@socketregistry/has-symbols@1.0.2' + hasown: '@socketregistry/hasown@1.0.2' + internal-slot: '@socketregistry/internal-slot@1.0.2' + is-array-buffer: '@socketregistry/is-array-buffer@1.0.2' is-callable: 1.2.7 is-data-view: 1.0.1 - is-negative-zero: 2.0.3 - is-regex: 1.1.4 - is-shared-array-buffer: 1.0.3 - is-string: 1.0.7 - is-typed-array: 1.1.13 - is-weakref: 1.0.2 + is-negative-zero: '@socketregistry/is-negative-zero@1.0.2' + is-regex: '@socketregistry/is-regex@1.0.2' + is-shared-array-buffer: '@socketregistry/is-shared-array-buffer@1.0.2' + is-string: '@socketregistry/is-string@1.0.2' + is-typed-array: '@socketregistry/is-typed-array@1.0.2' + is-weakref: '@socketregistry/is-weakref@1.0.2' object-inspect: 1.13.1 - object-keys: 1.1.1 - object.assign: 4.1.5 - regexp.prototype.flags: 1.5.2 - safe-array-concat: 1.1.2 - safe-regex-test: 1.0.3 - string.prototype.trim: 1.2.9 - string.prototype.trimend: 1.0.8 - string.prototype.trimstart: 1.0.8 - typed-array-buffer: 1.0.2 - typed-array-byte-length: 1.0.1 - typed-array-byte-offset: 1.0.2 - typed-array-length: 1.0.6 - unbox-primitive: 1.0.2 - which-typed-array: 1.1.15 - - es-define-property@1.0.0: - dependencies: - get-intrinsic: 1.2.4 + object-keys: '@socketregistry/object-keys@1.0.2' + object.assign: '@socketregistry/object.assign@1.0.2' + regexp.prototype.flags: '@socketregistry/regexp.prototype.flags@1.0.2' + safe-array-concat: '@socketregistry/safe-array-concat@1.0.2' + safe-regex-test: '@socketregistry/safe-regex-test@1.0.2' + string.prototype.trim: '@socketregistry/string.prototype.trim@1.0.2' + string.prototype.trimend: '@socketregistry/string.prototype.trimend@1.0.2' + string.prototype.trimstart: '@socketregistry/string.prototype.trimstart@1.0.2' + typed-array-buffer: '@socketregistry/typed-array-buffer@1.0.2' + typed-array-byte-length: '@socketregistry/typed-array-byte-length@1.0.2' + typed-array-byte-offset: '@socketregistry/typed-array-byte-offset@1.0.2' + typed-array-length: '@socketregistry/typed-array-length@1.0.2' + unbox-primitive: '@socketregistry/unbox-primitive@1.0.2' + which-typed-array: '@socketregistry/which-typed-array@1.0.2' es-errors@1.3.0: {} - es-get-iterator@1.1.3: - dependencies: - call-bind: 1.0.7 - get-intrinsic: 1.2.4 - has-symbols: 1.0.3 - is-arguments: 1.1.1 - is-map: 2.0.3 - is-set: 2.0.3 - is-string: 1.0.7 - isarray: 2.0.5 - stop-iteration-iterator: 1.0.0 - es-iterator-helpers@1.0.19: dependencies: call-bind: 1.0.7 - define-properties: 1.2.1 + define-properties: '@socketregistry/define-properties@1.0.2' es-abstract: 1.23.3 es-errors: 1.3.0 - es-set-tostringtag: 2.0.3 - function-bind: 1.1.2 + es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.2' + function-bind: '@socketregistry/function-bind@1.0.2' get-intrinsic: 1.2.4 - globalthis: 1.0.4 - has-property-descriptors: 1.0.2 - has-proto: 1.0.3 - has-symbols: 1.0.3 - internal-slot: 1.0.7 - iterator.prototype: 1.1.2 - safe-array-concat: 1.1.2 + globalthis: '@socketregistry/globalthis@1.0.2' + has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.2' + has-proto: '@socketregistry/has-proto@1.0.2' + has-symbols: '@socketregistry/has-symbols@1.0.2' + internal-slot: '@socketregistry/internal-slot@1.0.2' + iterator.prototype: '@socketregistry/iterator.prototype@1.0.2' + safe-array-concat: '@socketregistry/safe-array-concat@1.0.2' es-module-lexer@1.5.4: {} @@ -16210,26 +16223,20 @@ snapshots: dependencies: es-errors: 1.3.0 - es-set-tostringtag@2.0.3: - dependencies: - get-intrinsic: 1.2.4 - has-tostringtag: 1.0.2 - hasown: 2.0.2 - es-shim-unscopables@1.0.2: dependencies: - hasown: 2.0.2 + hasown: '@socketregistry/hasown@1.0.2' es-to-primitive@1.2.1: dependencies: is-callable: 1.2.7 - is-date-object: 1.0.5 - is-symbol: 1.0.4 + is-date-object: '@socketregistry/is-date-object@1.0.2' + is-symbol: '@socketregistry/is-symbol@1.0.2' es5-ext@0.10.64: dependencies: es6-iterator: 2.0.3 - es6-symbol: 3.1.4 + es6-symbol: '@socketregistry/es6-symbol@1.0.2' esniff: 2.0.1 next-tick: 1.1.0 @@ -16237,15 +16244,10 @@ snapshots: dependencies: d: 1.0.2 es5-ext: 0.10.64 - es6-symbol: 3.1.4 + es6-symbol: '@socketregistry/es6-symbol@1.0.2' es6-promise@4.2.8: {} - es6-symbol@3.1.4: - dependencies: - d: 1.0.2 - ext: 1.7.0 - esbuild@0.17.19: optionalDependencies: '@esbuild/android-arm': 0.17.19 @@ -16312,8 +16314,8 @@ snapshots: confusing-browser-globals: 1.0.11 eslint: 8.50.0 eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) - object.assign: 4.1.5 - object.entries: 1.1.8 + object.assign: '@socketregistry/object.assign@1.0.2' + object.entries: '@socketregistry/object.entries@1.0.2' semver: 6.3.1 eslint-config-airbnb-typescript@17.1.0(@typescript-eslint/eslint-plugin@6.21.0(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0)(typescript@5.4.5))(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0): @@ -16332,8 +16334,8 @@ snapshots: eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) - object.assign: 4.1.5 - object.entries: 1.1.8 + object.assign: '@socketregistry/object.assign@1.0.2' + object.entries: '@socketregistry/object.entries@1.0.2' eslint-config-next@13.5.6(eslint@8.50.0)(typescript@5.4.5): dependencies: @@ -16360,7 +16362,7 @@ snapshots: eslint-import-resolver-node@0.3.9: dependencies: debug: 3.2.7 - is-core-module: 2.13.1 + is-core-module: '@socketregistry/is-core-module@1.0.2' resolve: 1.22.8 transitivePeerDependencies: - supports-color @@ -16374,7 +16376,7 @@ snapshots: eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 - is-core-module: 2.13.1 + is-core-module: '@socketregistry/is-core-module@1.0.2' is-glob: 4.0.3 transitivePeerDependencies: - '@typescript-eslint/parser' @@ -16395,22 +16397,22 @@ snapshots: eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0): dependencies: - array-includes: 3.1.8 - array.prototype.findlastindex: 1.2.5 - array.prototype.flat: 1.3.2 - array.prototype.flatmap: 1.3.2 + array-includes: '@socketregistry/array-includes@1.0.2' + array.prototype.findlastindex: '@socketregistry/array.prototype.findlastindex@1.0.2' + array.prototype.flat: '@socketregistry/array.prototype.flat@1.0.2' + array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.2' debug: 3.2.7 doctrine: 2.1.0 eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) - hasown: 2.0.2 - is-core-module: 2.13.1 + hasown: '@socketregistry/hasown@1.0.2' + is-core-module: '@socketregistry/is-core-module@1.0.2' is-glob: 4.0.3 minimatch: 3.1.2 - object.fromentries: 2.0.8 + object.fromentries: '@socketregistry/object.fromentries@1.0.2' object.groupby: 1.0.3 - object.values: 1.2.0 + object.values: '@socketregistry/object.values@1.0.2' semver: 6.3.1 tsconfig-paths: 3.15.0 optionalDependencies: @@ -16424,8 +16426,8 @@ snapshots: dependencies: '@babel/runtime': 7.24.6 aria-query: 5.3.0 - array-includes: 3.1.8 - array.prototype.flatmap: 1.3.2 + array-includes: '@socketregistry/array-includes@1.0.2' + array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.2' ast-types-flow: 0.0.8 axe-core: 4.7.0 axobject-query: 3.2.1 @@ -16433,12 +16435,12 @@ snapshots: emoji-regex: 9.2.2 es-iterator-helpers: 1.0.19 eslint: 8.50.0 - hasown: 2.0.2 + hasown: '@socketregistry/hasown@1.0.2' jsx-ast-utils: 3.3.5 language-tags: 1.0.9 minimatch: 3.1.2 - object.entries: 1.1.8 - object.fromentries: 2.0.8 + object.entries: '@socketregistry/object.entries@1.0.2' + object.fromentries: '@socketregistry/object.fromentries@1.0.2' eslint-plugin-prettier@5.1.3(@types/eslint@9.6.0)(eslint-config-prettier@9.1.0(eslint@8.50.0))(eslint@8.50.0)(prettier@3.0.3): dependencies: @@ -16456,9 +16458,9 @@ snapshots: eslint-plugin-react@7.34.1(eslint@8.50.0): dependencies: - array-includes: 3.1.8 - array.prototype.findlast: 1.2.5 - array.prototype.flatmap: 1.3.2 + array-includes: '@socketregistry/array-includes@1.0.2' + array.prototype.findlast: '@socketregistry/array.prototype.findlast@1.0.2' + array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.2' array.prototype.toreversed: 1.1.2 array.prototype.tosorted: 1.1.3 doctrine: 2.1.0 @@ -16467,14 +16469,14 @@ snapshots: estraverse: 5.3.0 jsx-ast-utils: 3.3.5 minimatch: 3.1.2 - object.entries: 1.1.8 - object.fromentries: 2.0.8 - object.hasown: 1.1.4 - object.values: 1.2.0 + object.entries: '@socketregistry/object.entries@1.0.2' + object.fromentries: '@socketregistry/object.fromentries@1.0.2' + object.hasown: '@socketregistry/object.hasown@1.0.2' + object.values: '@socketregistry/object.values@1.0.2' prop-types: 15.8.1 resolve: 2.0.0-next.5 semver: 6.3.1 - string.prototype.matchall: 4.0.11 + string.prototype.matchall: '@socketregistry/string.prototype.matchall@1.0.2' eslint-plugin-testing-library@6.2.2(eslint@8.50.0)(typescript@5.4.5): dependencies: @@ -16656,7 +16658,7 @@ snapshots: keccak: 3.0.4 pbkdf2: 3.1.2 randombytes: 2.1.0 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' scrypt-js: 3.0.1 secp256k1: 4.0.3 setimmediate: 1.0.5 @@ -16780,7 +16782,7 @@ snapshots: evp_bytestokey@1.0.3: dependencies: md5.js: 1.3.5 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' execa@5.1.1: dependencies: @@ -16822,7 +16824,7 @@ snapshots: express@4.19.2: dependencies: accepts: 1.3.8 - array-flatten: 1.1.1 + array-flatten: '@socketregistry/array-flatten@1.0.2' body-parser: 1.20.2 content-disposition: 0.5.4 content-type: 1.0.5 @@ -16844,7 +16846,7 @@ snapshots: proxy-addr: 2.0.7 qs: 6.11.0 range-parser: 1.2.1 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' send: 0.18.0 serve-static: 1.15.0 setprototypeof: 1.2.0 @@ -16855,10 +16857,6 @@ snapshots: transitivePeerDependencies: - supports-color - ext@1.7.0: - dependencies: - type: 2.7.2 - extend@3.0.2: {} extension-port-stream@3.0.0: @@ -17022,10 +17020,6 @@ snapshots: optionalDependencies: debug: 4.3.4(supports-color@5.5.0) - for-each@0.3.3: - dependencies: - is-callable: 1.2.7 - foreground-child@3.3.0: dependencies: cross-spawn: 7.0.3 @@ -17113,17 +17107,6 @@ snapshots: fsevents@2.3.3: optional: true - function-bind@1.1.2: {} - - function.prototype.name@1.1.6: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - functions-have-names: 1.2.3 - - functions-have-names@1.2.3: {} - futoin-hkdf@1.5.3: {} gauge@3.0.2: @@ -17132,7 +17115,7 @@ snapshots: color-support: 1.1.3 console-control-strings: 1.1.0 has-unicode: 2.0.1 - object-assign: 4.1.1 + object-assign: '@socketregistry/object-assign@1.0.1' signal-exit: 3.0.7 string-width: 4.2.3 strip-ansi: 6.0.1 @@ -17149,10 +17132,10 @@ snapshots: get-intrinsic@1.2.4: dependencies: es-errors: 1.3.0 - function-bind: 1.1.2 - has-proto: 1.0.3 - has-symbols: 1.0.3 - hasown: 2.0.2 + function-bind: '@socketregistry/function-bind@1.0.2' + has-proto: '@socketregistry/has-proto@1.0.2' + has-symbols: '@socketregistry/has-symbols@1.0.2' + hasown: '@socketregistry/hasown@1.0.2' get-nonce@1.0.1: {} @@ -17171,12 +17154,6 @@ snapshots: get-stream@8.0.1: {} - get-symbol-description@1.0.2: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - get-intrinsic: 1.2.4 - get-tsconfig@4.7.5: dependencies: resolve-pkg-maps: 1.0.0 @@ -17260,11 +17237,6 @@ snapshots: dependencies: type-fest: 0.20.2 - globalthis@1.0.4: - dependencies: - define-properties: 1.2.1 - gopd: 1.0.1 - globby@11.1.0: dependencies: array-union: 2.1.0 @@ -17276,10 +17248,6 @@ snapshots: globjoin@0.1.4: {} - gopd@1.0.1: - dependencies: - get-intrinsic: 1.2.4 - got@11.8.6: dependencies: '@sindresorhus/is': 4.6.0 @@ -17415,7 +17383,7 @@ snapshots: '@types/bn.js': 5.1.5 '@types/lru-cache': 5.1.1 adm-zip: 0.4.16 - aggregate-error: 3.1.0 + aggregate-error: '@socketregistry/aggregate-error@1.0.2' ansi-escapes: 4.3.2 boxen: 5.1.2 chalk: 2.4.2 @@ -17456,31 +17424,17 @@ snapshots: - supports-color - utf-8-validate - has-bigints@1.0.2: {} - has-flag@3.0.0: {} has-flag@4.0.0: {} - has-property-descriptors@1.0.2: - dependencies: - es-define-property: 1.0.0 - - has-proto@1.0.3: {} - - has-symbols@1.0.3: {} - - has-tostringtag@1.0.2: - dependencies: - has-symbols: 1.0.3 - has-unicode@2.0.1: {} hash-base@3.1.0: dependencies: inherits: 2.0.4 readable-stream: 3.6.2 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' hash-test-vectors@1.3.2: {} @@ -17494,10 +17448,6 @@ snapshots: inherits: 2.0.4 minimalistic-assert: 1.0.1 - hasown@2.0.2: - dependencies: - function-bind: 1.1.2 - he@1.2.0: {} header-case@1.0.1: @@ -17647,11 +17597,11 @@ snapshots: iconv-lite@0.4.24: dependencies: - safer-buffer: 2.1.2 + safer-buffer: '@socketregistry/safer-buffer@1.0.2' iconv-lite@0.6.3: dependencies: - safer-buffer: 2.1.2 + safer-buffer: '@socketregistry/safer-buffer@1.0.2' idb-keyval@6.2.1: {} @@ -17693,8 +17643,6 @@ snapshots: imurmurhash@0.1.4: {} - indent-string@4.0.0: {} - inflight@1.0.6: dependencies: once: 1.4.0 @@ -17729,12 +17677,6 @@ snapshots: through: 2.3.8 wrap-ansi: 6.2.0 - internal-slot@1.0.7: - dependencies: - es-errors: 1.3.0 - hasown: 2.0.2 - side-channel: 1.0.6 - intl-segmenter-polyfill@0.4.4: dependencies: fast-text-encoding: 1.0.6 @@ -17753,48 +17695,17 @@ snapshots: iron-webcrypto@1.2.1: {} - is-arguments@1.1.1: - dependencies: - call-bind: 1.0.7 - has-tostringtag: 1.0.2 - - is-array-buffer@3.0.4: - dependencies: - call-bind: 1.0.7 - get-intrinsic: 1.2.4 - is-arrayish@0.2.1: {} - is-async-function@2.0.0: - dependencies: - has-tostringtag: 1.0.2 - - is-bigint@1.0.4: - dependencies: - has-bigints: 1.0.2 - is-binary-path@2.1.0: dependencies: binary-extensions: 2.3.0 - is-boolean-object@1.1.2: - dependencies: - call-bind: 1.0.7 - has-tostringtag: 1.0.2 - is-callable@1.2.7: {} - is-core-module@2.13.1: - dependencies: - hasown: 2.0.2 - is-data-view@1.0.1: dependencies: - is-typed-array: 1.1.13 - - is-date-object@1.0.5: - dependencies: - has-tostringtag: 1.0.2 + is-typed-array: '@socketregistry/is-typed-array@1.0.2' is-directory@0.3.1: {} @@ -17804,13 +17715,9 @@ snapshots: is-extglob@2.1.1: {} - is-finalizationregistry@1.0.2: - dependencies: - call-bind: 1.0.7 - is-fullwidth-code-point@1.0.0: dependencies: - number-is-nan: 1.0.1 + number-is-nan: '@socketregistry/number-is-nan@1.0.2' is-fullwidth-code-point@2.0.0: {} @@ -17818,10 +17725,6 @@ snapshots: is-function@1.0.2: {} - is-generator-function@1.0.10: - dependencies: - has-tostringtag: 1.0.2 - is-glob@4.0.3: dependencies: is-extglob: 2.1.1 @@ -17838,16 +17741,8 @@ snapshots: dependencies: lower-case: 1.1.4 - is-map@2.0.3: {} - - is-negative-zero@2.0.3: {} - is-node-process@1.2.0: {} - is-number-object@1.0.7: - dependencies: - has-tostringtag: 1.0.2 - is-number@7.0.0: {} is-path-inside@3.0.3: {} @@ -17868,33 +17763,10 @@ snapshots: dependencies: '@types/estree': 1.0.5 - is-regex@1.1.4: - dependencies: - call-bind: 1.0.7 - has-tostringtag: 1.0.2 - - is-set@2.0.3: {} - - is-shared-array-buffer@1.0.3: - dependencies: - call-bind: 1.0.7 - is-stream@2.0.1: {} is-stream@3.0.0: {} - is-string@1.0.7: - dependencies: - has-tostringtag: 1.0.2 - - is-symbol@1.0.4: - dependencies: - has-symbols: 1.0.3 - - is-typed-array@1.1.13: - dependencies: - which-typed-array: 1.1.15 - is-typedarray@1.0.0: {} is-unicode-supported@0.1.0: {} @@ -17905,17 +17777,6 @@ snapshots: is-utf8@0.2.1: {} - is-weakmap@2.0.2: {} - - is-weakref@1.0.2: - dependencies: - call-bind: 1.0.7 - - is-weakset@2.0.3: - dependencies: - call-bind: 1.0.7 - get-intrinsic: 1.2.4 - is-wsl@1.1.0: {} is-wsl@2.2.0: @@ -17930,10 +17791,6 @@ snapshots: dependencies: system-architecture: 0.1.0 - isarray@1.0.0: {} - - isarray@2.0.5: {} - isexe@2.0.0: {} iso-639-1@2.1.15: {} @@ -17978,14 +17835,6 @@ snapshots: html-escaper: 2.0.2 istanbul-lib-report: 3.0.1 - iterator.prototype@1.1.2: - dependencies: - define-properties: 1.2.1 - get-intrinsic: 1.2.4 - has-symbols: 1.0.3 - reflect.getprototypeof: 1.0.6 - set-function-name: 2.0.2 - jackspeak@3.4.3: dependencies: '@isaacs/cliui': 8.0.2 @@ -18240,10 +18089,10 @@ snapshots: jsx-ast-utils@3.3.5: dependencies: - array-includes: 3.1.8 - array.prototype.flat: 1.3.2 - object.assign: 4.1.5 - object.values: 1.2.0 + array-includes: '@socketregistry/array-includes@1.0.2' + array.prototype.flat: '@socketregistry/array.prototype.flat@1.0.2' + object.assign: '@socketregistry/object.assign@1.0.2' + object.values: '@socketregistry/object.values@1.0.2' keccak@3.0.4: dependencies: @@ -18520,7 +18369,7 @@ snapshots: dependencies: hash-base: 3.1.0 inherits: 2.0.4 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' mdn-data@2.0.14: {} @@ -18833,7 +18682,7 @@ snapshots: minipass@2.9.0: dependencies: - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' yallist: 3.1.1 minipass@3.3.6: @@ -19074,7 +18923,7 @@ snapshots: no-case@3.0.4: dependencies: lower-case: 2.0.2 - tslib: 2.6.2 + tslib: 2.6.3 nocache@3.0.4: {} @@ -19142,7 +18991,7 @@ snapshots: normalize-package-data@3.0.3: dependencies: hosted-git-info: 4.1.0 - is-core-module: 2.13.1 + is-core-module: '@socketregistry/is-core-module@1.0.2' semver: 7.6.2 validate-npm-package-license: 3.0.4 @@ -19184,8 +19033,6 @@ snapshots: nullthrows@1.1.1: {} - number-is-nan@1.0.1: {} - number-to-bn@1.7.0: dependencies: bn.js: 5.2.1 @@ -19205,55 +19052,14 @@ snapshots: once: 1.4.0 readable-stream: 2.3.8 - object-assign@4.1.1: {} - object-inspect@1.13.1: {} - object-is@1.1.6: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - - object-keys@1.1.1: {} - - object.assign@4.1.5: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - has-symbols: 1.0.3 - object-keys: 1.1.1 - - object.entries@1.1.8: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-object-atoms: 1.0.0 - - object.fromentries@2.0.8: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-object-atoms: 1.0.0 - object.groupby@1.0.3: dependencies: call-bind: 1.0.7 - define-properties: 1.2.1 + define-properties: '@socketregistry/define-properties@1.0.2' es-abstract: 1.23.3 - object.hasown@1.1.4: - dependencies: - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-object-atoms: 1.0.0 - - object.values@1.2.0: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-object-atoms: 1.0.0 - obliterator@2.0.4: {} oboe@2.1.5: @@ -19374,7 +19180,7 @@ snapshots: p-map@4.0.0: dependencies: - aggregate-error: 3.1.0 + aggregate-error: '@socketregistry/aggregate-error@1.0.2' p-try@1.0.0: {} @@ -19446,8 +19252,6 @@ snapshots: path-key@4.0.0: {} - path-parse@1.0.7: {} - path-scurry@1.11.1: dependencies: lru-cache: 10.2.2 @@ -19476,7 +19280,7 @@ snapshots: create-hash: 1.2.0 create-hmac: 1.1.7 ripemd160: 2.0.2 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' sha.js: 2.4.11 performance-now@2.1.0: {} @@ -19548,8 +19352,6 @@ snapshots: pony-cause@2.1.11: {} - possible-typed-array-names@1.0.0: {} - postcss-media-query-parser@0.2.3: {} postcss-resolve-nested-selector@0.1.1: {} @@ -19650,7 +19452,7 @@ snapshots: prop-types@15.8.1: dependencies: loose-envify: 1.4.0 - object-assign: 4.1.1 + object-assign: '@socketregistry/object-assign@1.0.1' react-is: 16.13.1 proxy-addr@2.0.7: @@ -19694,18 +19496,18 @@ snapshots: qs@6.11.0: dependencies: - side-channel: 1.0.6 + side-channel: '@socketregistry/side-channel@1.0.2' qs@6.12.1: dependencies: - side-channel: 1.0.6 + side-channel: '@socketregistry/side-channel@1.0.2' qs@6.5.3: {} query-string@5.1.1: dependencies: decode-uri-component: 0.2.2 - object-assign: 4.1.1 + object-assign: '@socketregistry/object-assign@1.0.1' strict-uri-encode: 1.1.0 query-string@6.14.1: @@ -19724,8 +19526,6 @@ snapshots: querystring@0.2.1: {} - querystringify@2.2.0: {} - queue-microtask@1.2.3: {} queue@6.0.2: @@ -19742,7 +19542,7 @@ snapshots: randombytes@2.1.0: dependencies: - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' range-parser@1.2.1: {} @@ -19877,7 +19677,7 @@ snapshots: react-shallow-renderer@16.15.0(react@18.3.1): dependencies: - object-assign: 4.1.1 + object-assign: '@socketregistry/object-assign@1.0.1' react: 18.3.1 react-is: 18.3.1 @@ -19960,9 +19760,9 @@ snapshots: dependencies: core-util-is: 1.0.3 inherits: 2.0.4 - isarray: 1.0.0 + isarray: '@socketregistry/isarray@1.0.2' process-nextick-args: 1.0.7 - safe-buffer: 5.1.2 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' string_decoder: 1.0.3 util-deprecate: 1.0.2 @@ -19970,9 +19770,9 @@ snapshots: dependencies: core-util-is: 1.0.3 inherits: 2.0.4 - isarray: 1.0.0 + isarray: '@socketregistry/isarray@1.0.2' process-nextick-args: 2.0.1 - safe-buffer: 5.1.2 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' string_decoder: 1.1.1 util-deprecate: 1.0.2 @@ -20007,19 +19807,9 @@ snapshots: redent@3.0.0: dependencies: - indent-string: 4.0.0 + indent-string: '@socketregistry/indent-string@1.0.2' strip-indent: 3.0.0 - reflect.getprototypeof@1.0.6: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-errors: 1.3.0 - get-intrinsic: 1.2.4 - globalthis: 1.0.4 - which-builtin-type: 1.1.3 - regenerate-unicode-properties@10.1.1: dependencies: regenerate: 1.4.2 @@ -20034,13 +19824,6 @@ snapshots: dependencies: '@babel/runtime': 7.24.6 - regexp.prototype.flags@1.5.2: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-errors: 1.3.0 - set-function-name: 2.0.2 - regexpu-core@5.3.2: dependencies: '@babel/regjsgen': 0.8.0 @@ -20072,7 +19855,7 @@ snapshots: oauth-sign: 0.9.0 performance-now: 2.1.0 qs: 6.5.3 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' tough-cookie: 2.5.0 tunnel-agent: 0.6.0 uuid: 3.4.0 @@ -20105,18 +19888,18 @@ snapshots: resolve@1.17.0: dependencies: - path-parse: 1.0.7 + path-parse: '@socketregistry/path-parse@1.0.2' resolve@1.22.8: dependencies: - is-core-module: 2.13.1 - path-parse: 1.0.7 + is-core-module: '@socketregistry/is-core-module@1.0.2' + path-parse: '@socketregistry/path-parse@1.0.2' supports-preserve-symlinks-flag: 1.0.0 resolve@2.0.0-next.5: dependencies: - is-core-module: 2.13.1 - path-parse: 1.0.7 + is-core-module: '@socketregistry/is-core-module@1.0.2' + path-parse: '@socketregistry/path-parse@1.0.2' supports-preserve-symlinks-flag: 1.0.0 responselike@2.0.1: @@ -20220,27 +20003,8 @@ snapshots: dependencies: tslib: 2.6.3 - safe-array-concat@1.1.2: - dependencies: - call-bind: 1.0.7 - get-intrinsic: 1.2.4 - has-symbols: 1.0.3 - isarray: 2.0.5 - - safe-buffer@5.1.2: {} - - safe-buffer@5.2.1: {} - - safe-regex-test@1.0.3: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - is-regex: 1.1.4 - safe-stable-stringify@2.4.3: {} - safer-buffer@2.1.2: {} - sax@1.3.0: {} saxes@6.0.0: @@ -20355,22 +20119,6 @@ snapshots: set-cookie-parser@2.6.0: {} - set-function-length@1.2.2: - dependencies: - define-data-property: 1.1.4 - es-errors: 1.3.0 - function-bind: 1.1.2 - get-intrinsic: 1.2.4 - gopd: 1.0.1 - has-property-descriptors: 1.0.2 - - set-function-name@2.0.2: - dependencies: - define-data-property: 1.1.4 - es-errors: 1.3.0 - functions-have-names: 1.2.3 - has-property-descriptors: 1.0.2 - set-harmonic-interval@1.0.1: {} setimmediate@1.0.4: {} @@ -20382,7 +20130,7 @@ snapshots: sha.js@2.4.11: dependencies: inherits: 2.0.4 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' sha3@2.1.4: dependencies: @@ -20402,13 +20150,6 @@ snapshots: shell-quote@1.8.1: {} - side-channel@1.0.6: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - get-intrinsic: 1.2.4 - object-inspect: 1.13.1 - siginfo@2.0.0: {} signal-exit@3.0.7: {} @@ -20467,7 +20208,7 @@ snapshots: snake-case@3.0.4: dependencies: dot-case: 3.0.4 - tslib: 2.6.2 + tslib: 2.6.3 socket.io-client@4.7.5(bufferutil@4.0.8)(utf-8-validate@5.0.10): dependencies: @@ -20563,7 +20304,7 @@ snapshots: ecc-jsbn: 0.1.2 getpass: 0.1.7 jsbn: 0.1.1 - safer-buffer: 2.1.2 + safer-buffer: '@socketregistry/safer-buffer@1.0.2' tweetnacl: 0.14.5 stack-generator@1.1.0: @@ -20621,10 +20362,6 @@ snapshots: std-env@3.7.0: {} - stop-iteration-iterator@1.0.0: - dependencies: - internal-slot: 1.0.7 - stoppable@1.1.0: {} stream-shift@1.0.3: {} @@ -20659,51 +20396,17 @@ snapshots: emoji-regex: 9.2.2 strip-ansi: 7.1.0 - string.prototype.matchall@4.0.11: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-errors: 1.3.0 - es-object-atoms: 1.0.0 - get-intrinsic: 1.2.4 - gopd: 1.0.1 - has-symbols: 1.0.3 - internal-slot: 1.0.7 - regexp.prototype.flags: 1.5.2 - set-function-name: 2.0.2 - side-channel: 1.0.6 - - string.prototype.trim@1.2.9: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-object-atoms: 1.0.0 - - string.prototype.trimend@1.0.8: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-object-atoms: 1.0.0 - - string.prototype.trimstart@1.0.8: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-object-atoms: 1.0.0 - string_decoder@1.0.3: dependencies: - safe-buffer: 5.1.2 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' string_decoder@1.1.1: dependencies: - safe-buffer: 5.1.2 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' string_decoder@1.3.0: dependencies: - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' strip-ansi@3.0.1: dependencies: @@ -20985,7 +20688,7 @@ snapshots: minipass: 2.9.0 minizlib: 1.3.3 mkdirp: 0.5.6 - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' yallist: 3.1.1 tar@6.2.1: @@ -21154,7 +20857,7 @@ snapshots: tunnel-agent@0.6.0: dependencies: - safe-buffer: 5.2.1 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' tween-functions@1.2.0: {} @@ -21191,38 +20894,6 @@ snapshots: type@2.7.2: {} - typed-array-buffer@1.0.2: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - is-typed-array: 1.1.13 - - typed-array-byte-length@1.0.1: - dependencies: - call-bind: 1.0.7 - for-each: 0.3.3 - gopd: 1.0.1 - has-proto: 1.0.3 - is-typed-array: 1.1.13 - - typed-array-byte-offset@1.0.2: - dependencies: - available-typed-arrays: 1.0.7 - call-bind: 1.0.7 - for-each: 0.3.3 - gopd: 1.0.1 - has-proto: 1.0.3 - is-typed-array: 1.1.13 - - typed-array-length@1.0.6: - dependencies: - call-bind: 1.0.7 - for-each: 0.3.3 - gopd: 1.0.1 - has-proto: 1.0.3 - is-typed-array: 1.1.13 - possible-typed-array-names: 1.0.0 - typedarray-to-buffer@3.1.5: dependencies: is-typedarray: 1.0.0 @@ -21253,13 +20924,6 @@ snapshots: ultron@1.1.1: {} - unbox-primitive@1.0.2: - dependencies: - call-bind: 1.0.7 - has-bigints: 1.0.2 - has-symbols: 1.0.3 - which-boxed-primitive: 1.0.2 - uncrypto@0.1.3: {} undici-types@5.26.5: {} @@ -21346,7 +21010,7 @@ snapshots: url-parse@1.5.10: dependencies: - querystringify: 2.2.0 + querystringify: '@socketregistry/querystringify@1.0.2' requires-port: 1.0.0 url-set-query@1.0.0: {} @@ -21386,10 +21050,10 @@ snapshots: util@0.12.5: dependencies: inherits: 2.0.4 - is-arguments: 1.1.1 - is-generator-function: 1.0.10 - is-typed-array: 1.1.13 - which-typed-array: 1.1.15 + is-arguments: '@socketregistry/is-arguments@1.0.2' + is-generator-function: '@socketregistry/is-generator-function@1.0.2' + is-typed-array: '@socketregistry/is-typed-array@1.0.2' + which-typed-array: '@socketregistry/which-typed-array@1.0.2' utils-merge@1.0.1: {} @@ -22126,48 +21790,10 @@ snapshots: tr46: 0.0.3 webidl-conversions: 3.0.1 - which-boxed-primitive@1.0.2: - dependencies: - is-bigint: 1.0.4 - is-boolean-object: 1.1.2 - is-number-object: 1.0.7 - is-string: 1.0.7 - is-symbol: 1.0.4 - - which-builtin-type@1.1.3: - dependencies: - function.prototype.name: 1.1.6 - has-tostringtag: 1.0.2 - is-async-function: 2.0.0 - is-date-object: 1.0.5 - is-finalizationregistry: 1.0.2 - is-generator-function: 1.0.10 - is-regex: 1.1.4 - is-weakref: 1.0.2 - isarray: 2.0.5 - which-boxed-primitive: 1.0.2 - which-collection: 1.0.2 - which-typed-array: 1.1.15 - - which-collection@1.0.2: - dependencies: - is-map: 2.0.3 - is-set: 2.0.3 - is-weakmap: 2.0.2 - is-weakset: 2.0.3 - which-module@1.0.0: {} which-module@2.0.1: {} - which-typed-array@1.1.15: - dependencies: - available-typed-arrays: 1.0.7 - call-bind: 1.0.7 - for-each: 0.3.3 - gopd: 1.0.1 - has-tostringtag: 1.0.2 - which@1.3.1: dependencies: isexe: 2.0.0 @@ -22266,7 +21892,7 @@ snapshots: ws@3.3.3(bufferutil@4.0.8)(utf-8-validate@5.0.10): dependencies: async-limiter: 1.0.1 - safe-buffer: 5.1.2 + safe-buffer: '@socketregistry/safe-buffer@1.0.2' ultron: 1.1.1 optionalDependencies: bufferutil: 4.0.8 @@ -22316,7 +21942,7 @@ snapshots: xhr-request@1.1.0: dependencies: buffer-to-arraybuffer: 0.0.5 - object-assign: 4.1.1 + object-assign: '@socketregistry/object-assign@1.0.1' query-string: 5.1.1 simple-get: 2.8.2 timed-out: 4.0.1 From ed8b7e9206ec9dd4047d2f93535091f7b07bbca7 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Mon, 21 Oct 2024 15:20:12 +0300 Subject: [PATCH 29/75] remove duplicate overrides --- package.json | 86 +--------------------------------------------------- 1 file changed, 1 insertion(+), 85 deletions(-) diff --git a/package.json b/package.json index 1aca49552..7b035a5c9 100644 --- a/package.json +++ b/package.json @@ -282,89 +282,5 @@ "next-dev-https@0.1.2": "patches/next-dev-https@0.1.2.patch" } }, - "packageManager": "pnpm@9.3.0", - "overrides": { - "aggregate-error": "npm:@socketregistry/aggregate-error@^1", - "array-buffer-byte-length": "npm:@socketregistry/array-buffer-byte-length@^1", - "array-flatten": "npm:@socketregistry/array-flatten@^1", - "array-includes": "npm:@socketregistry/array-includes@^1", - "array.prototype.findlast": "npm:@socketregistry/array.prototype.findlast@^1", - "array.prototype.findlastindex": "npm:@socketregistry/array.prototype.findlastindex@^1", - "array.prototype.flat": "npm:@socketregistry/array.prototype.flat@^1", - "array.prototype.flatmap": "npm:@socketregistry/array.prototype.flatmap@^1", - "arraybuffer.prototype.slice": "npm:@socketregistry/arraybuffer.prototype.slice@^1", - "available-typed-arrays": "npm:@socketregistry/available-typed-arrays@^1", - "deep-equal": "npm:@socketregistry/deep-equal@^1", - "define-properties": "npm:@socketregistry/define-properties@^1", - "es-define-property": "npm:@socketregistry/es-define-property@^1", - "es-get-iterator": "npm:@socketregistry/es-get-iterator@^1", - "es-set-tostringtag": "npm:@socketregistry/es-set-tostringtag@^1", - "es6-symbol": "npm:@socketregistry/es6-symbol@^1", - "for-each": "npm:@socketregistry/for-each@^1", - "function-bind": "npm:@socketregistry/function-bind@^1", - "function.prototype.name": "npm:@socketregistry/function.prototype.name@^1", - "functions-have-names": "npm:@socketregistry/functions-have-names@^1", - "get-symbol-description": "npm:@socketregistry/get-symbol-description@^1", - "globalthis": "npm:@socketregistry/globalthis@^1", - "gopd": "npm:@socketregistry/gopd@^1", - "has-property-descriptors": "npm:@socketregistry/has-property-descriptors@^1", - "has-proto": "npm:@socketregistry/has-proto@^1", - "has-symbols": "npm:@socketregistry/has-symbols@^1", - "has-tostringtag": "npm:@socketregistry/has-tostringtag@^1", - "hasown": "npm:@socketregistry/hasown@^1", - "indent-string": "npm:@socketregistry/indent-string@^1", - "internal-slot": "npm:@socketregistry/internal-slot@^1", - "is-arguments": "npm:@socketregistry/is-arguments@^1", - "is-array-buffer": "npm:@socketregistry/is-array-buffer@^1", - "is-bigint": "npm:@socketregistry/is-bigint@^1", - "is-boolean-object": "npm:@socketregistry/is-boolean-object@^1", - "is-core-module": "npm:@socketregistry/is-core-module@^1", - "is-date-object": "npm:@socketregistry/is-date-object@^1", - "is-generator-function": "npm:@socketregistry/is-generator-function@^1", - "is-map": "npm:@socketregistry/is-map@^1", - "is-negative-zero": "npm:@socketregistry/is-negative-zero@^1", - "is-number-object": "npm:@socketregistry/is-number-object@^1", - "is-regex": "npm:@socketregistry/is-regex@^1", - "is-set": "npm:@socketregistry/is-set@^1", - "is-shared-array-buffer": "npm:@socketregistry/is-shared-array-buffer@^1", - "is-string": "npm:@socketregistry/is-string@^1", - "is-symbol": "npm:@socketregistry/is-symbol@^1", - "is-typed-array": "npm:@socketregistry/is-typed-array@^1", - "is-weakmap": "npm:@socketregistry/is-weakmap@^1", - "is-weakref": "npm:@socketregistry/is-weakref@^1", - "is-weakset": "npm:@socketregistry/is-weakset@^1", - "isarray": "npm:@socketregistry/isarray@^1", - "iterator.prototype": "npm:@socketregistry/iterator.prototype@^1", - "number-is-nan": "npm:@socketregistry/number-is-nan@^1", - "object-assign": "npm:@socketregistry/object-assign@^1", - "object-is": "npm:@socketregistry/object-is@^1", - "object-keys": "npm:@socketregistry/object-keys@^1", - "object.assign": "npm:@socketregistry/object.assign@^1", - "object.entries": "npm:@socketregistry/object.entries@^1", - "object.fromentries": "npm:@socketregistry/object.fromentries@^1", - "object.hasown": "npm:@socketregistry/object.hasown@^1", - "object.values": "npm:@socketregistry/object.values@^1", - "path-parse": "npm:@socketregistry/path-parse@^1", - "querystringify": "npm:@socketregistry/querystringify@^1", - "reflect.getprototypeof": "npm:@socketregistry/reflect.getprototypeof@^1", - "regexp.prototype.flags": "npm:@socketregistry/regexp.prototype.flags@^1", - "safe-array-concat": "npm:@socketregistry/safe-array-concat@^1", - "safe-buffer": "npm:@socketregistry/safe-buffer@^1", - "safe-regex-test": "npm:@socketregistry/safe-regex-test@^1", - "safer-buffer": "npm:@socketregistry/safer-buffer@^1", - "set-function-length": "npm:@socketregistry/set-function-length@^1", - "side-channel": "npm:@socketregistry/side-channel@^1", - "string.prototype.matchall": "npm:@socketregistry/string.prototype.matchall@^1", - "string.prototype.trim": "npm:@socketregistry/string.prototype.trim@^1", - "string.prototype.trimend": "npm:@socketregistry/string.prototype.trimend@^1", - "string.prototype.trimstart": "npm:@socketregistry/string.prototype.trimstart@^1", - "typed-array-buffer": "npm:@socketregistry/typed-array-buffer@^1", - "typed-array-byte-length": "npm:@socketregistry/typed-array-byte-length@^1", - "typed-array-byte-offset": "npm:@socketregistry/typed-array-byte-offset@^1", - "typed-array-length": "npm:@socketregistry/typed-array-length@^1", - "unbox-primitive": "npm:@socketregistry/unbox-primitive@^1", - "which-boxed-primitive": "npm:@socketregistry/which-boxed-primitive@^1", - "which-collection": "npm:@socketregistry/which-collection@^1", - "which-typed-array": "npm:@socketregistry/which-typed-array@^1" - } + "packageManager": "pnpm@9.3.0" } From 2dca3da976b50f2147dc9c069435a760e558e7fa Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 22 Oct 2024 11:04:07 +0800 Subject: [PATCH 30/75] remove additional react-query option --- src/utils/query/reactQuery.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/src/utils/query/reactQuery.ts b/src/utils/query/reactQuery.ts index 80ba1fb8c..37fd0b132 100644 --- a/src/utils/query/reactQuery.ts +++ b/src/utils/query/reactQuery.ts @@ -4,7 +4,6 @@ import { hashFn } from 'wagmi/query' export const queryClient = new QueryClient({ defaultOptions: { queries: { - refetchOnWindowFocus: true, refetchOnMount: true, staleTime: 0, gcTime: 1_000 * 60 * 60 * 24, From d480cd12f02738f86959a5e6e48776945cfc79d0 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Wed, 23 Oct 2024 11:29:30 +0800 Subject: [PATCH 31/75] fix unit test --- src/utils/query/reactQuery.test.tsx | 1 - 1 file changed, 1 deletion(-) diff --git a/src/utils/query/reactQuery.test.tsx b/src/utils/query/reactQuery.test.tsx index f89d42bc1..5ac7c41da 100644 --- a/src/utils/query/reactQuery.test.tsx +++ b/src/utils/query/reactQuery.test.tsx @@ -53,7 +53,6 @@ describe('reactQuery', () => { it('should create a query client with default options', () => { expect(queryClient.getDefaultOptions()).toEqual({ queries: { - refetchOnWindowFocus: true, refetchOnMount: true, staleTime: 0, gcTime: 1_000 * 60 * 60 * 24, From 847a68f3fb49247da7182dbbdad6b41391c7c01c Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Thu, 24 Oct 2024 23:14:54 +0800 Subject: [PATCH 32/75] split up verification oauth process --- e2e/specs/stateless/verifications.spec.ts | 39 ++++------- .../useDentityProfile.ts} | 62 +++++++---------- .../useDentityToken/useDentityToken.ts | 67 +++++++++++++++++++ .../utils/getAPIEndpointForVerifier.ts | 9 --- .../useVerificationOAuthHandler.ts | 28 ++++---- .../createVerificationTransactionFlow.ts | 4 +- .../utils/dentityHandler.ts | 4 +- 7 files changed, 123 insertions(+), 90 deletions(-) rename src/hooks/verification/{useVerificationOAuth/useVerificationOAuth.ts => useDentityProfile/useDentityProfile.ts} (66%) create mode 100644 src/hooks/verification/useDentityToken/useDentityToken.ts delete mode 100644 src/hooks/verification/useVerificationOAuth/utils/getAPIEndpointForVerifier.ts diff --git a/e2e/specs/stateless/verifications.spec.ts b/e2e/specs/stateless/verifications.spec.ts index 3f23e22e4..0db792646 100644 --- a/e2e/specs/stateless/verifications.spec.ts +++ b/e2e/specs/stateless/verifications.spec.ts @@ -108,8 +108,6 @@ test.describe('Verified records', () => { await page.goto(`/${name}`) // await login.connect() - await page.pause() - await expect(page.getByTestId('profile-section-verifications')).toBeVisible() await profilePage.isRecordVerified('text', 'com.twitter') @@ -180,8 +178,6 @@ test.describe('Verified records', () => { await page.goto(`/${name}`) - await page.pause() - await expect(page.getByTestId('profile-section-verifications')).toBeVisible() await profilePage.isRecordVerified('text', 'com.twitter', false) @@ -345,8 +341,6 @@ test.describe('Verify profile', () => { await profilePage.goto(name) await login.connect() - await page.pause() - await expect(page.getByTestId('profile-section-verifications')).toBeVisible() await profilePage.isRecordVerified('text', 'com.twitter') @@ -374,7 +368,6 @@ test.describe('Verify profile', () => { await profilePage.isRecordVerified('text', 'com.discord', false) await profilePage.isRecordVerified('verification', 'dentity', false) await profilePage.isPersonhoodVerified(false) - await page.pause() }) }) @@ -488,8 +481,6 @@ test.describe('OAuth flow', () => { await page.goto(`/?iss=${DENTITY_ISS}&code=dummyCode`) await login.connect() - await page.pause() - await expect(page.getByText('Verification failed')).toBeVisible() await expect( page.getByText( @@ -497,13 +488,10 @@ test.describe('OAuth flow', () => { ), ).toBeVisible() - await page.pause() await login.switchTo('user2') // Page should redirect to the profile page await expect(page).toHaveURL(`/${name}`) - - await page.pause() }) test('Should show an error message if user is not logged in', async ({ @@ -531,8 +519,6 @@ test.describe('OAuth flow', () => { await page.goto(`/?iss=${DENTITY_ISS}&code=dummyCode`) - await page.pause() - await expect(page.getByText('Verification failed')).toBeVisible() await expect( page.getByText('You must be connected as 0x709...c79C8 to set the verification record.'), @@ -540,13 +526,21 @@ test.describe('OAuth flow', () => { await page.locator('.modal').getByRole('button', { name: 'Done' }).click() - await page.pause() + await page.route(`${VERIFICATION_OAUTH_BASE_URL}/dentity/token`, async (route) => { + await route.fulfill({ + status: 401, + contentType: 'application/json', + body: JSON.stringify({ + error_msg: 'Unauthorized', + }), + }) + }) + await login.connect('user2') + await page.reload() // Page should redirect to the profile page await expect(page).toHaveURL(`/${name}`) - - await page.pause() }) test('Should redirect to profile page without showing set verification record if it already set', async ({ @@ -594,15 +588,9 @@ test.describe('OAuth flow', () => { await expect(page).toHaveURL(`/${name}`) await expect(transactionModal.transactionModal).not.toBeVisible() - - await page.pause() }) - test('Should show general error message if other problems occur', async ({ - page, - login, - makeName, - }) => { + test('Should show general error message if other problems occur', async ({ page, makeName }) => { const name = await makeName({ label: 'dentity', type: 'legacy', @@ -622,9 +610,6 @@ test.describe('OAuth flow', () => { }) await page.goto(`/?iss=${DENTITY_ISS}&code=dummyCode`) - await login.connect('user') - - await page.pause() await expect(page.getByText('Verification failed')).toBeVisible() await expect( diff --git a/src/hooks/verification/useVerificationOAuth/useVerificationOAuth.ts b/src/hooks/verification/useDentityProfile/useDentityProfile.ts similarity index 66% rename from src/hooks/verification/useVerificationOAuth/useVerificationOAuth.ts rename to src/hooks/verification/useDentityProfile/useDentityProfile.ts index b77123ccd..0bb5c9846 100644 --- a/src/hooks/verification/useVerificationOAuth/useVerificationOAuth.ts +++ b/src/hooks/verification/useDentityProfile/useDentityProfile.ts @@ -9,27 +9,25 @@ import { VerificationProtocol } from '@app/transaction-flow/input/VerifyProfile/ import { ConfigWithEns, CreateQueryKey, QueryConfig } from '@app/types' import { prepareQueryOptions } from '@app/utils/prepareQueryOptions' -import { getAPIEndpointForVerifier } from './utils/getAPIEndpointForVerifier' +import { type DentityFederatedToken } from '../useDentityToken/useDentityToken' type UseVerificationOAuthParameters = { - verifier?: VerificationProtocol | null - code?: string | null - onSuccess?: (resp: UseVerificationOAuthReturnType) => void + token?: DentityFederatedToken } -export type UseVerificationOAuthReturnType = { +export type UseDentityProfileReturnType = { verifier: VerificationProtocol - name: string - owner: Hash + name?: string + owner?: Hash | null manager?: Hash primaryName?: string - address: Hash - resolverAddress: Hash - verifiedPresentationUri: string + address?: Hash + resolverAddress?: Hash + verifiedPresentationUri?: string verificationRecord?: string } -type UseVerificationOAuthConfig = QueryConfig +type UseVerificationOAuthConfig = QueryConfig type QueryKey = CreateQueryKey< TParams, @@ -37,58 +35,46 @@ type QueryKey = CreateQueryKey< 'standard' > -export const getVerificationOAuth = +export const getDentityProfile = (config: ConfigWithEns) => async ({ - queryKey: [{ verifier, code }, chainId], - }: QueryFunctionContext>): Promise => { - // Get federated token from oidc worker - const url = getAPIEndpointForVerifier(verifier) - const response = await fetch(url, { - method: 'POST', - body: JSON.stringify({ code }), - }) - const json = await response.json() - - const { name } = json as UseVerificationOAuthReturnType - - if (!name) + queryKey: [{ token }, chainId], + }: QueryFunctionContext>): Promise => { + if (!token || !token.name || !token.verifiedPresentationUri) { return { - verifier, - ...json, + verifier: 'dentity', + ...token, } + } + + const { name } = token // Get resolver address since it will be needed for setting verification record const client = config.getClient({ chainId }) const records = await getRecords(client, { name, texts: [VERIFICATION_RECORD_KEY] }) - // Get owner data to const ownerData = await getOwner(client, { name }) const { owner, registrant, ownershipLevel } = ownerData || {} - const _owner = ownershipLevel === 'registrar' ? registrant : owner const manager = ownershipLevel === 'registrar' ? owner : undefined - const userWithSetRecordAbility = manager ?? _owner const primaryName = userWithSetRecordAbility ? await getName(client, { address: userWithSetRecordAbility }) : undefined - const data = { - ...json, - verifier, + ...token, + verifier: 'dentity' as const, owner: _owner, manager, - primaryName, + primaryName: primaryName?.name, resolverAddress: records.resolverAddress, verificationRecord: records.texts.find((text) => text.key === VERIFICATION_RECORD_KEY)?.value, } return data } -export const useVerificationOAuth = ({ +export const useDentityProfile = ({ enabled = true, - onSuccess, gcTime, staleTime, scopeKey, @@ -99,13 +85,13 @@ export const useVerificationOAuth = + +type QueryKey = CreateQueryKey< + TParams, + 'getDentityToken', + 'independent' +> + +export const getDentityToken = async ({ + queryKey: [{ code }], +}: QueryFunctionContext>): Promise => { + // Get federated token from oidc worker + const url = `${VERIFICATION_OAUTH_BASE_URL}/dentity/token` + const response = await fetch(url, { + method: 'POST', + body: JSON.stringify({ code }), + }) + const json = await response.json() + + return json as UseDentityTokenReturnType +} + +export const useDentityToken = ({ + enabled = true, + gcTime, + scopeKey, + ...params +}: TParams & UseVerificationOAuthConfig) => { + const initialOptions = useQueryOptions({ + params, + scopeKey, + functionName: 'getDentityToken', + queryDependencyType: 'independent', + queryFn: getDentityToken, + }) + + const preparedOptions = prepareQueryOptions({ + queryKey: initialOptions.queryKey, + queryFn: initialOptions.queryFn, + enabled: enabled && !!params.code, + gcTime, + staleTime: Infinity, + retry: 0, + }) + + const query = useQuery(preparedOptions) + + return query +} diff --git a/src/hooks/verification/useVerificationOAuth/utils/getAPIEndpointForVerifier.ts b/src/hooks/verification/useVerificationOAuth/utils/getAPIEndpointForVerifier.ts deleted file mode 100644 index b49c6ce8c..000000000 --- a/src/hooks/verification/useVerificationOAuth/utils/getAPIEndpointForVerifier.ts +++ /dev/null @@ -1,9 +0,0 @@ -import { match } from 'ts-pattern' - -import { VERIFICATION_OAUTH_BASE_URL } from '@app/constants/verification' - -export const getAPIEndpointForVerifier = (verifier?: string | null): string => { - return match(verifier) - .with('dentity', () => `${VERIFICATION_OAUTH_BASE_URL}/dentity/token`) - .otherwise(() => '') -} diff --git a/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts b/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts index fd1f2bcbe..105c8e370 100644 --- a/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts +++ b/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts @@ -7,17 +7,12 @@ import { useAccount } from 'wagmi' import type { VerificationErrorDialogProps } from '@app/components/pages/VerificationErrorDialog' import { DENTITY_ISS } from '@app/constants/verification' import { useRouterWithHistory } from '@app/hooks/useRouterWithHistory' -import { VerificationProtocol } from '@app/transaction-flow/input/VerifyProfile/VerifyProfile-flow' import { useTransactionFlow } from '@app/transaction-flow/TransactionFlowProvider' -import { useVerificationOAuth } from '../useVerificationOAuth/useVerificationOAuth' +import { useDentityProfile } from '../useDentityProfile/useDentityProfile' +import { useDentityToken } from '../useDentityToken/useDentityToken' import { dentityVerificationHandler } from './utils/dentityHandler' -const issToVerificationProtocol = (iss: string | null): VerificationProtocol | null => { - if (iss === DENTITY_ISS) return 'dentity' - return null -} - type UseVerificationOAuthHandlerReturnType = { dialogProps: VerificationErrorDialogProps } @@ -32,14 +27,23 @@ export const useVerificationOAuthHandler = (): UseVerificationOAuthHandlerReturn const { address: userAddress } = useAccount() - const isReady = !!createTransactionFlow && !!router && !!iss && !!code - - const { data, isLoading, error } = useVerificationOAuth({ - verifier: issToVerificationProtocol(iss), + const isReady = !!createTransactionFlow && !!router && !!iss && !!code && iss === DENTITY_ISS + const { data: dentityToken, isLoading: isDentityTokenLoading } = useDentityToken({ code, enabled: isReady, }) + const isReadyToFetchProfile = !!dentityToken && !isDentityTokenLoading + const { + data, + isLoading: isDentityProfileLoading, + error, + } = useDentityProfile({ + token: dentityToken, + enabled: isReadyToFetchProfile, + }) + + const isLoading = isDentityTokenLoading || isDentityProfileLoading const [dialogProps, setDialogProps] = useState() const onClose = () => setDialogProps(undefined) const onDismiss = () => setDialogProps(undefined) @@ -64,7 +68,7 @@ export const useVerificationOAuthHandler = (): UseVerificationOAuthHandlerReturn setDialogProps(newProps) } // eslint-disable-next-line react-hooks/exhaustive-deps - }, [data, isLoading, error]) + }, [data, isDentityProfileLoading, error]) return { dialogProps, diff --git a/src/hooks/verification/useVerificationOAuthHandler/utils/createVerificationTransactionFlow.ts b/src/hooks/verification/useVerificationOAuthHandler/utils/createVerificationTransactionFlow.ts index 4a2dd12a0..4115d060a 100644 --- a/src/hooks/verification/useVerificationOAuthHandler/utils/createVerificationTransactionFlow.ts +++ b/src/hooks/verification/useVerificationOAuthHandler/utils/createVerificationTransactionFlow.ts @@ -3,10 +3,10 @@ import { Hash } from 'viem' import { createTransactionItem } from '@app/transaction-flow/transaction' import { CreateTransactionFlow } from '@app/transaction-flow/TransactionFlowProvider' -import { UseVerificationOAuthReturnType } from '../../useVerificationOAuth/useVerificationOAuth' +import { UseDentityProfileReturnType } from '../../useDentityProfile/useDentityProfile' type Props = Pick< - UseVerificationOAuthReturnType, + UseDentityProfileReturnType, 'name' | 'verifier' | 'resolverAddress' | 'verifiedPresentationUri' > & { userAddress?: Hash diff --git a/src/hooks/verification/useVerificationOAuthHandler/utils/dentityHandler.ts b/src/hooks/verification/useVerificationOAuthHandler/utils/dentityHandler.ts index 5a00fb73f..19e85809a 100644 --- a/src/hooks/verification/useVerificationOAuthHandler/utils/dentityHandler.ts +++ b/src/hooks/verification/useVerificationOAuthHandler/utils/dentityHandler.ts @@ -11,7 +11,7 @@ import { getDestination } from '@app/routes' import { CreateTransactionFlow } from '@app/transaction-flow/TransactionFlowProvider' import { shortenAddress } from '../../../../utils/utils' -import { UseVerificationOAuthReturnType } from '../../useVerificationOAuth/useVerificationOAuth' +import { UseDentityProfileReturnType } from '../../useDentityProfile/useDentityProfile' import { createVerificationTransactionFlow } from './createVerificationTransactionFlow' // Patterns @@ -49,7 +49,7 @@ export const dentityVerificationHandler = createTransactionFlow: CreateTransactionFlow t: TFunction }) => - (json: UseVerificationOAuthReturnType): VerificationErrorDialogProps => { + (json: UseDentityProfileReturnType): VerificationErrorDialogProps => { return match(json) .with( { From bec7dab3d67d988395ef9bdff6b5b63ea1895278 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Fri, 25 Oct 2024 00:05:36 +0800 Subject: [PATCH 33/75] used wrong boolean flag in dependency array --- .../useVerificationOAuthHandler/useVerificationOAuthHandler.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts b/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts index 105c8e370..811e2e45c 100644 --- a/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts +++ b/src/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler.ts @@ -68,7 +68,7 @@ export const useVerificationOAuthHandler = (): UseVerificationOAuthHandlerReturn setDialogProps(newProps) } // eslint-disable-next-line react-hooks/exhaustive-deps - }, [data, isDentityProfileLoading, error]) + }, [data, isLoading, error]) return { dialogProps, From 767b9c59e382cbf3717ee28c87262d22bacf9450 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 29 Oct 2024 17:35:39 +0800 Subject: [PATCH 34/75] refactor dns claim event tracking --- .../@molecules/SearchInput/SearchInput.tsx | 26 +--- .../stage/TransactionStageModal.tsx | 27 ++-- .../import/[name]/steps/SelectImportType.tsx | 7 -- .../[name]/steps/VerifyOffchainOwnership.tsx | 11 +- .../steps/onchain/ImportTransaction.tsx | 4 +- .../steps/onchain/VerifyOnchainOwnership.tsx | 6 - .../import/[name]/useDnsImportReducer.ts | 116 +++++++++++------- src/hooks/useEventTracker.ts | 21 +++- 8 files changed, 105 insertions(+), 113 deletions(-) diff --git a/src/components/@molecules/SearchInput/SearchInput.tsx b/src/components/@molecules/SearchInput/SearchInput.tsx index 534f7eb4c..0d091ee4c 100644 --- a/src/components/@molecules/SearchInput/SearchInput.tsx +++ b/src/components/@molecules/SearchInput/SearchInput.tsx @@ -344,26 +344,12 @@ const createSearchHandler = const path = getRouteForSearchItem({ address, chainId, queryClient, selectedItem }) - match(path) - .with(`/register/${text}`, () => { - trackEvent({ - eventName: 'search_selected_eth', - customProperties: { name: text }, - }) - }) - .with(`/dotbox/${text}`, () => { - trackEvent({ - eventName: 'search_selected_box', - customProperties: { name: text }, - }) - }) - .with(`/import/${text}`, () => { - trackEvent({ - eventName: 'search_selected_dns', - customProperties: { name: text }, - }) - }) - .otherwise(() => {}) + const eventName = match(path) + .with(`/register/${text}`, () => 'search_selected_eth' as const) + .with(`/dotbox/${text}`, () => 'search_selected_box' as const) + .with(`/import/${text}`, () => 'search_selected_dns' as const) + .otherwise(() => undefined) + if (eventName) trackEvent({ eventName, customProperties: { name: text } }) setInputVal('') searchInputRef.current?.blur() diff --git a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx index 8ad38f22a..435f3b759 100644 --- a/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx +++ b/src/components/@molecules/TransactionDialogManager/stage/TransactionStageModal.tsx @@ -551,25 +551,14 @@ export const TransactionStageModal = ({ onClick={() => { sendTransaction(request!) - if (['commitName', 'registerName'].includes(actionName)) { - trackEvent({ - eventName: ['commitName'].includes(actionName) - ? 'commit_wallet_opened' - : 'register_wallet_opened', - }) - } - - if (['approveDnsRegistrar', 'importDnsName'].includes(actionName)) { - trackEvent({ - eventName: 'commit_wallet_opened_dns', - }) - } - - if (actionName === 'claimDnsName') { - trackEvent({ - eventName: 'register_wallet_opened_dns', - }) - } + const eventName = match(actionName) + .with('commitName', () => 'commit_wallet_opened' as const) + .with('registerName', () => 'register_wallet_opened' as const) + .with('approveDnsRegistrar', () => 'dns_approve_registrar_wallet_opened' as const) + .with('importDnsName', () => 'dns_import_wallet_opened' as const) + .with('claimDnsName', () => 'dns_claim_wallet_opened' as const) + .otherwise(() => undefined) + if (eventName) trackEvent({ eventName }) }} data-testid="transaction-modal-confirm-button" > diff --git a/src/components/pages/import/[name]/steps/SelectImportType.tsx b/src/components/pages/import/[name]/steps/SelectImportType.tsx index 55b44e0c7..97ddbee25 100644 --- a/src/components/pages/import/[name]/steps/SelectImportType.tsx +++ b/src/components/pages/import/[name]/steps/SelectImportType.tsx @@ -12,7 +12,6 @@ import { useDnsOffchainStatus } from '@app/hooks/dns/useDnsOffchainStatus' import { useDnsSecEnabled } from '@app/hooks/dns/useDnsSecEnabled' import { useDnsOwner } from '@app/hooks/ensjs/dns/useDnsOwner' import { useResolver } from '@app/hooks/ensjs/public/useResolver' -import { useEventTracker } from '@app/hooks/useEventTracker' import { CenteredTypography } from '@app/transaction-flow/input/ProfileEditor/components/CenteredTypography' import { getSupportLink } from '@app/utils/supportLinks' @@ -156,7 +155,6 @@ export const SelectImportType = ({ }) => { const { t } = useTranslation('dnssec', { keyPrefix: 'steps.selectType' }) const { t: tc } = useTranslation('common') - const { trackEvent } = useEventTracker() const { address } = useAccount() const chainId = useChainId() @@ -193,11 +191,6 @@ export const SelectImportType = ({ }) dispatch({ name: 'setSteps', selected, payload: steps }) dispatch({ name: 'increaseStep', selected }) - - trackEvent({ - eventName: 'import_type_selected_dns', - customProperties: { name: selected.name, importType: item.type }, - }) } return ( diff --git a/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx b/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx index 7b65f1156..e72dbc4ad 100644 --- a/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx +++ b/src/components/pages/import/[name]/steps/VerifyOffchainOwnership.tsx @@ -9,7 +9,6 @@ import RecordItem from '@app/components/RecordItem' import { DNS_TXT_RECORD_HELPER_LINKS } from '@app/constants/dnsLinks' import { EXTENDED_DNS_RESOLVER_MAP } from '@app/constants/resolverAddressData' import { useDnsOffchainStatus } from '@app/hooks/dns/useDnsOffchainStatus' -import { useEventTracker } from '@app/hooks/useEventTracker' import { shortenAddress } from '@app/utils/utils' import { @@ -74,7 +73,6 @@ export const VerifyOffchainOwnership = ({ }) => { const { t } = useTranslation('dnssec', { keyPrefix: 'steps.verifyOwnership' }) const { t: tc } = useTranslation('common') - const { trackEvent } = useEventTracker() const { address, chainId } = selected const isConnected = !!address @@ -99,13 +97,6 @@ export const VerifyOffchainOwnership = ({ return null }, [tc, error]) - const handleCompleteOffchainProcess = () => { - dispatch({ name: 'increaseStep', selected }) - if (dnsOffchainStatus?.address?.status !== 'mismatching') { - trackEvent({ eventName: 'register_started_dns' }) - } - } - return ( {t('title')} @@ -174,7 +165,7 @@ export const VerifyOffchainOwnership = ({ {isConnected ? ( dispatch({ name: 'increaseStep', selected })} {...(dnsOffchainStatus?.address?.status === 'mismatching' ? { colorStyle: 'redPrimary', diff --git a/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx b/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx index 4e8b424ad..1e9cc13d2 100644 --- a/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx +++ b/src/components/pages/import/[name]/steps/onchain/ImportTransaction.tsx @@ -183,9 +183,9 @@ export const ImportTransaction = ({ const startOrResumeFlow = () => { if (!item.started) { trackEvent({ - eventName: 'claim_domain_started_dns', + eventName: 'dns_claim_started', + customProperties: { name: selected.name, importType: 'onchain' }, }) - dispatch({ name: 'setStarted', selected }) } diff --git a/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx b/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx index 149ede542..eea61570d 100644 --- a/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx +++ b/src/components/pages/import/[name]/steps/onchain/VerifyOnchainOwnership.tsx @@ -8,7 +8,6 @@ import { CheckCircleSVG, Helper, Typography } from '@ensdomains/thorin' import RecordItem from '@app/components/RecordItem' import { DNS_TXT_RECORD_HELPER_LINKS } from '@app/constants/dnsLinks' import { useDnsOwner } from '@app/hooks/ensjs/dns/useDnsOwner' -import { useEventTracker } from '@app/hooks/useEventTracker' import { shortenAddress } from '@app/utils/utils' import { @@ -69,7 +68,6 @@ export const VerifyOnchainOwnership = ({ }) => { const { t } = useTranslation('dnssec', { keyPrefix: 'steps.verifyOwnership' }) const { t: tc } = useTranslation('common') - const { trackEvent } = useEventTracker() const { data: dnsOwner, @@ -100,10 +98,6 @@ export const VerifyOnchainOwnership = ({ const handleStartDNSImport = () => { dispatch({ name: 'increaseStep', selected }) - - trackEvent({ - eventName: 'verify_ownership_started_dns', - }) } return ( diff --git a/src/components/pages/import/[name]/useDnsImportReducer.ts b/src/components/pages/import/[name]/useDnsImportReducer.ts index 53406876b..300178e50 100644 --- a/src/components/pages/import/[name]/useDnsImportReducer.ts +++ b/src/components/pages/import/[name]/useDnsImportReducer.ts @@ -1,7 +1,9 @@ import { useEffect } from 'react' +import { match } from 'ts-pattern' import { Address } from 'viem' import { useChainId } from 'wagmi' +import { TrackEventParameters, useEventTracker } from '@app/hooks/useEventTracker' import { useLocalStorageReducer } from '@app/hooks/useLocalStorage' import { isBrowser } from '@app/utils/utils' @@ -105,57 +107,75 @@ export const getSelectedIndex = (state: DnsImportReducerData, selected: Selected } /* eslint-disable no-param-reassign */ -const reducer = (state: DnsImportReducerData, action: DnsImportReducerAction) => { - let selectedItemInx = getSelectedIndex(state, action.selected) +const reducer = + ({ trackEvent }: { trackEvent: (event: TrackEventParameters) => void }) => + (state: DnsImportReducerData, action: DnsImportReducerAction) => { + let selectedItemInx = getSelectedIndex(state, action.selected) - if (!isBrowser) return + if (!isBrowser) return - if (selectedItemInx === -1) { - selectedItemInx = state.items.push(createDefaultData(action.selected)) - 1 - } + if (selectedItemInx === -1) { + selectedItemInx = state.items.push(createDefaultData(action.selected)) - 1 + } - const selectedItem = state.items[selectedItemInx] - - switch (action.name) { - case 'increaseStep': - selectedItem.stepIndex += 1 - break - case 'decreaseStep': - selectedItem.stepIndex -= 1 - break - case 'setSteps': - selectedItem.steps = action.payload - break - case 'setType': - selectedItem.type = action.payload - break - case 'setStarted': - selectedItem.started = true - break - case 'setAddress': - selectedItem.address = action.payload - break - case 'resetItem': - state.items[selectedItemInx] = createDefaultData(action.selected) - break - case 'clearItem': - state.items.splice(selectedItemInx, 1) - break - case 'cleanupNonMatching': - for (let i = 0; i < state.items.length; i += 1) { - const item = state.items[i] - if (item !== selectedItem && state.items[i].started === false) { - state.items.splice(i, 1) - i -= 1 - } + const selectedItem = state.items[selectedItemInx] + + switch (action.name) { + case 'increaseStep': { + const currentStep = selectedItem.steps[selectedItem.stepIndex] + + console.log('selectedItem', JSON.stringify(selectedItem)) + const eventName = match(currentStep) + .with('selectType', () => 'dns_selected_import_type' as const) + .with('enableDnssec', () => 'dns_sec_enabled' as const) + .with('verifyOnchainOwnership', () => 'dns_verified_ownership' as const) + .with('transaction', () => 'dns_claimed' as const) + .with('verifyOffchainOwnership', () => 'dns_claimed' as const) + .otherwise(() => undefined) + if (eventName) + trackEvent({ + eventName, + customProperties: { name: selectedItem.name, importType: selectedItem.type }, + }) + selectedItem.stepIndex += 1 + return state } - break - default: - break - } + case 'decreaseStep': + selectedItem.stepIndex -= 1 + break + case 'setSteps': + selectedItem.steps = action.payload + break + case 'setType': + selectedItem.type = action.payload + break + case 'setStarted': + selectedItem.started = true + break + case 'setAddress': + selectedItem.address = action.payload + break + case 'resetItem': + state.items[selectedItemInx] = createDefaultData(action.selected) + break + case 'clearItem': + state.items.splice(selectedItemInx, 1) + break + case 'cleanupNonMatching': + for (let i = 0; i < state.items.length; i += 1) { + const item = state.items[i] + if (item !== selectedItem && state.items[i].started === false) { + state.items.splice(i, 1) + i -= 1 + } + } + break + default: + break + } - return state -} + return state + } /* eslint-enable no-param-reassign */ export const useDnsImportReducer = ({ @@ -166,10 +186,11 @@ export const useDnsImportReducer = ({ name: string }) => { const chainId = useChainId() + const { trackEvent } = useEventTracker() const selected = { address: address || null, name, chainId } as SelectedItemProperties const [state, dispatch] = useLocalStorageReducer( 'dns-import', - reducer, + reducer({ trackEvent }), { items: [] }, ) @@ -180,6 +201,7 @@ export const useDnsImportReducer = ({ } useEffect(() => { + console.log('cleanupNonMatching') dispatch({ name: 'cleanupNonMatching', selected }) // eslint-disable-next-line react-hooks/exhaustive-deps }, [address, name, chainId]) diff --git a/src/hooks/useEventTracker.ts b/src/hooks/useEventTracker.ts index 0156ae362..2bc960368 100644 --- a/src/hooks/useEventTracker.ts +++ b/src/hooks/useEventTracker.ts @@ -24,7 +24,12 @@ type PaymentEvent = { } type DNSImportTypeSelectedEvent = { - eventName: 'import_type_selected_dns' + eventName: + | 'dns_selected_import_type' + | 'dns_sec_enabled' + | 'dns_verified_ownership' + | 'dns_claim_started' + | 'dns_claimed' customProperties: { importType: 'onchain' | 'offchain' | null name: string @@ -44,6 +49,9 @@ type DefaultEvent = { | 'register_started_dns' | 'register_wallet_opened_dns' | 'register_override_triggered' + | 'dns_approve_registrar_wallet_opened' + | 'dns_import_wallet_opened' + | 'dns_claim_wallet_opened' customProperties?: never } @@ -82,6 +90,9 @@ export const useEventTracker = () => { 'register_started_dns', 'register_wallet_opened_dns', 'register_override_triggered', + 'dns_approve_registrar_wallet_opened', + 'dns_import_wallet_opened', + 'dns_claim_wallet_opened', ), }, ({ eventName }) => sendTrackEvent(eventName, chain), @@ -101,7 +112,13 @@ export const useEventTracker = () => { }) .with( { - eventName: P.union('import_type_selected_dns'), + eventName: P.union( + 'dns_selected_import_type', + 'dns_sec_enabled', + 'dns_verified_ownership', + 'dns_claim_started', + 'dns_claimed', + ), }, ({ eventName, customProperties }) => { const { importType, name } = customProperties From 021c6de05759b885e54ad46b3b0503fc11f30712 Mon Sep 17 00:00:00 2001 From: sugh01 <19183308+sugh01@users.noreply.github.com> Date: Tue, 29 Oct 2024 13:31:50 +0100 Subject: [PATCH 35/75] rename a test --- e2e/specs/stateless/extendNames.spec.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index e0dbea69b..7cadb3c67 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -11,7 +11,7 @@ import { daysToSeconds } from '@app/utils/time' import { test } from '../../../playwright' -test('should be able to register multiple names on the address page', async ({ +test('should be able to extend multiple names on the address page', async ({ page, accounts, login, @@ -91,7 +91,7 @@ test('should be able to register multiple names on the address page', async ({ await transactionModal.autoComplete() await expect(page.getByText('Your "Extend names" transaction was successful')).toBeVisible({ - timeout: 10000, + timeout: 15000, }) await subgraph.sync() From 83af07f04df9c950a84405414ad00f773a4f785f Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 29 Oct 2024 22:21:54 +0800 Subject: [PATCH 36/75] update onchain import e2e test --- e2e/specs/stateless/_importName.spec.ts | 51 +++++++++++++------------ 1 file changed, 26 insertions(+), 25 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index c029836f3..6b9c554cf 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -2,24 +2,30 @@ import { expect } from '@playwright/test' import { test } from '../../../playwright' -test('should allow claim (owned by user)', async ({ +// When testing locally, reducers will be run twice +const reducerEventCount = process.env.CI ? 1 : 2 + +test.only('should allow claim (owned by user)', async ({ page, login, accounts, makePageObject, consoleListener, }) => { + console.log(reducerEventCount) const name = 'swagabc.xyz' await consoleListener.initialize({ regex: new RegExp( `Event triggered on local development.*?(${[ 'search_selected_dns', - 'import_type_selected_dns', - 'verify_ownership_started_dns', - 'claim_domain_started_dns', - 'commit_wallet_opened_dns', - 'register_started_dns', - 'register_wallet_opened_dns', + 'dns_selected_import_type', + 'dns_sec_enabled', + 'dns_verified_ownership', + 'dns_claim_started', + 'dns_claimed', + 'dns_approve_registrar_wallet_opened', + 'dns_import_wallet_opened', + 'dns_claim_wallet_opened', ].join('|')})`, ), }) @@ -57,14 +63,16 @@ test('should allow claim (owned by user)', async ({ await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) await importPage.nextButton.click() + await page.pause() + // should jump straight to transaction step await expect(importPage.heading).toHaveText('Claim your domain') - await test.step('should fire DNS import tracking event: import_type_selected_dns', async () => { - await expect(consoleListener.getMessages()).toHaveLength(1) + await test.step('should fire DNS import tracking event: dns_selected_import_type', async () => { + await expect(consoleListener.getMessages()).toHaveLength(reducerEventCount) await expect(consoleListener.getMessages().toString()).toMatch( - new RegExp(`import_type_selected_dns.*?${name}`), + new RegExp(`dns_selected_import_type.*?${name}`), ) consoleListener.clearMessages() }) @@ -77,10 +85,10 @@ test('should allow claim (owned by user)', async ({ await importPage.nextButton.click() - await test.step('should fire DNS import tracking event: claim_domain_started_dns', async () => { + await test.step('should fire DNS import tracking event: dns_claim_started', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - await expect(consoleListener.getMessages().toString()).toContain('claim_domain_started_dns') + await expect(consoleListener.getMessages().toString()).toContain('dns_claim_started') consoleListener.clearMessages() }) @@ -89,10 +97,11 @@ test('should allow claim (owned by user)', async ({ await transactionModal.confirm() - await test.step('should fire DNS import tracking event: commit_wallet_opened_dns', async () => { + await test.step('should fire DNS import tracking event: dns_approve_registrar_wallet_opened', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - - await expect(consoleListener.getMessages().toString()).toContain('commit_wallet_opened_dns') + await expect(consoleListener.getMessages().toString()).toContain( + 'dns_approve_registrar_wallet_opened', + ) consoleListener.clearMessages() }) @@ -106,23 +115,15 @@ test('should allow claim (owned by user)', async ({ // should allow finalising await importPage.nextButton.click() - await test.step('should fire DNS import tracking event: register_started_dns', async () => { - await expect(consoleListener.getMessages()).toHaveLength(1) - - await expect(consoleListener.getMessages().toString()).toContain('register_started_dns') - consoleListener.clearMessages() - }) - // transaction modal should still have 2 steps await expect(transactionModal.getStepCount()).resolves.toEqual(2) await expect(page.getByText('Open Wallet')).toBeVisible() await transactionModal.confirm() - await test.step('should fire DNS import tracking event: register_wallet_opened_dns', async () => { + await test.step('should fire DNS import tracking event: dns_claim_wallet_opened', async () => { await expect(consoleListener.getMessages()).toHaveLength(1) - - await expect(consoleListener.getMessages().toString()).toContain('register_wallet_opened_dns') + await expect(consoleListener.getMessages().toString()).toContain('dns_claim_wallet_opened') consoleListener.clearMessages() }) From f5a2bcf46b2f84aa995af6c0a9f4789b653289dd Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 29 Oct 2024 22:36:36 +0800 Subject: [PATCH 37/75] fix onchain not owner e2e test --- e2e/specs/stateless/_importName.spec.ts | 26 ++++++++++++------------- src/hooks/useEventTracker.ts | 2 -- 2 files changed, 13 insertions(+), 15 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index 6b9c554cf..f60566b6c 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -2,17 +2,17 @@ import { expect } from '@playwright/test' import { test } from '../../../playwright' -// When testing locally, reducers will be run twice -const reducerEventCount = process.env.CI ? 1 : 2 +// When testing locally, reducers will be run twice because of strict mode +const strictModeEventCount = process.env.CI ? 1 : 2 -test.only('should allow claim (owned by user)', async ({ +test('should allow claim (owned by user)', async ({ page, login, accounts, makePageObject, consoleListener, }) => { - console.log(reducerEventCount) + console.log(strictModeEventCount) const name = 'swagabc.xyz' await consoleListener.initialize({ regex: new RegExp( @@ -69,7 +69,7 @@ test.only('should allow claim (owned by user)', async ({ await expect(importPage.heading).toHaveText('Claim your domain') await test.step('should fire DNS import tracking event: dns_selected_import_type', async () => { - await expect(consoleListener.getMessages()).toHaveLength(reducerEventCount) + await expect(consoleListener.getMessages()).toHaveLength(strictModeEventCount) await expect(consoleListener.getMessages().toString()).toMatch( new RegExp(`dns_selected_import_type.*?${name}`), @@ -149,8 +149,8 @@ test('should allow import (not owned by user)', async ({ regex: new RegExp( `Event triggered on local development.*?(${[ 'search_selected_dns', - 'import_type_selected_dns', - 'verify_ownership_started_dns', + 'dns_selected_import_type', + 'dns_verified_ownership', ].join('|')})`, ), }) @@ -190,11 +190,11 @@ test('should allow import (not owned by user)', async ({ await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) await importPage.nextButton.click() - await test.step('should fire DNS import tracking event: import_type_selected_dns', async () => { - await expect(consoleListener.getMessages()).toHaveLength(1) + await test.step('should fire DNS import tracking event: dns_selected_import_type', async () => { + await expect(consoleListener.getMessages()).toHaveLength(strictModeEventCount) await expect(consoleListener.getMessages().toString()).toMatch( - new RegExp(`import_type_selected_dns.*?${name}`), + new RegExp(`dns_selected_import_type.*?${name}`), ) consoleListener.clearMessages() }) @@ -211,10 +211,10 @@ test('should allow import (not owned by user)', async ({ await importPage.nextButton.click() - await test.step('should fire DNS import tracking event: verify_ownership_started_dns', async () => { - await expect(consoleListener.getMessages()).toHaveLength(1) + await test.step('should fire DNS import tracking event: dns_verified_ownership', async () => { + await expect(consoleListener.getMessages()).toHaveLength(strictModeEventCount) - await expect(consoleListener.getMessages().toString()).toContain('verify_ownership_started_dns') + await expect(consoleListener.getMessages().toString()).toContain('dns_verified_ownership') consoleListener.clearMessages() }) diff --git a/src/hooks/useEventTracker.ts b/src/hooks/useEventTracker.ts index 2bc960368..b7257638d 100644 --- a/src/hooks/useEventTracker.ts +++ b/src/hooks/useEventTracker.ts @@ -43,7 +43,6 @@ type DefaultEvent = { | 'register_started' | 'register_started_box' | 'register_wallet_opened' - | 'verify_ownership_started_dns' | 'claim_domain_started_dns' | 'commit_wallet_opened_dns' | 'register_started_dns' @@ -84,7 +83,6 @@ export const useEventTracker = () => { 'register_started', 'register_started_box', 'register_wallet_opened', - 'verify_ownership_started_dns', 'claim_domain_started_dns', 'commit_wallet_opened_dns', 'register_started_dns', From 96746a204b8f54a57373156e116436effd11651c Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 29 Oct 2024 23:22:50 +0800 Subject: [PATCH 38/75] clean up console logs and page pauses --- e2e/specs/stateless/_importName.spec.ts | 2 -- e2e/specs/stateless/advancedEditor.spec.ts | 5 ++- e2e/specs/stateless/deleteSubname.spec.ts | 1 - e2e/specs/stateless/extendNames.spec.ts | 5 --- e2e/specs/stateless/myNames.spec.ts | 3 -- e2e/specs/stateless/ownership.2LD.spec.ts | 8 ++--- e2e/specs/stateless/ownership.4LD.spec.ts | 3 -- e2e/specs/stateless/profileEditor.spec.ts | 32 +++---------------- e2e/specs/stateless/setPrimary.spec.ts | 8 ++--- e2e/specs/stateless/verifications.spec.ts | 21 ------------ e2e/specs/stateless/wrapName.spec.ts | 3 -- .../import/[name]/useDnsImportReducer.ts | 2 -- .../input/ProfileReclaim-flow.tsx | 1 - 13 files changed, 11 insertions(+), 83 deletions(-) diff --git a/e2e/specs/stateless/_importName.spec.ts b/e2e/specs/stateless/_importName.spec.ts index f60566b6c..1c9c9de6f 100644 --- a/e2e/specs/stateless/_importName.spec.ts +++ b/e2e/specs/stateless/_importName.spec.ts @@ -63,8 +63,6 @@ test('should allow claim (owned by user)', async ({ await expect(importPage.nextButton).toBeEnabled({ timeout: 15000 }) await importPage.nextButton.click() - await page.pause() - // should jump straight to transaction step await expect(importPage.heading).toHaveText('Claim your domain') diff --git a/e2e/specs/stateless/advancedEditor.spec.ts b/e2e/specs/stateless/advancedEditor.spec.ts index 1f4e770d1..ec83ed3a3 100644 --- a/e2e/specs/stateless/advancedEditor.spec.ts +++ b/e2e/specs/stateless/advancedEditor.spec.ts @@ -152,7 +152,6 @@ test('should maintain state and when returning from transaction modal when addin await recordsPage.goto(name) await login.connect() - await page.pause() // Validate records await expect(recordsPage.getRecordValue('text', 'name')).toHaveText('Bob') @@ -257,7 +256,7 @@ test('should maintain state and when returning from transaction modal when addin await transactionModal.autoComplete() // Validate change in records - await page.pause() + await expect(recordsPage.getRecordValue('text', 'name')).toHaveText('Nick') await expect(recordsPage.getRecordValue('text', 'another text')).toHaveText('another record') await expect(recordsPage.getRecordValue('address', 'bnb')).toHaveText( @@ -266,7 +265,7 @@ test('should maintain state and when returning from transaction modal when addin await expect(recordsPage.getRecordValue('address', 'eth')).toHaveText( '0x70997970C51812dc3A010C7d01b50e0d17dc79C8', ) - await page.pause() + await expect(recordsPage.getRecordValue('contentHash')).toHaveText( 'bzz://e40101fa011b20d1de9994b4d039f6548d191eb26786769f580809256b4685ef316805265ea162'.toLowerCase(), ) diff --git a/e2e/specs/stateless/deleteSubname.spec.ts b/e2e/specs/stateless/deleteSubname.spec.ts index 094c294ed..25b4b61a8 100644 --- a/e2e/specs/stateless/deleteSubname.spec.ts +++ b/e2e/specs/stateless/deleteSubname.spec.ts @@ -26,7 +26,6 @@ test.describe('unwrapped', () => { await profilePage.goto(subname) await login.connect() - await page.pause() // Manager button should exist await expect(page.getByTestId('owner-profile-button-name.manager')).toBeVisible() diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index e0dbea69b..67515f294 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -196,7 +196,6 @@ test('should be able to extend a single unwrapped name in grace period from prof const timestamp = await profilePage.getExpiryTimestamp() - await page.pause() await profilePage.getExtendButton.click() const extendNamesModal = makePageObject('ExtendNamesModal') @@ -343,7 +342,6 @@ test('should be able to extend a name by a month', async ({ await profilePage.goto(name) await login.connect() - await page.pause() const timestamp = await profilePage.getExpiryTimestamp() await profilePage.getExtendButton.click() @@ -408,7 +406,6 @@ test('should be able to extend a name by a day', async ({ await profilePage.goto(name) await login.connect() - await page.pause() const timestamp = await profilePage.getExpiryTimestamp() await profilePage.getExtendButton.click() @@ -475,7 +472,6 @@ test('should be able to extend a name in grace period by a month', async ({ const timestamp = await profilePage.getExpiryTimestamp() - await page.pause() await profilePage.getExtendButton.click() const extendNamesModal = makePageObject('ExtendNamesModal') @@ -552,7 +548,6 @@ test('should be able to extend a name in grace period by 1 day', async ({ const timestamp = await profilePage.getExpiryTimestamp() - await page.pause() await profilePage.getExtendButton.click() const extendNamesModal = makePageObject('ExtendNamesModal') diff --git a/e2e/specs/stateless/myNames.spec.ts b/e2e/specs/stateless/myNames.spec.ts index 0c3ae97c5..506770b62 100644 --- a/e2e/specs/stateless/myNames.spec.ts +++ b/e2e/specs/stateless/myNames.spec.ts @@ -18,7 +18,6 @@ test('myNames', async ({ page, login, makeName }) => { await page.goto('/') await login.connect('user2') - await page.pause() await page.goto('/my/names') @@ -32,6 +31,4 @@ test('myNames', async ({ page, login, makeName }) => { ) expect(timestamps.every((timestamp) => timestamp === timestamps[0])).toBe(true) - - await page.pause() }) diff --git a/e2e/specs/stateless/ownership.2LD.spec.ts b/e2e/specs/stateless/ownership.2LD.spec.ts index f4aa055c4..8fa590a0d 100644 --- a/e2e/specs/stateless/ownership.2LD.spec.ts +++ b/e2e/specs/stateless/ownership.2LD.spec.ts @@ -48,7 +48,6 @@ test.describe('Unwrapped 2LD - Owner and Manager', () => { await transactionModal.autoComplete() - await page.pause() await expect(ownershipPage.roleRow(accounts.getAddress('user3'))).toContainText('owner', { timeout: 15000, }) @@ -368,7 +367,6 @@ test.describe('Unwrapped 2LD - Manager Only', () => { await ownershipPage.goto(name) await login.connect() - await page.pause() expect(await ownershipPage.getExpiryTimestamp()).toBeGreaterThan(0) await expect(ownershipPage.expiryPanelRegistrationDate).toHaveCount(1) await expect(ownershipPage.expiryPanelGracePeriod).toHaveCount(1) @@ -538,7 +536,6 @@ test.describe('Grace Period Unwrapped 2LD', () => { await ownershipPage.goto(name) await login.connect() - await page.pause() await expect(ownershipPage.sendNameButton).toHaveCount(0) }) @@ -580,7 +577,7 @@ test.describe('Grace Period Unwrapped 2LD', () => { await ownershipPage.goto(name) await login.connect() - await page.pause() + await ownershipPage.editRolesButton.click() await expect(editRolesModal.roleCardChangeButton('owner')).toHaveCount(0) @@ -650,7 +647,6 @@ test.describe('Grace Period Wrapped 2LD', () => { await ownershipPage.goto(name) await login.connect() - await page.pause() await expect(ownershipPage.sendNameButton).toHaveCount(0) }) @@ -691,7 +687,7 @@ test.describe('Grace Period Wrapped 2LD', () => { await ownershipPage.goto(name) await login.connect() - await page.pause() + await ownershipPage.editRolesButton.click() await expect(editRolesModal.roleCardChangeButton('owner')).toHaveCount(0) diff --git a/e2e/specs/stateless/ownership.4LD.spec.ts b/e2e/specs/stateless/ownership.4LD.spec.ts index 19ffef7c6..58c7ed289 100644 --- a/e2e/specs/stateless/ownership.4LD.spec.ts +++ b/e2e/specs/stateless/ownership.4LD.spec.ts @@ -424,7 +424,6 @@ test.describe('Unwrapped 4LD, Unwrapped 3LD,2LD - Manager Only', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await expect(ownershipPage.expiryPanelExpiry).toHaveCount(0) await expect(ownershipPage.expiryPanelGracePeriod).toHaveCount(0) @@ -683,7 +682,6 @@ test.describe('Unwrapped 4LD - Wrapped 3LD,2LD - Parent Owner only', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await page.waitForTimeout(2000) await expect(ownershipPage.sendNameButton).toHaveCount(0) await expect(ownershipPage.editRolesButton).toHaveCount(0) @@ -776,7 +774,6 @@ test.describe('Unwrapped 4LD, Wrapped 3LD,2LD - Manager Only', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await ownershipPage.sendNameButton.click() await sendNameModal.searchInput.fill(accounts.getAddress('user3')) await sendNameModal.searchResult(accounts.getAddress('user3')).click() diff --git a/e2e/specs/stateless/profileEditor.spec.ts b/e2e/specs/stateless/profileEditor.spec.ts index 77839e758..f0733b6ca 100644 --- a/e2e/specs/stateless/profileEditor.spec.ts +++ b/e2e/specs/stateless/profileEditor.spec.ts @@ -96,7 +96,6 @@ test.describe('profile', () => { await profilePage.goto(name) await login.connect() - await page.pause() await expect(profilePage.record('text', 'description')).toHaveText('Hello2') await expect(profilePage.record('text', 'url')).toHaveText('twitter.com') await expect(profilePage.record('address', 'btc')).toHaveText('bc1qj...pwa6n') @@ -126,7 +125,6 @@ test.describe('profile', () => { await expect(page).toHaveURL(`/${name}`) - await page.pause() await expect(profilePage.record('text', 'description')).toHaveText('Hello2') await expect(profilePage.record('text', 'url')).toHaveText('twitter.com') await expect(profilePage.record('address', 'btc')).toHaveText('bc1qj...pwa6n') @@ -215,7 +213,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect('user2') - await page.pause() await expect(morePage.resolver.getByText(ownedResolverAddress)).toBeVisible() @@ -250,7 +247,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(invalidResolverAddress)).toBeVisible() @@ -283,7 +279,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver).toHaveText(oldResolver) @@ -329,7 +324,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -350,7 +344,7 @@ test.describe('migrations', () => { await expect(morePage.resolver.getByText(newResolver)).toBeVisible() await recordsPage.goto(name) - await page.pause() + await expect(recordsPage.getRecordValue('text', 'email')).toHaveText('fakeemail@fake.com') await expect(recordsPage.getRecordValue('text', 'description')).toHaveText('Hello2') await expect(recordsPage.getRecordValue('text', 'url')).toHaveText('https://twitter.com') @@ -399,7 +393,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -424,7 +417,7 @@ test.describe('migrations', () => { await expect(morePage.resolver.getByText(newResolver)).toBeVisible() await recordsPage.goto(name) - await page.pause() + await expect(page.getByTestId('text-amount')).toHaveText('0 Records') await expect(page.getByTestId('address-amount')).toHaveText('0 Records') await expect(page.getByText('No Content Hash')).toBeVisible() @@ -466,7 +459,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -484,7 +476,7 @@ test.describe('migrations', () => { await expect(morePage.resolver.getByText(newResolver)).toBeVisible() await recordsPage.goto(name) - await page.pause() + await expect(recordsPage.getRecordValue('text', 'email')).toHaveText('fakeemail@fake.com') await expect(recordsPage.getRecordValue('text', 'description')).toHaveText('New profile') await expect(recordsPage.getRecordValue('text', 'url')).toHaveText('https://twitter.com') @@ -538,7 +530,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -547,7 +538,6 @@ test.describe('migrations', () => { await expect(page.getByText('Resolver out of sync')).toBeVisible() await profilePage.profileEditor.getByTestId('warning-overlay-next-button').click() - await page.pause() await page.getByTestId('migrate-profile-selector-current').check() await expect(page.getByTestId('migrate-profile-selector-current')).toBeChecked() await profilePage.profileEditor.getByTestId('warning-overlay-next-button').click() @@ -561,7 +551,7 @@ test.describe('migrations', () => { await expect(morePage.resolver.getByText(newResolver)).toBeVisible() await recordsPage.goto(name) - await page.pause() + await expect(page.getByTestId('text-amount')).toHaveText('3 Records') await expect(recordsPage.getRecordValue('text', 'email')).toHaveText('fakeemail@fake.com') await expect(recordsPage.getRecordValue('text', 'description')).toHaveText('Hello2') @@ -615,7 +605,6 @@ test.describe('migrations', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -624,13 +613,10 @@ test.describe('migrations', () => { await expect(page.getByText('Resolver out of sync')).toBeVisible() await profilePage.profileEditor.getByTestId('warning-overlay-next-button').click() - await page.pause() await page.getByTestId('migrate-profile-selector-reset').check() await expect(page.getByTestId('migrate-profile-selector-reset')).toBeChecked() await profilePage.profileEditor.getByTestId('warning-overlay-next-button').click() - await page.pause() - await expect(page.getByText('Reset profile')).toBeVisible() await profilePage.profileEditor.getByTestId('warning-overlay-next-button').click() @@ -640,7 +626,7 @@ test.describe('migrations', () => { await expect(morePage.resolver.getByText(newResolver)).toBeVisible() await recordsPage.goto(name) - await page.pause() + await expect(page.getByTestId('text-amount')).toHaveText('0 Records') await expect(page.getByTestId('address-amount')).toHaveText('0 Records') await expect(page.getByText('No Content Hash')).toBeVisible() @@ -670,7 +656,6 @@ test.describe('unwrapped', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -702,7 +687,6 @@ test.describe('unwrapped', () => { await morePage.goto(name) await expect(morePage.resolver).toHaveText(oldResolver) - await page.pause() await recordsPage.goto(name) await expect(recordsPage.getRecordValue('text', 'location')).toHaveText('L1 chain') await expect(recordsPage.getRecordValue('text', 'description')).toHaveText('new name') @@ -737,7 +721,6 @@ test.describe('unwrapped', () => { await morePage.goto(name) await login.connect() - await page.pause() await expect(morePage.resolver.getByText(oldResolver)).toBeVisible() @@ -785,7 +768,6 @@ test.describe('unwrapped', () => { await morePage.goto(name) await expect(morePage.resolver).toHaveText(oldResolver) - await page.pause() await recordsPage.goto(name) await expect(page.getByTestId('text-amount')).toHaveText('0 Records') await expect(page.getByTestId('address-amount')).toHaveText('0 Records') @@ -814,7 +796,6 @@ test.describe('wrapped', () => { await profilePage.goto(name) await login.connect() - await page.pause() await expect(profilePage.record('text', 'description')).toHaveText('Hello2') await expect(profilePage.record('text', 'url')).toHaveText('twitter.com') @@ -838,7 +819,6 @@ test.describe('wrapped', () => { await transactionModal.autoComplete() - await page.pause() await recordsPage.goto(name) await expect(recordsPage.getRecordValue('text', 'location')).toHaveText('L1 chain') await expect(recordsPage.getRecordValue('text', 'description')).toHaveText('new name') @@ -871,7 +851,6 @@ test.describe('wrapped', () => { await profilePage.goto(name) await login.connect() - await page.pause() await expect(profilePage.record('text', 'description')).toHaveText('Hello2') await expect(profilePage.record('text', 'url')).toHaveText('twitter.com') @@ -911,7 +890,6 @@ test.describe('wrapped', () => { await transactionModal.autoComplete() - await page.pause() await recordsPage.goto(name) await expect(page.getByTestId('text-amount')).toHaveText('0 Records') await expect(page.getByTestId('address-amount')).toHaveText('0 Records') diff --git a/e2e/specs/stateless/setPrimary.spec.ts b/e2e/specs/stateless/setPrimary.spec.ts index df0bf6040..8237984eb 100644 --- a/e2e/specs/stateless/setPrimary.spec.ts +++ b/e2e/specs/stateless/setPrimary.spec.ts @@ -186,7 +186,7 @@ test.describe('profile', () => { await morePage.goto(subname) await login.connect() - await page.pause() + await expect(morePage.resolver).toContainText(UNAUTHORISED_RESOLVER) await profilePage.goto(subname) @@ -317,7 +317,7 @@ test.describe('profile', () => { await profilePage.goto(subname) await login.connect() - await page.pause() + // Assert state await expect(page.getByTestId('profile-title')).not.toContainText(subname) @@ -426,8 +426,6 @@ test.describe('profile', () => { await profilePage.goto(subname) await login.connect() - await page.pause() - // Assert state await expect(page.getByTestId('owner-profile-button-name.manager')).toContainText( accounts.getAddress('user', 5), @@ -482,8 +480,6 @@ test.describe('profile', () => { await profilePage.goto(name) await login.connect() - await page.pause() - await expect(page.getByTestId('profile-action-Set as primary name')).toHaveCount(0) // Assert state diff --git a/e2e/specs/stateless/verifications.spec.ts b/e2e/specs/stateless/verifications.spec.ts index 3f23e22e4..3145b4ac6 100644 --- a/e2e/specs/stateless/verifications.spec.ts +++ b/e2e/specs/stateless/verifications.spec.ts @@ -108,8 +108,6 @@ test.describe('Verified records', () => { await page.goto(`/${name}`) // await login.connect() - await page.pause() - await expect(page.getByTestId('profile-section-verifications')).toBeVisible() await profilePage.isRecordVerified('text', 'com.twitter') @@ -180,8 +178,6 @@ test.describe('Verified records', () => { await page.goto(`/${name}`) - await page.pause() - await expect(page.getByTestId('profile-section-verifications')).toBeVisible() await profilePage.isRecordVerified('text', 'com.twitter', false) @@ -345,8 +341,6 @@ test.describe('Verify profile', () => { await profilePage.goto(name) await login.connect() - await page.pause() - await expect(page.getByTestId('profile-section-verifications')).toBeVisible() await profilePage.isRecordVerified('text', 'com.twitter') @@ -374,7 +368,6 @@ test.describe('Verify profile', () => { await profilePage.isRecordVerified('text', 'com.discord', false) await profilePage.isRecordVerified('verification', 'dentity', false) await profilePage.isPersonhoodVerified(false) - await page.pause() }) }) @@ -488,8 +481,6 @@ test.describe('OAuth flow', () => { await page.goto(`/?iss=${DENTITY_ISS}&code=dummyCode`) await login.connect() - await page.pause() - await expect(page.getByText('Verification failed')).toBeVisible() await expect( page.getByText( @@ -497,13 +488,10 @@ test.describe('OAuth flow', () => { ), ).toBeVisible() - await page.pause() await login.switchTo('user2') // Page should redirect to the profile page await expect(page).toHaveURL(`/${name}`) - - await page.pause() }) test('Should show an error message if user is not logged in', async ({ @@ -531,8 +519,6 @@ test.describe('OAuth flow', () => { await page.goto(`/?iss=${DENTITY_ISS}&code=dummyCode`) - await page.pause() - await expect(page.getByText('Verification failed')).toBeVisible() await expect( page.getByText('You must be connected as 0x709...c79C8 to set the verification record.'), @@ -540,13 +526,10 @@ test.describe('OAuth flow', () => { await page.locator('.modal').getByRole('button', { name: 'Done' }).click() - await page.pause() await login.connect('user2') // Page should redirect to the profile page await expect(page).toHaveURL(`/${name}`) - - await page.pause() }) test('Should redirect to profile page without showing set verification record if it already set', async ({ @@ -594,8 +577,6 @@ test.describe('OAuth flow', () => { await expect(page).toHaveURL(`/${name}`) await expect(transactionModal.transactionModal).not.toBeVisible() - - await page.pause() }) test('Should show general error message if other problems occur', async ({ @@ -624,8 +605,6 @@ test.describe('OAuth flow', () => { await page.goto(`/?iss=${DENTITY_ISS}&code=dummyCode`) await login.connect('user') - await page.pause() - await expect(page.getByText('Verification failed')).toBeVisible() await expect( page.getByText("We could't verify your account. Please return to Dentity and try again."), diff --git a/e2e/specs/stateless/wrapName.spec.ts b/e2e/specs/stateless/wrapName.spec.ts index a1d104e0d..8b370f822 100644 --- a/e2e/specs/stateless/wrapName.spec.ts +++ b/e2e/specs/stateless/wrapName.spec.ts @@ -158,8 +158,6 @@ test('should allow wrapping a subdomain', async ({ page, makeName, login, makePa await morePage.goto(subname) await login.connect() - await page.pause() - // should approve name wrapper for address await morePage.wrapButton.click() @@ -198,7 +196,6 @@ test('should allow wrapping a name with an unknown label', async ({ await morePage.goto(subname) await login.connect() - await page.pause() await morePage.wrapButton.click() const input = page.getByTestId(`unknown-label-input-${unknownLabelhash}`) diff --git a/src/components/pages/import/[name]/useDnsImportReducer.ts b/src/components/pages/import/[name]/useDnsImportReducer.ts index 300178e50..24a5af4a2 100644 --- a/src/components/pages/import/[name]/useDnsImportReducer.ts +++ b/src/components/pages/import/[name]/useDnsImportReducer.ts @@ -124,7 +124,6 @@ const reducer = case 'increaseStep': { const currentStep = selectedItem.steps[selectedItem.stepIndex] - console.log('selectedItem', JSON.stringify(selectedItem)) const eventName = match(currentStep) .with('selectType', () => 'dns_selected_import_type' as const) .with('enableDnssec', () => 'dns_sec_enabled' as const) @@ -201,7 +200,6 @@ export const useDnsImportReducer = ({ } useEffect(() => { - console.log('cleanupNonMatching') dispatch({ name: 'cleanupNonMatching', selected }) // eslint-disable-next-line react-hooks/exhaustive-deps }, [address, name, chainId]) diff --git a/src/transaction-flow/input/ProfileReclaim-flow.tsx b/src/transaction-flow/input/ProfileReclaim-flow.tsx index a71448ecb..407a0727e 100644 --- a/src/transaction-flow/input/ProfileReclaim-flow.tsx +++ b/src/transaction-flow/input/ProfileReclaim-flow.tsx @@ -85,7 +85,6 @@ const ProfileReclaim = ({ data: { name, label, parent }, dispatch, onDismiss }: errorForRecordAtIndex, isDirtyForRecordAtIndex, } = useProfileEditorForm(existingRecords) - console.log(existingRecords) const handleSubmit = () => { const payload = [ createTransactionItem('createSubname', { From 0006c4a13a17798a74e3394f75ecd5ac4a229a2e Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 29 Oct 2024 23:23:16 +0800 Subject: [PATCH 39/75] remove page pause --- e2e/specs/stateful/address.spec.ts | 1 - e2e/specs/stateless/ownership.3LD.spec.ts | 3 --- e2e/specs/stateless/ownership.spec.ts | 13 ++++--------- e2e/specs/stateless/registerName.spec.ts | 2 -- 4 files changed, 4 insertions(+), 15 deletions(-) diff --git a/e2e/specs/stateful/address.spec.ts b/e2e/specs/stateful/address.spec.ts index 3997ab815..4fce98112 100644 --- a/e2e/specs/stateful/address.spec.ts +++ b/e2e/specs/stateful/address.spec.ts @@ -18,7 +18,6 @@ test('should go to the address page', async ({ page, login }) => { await page.goto('/') await login.connect() - await page.pause() await page .getByPlaceholder('Search for a name') .fill('0xFc5958B4B6F9a06D21E06429c8833f865577acf0') diff --git a/e2e/specs/stateless/ownership.3LD.spec.ts b/e2e/specs/stateless/ownership.3LD.spec.ts index 000cbef68..4c42a7288 100644 --- a/e2e/specs/stateless/ownership.3LD.spec.ts +++ b/e2e/specs/stateless/ownership.3LD.spec.ts @@ -34,7 +34,6 @@ test.describe('Unwrapped 3LD, Unwrapped 2LD - Parent Owner and Manager', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await ownershipPage.sendNameButton.click() await sendNameModal.searchInput.fill(accounts.getAddress('user3')) await sendNameModal.searchResult(accounts.getAddress('user3')).click() @@ -1193,7 +1192,6 @@ test.describe('Wrapped 3LD, Unwrapped 2LD - Manager only', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await ownershipPage.sendNameButton.click() await sendNameModal.searchInput.fill(accounts.getAddress('user3')) await sendNameModal.searchResult(accounts.getAddress('user3')).click() @@ -1390,7 +1388,6 @@ test.describe('Wrapped 3LD, Unwrapped 2LD - Parent only', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await page.waitForTimeout(2000) await expect(ownershipPage.sendNameButton).toHaveCount(0) await expect(ownershipPage.editRolesButton).toHaveCount(0) diff --git a/e2e/specs/stateless/ownership.spec.ts b/e2e/specs/stateless/ownership.spec.ts index 332de2f35..890f57477 100644 --- a/e2e/specs/stateless/ownership.spec.ts +++ b/e2e/specs/stateless/ownership.spec.ts @@ -389,7 +389,7 @@ test.describe('Send name', () => { await expect(ownershipPage.roleRow(accounts.getAddress('user3'))).toContainText('manager', { timeout: 15000, }) - await page.pause() + await expect(ownershipPage.roleRow(accounts.getAddress('user2'))).toContainText('Parent owner') await expect(ownershipPage.roleRow(accounts.getAddress('user3'))).toContainText('ETH record') }) @@ -436,7 +436,6 @@ test.describe('Send name', () => { await profilePage.goto(subname) await login.connect() await expect(profilePage.record('text', 'nickname')).toContainText('test') - await page.pause() await ownershipPage.goto(subname) await ownershipPage.sendNameButton.click() @@ -460,7 +459,7 @@ test.describe('Send name', () => { await expect(ownershipPage.roleRow(accounts.getAddress('user3'))).toContainText('manager', { timeout: 15000, }) - await page.pause() + await expect(ownershipPage.roleRow(accounts.getAddress('user'))).toContainText('Parent owner') await expect(ownershipPage.roleRow('0x42D63ae25990889E35F215bC95884039Ba354115')).toContainText( 'ETH record', @@ -535,7 +534,7 @@ test.describe('Send name', () => { await expect(ownershipPage.roleRow(accounts.getAddress('user3'))).toContainText('manager', { timeout: 15000, }) - await page.pause() + await expect(ownershipPage.roleRow(accounts.getAddress('user2'))).toContainText('Parent owner') await expect(ownershipPage.roleRow(accounts.getAddress('user3'))).toContainText('ETH record') @@ -601,7 +600,6 @@ test.describe('Send name', () => { await sendNameModal.searchResult(accounts.getAddress('user3')).click() await sendNameModal.resetProfileSwitch.check() - await page.pause() // Should not be able to set owner because name is unwrapped // Should not be able to set eth record because user is not the manager // Should not be able to reset profile since old resolver does not support VersionableResolver @@ -682,7 +680,7 @@ test.describe('Edit roles: Happy ', () => { // Should not allow the manager to change the owner await expect(editRolesModal.roleCard('owner')).toHaveCount(0) await editRolesModal.roleCardChangeButton('manager').click() - await page.pause() + await editRolesModal.searchInput.fill(accounts.getAddress('user3')) await editRolesModal.searchResult(accounts.getAddress('user3')).click() await editRolesModal.saveButton.click() @@ -889,7 +887,6 @@ test.describe('Edit roles: Unwrapped subnames', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await page.waitForTimeout(2000) await expect(ownershipPage.sendNameButton).toHaveCount(0) @@ -959,7 +956,6 @@ test.describe('Edit roles: Wrapped subnames', () => { await ownershipPage.goto(subname) await login.connect() - await page.pause() await ownershipPage.editRolesButton.click() await editRolesModal.roleCardChangeButton('manager').click() @@ -1143,7 +1139,6 @@ test.describe('Extend name', () => { await ownershipPage.goto(name) await login.connect() - await page.pause() const timestamp = await ownershipPage.getExpiryTimestamp() diff --git a/e2e/specs/stateless/registerName.spec.ts b/e2e/specs/stateless/registerName.spec.ts index 1b2209a93..d4ccb4326 100644 --- a/e2e/specs/stateless/registerName.spec.ts +++ b/e2e/specs/stateless/registerName.spec.ts @@ -388,7 +388,6 @@ test('should allow registering a name and resuming from the commit toast', async await page.goto(`/${name}/register`) await login.connect() - await page.pause() await page.getByTestId('payment-choice-ethereum').click() await page.getByTestId('primary-name-toggle').uncheck() await page.getByTestId('next-button').click() @@ -449,7 +448,6 @@ test('should allow registering with a specific date', async ({ page, login, make await calendar.fill(dateToDateInput(twoYearsAndHalfLater)) - await page.pause() await expect(page.getByTestId('calendar-date')).toHaveValue( dateToDateInput(twoYearsAndHalfLater), ) From 6ef12d787833e545fb1a15a72a58d9ab27b8d405 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Tue, 29 Oct 2024 23:40:13 +0800 Subject: [PATCH 40/75] fix build errors --- e2e/specs/stateless/ownership.2LD.spec.ts | 10 +++++----- e2e/specs/stateless/ownership.3LD.spec.ts | 4 ++-- e2e/specs/stateless/ownership.4LD.spec.ts | 9 ++------- e2e/specs/stateless/ownership.spec.ts | 3 --- e2e/specs/stateless/profileEditor.spec.ts | 7 +------ e2e/specs/stateless/wrapName.spec.ts | 2 +- 6 files changed, 11 insertions(+), 24 deletions(-) diff --git a/e2e/specs/stateless/ownership.2LD.spec.ts b/e2e/specs/stateless/ownership.2LD.spec.ts index 8fa590a0d..3910a0738 100644 --- a/e2e/specs/stateless/ownership.2LD.spec.ts +++ b/e2e/specs/stateless/ownership.2LD.spec.ts @@ -3,7 +3,7 @@ import { expect } from '@playwright/test' import { test } from '../../../playwright' test.describe('Unwrapped 2LD - Owner and Manager', () => { - test('Send feature', async ({ page, login, accounts, makeName, makePageObject }) => { + test('Send feature', async ({ login, accounts, makeName, makePageObject }) => { const name = await makeName({ label: 'owner-manager', type: 'legacy', @@ -516,7 +516,7 @@ test.describe('Wrapped and Emancipated 2LD - Owner', () => { }) test.describe('Grace Period Unwrapped 2LD', () => { - test('Send feature', async ({ page, login, makeName, makePageObject }) => { + test('Send feature', async ({ login, makeName, makePageObject }) => { const name = await makeName({ label: 'grace-period-unwrapped', type: 'legacy', @@ -564,7 +564,7 @@ test.describe('Grace Period Unwrapped 2LD', () => { await expect(ownershipPage.syncManagerButton).toHaveCount(0) }) - test('Edit Roles', async ({ page, login, accounts, makeName, makePageObject }) => { + test('Edit Roles', async ({ login, accounts, makeName, makePageObject }) => { const name = await makeName({ label: 'grace-period-unwrapped', type: 'legacy', @@ -627,7 +627,7 @@ test.describe('Grace Period Unwrapped 2LD', () => { }) test.describe('Grace Period Wrapped 2LD', () => { - test('Send feature', async ({ page, login, makeName, makePageObject }) => { + test('Send feature', async ({ login, makeName, makePageObject }) => { const name = await makeName({ label: 'grace-period-wrapped', type: 'wrapped', @@ -674,7 +674,7 @@ test.describe('Grace Period Wrapped 2LD', () => { await expect(ownershipPage.syncManagerButton).toHaveCount(0) }) - test('Edit Roles', async ({ page, login, accounts, makeName, makePageObject }) => { + test('Edit Roles', async ({ login, accounts, makeName, makePageObject }) => { const name = await makeName({ label: 'grace-period-wrapped', type: 'wrapped', diff --git a/e2e/specs/stateless/ownership.3LD.spec.ts b/e2e/specs/stateless/ownership.3LD.spec.ts index 4c42a7288..0d574db81 100644 --- a/e2e/specs/stateless/ownership.3LD.spec.ts +++ b/e2e/specs/stateless/ownership.3LD.spec.ts @@ -4,7 +4,7 @@ import { test } from '../../../playwright' import { testClient } from '../../../playwright/fixtures/contracts/utils/addTestContracts' test.describe('Unwrapped 3LD, Unwrapped 2LD - Parent Owner and Manager', () => { - test('Send feature', async ({ page, login, accounts, makeName, makePageObject }) => { + test('Send feature', async ({ login, accounts, makeName, makePageObject }) => { const name = await makeName({ label: 'unwrapped', type: 'legacy', @@ -1160,7 +1160,7 @@ test.describe('Wrapped 3LD - Wrapped 2LD - Parent Owner only', () => { }) test.describe('Wrapped 3LD, Unwrapped 2LD - Manager only', () => { - test('Send feature', async ({ page, login, accounts, makeName, makePageObject }) => { + test('Send feature', async ({ login, accounts, makeName, makePageObject }) => { const name = await makeName({ label: 'unwrapped', type: 'legacy', diff --git a/e2e/specs/stateless/ownership.4LD.spec.ts b/e2e/specs/stateless/ownership.4LD.spec.ts index 58c7ed289..702de55a2 100644 --- a/e2e/specs/stateless/ownership.4LD.spec.ts +++ b/e2e/specs/stateless/ownership.4LD.spec.ts @@ -386,12 +386,7 @@ test.describe('Unwrapped 4LD, Unwrapped 3LD,2LD - Manager Only', () => { }) }) - test('Expiry Section, Extend & Set Reminder', async ({ - login, - makeName, - makePageObject, - page, - }) => { + test('Expiry Section, Extend & Set Reminder', async ({ login, makeName, makePageObject }) => { const name = await makeName({ label: 'unwrapped', type: 'legacy', @@ -736,7 +731,7 @@ test.describe('Unwrapped 4LD - Wrapped 3LD,2LD - Parent Owner only', () => { }) test.describe('Unwrapped 4LD, Wrapped 3LD,2LD - Manager Only', () => { - test('Send feature', async ({ page, login, accounts, makeName, makePageObject }) => { + test('Send feature', async ({ login, accounts, makeName, makePageObject }) => { const name = await makeName({ label: 'unwrapped', type: 'wrapped', diff --git a/e2e/specs/stateless/ownership.spec.ts b/e2e/specs/stateless/ownership.spec.ts index 890f57477..50aa0cd55 100644 --- a/e2e/specs/stateless/ownership.spec.ts +++ b/e2e/specs/stateless/ownership.spec.ts @@ -328,7 +328,6 @@ test.describe('Send name', () => { }) test('should be able to send manager and eth-record if user is manager and not parent owner of unwrapped subname', async ({ - page, login, accounts, makeName, @@ -655,7 +654,6 @@ test.describe('Edit roles: Happy ', () => { }) test('Should allow manager to change manager when they are not the owner', async ({ - page, login, accounts, makeName, @@ -929,7 +927,6 @@ test.describe('Edit roles: Unwrapped name', () => { test.describe('Edit roles: Wrapped subnames', () => { test('should allow namewrapper subname owner to send name', async ({ - page, login, accounts, makeName, diff --git a/e2e/specs/stateless/profileEditor.spec.ts b/e2e/specs/stateless/profileEditor.spec.ts index f0733b6ca..823c9cdb6 100644 --- a/e2e/specs/stateless/profileEditor.spec.ts +++ b/e2e/specs/stateless/profileEditor.spec.ts @@ -84,7 +84,7 @@ const makeRecords = async (overwrites: RecordOptions = {}): Promise { - test('should display profile records', async ({ page, login, makeName, makePageObject }) => { + test('should display profile records', async ({ login, makeName, makePageObject }) => { const name = await makeName({ label: 'profile', type: 'legacy', @@ -194,7 +194,6 @@ test.describe('migrations', () => { }) test('should force a name with an unauthorised resolver to update their resolver', async ({ - page, login, makeName, makePageObject, @@ -228,7 +227,6 @@ test.describe('migrations', () => { }) test('should force a name with an invalid resolver to update their resolver', async ({ - page, login, makeName, makePageObject, @@ -262,7 +260,6 @@ test.describe('migrations', () => { }) test('should force a wrapped name with a resolver that is not name wrapper aware to migrate update their resolver', async ({ - page, login, makeName, makePageObject, @@ -636,7 +633,6 @@ test.describe('migrations', () => { test.describe('unwrapped', () => { test('should be able to add/update profile records without migration', async ({ - page, login, makeName, makePageObject, @@ -778,7 +774,6 @@ test.describe('unwrapped', () => { test.describe('wrapped', () => { test('should be able to add/update profile records without migration', async ({ - page, login, makeName, makePageObject, diff --git a/e2e/specs/stateless/wrapName.spec.ts b/e2e/specs/stateless/wrapName.spec.ts index 8b370f822..607839564 100644 --- a/e2e/specs/stateless/wrapName.spec.ts +++ b/e2e/specs/stateless/wrapName.spec.ts @@ -131,7 +131,7 @@ test('should wrap name', async ({ makeName, login, makePageObject }) => { await expect(morePage.wrapButton).toHaveCount(0) }) -test('should allow wrapping a subdomain', async ({ page, makeName, login, makePageObject }) => { +test('should allow wrapping a subdomain', async ({ makeName, login, makePageObject }) => { const name = await makeName({ label: 'unwrapped-with-wrapped-subnames', type: 'legacy', From 3b6c34b5d26939924ba9071fce4a9466da6a6133 Mon Sep 17 00:00:00 2001 From: sugh01 <19183308+sugh01@users.noreply.github.com> Date: Tue, 29 Oct 2024 20:53:49 +0100 Subject: [PATCH 41/75] fix flakiness --- e2e/specs/stateless/extendNames.spec.ts | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index 7cadb3c67..b8f7cb05c 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -90,9 +90,7 @@ test('should be able to extend multiple names on the address page', async ({ await transactionModal.autoComplete() - await expect(page.getByText('Your "Extend names" transaction was successful')).toBeVisible({ - timeout: 15000, - }) + expect(page.getByText('Your "Extend names" transaction was successful')).toBeDefined() await subgraph.sync() // Should be able to remove this after useQuery is fixed. Using to force a refetch. From cf8d9010044a9963c2bba3941ca414d651df94f8 Mon Sep 17 00:00:00 2001 From: sugh01 <19183308+sugh01@users.noreply.github.com> Date: Tue, 29 Oct 2024 22:24:18 +0100 Subject: [PATCH 42/75] fix flakiness --- e2e/specs/stateless/extendNames.spec.ts | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index b8f7cb05c..fb2e7f9d8 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -89,8 +89,11 @@ test('should be able to extend multiple names on the address page', async ({ await page.waitForLoadState('networkidle') await transactionModal.autoComplete() + await page.waitForLoadState('networkidle') - expect(page.getByText('Your "Extend names" transaction was successful')).toBeDefined() + await expect(page.getByText('Your "Extend names" transaction was successful')).toBeVisible({ + timeout: 10000, + }) await subgraph.sync() // Should be able to remove this after useQuery is fixed. Using to force a refetch. From f0b74a28d8e27f89d9e3670631725db9c00ba6a6 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Thu, 31 Oct 2024 15:41:20 +0200 Subject: [PATCH 43/75] wip migrate --- public/confetti.png | Bin 0 -> 107983 bytes public/locales/en/ensvs2.json | 4 + src/components/pages/migrate/Carousel.tsx | 21 +++ src/pages/migrate.tsx | 218 ++++++++++++++++++++++ 4 files changed, 243 insertions(+) create mode 100644 public/confetti.png create mode 100644 public/locales/en/ensvs2.json create mode 100644 src/components/pages/migrate/Carousel.tsx create mode 100644 src/pages/migrate.tsx diff --git a/public/confetti.png b/public/confetti.png new file mode 100644 index 0000000000000000000000000000000000000000..eab8f092f45b92920f6a2a432db23466c7268900 GIT binary patch literal 107983 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 SY0N0flgUacN&XNw4*Gu~l@Rg( literal 0 HcmV?d00001 diff --git a/public/locales/en/ensvs2.json b/public/locales/en/ensvs2.json new file mode 100644 index 000000000..ac4b3e432 --- /dev/null +++ b/public/locales/en/ensvs2.json @@ -0,0 +1,4 @@ +{ + "title": "ENSv2: The Next Generation of ENS", + "caption": "Approve your ENS names for ENSv2 now and enjoy automatic migration, paid for by ENS DAO." +} \ No newline at end of file diff --git a/src/components/pages/migrate/Carousel.tsx b/src/components/pages/migrate/Carousel.tsx new file mode 100644 index 000000000..9d25dca59 --- /dev/null +++ b/src/components/pages/migrate/Carousel.tsx @@ -0,0 +1,21 @@ +import { Splide, SplideSlide } from '@splidejs/react-splide' +import { ReactNode } from 'react' + +export const Carousel = ({ children }: { children: ReactNode[] }) => { + return ( + + {children.map((child, i) => ( + // eslint-disable-next-line react/no-array-index-key + {child} + ))} + + ) +} \ No newline at end of file diff --git a/src/pages/migrate.tsx b/src/pages/migrate.tsx new file mode 100644 index 000000000..948c5a7b3 --- /dev/null +++ b/src/pages/migrate.tsx @@ -0,0 +1,218 @@ +import { useTranslation } from 'react-i18next' +import styled, { css } from 'styled-components' + +import { + Banner, + Button, + Card, + GasPumpSVG, + KeySVG, + RightArrowSVG, + Typography, + WalletSVG, +} from '@ensdomains/thorin' + +import { Carousel } from '@app/components/pages/migrate/Carousel' + +const Title = styled.h1` + font-weight: 830; + text-align: center; + + font-size: 52px; + line-height: 104%; + + @media (min-width: 640px) { + font-size: 60px; + } + + @media (min-width: 1024px) { + font-size: 76px; + } +` + +const Header = styled.header( + ({ theme }) => css` + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + gap: ${theme.space[4]}; + padding: ${theme.space[4]}; + min-height: 530px; + `, +) + +const Main = styled.main( + ({ theme }) => css` + display: flex; + flex-direction: column; + gap: ${theme.space['16']}; + `, +) + +const PartnershipAnnouncement = styled.div( + ({ theme }) => css` + width: ${theme.space.full}; + padding: ${theme.space['4']}; + background-color: ${theme.colors.backgroundPrimary}; + border-radius: ${theme.radii['4xLarge']}; + font-size: ${theme.fontSizes.body}; + font-weight: ${theme.fontWeights.bold}; + display: flex; + justify-content: space-between; + & > a { + color: ${theme.colors.greenDim}; + cursor: pointer; + display: flex; + align-items: center; + gap: ${theme.space['2']}; + } + & > a:hover { + color: ${theme.colors.green}; + } + @media (min-width: 640px) { + border-radius: ${theme.radii['3xLarge']}; + } + `, +) + +const TopNav = styled.div( + ({ theme }) => css` + display: flex; + flex-direction: column; + gap: ${theme.space['6']}; + align-items: center; + position: sticky; + top: 0; + left: 0; + `, +) + +const CardWithEmoji = styled(Card)` + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + padding-top: 83px; + position: relative; + grid-column: 1 / -1; + & > img { + position: absolute; + top: -72px; + } +` + +const GridOneToThree = styled.div( + ({ theme }) => css` + display: grid; + grid-template-rows: auto; + gap: ${theme.space['4']}; + text-align: center; + grid-template-columns: 1fr; + @media (min-width: 640px) { + grid-template-columns: repeat(3, 1fr); + } + `, +) + +const CardHeader = styled.h3( + ({ theme }) => css` + display: flex; + flex-direction: column; + font-size: ${theme.fontSizes.extraLarge}; + color: ${theme.colors.greenDim}; + font-weight: ${theme.fontWeights.bold}; + gap: ${theme.space['2']}; + align-items: center; + `, +) + +const AnnouncementSlide = ({ title, text }: { title: string; text: string }) => ( + + {text} + +) + +const SlideshowContainer = styled.div( + ({ theme }) => css` + display: flex; + flex-direction: column; + gap: ${theme.space['6']}; + h3 { + text-align: center; + } + `, +) + +export default function ENSv2() { + const { t } = useTranslation('ensvs2') + return ( + + ) +} From eefb82b5173387f7a0b1fec55801de85830ad924 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Thu, 31 Oct 2024 18:08:04 +0200 Subject: [PATCH 44/75] landing page --- public/locales/en/ensvs2.json | 49 +++++++++- public/{ => migrate}/confetti.png | Bin public/migrate/preview.svg | 77 +++++++++++++++ src/assets/DAO.svg | 10 ++ src/assets/social/SocialX.svg | 2 +- src/components/pages/migrate/Carousel.tsx | 4 +- src/pages/_app.tsx | 1 + src/pages/migrate.tsx | 110 ++++++++++++++++++++-- 8 files changed, 243 insertions(+), 10 deletions(-) rename public/{ => migrate}/confetti.png (100%) create mode 100644 public/migrate/preview.svg create mode 100644 src/assets/DAO.svg diff --git a/public/locales/en/ensvs2.json b/public/locales/en/ensvs2.json index ac4b3e432..14a15d823 100644 --- a/public/locales/en/ensvs2.json +++ b/public/locales/en/ensvs2.json @@ -1,4 +1,51 @@ { "title": "ENSv2: The Next Generation of ENS", - "caption": "Approve your ENS names for ENSv2 now and enjoy automatic migration, paid for by ENS DAO." + "caption": "Approve your ENS names for ENSv2 now and enjoy automatic migration, paid for by ENS DAO.", + "accessible": { + "title": "Making ENS accessible to more people", + "caption": "We're taking our knowledge from the last 7 years at the frontier of web3 naming to re-envision the architecture from the ground up on L2 By utilizing L2s, we're excited to make ENS more accessible to a wider range of users.", + "link": "ENSv2 Project Plan", + "gas": { + "title": "Lower Gas Costs", + "text": "Layer 2 reduces gas fees, making .eth registrations and renewals cheaper and faster." + }, + "control": { + "title": "Enhanced Control", + "text": "ENSv2 gives each .eth name its own registry, offering more flexibility and control." + }, + "multichain": { + "title": "Improved Multi-Chain", + "text": "Layer 2 enables seamless .eth name use across blockchains with trustless connections." + } + }, + "announcement": { + "title": "Announcements", + "l2": { + "title": "L2 partner announcement", + "caption": "We’re announced that we’re partnering with _____! Watch Nick’s ___ presentation to see the full announcement." + }, + "ensv2": { + "title": "ENSv2: An Update on our Progress", + "caption": "This update aims to be informative and slightly technical, allowing you, the ENS community, to stay connected with our progress." + }, + "nextgen": { + "title": "ENSv2: The Next Generation of ENS", + "caption": "Our vision for the next iterations of the ENS protocol, on L2." + } + }, + "footer": { + "title": "Got questions?", + "learn": { + "title": "Learn", + "faq": "ENSv2 FAQs", + "plan": "ENSv2 Project Plan", + "base": "Knowledge base" + }, + "support": { + "title": "Support", + "ticket": "Open a ticket", + "twitter": "X (Twitter)", + "dao": "DAO forums" + } + } } \ No newline at end of file diff --git a/public/confetti.png b/public/migrate/confetti.png similarity index 100% rename from public/confetti.png rename to public/migrate/confetti.png diff --git a/public/migrate/preview.svg b/public/migrate/preview.svg new file mode 100644 index 000000000..5c5546d10 --- /dev/null +++ b/public/migrate/preview.svg @@ -0,0 +1,77 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/assets/DAO.svg b/src/assets/DAO.svg new file mode 100644 index 000000000..2d33444de --- /dev/null +++ b/src/assets/DAO.svg @@ -0,0 +1,10 @@ + + + + + + + + + + \ No newline at end of file diff --git a/src/assets/social/SocialX.svg b/src/assets/social/SocialX.svg index 6a7b7dfe7..134d9024f 100644 --- a/src/assets/social/SocialX.svg +++ b/src/assets/social/SocialX.svg @@ -1,3 +1,3 @@ - + diff --git a/src/components/pages/migrate/Carousel.tsx b/src/components/pages/migrate/Carousel.tsx index 9d25dca59..1f7f254a5 100644 --- a/src/components/pages/migrate/Carousel.tsx +++ b/src/components/pages/migrate/Carousel.tsx @@ -8,7 +8,7 @@ export const Carousel = ({ children }: { children: ReactNode[] }) => { arrows: false, pagination: false, gap: '16px', - perPage: 2, + perPage: 1, fixedWidth: 312, }} > @@ -18,4 +18,4 @@ export const Carousel = ({ children }: { children: ReactNode[] }) => { ))} ) -} \ No newline at end of file +} diff --git a/src/pages/_app.tsx b/src/pages/_app.tsx index 3c5d9dfb9..294ed4587 100644 --- a/src/pages/_app.tsx +++ b/src/pages/_app.tsx @@ -1,6 +1,7 @@ import { lightTheme, RainbowKitProvider, Theme } from '@rainbow-me/rainbowkit' import '@rainbow-me/rainbowkit/styles.css' +import '@splidejs/react-splide/css' import { NextPage } from 'next' import type { AppProps } from 'next/app' diff --git a/src/pages/migrate.tsx b/src/pages/migrate.tsx index 948c5a7b3..b6be85326 100644 --- a/src/pages/migrate.tsx +++ b/src/pages/migrate.tsx @@ -6,14 +6,21 @@ import { Button, Card, GasPumpSVG, + InfoCircleSVG, KeySVG, + QuestionBubbleSVG, + QuestionCircleSVG, RightArrowSVG, + SpannerAltSVG, Typography, WalletSVG, } from '@ensdomains/thorin' import { Carousel } from '@app/components/pages/migrate/Carousel' +import DAOSVG from '../assets/DAO.svg' +import SocialX from '../assets/social/SocialX.svg' + const Title = styled.h1` font-weight: 830; text-align: center; @@ -50,6 +57,54 @@ const Main = styled.main( `, ) +const Footer = styled.div( + ({ theme }) => css` + display: flex; + flex-direction: column; + gap: ${theme.space['6']}; + h3 { + text-align: center; + } + span { + display: flex; + flex-direction: row; + align-items: center; + gap: ${theme.space['2']}; + color: ${theme.colors.green}; + } + & > div { + display: grid; + grid-template-columns: repeat(1, 1fr); + gap: ${theme.space['4']}; + } + & > div > div { + width: 100%; + display: flex; + align-items: center; + } + @media (min-width: 480px) { + & > div { + grid-template-columns: repeat(2, 1fr); + } + } + `, +) + +const AnnouncementBanner = styled.div( + ({ theme }) => css` + height: ${theme.space.full}; + text-align: center; + & > a { + height: ${theme.space.full}; + justify-content: flex-start; + & > div { + height: ${theme.space.full}; + justify-content: flex-start; + } + } + `, +) + const PartnershipAnnouncement = styled.div( ({ theme }) => css` width: ${theme.space.full}; @@ -83,8 +138,9 @@ const TopNav = styled.div( gap: ${theme.space['6']}; align-items: center; position: sticky; - top: 0; + top: ${theme.space['4']}; left: 0; + z-index: 1; `, ) @@ -128,9 +184,11 @@ const CardHeader = styled.h3( ) const AnnouncementSlide = ({ title, text }: { title: string; text: string }) => ( - - {text} - + + + {text} + + ) const SlideshowContainer = styled.div( @@ -144,6 +202,15 @@ const SlideshowContainer = styled.div( `, ) +const Video = styled.video( + ({ theme }) => css` + height: ${theme.space.full}; + width: ${theme.space.full}; + border-radius: ${theme.radii.card}; + margin-bottom: ${theme.space[18]}; + `, +) + export default function ENSv2() { const { t } = useTranslation('ensvs2') return ( @@ -160,10 +227,12 @@ export default function ENSv2() { {t('title')} {t('caption')} -
video
+ - 🎉 + 🎉 {t('accessible.title')} @@ -213,6 +282,35 @@ export default function ENSv2() { /> +
+ + {t('footer.title')} + +
+ + + {t('footer.learn.faq')} + + + {t('footer.learn.plan')} + + + {t('footer.learn.base')} + + + + + {t('footer.support.ticket')} + + + {t('footer.support.twitter')} + + + {t('footer.support.dao')} + + +
+
) } From 148f7d452a52f2e70b0b169da5d379debcafb1c9 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Thu, 31 Oct 2024 18:10:05 +0200 Subject: [PATCH 45/75] fix --- package.json | 1 + pnpm-lock.yaml | 41 ++++++++++++++++++++++++++++------------- 2 files changed, 29 insertions(+), 13 deletions(-) diff --git a/package.json b/package.json index d223d48ec..1742cc73d 100644 --- a/package.json +++ b/package.json @@ -61,6 +61,7 @@ "@noble/hashes": "^1.3.2", "@rainbow-me/rainbowkit": "2.1.2", "@sentry/nextjs": "7.43.x", + "@splidejs/react-splide": "^0.7.12", "@svgr/webpack": "^8.1.0", "@tanstack/query-persist-client-core": "5.22.2", "@tanstack/query-sync-storage-persister": "5.22.2", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 8bd38f822..e774a7f8e 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -56,6 +56,9 @@ importers: '@sentry/nextjs': specifier: 7.43.x version: 7.43.0(encoding@0.1.13)(next@13.5.6(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(webpack@5.91.0(esbuild@0.17.19)) + '@splidejs/react-splide': + specifier: ^0.7.12 + version: 0.7.12 '@svgr/webpack': specifier: ^8.1.0 version: 8.1.0(typescript@5.4.5) @@ -296,7 +299,7 @@ importers: version: 0.3.9 eslint-plugin-import: specifier: ^2.28.1 - version: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + version: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: specifier: ^6.7.1 version: 6.8.0(eslint@8.50.0) @@ -2950,6 +2953,12 @@ packages: '@socket.io/component-emitter@3.1.2': resolution: {integrity: sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==} + '@splidejs/react-splide@0.7.12': + resolution: {integrity: sha512-UfXH+j47jsMc4x5HA/aOwuuHPqn6y9+ZTNYPWDRD8iLKvIVMZlzq2unjUEvyDAU+TTVPZOXkG2Ojeoz0P4AkZw==} + + '@splidejs/splide@4.1.4': + resolution: {integrity: sha512-5I30evTJcAJQXt6vJ26g2xEkG+l1nXcpEw4xpKh0/FWQ8ozmAeTbtniVtVmz2sH1Es3vgfC4SS8B2X4o5JMptA==} + '@stablelib/aead@1.0.1': resolution: {integrity: sha512-q39ik6sxGHewqtO0nP4BuSe3db5G1fEJE8ukvngS2gLkBXyy6E7pLubhbYgnkDFv6V8cWaxcE4Xn0t6LWcJkyg==} @@ -13641,6 +13650,12 @@ snapshots: '@socket.io/component-emitter@3.1.2': {} + '@splidejs/react-splide@0.7.12': + dependencies: + '@splidejs/splide': 4.1.4 + + '@splidejs/splide@4.1.4': {} + '@stablelib/aead@1.0.1': {} '@stablelib/binary@1.0.1': @@ -16657,7 +16672,7 @@ snapshots: dependencies: confusing-browser-globals: 1.0.11 eslint: 8.50.0 - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) object.assign: 4.1.5 object.entries: 1.1.8 semver: 6.3.1 @@ -16668,13 +16683,13 @@ snapshots: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-config-airbnb@19.0.4(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint-plugin-jsx-a11y@6.8.0(eslint@8.50.0))(eslint-plugin-react-hooks@4.6.2(eslint@8.50.0))(eslint-plugin-react@7.34.1(eslint@8.50.0))(eslint@8.50.0): dependencies: eslint: 8.50.0 eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) @@ -16688,8 +16703,8 @@ snapshots: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) @@ -16711,13 +16726,13 @@ snapshots: transitivePeerDependencies: - supports-color - eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0): + eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0): dependencies: debug: 4.3.4(supports-color@5.5.0) enhanced-resolve: 5.16.1 eslint: 8.50.0 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 is-core-module: 2.13.1 @@ -16728,18 +16743,18 @@ snapshots: - eslint-import-resolver-webpack - supports-color - eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0): + eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0): dependencies: debug: 3.2.7 optionalDependencies: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) + eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0) transitivePeerDependencies: - supports-color - eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0): + eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0): dependencies: array-includes: 3.1.8 array.prototype.findlastindex: 1.2.5 @@ -16749,7 +16764,7 @@ snapshots: doctrine: 2.1.0 eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) hasown: 2.0.2 is-core-module: 2.13.1 is-glob: 4.0.3 From e471abb9deef9382fc1c39599286a8b73834b28b Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 4 Nov 2024 23:34:08 +0800 Subject: [PATCH 46/75] bump ensjs to 4.0.2-alpha.5 --- e2e/specs/stateless/myNames.spec.ts | 235 +++++++++++++++++- package.json | 5 +- playwright/fixtures/accounts.ts | 5 +- .../generators/legacyNameGenerator.ts | 17 +- .../legacyWithConfigNameGenerator.ts | 18 +- .../generators/wrappedNameGenerator.ts | 10 +- playwright/fixtures/makeName/index.ts | 19 +- playwright/fixtures/subgraph.ts | 17 +- pnpm-lock.yaml | 218 ++++++++++++++-- .../NameTableHeader/NameTableHeader.tsx | 2 + 10 files changed, 473 insertions(+), 73 deletions(-) diff --git a/e2e/specs/stateless/myNames.spec.ts b/e2e/specs/stateless/myNames.spec.ts index 0c3ae97c5..ac85f255e 100644 --- a/e2e/specs/stateless/myNames.spec.ts +++ b/e2e/specs/stateless/myNames.spec.ts @@ -1,5 +1,12 @@ import { expect } from '@playwright/test' -import { testClient } from '@root/playwright/fixtures/contracts/utils/addTestContracts' +import { createAccounts } from '@root/playwright/fixtures/accounts' +import { + testClient, + walletClient, +} from '@root/playwright/fixtures/contracts/utils/addTestContracts' +import { Address, labelhash } from 'viem' + +import { deleteSubname } from '@ensdomains/ensjs/wallet' import { test } from '../../../playwright' import { Name } from '../../../playwright/fixtures/makeName' @@ -18,7 +25,6 @@ test('myNames', async ({ page, login, makeName }) => { await page.goto('/') await login.connect('user2') - await page.pause() await page.goto('/my/names') @@ -32,6 +38,229 @@ test('myNames', async ({ page, login, makeName }) => { ) expect(timestamps.every((timestamp) => timestamp === timestamps[0])).toBe(true) +}) + +test.describe.serial('myNames', () => { + test.beforeAll(async ({ subgraph }) => { + // Move time to the future to force previous names to expire + await testClient.increaseTime({ seconds: 2 * 365 * 24 * 60 * 60 }) + await testClient.mine({ blocks: 1 }) + await subgraph.sync() + }) + + let subnamesToDelete: string[] = [] + let allNames: string[] = [] + + test.afterAll(async () => { + console.log('cleaning up subnames') + const account = createAccounts().getAddress('user4') as Address + for (const subname of subnamesToDelete) { + const contract = subname.includes('wrapped') ? 'nameWrapper' : 'registry' + console.log('deleting subname:', subname, 'on', contract) + // eslint-disable-next-line no-await-in-loop + await deleteSubname(walletClient, { + name: subname, + account, + contract, + }) + } + }) + + const makeSubnamesConfig = (type: 'legacy' | 'wrapped') => + Array.from( + { length: 10 }, + (_, i) => + ({ + label: `sub${i}`, + owner: 'user4', + type, + ...(type === 'wrapped' + ? { + fuses: { + parent: { + named: ['PARENT_CANNOT_CONTROL'], + }, + }, + } + : {}), + }) as any, + ) + + test('should display all names for expiry date ASC', async ({ page, login, makeName }) => { + const earlierName = await makeName({ + label: 'earlier-wrapped', + type: 'wrapped', + owner: 'user4', + fuses: { + named: ['CANNOT_UNWRAP'], + }, + subnames: makeSubnamesConfig('wrapped'), + }) + const concurrentNames = await makeName([ + { + label: `concurrent-legacy`, + type: 'legacy', + owner: 'user4', + subnames: makeSubnamesConfig('legacy'), + } as Name, + { + label: `concurrent-wrapped`, + type: 'wrapped', + owner: 'user4', + fuses: { + named: ['CANNOT_UNWRAP'], + }, + subnames: makeSubnamesConfig('wrapped'), + }, + ]) + const laterName = await makeName({ + label: 'later-legacy-name', + type: 'legacy', + owner: 'user4', + subnames: makeSubnamesConfig('legacy'), + }) + + subnamesToDelete = [earlierName, ...concurrentNames, laterName].flatMap((name) => + Array.from({ length: 10 }, (_, i) => `sub${i}.${name}`), + ) + allNames = [earlierName, ...concurrentNames, laterName, ...subnamesToDelete] + + await page.goto('/') + await login.connect('user4') + await page.goto('/my/names') + + await expect(page.getByTestId('names-list')).toBeVisible({ timeout: 10000 }) + + await page.evaluate(async () => { + let previousScrollHeight = 0 + let { scrollHeight } = document.body + do { + window.scrollTo(0, scrollHeight) + // eslint-disable-next-line no-await-in-loop + await new Promise((resolve) => { + setTimeout(resolve, 1000) + }) + previousScrollHeight = scrollHeight + scrollHeight = document.body.scrollHeight + } while (previousScrollHeight !== scrollHeight) + }) + + for (const name of allNames) { + const decryptedLocator = page.getByTestId(`name-item-${name}`) + const nameParts = name.split('.') + const label = nameParts.shift()! + const labelHash = `[${labelhash(label).replace('0x', '')}]` + const encryptedLocator = page.getByTestId(`name-item-${[labelHash, ...nameParts].join('.')}`) + // eslint-disable-next-line no-await-in-loop + await expect(decryptedLocator.or(encryptedLocator)).toBeVisible() + } + }) + + test('should display all names for expiry date DESC', async ({ page, login }) => { + await page.goto('/') + await login.connect('user4') + await page.goto('/my/names') + + await expect(page.getByTestId('names-list')).toBeVisible({ timeout: 10000 }) + + await page.getByTestId('sort-desc').click() + await page.waitForTimeout(1000) + + await page.evaluate(async () => { + let previousScrollHeight = 0 + let { scrollHeight } = document.body + do { + window.scrollTo(0, scrollHeight) + // eslint-disable-next-line no-await-in-loop + await new Promise((resolve) => { + setTimeout(resolve, 1000) + }) + previousScrollHeight = scrollHeight + scrollHeight = document.body.scrollHeight + } while (previousScrollHeight !== scrollHeight) + }) + + for (const name of allNames) { + const decryptedLocator = page.getByTestId(`name-item-${name}`) + const nameParts = name.split('.') + const label = nameParts.shift()! + const labelHash = `[${labelhash(label).replace('0x', '')}]` + const encryptedLocator = page.getByTestId(`name-item-${[labelHash, ...nameParts].join('.')}`) + // eslint-disable-next-line no-await-in-loop + await expect(decryptedLocator.or(encryptedLocator)).toBeVisible() + } + }) + + test('should display all names for createdAt ASC', async ({ page, login }) => { + await page.goto('/') + await login.connect('user4') + await page.goto('/my/names') + + await expect(page.getByTestId('names-list')).toBeVisible({ timeout: 10000 }) + + await page.getByTestId('select-container').getByRole('button').click() + await page.getByTestId('select-option-createdAt').click() + await page.waitForTimeout(1000) + + await page.evaluate(async () => { + let previousScrollHeight = 0 + let { scrollHeight } = document.body + do { + window.scrollTo(0, scrollHeight) + // eslint-disable-next-line no-await-in-loop + await new Promise((resolve) => { + setTimeout(resolve, 1000) + }) + previousScrollHeight = scrollHeight + scrollHeight = document.body.scrollHeight + } while (previousScrollHeight !== scrollHeight) + }) + + for (const name of allNames) { + const decryptedLocator = page.getByTestId(`name-item-${name}`) + const nameParts = name.split('.') + const label = nameParts.shift()! + const labelHash = `[${labelhash(label).replace('0x', '')}]` + const encryptedLocator = page.getByTestId(`name-item-${[labelHash, ...nameParts].join('.')}`) + // eslint-disable-next-line no-await-in-loop + await expect(decryptedLocator.or(encryptedLocator)).toBeVisible() + } + }) + + test('should display all names for createdAt DESC', async ({ page, login }) => { + await page.goto('/') + await login.connect('user4') + await page.goto('/my/names') + + await expect(page.getByTestId('names-list')).toBeVisible({ timeout: 10000 }) + + await page.getByTestId('select-container').getByRole('button').click() + await page.getByTestId('select-option-createdAt').click() + await page.getByTestId('sort-desc').click() + await page.waitForTimeout(1000) + + await page.evaluate(async () => { + let previousScrollHeight = 0 + let { scrollHeight } = document.body + do { + window.scrollTo(0, scrollHeight) + // eslint-disable-next-line no-await-in-loop + await new Promise((resolve) => { + setTimeout(resolve, 1000) + }) + previousScrollHeight = scrollHeight + scrollHeight = document.body.scrollHeight + } while (previousScrollHeight !== scrollHeight) + }) - await page.pause() + for (const name of allNames) { + const decryptedLocator = page.getByTestId(`name-item-${name}`) + const nameParts = name.split('.') + const label = nameParts.shift()! + const labelHash = `[${labelhash(label).replace('0x', '')}]` + const encryptedLocator = page.getByTestId(`name-item-${[labelHash, ...nameParts].join('.')}`) + // eslint-disable-next-line no-await-in-loop + await expect(decryptedLocator.or(encryptedLocator)).toBeVisible() + } + }) }) diff --git a/package.json b/package.json index 17cb30b03..75aaaac08 100644 --- a/package.json +++ b/package.json @@ -51,10 +51,11 @@ "knip:fix": "knip --fix --allow-remove-files" }, "dependencies": { + "@adraffy/ens-normalize": "1.10.1", "@ensdomains/address-encoder": "1.1.1", "@ensdomains/content-hash": "^3.0.0-beta.5", "@ensdomains/ens-contracts": "1.2.0-beta.0", - "@ensdomains/ensjs": "4.0.0", + "@ensdomains/ensjs": "4.0.2-alpha.5", "@ensdomains/thorin": "0.6.50", "@metamask/post-message-stream": "^6.1.2", "@metamask/providers": "^14.0.2", @@ -206,4 +207,4 @@ } }, "packageManager": "pnpm@9.3.0" -} \ No newline at end of file +} diff --git a/playwright/fixtures/accounts.ts b/playwright/fixtures/accounts.ts index ff1ea21ea..5aa446225 100644 --- a/playwright/fixtures/accounts.ts +++ b/playwright/fixtures/accounts.ts @@ -17,13 +17,12 @@ const shortenAddress = (address = '', maxLength = 10, leftSlice = 5, rightSlice export type Accounts = ReturnType -export type User = 'user' | 'user2' | 'user3' +const users = ['user', 'user2', 'user3', 'user4'] as const +export type User = typeof users[number] export const createAccounts = (stateful = false) => { const mnemonic = stateful ? process.env.SECRET_WORDS || DEFAULT_MNEMONIC : DEFAULT_MNEMONIC - const users: User[] = ['user', 'user2', 'user3'] - const { accounts, privateKeys } = users.reduce<{ accounts: Account[]; privateKeys: Hash[] }>( (acc, _, index) => { const { getHdKey } = mnemonicToAccount(mnemonic, { addressIndex: index }) diff --git a/playwright/fixtures/makeName/generators/legacyNameGenerator.ts b/playwright/fixtures/makeName/generators/legacyNameGenerator.ts index 9aaa527b8..4d8c65172 100644 --- a/playwright/fixtures/makeName/generators/legacyNameGenerator.ts +++ b/playwright/fixtures/makeName/generators/legacyNameGenerator.ts @@ -101,16 +101,15 @@ export const makeLegacyNameGenerator = ({ accounts }: Dependencies) => ({ configure: async (nameConfig: LegacyName) => { const { label, owner, manager, subnames = [], secret } = nameWithDefaults(nameConfig) const name = `${label}.eth` + // Create subnames - await Promise.all( - subnames.map((subname) => { - return generateLegacySubname({ accounts })({ - ...subname, - name: `${label}.eth`, - nameOwner: owner, - }) - }), - ) + for (const subname of subnames) { + await generateLegacySubname({ accounts })({ + ...subname, + name: `${label}.eth`, + nameOwner: owner, + }) + } if (!!manager && manager !== owner) { console.log('setting manager:', name, manager) diff --git a/playwright/fixtures/makeName/generators/legacyWithConfigNameGenerator.ts b/playwright/fixtures/makeName/generators/legacyWithConfigNameGenerator.ts index 0d58f8c49..65158fd2e 100644 --- a/playwright/fixtures/makeName/generators/legacyWithConfigNameGenerator.ts +++ b/playwright/fixtures/makeName/generators/legacyWithConfigNameGenerator.ts @@ -130,16 +130,14 @@ export const makeLegacyWithConfigNameGenerator = ({ accounts }: Dependencies) => await generateRecords({ accounts })({ name: `${label}.eth`, owner, resolver, records }) // Create subnames - await Promise.all( - subnames.map((subname) => - generateLegacySubname({ accounts })({ - ...subname, - name, - nameOwner: owner, - resolver: subname.resolver ?? _resolver, - }), - ), - ) + for (const subname of subnames) { + await generateLegacySubname({ accounts })({ + ...subname, + name, + nameOwner: owner, + resolver: subname.resolver ?? _resolver, + }) + } // Set resolver if not valid if (!hasValidResolver && resolver) { diff --git a/playwright/fixtures/makeName/generators/wrappedNameGenerator.ts b/playwright/fixtures/makeName/generators/wrappedNameGenerator.ts index 0d3dbd865..0d9ff76ab 100644 --- a/playwright/fixtures/makeName/generators/wrappedNameGenerator.ts +++ b/playwright/fixtures/makeName/generators/wrappedNameGenerator.ts @@ -159,16 +159,14 @@ export const makeWrappedNameGenerator = ({ accounts }: Dependencies) => ({ }) } - await Promise.all( - subnames.map((subname) => - generateWrappedSubname({ accounts })({ + for (const subname of subnames) { + await generateWrappedSubname({ accounts })({ ...subname, name: `${label}.eth`, nameOwner: owner, resolver: subname.resolver ?? _resolver, - }), - ), - ) + }) + } if (!hasValidResolver && resolver) { console.log('setting resolver: ', name, resolver) diff --git a/playwright/fixtures/makeName/index.ts b/playwright/fixtures/makeName/index.ts index 3bcd6dbcd..9e3030b75 100644 --- a/playwright/fixtures/makeName/index.ts +++ b/playwright/fixtures/makeName/index.ts @@ -91,18 +91,21 @@ export function createMakeNames({ accounts, time, subgraph }: Dependencies) { await testClient.setAutomine(true) - // Finish setting up names - await Promise.all( - adjustedNames.map((name) => { + // Make sure that registration and subnames are on different block or it might cause the subgraph to crash due to + // RegisterName and TransferName event having the same event ids. + await testClient.mine({ blocks: 1 }) + + // Finish setting up names + for (const name of adjustedNames) { if (isWrappendName(name)) { - return wrappedNameGenerator.configure(name) + await wrappedNameGenerator.configure(name) } else if (isLegacyName(name)) { - return legacyRegisterNameGenerator.configure(name) + console.log('registering legacy name:', name) + await legacyRegisterNameGenerator.configure(name) } else { - return legacyNameGenerator.configure(name) + await legacyNameGenerator.configure(name) } - }), - ) + } if (offset > 0) { console.warn('You are increasing the block timestamp. Do not run this test in parallel mode.') diff --git a/playwright/fixtures/subgraph.ts b/playwright/fixtures/subgraph.ts index 0fda0a1ff..78867ab69 100644 --- a/playwright/fixtures/subgraph.ts +++ b/playwright/fixtures/subgraph.ts @@ -23,17 +23,20 @@ const query = gql` export const waitForSubgraph = () => async () => { const blockNumber = await getBlockNumber(publicClient) - - let wait = true - let count = 0 + const anvilBlockNumbers: number[] = [] do { await new Promise((resolve) => setTimeout(resolve, 500)) const client = new GraphQLClient('http://localhost:8000/subgraphs/name/graphprotocol/ens') const res = await client.request(query) - wait = blockNumber > res._meta.block.number - count += 1 - console.log(`subgraph: ${res._meta.block.number} -> ${blockNumber} ${!wait ? '[IN SYNC]' : ''}`) - } while (wait && count < 10) + + anvilBlockNumbers.push(res._meta.block.number) + if (anvilBlockNumbers.length > 10) anvilBlockNumbers.shift() + + const finished = res._meta.block.number >= blockNumber + console.log(`subgraph: ${res._meta.block.number} -> ${blockNumber} ${finished ? '[IN SYNC]' : ''}`) + + if (anvilBlockNumbers.length >= 10 && anvilBlockNumbers.every((blockNumb) => blockNumb === anvilBlockNumbers[0])) throw new Error('Subgraph not in sync') + } while (anvilBlockNumbers[anvilBlockNumbers.length - 1] < blockNumber) } export const createSubgraph = () => ({ diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 96fc7eb4e..13a68c7a1 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -26,6 +26,9 @@ importers: .: dependencies: + '@adraffy/ens-normalize': + specifier: 1.10.1 + version: 1.10.1 '@ensdomains/address-encoder': specifier: 1.1.1 version: 1.1.1 @@ -36,8 +39,8 @@ importers: specifier: 1.2.0-beta.0 version: 1.2.0-beta.0 '@ensdomains/ensjs': - specifier: 4.0.0 - version: 4.0.0(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8) + specifier: 4.0.2-alpha.5 + version: 4.0.2-alpha.5(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8) '@ensdomains/thorin': specifier: 0.6.50 version: 0.6.50(react-dom@18.3.1(react@18.3.1))(react-transition-state@1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1)) @@ -421,6 +424,48 @@ importers: specifier: ^1.0.0-pre.53 version: 1.0.0-pre.53 + .yalc/@ensdomains/ens-test-env: + dependencies: + '@ethersproject/wallet': + specifier: ^5.6.0 + version: 5.7.0 + ansi-colors: + specifier: ^4.1.1 + version: 4.1.3 + cli-progress: + specifier: ^3.10.0 + version: 3.12.0 + commander: + specifier: ^9.3.0 + version: 9.5.0 + concurrently: + specifier: ^7.1.0 + version: 7.6.0 + docker-compose: + specifier: ^0.24.7 + version: 0.24.8 + dotenv: + specifier: ^16.0.1 + version: 16.4.5 + js-yaml: + specifier: ^4.1.0 + version: 4.1.0 + lz4: + specifier: ^0.6.5 + version: 0.6.5 + progress-stream: + specifier: ^2.0.0 + version: 2.0.0 + tar-fs: + specifier: ^2.1.1 + version: 2.1.1 + viem: + specifier: ^2.21.37 + version: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) + wait-on: + specifier: ^6.0.1 + version: 6.0.1 + packages: '@adobe/css-tools@4.3.3': @@ -432,6 +477,9 @@ packages: '@adraffy/ens-normalize@1.10.1': resolution: {integrity: sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==} + '@adraffy/ens-normalize@1.11.0': + resolution: {integrity: sha512-/3DDPKHqqIqxUULp8yP4zODUY1i+2xvVWsv8A79xGWdCAG+8sb0hRh0Rk2QyOJUnnbyPUAZYcpBuRe3nS2OIUg==} + '@ampproject/remapping@2.3.0': resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} @@ -1556,8 +1604,8 @@ packages: '@ensdomains/ensjs@2.1.0': resolution: {integrity: sha512-GRbGPT8Z/OJMDuxs75U/jUNEC0tbL0aj7/L/QQznGYKm/tiasp+ndLOaoULy9kKJFC0TBByqfFliEHDgoLhyog==} - '@ensdomains/ensjs@4.0.0': - resolution: {integrity: sha512-iI6ieuP0TeSK46JCP21EGxyup5rPE5rMmDMTrpRs+u3iwk42Bx3e4oG5sEtTRmxnXFO9uaSqk+WSXEMcHyPKxQ==} + '@ensdomains/ensjs@4.0.2-alpha.5': + resolution: {integrity: sha512-xDlnEg+JbZMs+vV5C3v0ks8nBrJciwVD9gYeFH5TzDpSM1zcGxb4KO4vvv0F+f8UI0aZFLLldZ7xyWfn4egjAw==} peerDependencies: viem: ^2.9.2 @@ -2324,6 +2372,10 @@ packages: '@noble/curves@1.4.0': resolution: {integrity: sha512-p+4cb332SFCrReJkCYe8Xzm0OWi4Jji5jVdIZRL/PmacmDkFNw6MrrV+gGpiPxLHbV+zKFRywUWbaseT+tZRXg==} + '@noble/curves@1.6.0': + resolution: {integrity: sha512-TlaHRXDehJuRNR9TfZDNQ45mMEd5dwUwmicsafcIX4SsNiqnCHKjE/1alYPd/lDRVhxdhUAlv8uEhMCI5zjIJQ==} + engines: {node: ^14.21.3 || >=16} + '@noble/hashes@1.2.0': resolution: {integrity: sha512-FZfhjEDbT5GRswV3C6uvLPHMiVD6lQBmpoX5+eSiPaMTXte/IKqI5dykDxzZB/WBeK/CDuQRBWarPdi3FNY2zQ==} @@ -2335,6 +2387,10 @@ packages: resolution: {integrity: sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg==} engines: {node: '>= 16'} + '@noble/hashes@1.5.0': + resolution: {integrity: sha512-1j6kQFb7QRru7eKN3ZDvRcP13rugwdxZqCjbiAVZfIJwgj2A65UmT4TgARXGlXgnRkORLTDTrO19ZErt7+QXgA==} + engines: {node: ^14.21.3 || >=16} + '@noble/secp256k1@1.7.1': resolution: {integrity: sha512-hOUk6AyBFmqVrv7k5WAw/LpszxVbj9gGN4JRkIX52fdFAj1UA61KXmZDvqVEm+pOyec3+fIeZB02LYa/pWOArw==} @@ -2813,6 +2869,9 @@ packages: '@scure/base@1.1.6': resolution: {integrity: sha512-ok9AWwhcgYuGG3Zfhyqg+zwl+Wn5uE+dwC0NV/2qQkx4dABbb/bx96vWu8NSj+BNjjSjno+JRYRjle1jV08k3g==} + '@scure/base@1.1.9': + resolution: {integrity: sha512-8YKhl8GHiNI/pU2VMaofa2Tor7PJRAjwQLBBuilkJ9L5+13yVbC7JO/wS7piioAvPSwR3JKM1IJ/u4xQzbcXKg==} + '@scure/bip32@1.1.5': resolution: {integrity: sha512-XyNh1rB0SkEqd3tXcXMi+Xe1fvg+kUIcoRIEujP1Jgv7DqW2r9lg3Ah0NkFaCs9sTkQAQA8kw7xiRXzENi9Rtw==} @@ -2822,6 +2881,9 @@ packages: '@scure/bip32@1.4.0': resolution: {integrity: sha512-sVUpc0Vq3tXCkDGYVWGIZTRfnvu8LoTDaev7vbwh0omSvVORONr960MQWdKqJDCReIEmTj3PAr73O3aoxz7OPg==} + '@scure/bip32@1.5.0': + resolution: {integrity: sha512-8EnFYkqEQdnkuGBVpCzKxyIwDCBLDVj3oiX0EKUFre/tOjL/Hqba1D6n/8RcmaQy4f95qQFrO2A8Sr6ybh4NRw==} + '@scure/bip39@1.1.1': resolution: {integrity: sha512-t+wDck2rVkh65Hmv280fYdVdY25J9YeEUIgn2LG1WM6gxFkGzcksoDiUkWVpVp3Oex9xGC68JU2dSbUfwZ2jPg==} @@ -2831,6 +2893,9 @@ packages: '@scure/bip39@1.3.0': resolution: {integrity: sha512-disdg7gHuTDZtY+ZdkmLpPCk7fxZSu3gBiEGuoC1XYxv9cGx3Z6cpTggCgW6odSOOIXCiDjuGejW+aJKCY/pIQ==} + '@scure/bip39@1.4.0': + resolution: {integrity: sha512-BEEm6p8IueV/ZTfQLp/0vhw4NPnT9oWf5+28nvmeUICjP99f4vr2d+qc7AVGDDtwRep6ifR43Yed9ERVmiITzw==} + '@sentry/browser@7.43.0': resolution: {integrity: sha512-NlRkBYKb9o5IQdGY8Ktps19Hz9RdSuqS1tlLC7Sjr+MqZqSHmhKq8MWJKciRynxBeMbeGt0smExi9BqpVQdCEg==} engines: {node: '>=8'} @@ -3756,6 +3821,17 @@ packages: zod: optional: true + abitype@1.0.6: + resolution: {integrity: sha512-MMSqYh4+C/aVqI2RQaWqbvI4Kxo5cQV40WQ4QFtDnNzCkqChm8MuENhElmynZlO0qUy/ObkEUaXtKqYnx1Kp3A==} + peerDependencies: + typescript: '>=5.0.4' + zod: ^3 >=3.22.0 + peerDependenciesMeta: + typescript: + optional: true + zod: + optional: true + abort-controller@3.0.0: resolution: {integrity: sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==} engines: {node: '>=6.5'} @@ -6535,6 +6611,11 @@ packages: peerDependencies: ws: '*' + isows@1.0.6: + resolution: {integrity: sha512-lPHCayd40oW98/I0uvgaHKWCSvkzY27LjWLbtzOm64yQ+G3Q5npjjbdppU65iZXkK1Zt+kH9pfegli0AYfwYYw==} + peerDependencies: + ws: '*' + isstream@0.1.2: resolution: {integrity: sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==} @@ -9329,6 +9410,9 @@ packages: ts-pattern@4.3.0: resolution: {integrity: sha512-pefrkcd4lmIVR0LA49Imjf9DYLK8vtWhqBPA3Ya1ir8xCW0O2yjL9dsCVvI7pCodLC5q7smNpEtDR2yVulQxOg==} + ts-pattern@5.5.0: + resolution: {integrity: sha512-jqbIpTsa/KKTJYWgPNsFNbLVpwCgzXfFJ1ukNn4I8hMwyQzHMJnk/BqWzggB0xpkILuKzaO/aMYhS0SkaJyKXg==} + tsconfig-paths@3.15.0: resolution: {integrity: sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==} @@ -9694,6 +9778,14 @@ packages: typescript: optional: true + viem@2.21.40: + resolution: {integrity: sha512-no/mE3l7B0mdUTtvO7z/cTLENttQ/M7+ombqFGXJqsQrxv9wrYsTIGpS3za+FA5a447hY+x9D8Wxny84q1zAaA==} + peerDependencies: + typescript: '>=5.0.4' + peerDependenciesMeta: + typescript: + optional: true + vite-node@2.0.5: resolution: {integrity: sha512-LdsW4pxj0Ot69FAoXZ1yTnA9bjGohr2yNBU7QKRxpz8ITSkhuDl6h3zS/tvgz4qrNjeRnvrWeXQ8ZF7Um4W00Q==} engines: {node: ^18.0.0 || >=20.0.0} @@ -10000,6 +10092,9 @@ packages: resolution: {integrity: sha512-kgJvQZjkmjOEKimx/tJQsqWfRDPTTcBfYPa9XletxuHLpHcXdx67w8EFn5AW3eVxCutE9dTVHgGa9VYe8vgsEA==} engines: {node: '>=8.0.0'} + webauthn-p256@0.0.10: + resolution: {integrity: sha512-EeYD+gmIT80YkSIDb2iWq0lq2zbHo1CxHlQTeJ+KkCILWpVy3zASH3ByD4bopzfk0uCwXxLqKGLqp2W4O28VFA==} + webauthn-p256@0.0.5: resolution: {integrity: sha512-drMGNWKdaixZNobeORVIqq7k5DsRC9FnG201K2QjeOoQLmtSDaSsVZdkg6n5jUALJKcAG++zBPJXmv6hy0nWFg==} @@ -10243,6 +10338,18 @@ packages: utf-8-validate: optional: true + ws@8.18.0: + resolution: {integrity: sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw==} + engines: {node: '>=10.0.0'} + peerDependencies: + bufferutil: ^4.0.1 + utf-8-validate: '>=5.0.2' + peerDependenciesMeta: + bufferutil: + optional: true + utf-8-validate: + optional: true + xhr-request-promise@0.1.3: resolution: {integrity: sha512-YUBytBsuwgitWtdRzXDDkWAXzhdGB8bYm0sSzMPZT7Z2MBjMSTHFsyCT1yCRATY+XC69DUrQraRAEgcoCRaIPg==} @@ -10411,6 +10518,8 @@ snapshots: '@adraffy/ens-normalize@1.10.1': {} + '@adraffy/ens-normalize@1.11.0': {} + '@ampproject/remapping@2.3.0': dependencies: '@jridgewell/gen-mapping': 0.3.5 @@ -11791,7 +11900,7 @@ snapshots: '@ensdomains/ensjs@2.1.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)': dependencies: - '@babel/runtime': 7.24.6 + '@babel/runtime': 7.25.0 '@ensdomains/address-encoder': 0.1.9 '@ensdomains/ens': 0.4.5 '@ensdomains/resolver': 0.2.4 @@ -11803,7 +11912,7 @@ snapshots: - bufferutil - utf-8-validate - '@ensdomains/ensjs@4.0.0(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8)': + '@ensdomains/ensjs@4.0.2-alpha.5(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8)': dependencies: '@adraffy/ens-normalize': 1.10.1 '@ensdomains/address-encoder': 1.1.1 @@ -11814,6 +11923,7 @@ snapshots: graphql: 16.8.1 graphql-request: 6.1.0(encoding@0.1.13)(graphql@16.8.1) pako: 2.1.0 + ts-pattern: 5.5.0 viem: 2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) transitivePeerDependencies: - encoding @@ -12674,7 +12784,7 @@ snapshots: '@motionone/easing': 10.17.0 '@motionone/types': 10.17.0 '@motionone/utils': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/dom@10.17.0': dependencies: @@ -12683,12 +12793,12 @@ snapshots: '@motionone/types': 10.17.0 '@motionone/utils': 10.17.0 hey-listen: 1.0.8 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/easing@10.17.0': dependencies: '@motionone/utils': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/generators@10.17.0': dependencies: @@ -12699,7 +12809,7 @@ snapshots: '@motionone/svelte@10.16.4': dependencies: '@motionone/dom': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/types@10.17.0': {} @@ -12707,12 +12817,12 @@ snapshots: dependencies: '@motionone/types': 10.17.0 hey-listen: 1.0.8 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/vue@10.16.4': dependencies: '@motionone/dom': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@mswjs/cookies@0.2.2': dependencies: @@ -12785,12 +12895,18 @@ snapshots: dependencies: '@noble/hashes': 1.4.0 + '@noble/curves@1.6.0': + dependencies: + '@noble/hashes': 1.5.0 + '@noble/hashes@1.2.0': {} '@noble/hashes@1.3.3': {} '@noble/hashes@1.4.0': {} + '@noble/hashes@1.5.0': {} + '@noble/secp256k1@1.7.1': {} '@nodelib/fs.scandir@2.1.5': @@ -13403,7 +13519,7 @@ snapshots: '@safe-global/safe-apps-sdk@9.1.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8)': dependencies: '@safe-global/safe-gateway-typescript-sdk': 3.21.1 - viem: 2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) + viem: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) transitivePeerDependencies: - bufferutil - typescript @@ -13414,6 +13530,8 @@ snapshots: '@scure/base@1.1.6': {} + '@scure/base@1.1.9': {} + '@scure/bip32@1.1.5': dependencies: '@noble/hashes': 1.2.0 @@ -13432,6 +13550,12 @@ snapshots: '@noble/hashes': 1.4.0 '@scure/base': 1.1.6 + '@scure/bip32@1.5.0': + dependencies: + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 + '@scure/bip39@1.1.1': dependencies: '@noble/hashes': 1.2.0 @@ -13447,6 +13571,11 @@ snapshots: '@noble/hashes': 1.4.0 '@scure/base': 1.1.6 + '@scure/bip39@1.4.0': + dependencies: + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 + '@sentry/browser@7.43.0': dependencies: '@sentry/core': 7.43.0 @@ -13804,7 +13933,7 @@ snapshots: '@swc/helpers@0.5.2': dependencies: - tslib: 2.6.2 + tslib: 2.6.3 '@szmarczak/http-timer@4.0.6': dependencies: @@ -14935,6 +15064,11 @@ snapshots: typescript: 5.4.5 zod: 3.23.8 + abitype@1.0.6(typescript@5.4.5)(zod@3.23.8): + optionalDependencies: + typescript: 5.4.5 + zod: 3.23.8 + abort-controller@3.0.0: dependencies: event-target-shim: 5.0.1 @@ -15542,7 +15676,7 @@ snapshots: capnp-ts@0.7.0: dependencies: debug: 4.3.6 - tslib: 2.6.2 + tslib: 2.6.3 transitivePeerDependencies: - supports-color @@ -16306,7 +16440,7 @@ snapshots: dot-case@3.0.4: dependencies: no-case: 3.0.4 - tslib: 2.6.2 + tslib: 2.6.3 dotenv@16.4.5: {} @@ -18317,6 +18451,10 @@ snapshots: dependencies: ws: 8.17.1(bufferutil@4.0.8)(utf-8-validate@5.0.10) + isows@1.0.6(ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)): + dependencies: + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + isstream@0.1.2: {} istanbul-lib-coverage@3.2.2: {} @@ -18896,7 +19034,7 @@ snapshots: media-query-parser@2.0.2: dependencies: - '@babel/runtime': 7.24.6 + '@babel/runtime': 7.25.0 media-typer@0.3.0: {} @@ -19449,7 +19587,7 @@ snapshots: no-case@3.0.4: dependencies: lower-case: 2.0.2 - tslib: 2.6.2 + tslib: 2.6.3 nocache@3.0.4: {} @@ -20294,7 +20432,7 @@ snapshots: dependencies: react: 18.3.1 react-style-singleton: 2.2.1(@types/react@18.2.21)(react@18.3.1) - tslib: 2.6.2 + tslib: 2.6.3 optionalDependencies: '@types/react': 18.2.21 @@ -20320,7 +20458,7 @@ snapshots: get-nonce: 1.0.1 invariant: 2.2.4 react: 18.3.1 - tslib: 2.6.2 + tslib: 2.6.3 optionalDependencies: '@types/react': 18.2.21 @@ -20466,7 +20604,7 @@ snapshots: regenerator-transform@0.15.2: dependencies: - '@babel/runtime': 7.24.6 + '@babel/runtime': 7.25.0 regexp.prototype.flags@1.5.2: dependencies: @@ -20642,7 +20780,7 @@ snapshots: rtl-css-js@1.16.1: dependencies: - '@babel/runtime': 7.24.6 + '@babel/runtime': 7.25.0 run-async@2.4.1: {} @@ -20907,7 +21045,7 @@ snapshots: snake-case@3.0.4: dependencies: dot-case: 3.0.4 - tslib: 2.6.2 + tslib: 2.6.3 socket.io-client@4.7.5(bufferutil@4.0.8)(utf-8-validate@5.0.10): dependencies: @@ -21608,6 +21746,8 @@ snapshots: ts-pattern@4.3.0: {} + ts-pattern@5.5.0: {} + tsconfig-paths@3.15.0: dependencies: '@types/json5': 0.0.29 @@ -21837,7 +21977,7 @@ snapshots: use-callback-ref@1.3.2(@types/react@18.2.21)(react@18.3.1): dependencies: react: 18.3.1 - tslib: 2.6.2 + tslib: 2.6.3 optionalDependencies: '@types/react': 18.2.21 @@ -21850,7 +21990,7 @@ snapshots: dependencies: detect-node-es: 1.1.0 react: 18.3.1 - tslib: 2.6.2 + tslib: 2.6.3 optionalDependencies: '@types/react': 18.2.21 @@ -21929,6 +22069,24 @@ snapshots: - utf-8-validate - zod + viem@2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8): + dependencies: + '@adraffy/ens-normalize': 1.11.0 + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/bip32': 1.5.0 + '@scure/bip39': 1.4.0 + abitype: 1.0.6(typescript@5.4.5)(zod@3.23.8) + isows: 1.0.6(ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)) + webauthn-p256: 0.0.10 + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + optionalDependencies: + typescript: 5.4.5 + transitivePeerDependencies: + - bufferutil + - utf-8-validate + - zod + vite-node@2.0.5(@types/node@18.19.33)(terser@5.31.5): dependencies: cac: 6.7.14 @@ -22521,6 +22679,11 @@ snapshots: - supports-color - utf-8-validate + webauthn-p256@0.0.10: + dependencies: + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + webauthn-p256@0.0.5: dependencies: '@noble/curves': 1.4.0 @@ -22792,6 +22955,11 @@ snapshots: bufferutil: 4.0.8 utf-8-validate: 5.0.10 + ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10): + optionalDependencies: + bufferutil: 4.0.8 + utf-8-validate: 5.0.10 + xhr-request-promise@0.1.3: dependencies: xhr-request: 1.1.0 diff --git a/src/components/@molecules/NameTableHeader/NameTableHeader.tsx b/src/components/@molecules/NameTableHeader/NameTableHeader.tsx index 1c4479a40..141416219 100644 --- a/src/components/@molecules/NameTableHeader/NameTableHeader.tsx +++ b/src/components/@molecules/NameTableHeader/NameTableHeader.tsx @@ -189,12 +189,14 @@ export const NameTableHeader = ({ /> onSortDirectionChange?.('asc')} > onSortDirectionChange?.('desc')} > From 270c253e7fc7af7889d6393239a8c0e9d61e06e6 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Wed, 6 Nov 2024 00:11:11 +0200 Subject: [PATCH 47/75] page rename --- src/pages/{migrate.tsx => ens-v2.tsx} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename src/pages/{migrate.tsx => ens-v2.tsx} (100%) diff --git a/src/pages/migrate.tsx b/src/pages/ens-v2.tsx similarity index 100% rename from src/pages/migrate.tsx rename to src/pages/ens-v2.tsx From 3a86d2081a60f8e981eb8885992d6a85c41bcd2e Mon Sep 17 00:00:00 2001 From: v1rtl Date: Wed, 6 Nov 2024 00:39:03 +0200 Subject: [PATCH 48/75] update --- public/locales/en/ensvs2.json | 2 +- src/pages/ens-v2.tsx | 75 +++++++++++++++++++---------------- 2 files changed, 41 insertions(+), 36 deletions(-) diff --git a/public/locales/en/ensvs2.json b/public/locales/en/ensvs2.json index 14a15d823..a9df3484c 100644 --- a/public/locales/en/ensvs2.json +++ b/public/locales/en/ensvs2.json @@ -1,6 +1,6 @@ { "title": "ENSv2: The Next Generation of ENS", - "caption": "Approve your ENS names for ENSv2 now and enjoy automatic migration, paid for by ENS DAO.", + "caption": "After seven years at the frontier of web3 naming, we're re-envisioning ENS on L2.", "accessible": { "title": "Making ENS accessible to more people", "caption": "We're taking our knowledge from the last 7 years at the frontier of web3 naming to re-envision the architecture from the ground up on L2 By utilizing L2s, we're excited to make ENS more accessible to a wider range of users.", diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index b6be85326..7cb839202 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -1,3 +1,4 @@ +/* stylelint-disable no-descending-specificity */ import { useTranslation } from 'react-i18next' import styled, { css } from 'styled-components' @@ -57,6 +58,32 @@ const Main = styled.main( `, ) +const PartnershipAnnouncement = styled.div( + ({ theme }) => css` + width: ${theme.space.full}; + padding: ${theme.space['4']}; + background-color: ${theme.colors.backgroundPrimary}; + border-radius: ${theme.radii['4xLarge']}; + font-size: ${theme.fontSizes.body}; + font-weight: ${theme.fontWeights.bold}; + display: flex; + justify-content: space-between; + & > a { + color: ${theme.colors.greenDim}; + cursor: pointer; + display: flex; + align-items: center; + gap: ${theme.space['2']}; + } + & > a:hover { + color: ${theme.colors.green}; + } + @media (min-width: 640px) { + border-radius: ${theme.radii['3xLarge']}; + } + `, +) + const Footer = styled.div( ({ theme }) => css` display: flex; @@ -65,17 +92,21 @@ const Footer = styled.div( h3 { text-align: center; } - span { + + & > div { + display: grid; + grid-template-columns: repeat(1, 1fr); + gap: ${theme.space['4']}; + } + & > div a { display: flex; flex-direction: row; align-items: center; gap: ${theme.space['2']}; color: ${theme.colors.green}; } - & > div { - display: grid; - grid-template-columns: repeat(1, 1fr); - gap: ${theme.space['4']}; + & > div a:hover { + color: ${theme.colors.greenDim}; } & > div > div { width: 100%; @@ -105,32 +136,6 @@ const AnnouncementBanner = styled.div( `, ) -const PartnershipAnnouncement = styled.div( - ({ theme }) => css` - width: ${theme.space.full}; - padding: ${theme.space['4']}; - background-color: ${theme.colors.backgroundPrimary}; - border-radius: ${theme.radii['4xLarge']}; - font-size: ${theme.fontSizes.body}; - font-weight: ${theme.fontWeights.bold}; - display: flex; - justify-content: space-between; - & > a { - color: ${theme.colors.greenDim}; - cursor: pointer; - display: flex; - align-items: center; - gap: ${theme.space['2']}; - } - & > a:hover { - color: ${theme.colors.green}; - } - @media (min-width: 640px) { - border-radius: ${theme.radii['3xLarge']}; - } - `, -) - const TopNav = styled.div( ({ theme }) => css` display: flex; @@ -302,12 +307,12 @@ export default function ENSv2() { {t('footer.support.ticket')} - + {t('footer.support.twitter')} - - + + {t('footer.support.dao')} - + From 5860ec0a1d4c8b060fd3a34d47b1823886788091 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Thu, 7 Nov 2024 01:52:35 +0800 Subject: [PATCH 49/75] fix e2e issues --- e2e/specs/stateless/extendNames.spec.ts | 111 ++++++++- package.json | 2 +- pnpm-lock.yaml | 231 +++++++++++++++--- .../PlusMinusControl/PlusMinusControl.tsx | 2 +- .../input/ExtendNames/ExtendNames-flow.tsx | 146 +++++------ 5 files changed, 381 insertions(+), 111 deletions(-) diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index fb2e7f9d8..745ce4b69 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -82,12 +82,16 @@ test('should be able to extend multiple names on the address page', async ({ await page.waitForLoadState('networkidle') await expect(page.getByTestId('invoice-item-0-amount')).not.toBeEmpty() await expect(page.getByTestId('invoice-item-1-amount')).not.toBeEmpty() - await expect(page.getByTestId('invoice-total')).not.toBeEmpty() + await expect(page.getByTestId('invoice-total')).not.toHaveText('0.0000 ETH') - page.locator('button:has-text("Next")').waitFor({ state: 'visible' }) - await page.locator('button:has-text("Next")').click() - await page.waitForLoadState('networkidle') + console.log(await page.getByTestId('invoice-total').textContent()) + // await page.locator('button:has-text("Next")').waitFor({ state: 'visible' }) + // await page.locator('button:has-text("Next")').click() + // await page.waitForLoadState('networkidle') + await page.getByTestId('extend-names-confirm').click() + + await expect(transactionModal.transactionModal).toBeVisible({ timeout: 10000 }) await transactionModal.autoComplete() await page.waitForLoadState('networkidle') @@ -109,6 +113,105 @@ test('should be able to extend multiple names on the address page', async ({ } }) +test('should be able to extend multiple names in grace period on the address page', async ({ + page, + accounts, + login, + subgraph, + makePageObject, + makeName, + time, +}) => { + // Generating names in not neccessary but we want to make sure that there are names to extend + await makeName([ + { + label: 'extend-legacy', + type: 'legacy', + owner: 'user2', + duration: -24 * 60 * 60, + }, + { + label: 'wrapped', + type: 'wrapped', + owner: 'user2', + duration: -24 * 60 * 60, + }, + ]) + + const address = accounts.getAddress('user2') + const addresPage = makePageObject('AddressPage') + const transactionModal = makePageObject('TransactionModal') + + await addresPage.goto(address) + await login.connect() + + await addresPage.selectToggle.click() + + // await page.pause() + await expect(await page.locator('.name-detail-item').count()).toBeGreaterThan(0) + const nameItems = await page.locator('.name-detail-item').all() + const nameItemTestIds = await Promise.all( + nameItems.map((item) => item.getAttribute('data-testid')), + ) + const extendableNameItems = nameItemTestIds + .filter((testid): testid is string => !!testid) + .map((testid) => testid.replace('name-item-', '')) + .filter((name) => { + const nameParts = name?.split('.') ?? [] + return nameParts.length === 2 && nameParts[1] === 'eth' + }) + + const timestampDict: { [key: string]: number } = {} + for (const name of extendableNameItems) { + const timestamp = await addresPage.getTimestamp(name) + timestampDict[name] = timestamp + } + await addresPage.extendNamesButton.click() + + // warning message + await expect(page.getByText('You do not own all these names')).toBeVisible() + await page.getByTestId('extend-names-confirm').click() + + // name list + await expect(page.getByText(`Extend ${extendableNameItems.length} Names`)).toBeVisible() + await page.locator('button:has-text("Next")').waitFor({ state: 'visible' }) + await page.locator('button:has-text("Next")').click() + + // check the invoice details + // TODO: Reimplement when date duration bug is fixed + // await expect(page.getByText('1 year extension', { exact: true })).toBeVisible() + await expect(page.getByTestId('plus-minus-control-label')).toHaveText('1 year') + await page.getByTestId('plus-minus-control-plus').click() + await expect(page.getByTestId('plus-minus-control-label')).toHaveText('2 years') + await page.getByTestId('plus-minus-control-plus').click() + await expect(page.getByTestId('plus-minus-control-label')).toHaveText('3 years') + await expect(page.getByTestId('invoice-item-0-amount')).not.toBeEmpty() + await expect(page.getByTestId('invoice-item-1-amount')).not.toBeEmpty() + await expect(page.getByTestId('invoice-total')).not.toHaveText('0.0000 ETH') + + // increment and save + await page.getByTestId('extend-names-confirm').click() + await expect(transactionModal.transactionModal).toBeVisible({ timeout: 10000 }) + await transactionModal.autoComplete() + + await expect(page.getByText('Your "Extend names" transaction was successful')).toBeVisible({ + timeout: 10000, + }) + await subgraph.sync() + + // Should be able to remove this after useQuery is fixed. Using to force a refetch. + await time.increaseTime({ seconds: 15 }) + await page.reload() + await page.waitForLoadState('networkidle') + for (const name of extendableNameItems) { + const label = name.replace('.eth', '') + await addresPage.search(label) + await expect(addresPage.getNameRow(name)).toBeVisible({ timeout: 5000 }) + await expect(await addresPage.getTimestamp(name)).not.toBe(timestampDict[name]) + await expect(await addresPage.getTimestamp(name)).toBe(timestampDict[name] + 31536000000 * 3) + } +}) + test('should be able to extend a single unwrapped name from profile', async ({ page, login, diff --git a/package.json b/package.json index d223d48ec..f7556d335 100644 --- a/package.json +++ b/package.json @@ -116,7 +116,7 @@ "@nomiclabs/hardhat-ethers": "npm:hardhat-deploy-ethers@^0.3.0-beta.13", "@openzeppelin/contracts": "^4.7.3", "@openzeppelin/test-helpers": "^0.5.16", - "@playwright/test": "^1.48.0", + "@playwright/test": "^1.48.2", "@testing-library/jest-dom": "^6.4.2", "@testing-library/react": "^14.0.0", "@testing-library/react-hooks": "^8.0.1", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 8bd38f822..aafa93edd 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -205,8 +205,8 @@ importers: specifier: ^0.5.16 version: 0.5.16(bufferutil@4.0.8)(encoding@0.1.13)(utf-8-validate@5.0.10) '@playwright/test': - specifier: ^1.48.0 - version: 1.48.0 + specifier: ^1.48.2 + version: 1.48.2 '@testing-library/jest-dom': specifier: ^6.4.2 version: 6.4.5(@types/jest@29.5.12)(vitest@2.0.5(@types/node@18.19.33)(jsdom@24.1.0(bufferutil@4.0.8)(canvas@2.11.2(encoding@0.1.13))(utf-8-validate@5.0.10))(terser@5.31.5)) @@ -296,7 +296,7 @@ importers: version: 0.3.9 eslint-plugin-import: specifier: ^2.28.1 - version: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + version: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: specifier: ^6.7.1 version: 6.8.0(eslint@8.50.0) @@ -424,6 +424,48 @@ importers: specifier: ^1.0.0-pre.53 version: 1.0.0-pre.53 + .yalc/@ensdomains/ens-test-env: + dependencies: + '@ethersproject/wallet': + specifier: ^5.6.0 + version: 5.7.0 + ansi-colors: + specifier: ^4.1.1 + version: 4.1.3 + cli-progress: + specifier: ^3.10.0 + version: 3.12.0 + commander: + specifier: ^9.3.0 + version: 9.5.0 + concurrently: + specifier: ^7.1.0 + version: 7.6.0 + docker-compose: + specifier: ^0.24.7 + version: 0.24.8 + dotenv: + specifier: ^16.0.1 + version: 16.4.5 + js-yaml: + specifier: ^4.1.0 + version: 4.1.0 + lz4: + specifier: ^0.6.5 + version: 0.6.5 + progress-stream: + specifier: ^2.0.0 + version: 2.0.0 + tar-fs: + specifier: ^2.1.1 + version: 2.1.1 + viem: + specifier: ^2.21.37 + version: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) + wait-on: + specifier: ^6.0.1 + version: 6.0.1 + packages: '@adobe/css-tools@4.3.3': @@ -435,6 +477,9 @@ packages: '@adraffy/ens-normalize@1.10.1': resolution: {integrity: sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==} + '@adraffy/ens-normalize@1.11.0': + resolution: {integrity: sha512-/3DDPKHqqIqxUULp8yP4zODUY1i+2xvVWsv8A79xGWdCAG+8sb0hRh0Rk2QyOJUnnbyPUAZYcpBuRe3nS2OIUg==} + '@ampproject/remapping@2.3.0': resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} @@ -2327,6 +2372,10 @@ packages: '@noble/curves@1.4.0': resolution: {integrity: sha512-p+4cb332SFCrReJkCYe8Xzm0OWi4Jji5jVdIZRL/PmacmDkFNw6MrrV+gGpiPxLHbV+zKFRywUWbaseT+tZRXg==} + '@noble/curves@1.6.0': + resolution: {integrity: sha512-TlaHRXDehJuRNR9TfZDNQ45mMEd5dwUwmicsafcIX4SsNiqnCHKjE/1alYPd/lDRVhxdhUAlv8uEhMCI5zjIJQ==} + engines: {node: ^14.21.3 || >=16} + '@noble/hashes@1.2.0': resolution: {integrity: sha512-FZfhjEDbT5GRswV3C6uvLPHMiVD6lQBmpoX5+eSiPaMTXte/IKqI5dykDxzZB/WBeK/CDuQRBWarPdi3FNY2zQ==} @@ -2338,6 +2387,10 @@ packages: resolution: {integrity: sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg==} engines: {node: '>= 16'} + '@noble/hashes@1.5.0': + resolution: {integrity: sha512-1j6kQFb7QRru7eKN3ZDvRcP13rugwdxZqCjbiAVZfIJwgj2A65UmT4TgARXGlXgnRkORLTDTrO19ZErt7+QXgA==} + engines: {node: ^14.21.3 || >=16} + '@noble/secp256k1@1.7.1': resolution: {integrity: sha512-hOUk6AyBFmqVrv7k5WAw/LpszxVbj9gGN4JRkIX52fdFAj1UA61KXmZDvqVEm+pOyec3+fIeZB02LYa/pWOArw==} @@ -2577,8 +2630,8 @@ packages: resolution: {integrity: sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==} engines: {node: ^12.20.0 || ^14.18.0 || >=16.0.0} - '@playwright/test@1.48.0': - resolution: {integrity: sha512-W5lhqPUVPqhtc/ySvZI5Q8X2ztBOUgZ8LbAFy0JQgrXZs2xaILrUcNO3rQjwbLPfGK13+rZsDa1FpG+tqYkT5w==} + '@playwright/test@1.48.2': + resolution: {integrity: sha512-54w1xCWfXuax7dz4W2M9uw0gDyh+ti/0K/MxcCUxChFh37kkdxPdfZDw5QBbuPUJHr1CiHJ1hXgSs+GgeQc5Zw==} engines: {node: '>=18'} hasBin: true @@ -2816,6 +2869,9 @@ packages: '@scure/base@1.1.6': resolution: {integrity: sha512-ok9AWwhcgYuGG3Zfhyqg+zwl+Wn5uE+dwC0NV/2qQkx4dABbb/bx96vWu8NSj+BNjjSjno+JRYRjle1jV08k3g==} + '@scure/base@1.1.9': + resolution: {integrity: sha512-8YKhl8GHiNI/pU2VMaofa2Tor7PJRAjwQLBBuilkJ9L5+13yVbC7JO/wS7piioAvPSwR3JKM1IJ/u4xQzbcXKg==} + '@scure/bip32@1.1.5': resolution: {integrity: sha512-XyNh1rB0SkEqd3tXcXMi+Xe1fvg+kUIcoRIEujP1Jgv7DqW2r9lg3Ah0NkFaCs9sTkQAQA8kw7xiRXzENi9Rtw==} @@ -2825,6 +2881,9 @@ packages: '@scure/bip32@1.4.0': resolution: {integrity: sha512-sVUpc0Vq3tXCkDGYVWGIZTRfnvu8LoTDaev7vbwh0omSvVORONr960MQWdKqJDCReIEmTj3PAr73O3aoxz7OPg==} + '@scure/bip32@1.5.0': + resolution: {integrity: sha512-8EnFYkqEQdnkuGBVpCzKxyIwDCBLDVj3oiX0EKUFre/tOjL/Hqba1D6n/8RcmaQy4f95qQFrO2A8Sr6ybh4NRw==} + '@scure/bip39@1.1.1': resolution: {integrity: sha512-t+wDck2rVkh65Hmv280fYdVdY25J9YeEUIgn2LG1WM6gxFkGzcksoDiUkWVpVp3Oex9xGC68JU2dSbUfwZ2jPg==} @@ -2834,6 +2893,9 @@ packages: '@scure/bip39@1.3.0': resolution: {integrity: sha512-disdg7gHuTDZtY+ZdkmLpPCk7fxZSu3gBiEGuoC1XYxv9cGx3Z6cpTggCgW6odSOOIXCiDjuGejW+aJKCY/pIQ==} + '@scure/bip39@1.4.0': + resolution: {integrity: sha512-BEEm6p8IueV/ZTfQLp/0vhw4NPnT9oWf5+28nvmeUICjP99f4vr2d+qc7AVGDDtwRep6ifR43Yed9ERVmiITzw==} + '@sentry/browser@7.43.0': resolution: {integrity: sha512-NlRkBYKb9o5IQdGY8Ktps19Hz9RdSuqS1tlLC7Sjr+MqZqSHmhKq8MWJKciRynxBeMbeGt0smExi9BqpVQdCEg==} engines: {node: '>=8'} @@ -3768,6 +3830,17 @@ packages: zod: optional: true + abitype@1.0.6: + resolution: {integrity: sha512-MMSqYh4+C/aVqI2RQaWqbvI4Kxo5cQV40WQ4QFtDnNzCkqChm8MuENhElmynZlO0qUy/ObkEUaXtKqYnx1Kp3A==} + peerDependencies: + typescript: '>=5.0.4' + zod: ^3 >=3.22.0 + peerDependenciesMeta: + typescript: + optional: true + zod: + optional: true + abort-controller@3.0.0: resolution: {integrity: sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==} engines: {node: '>=6.5'} @@ -6547,6 +6620,11 @@ packages: peerDependencies: ws: '*' + isows@1.0.6: + resolution: {integrity: sha512-lPHCayd40oW98/I0uvgaHKWCSvkzY27LjWLbtzOm64yQ+G3Q5npjjbdppU65iZXkK1Zt+kH9pfegli0AYfwYYw==} + peerDependencies: + ws: '*' + isstream@0.1.2: resolution: {integrity: sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==} @@ -7909,13 +7987,13 @@ packages: pkg-types@1.1.1: resolution: {integrity: sha512-ko14TjmDuQJ14zsotODv7dBlwxKhUKQEhuhmbqo1uCi9BB0Z2alo/wAXg6q1dTR5TyuqYyWhjtfe/Tsh+X28jQ==} - playwright-core@1.48.0: - resolution: {integrity: sha512-RBvzjM9rdpP7UUFrQzRwR8L/xR4HyC1QXMzGYTbf1vjw25/ya9NRAVnXi/0fvFopjebvyPzsmoK58xxeEOaVvA==} + playwright-core@1.48.2: + resolution: {integrity: sha512-sjjw+qrLFlriJo64du+EK0kJgZzoQPsabGF4lBvsid+3CNIZIYLgnMj9V6JY5VhM2Peh20DJWIVpVljLLnlawA==} engines: {node: '>=18'} hasBin: true - playwright@1.48.0: - resolution: {integrity: sha512-qPqFaMEHuY/ug8o0uteYJSRfMGFikhUysk8ZvAtfKmUK3kc/6oNl/y3EczF8OFGYIi/Ex2HspMfzYArk6+XQSA==} + playwright@1.48.2: + resolution: {integrity: sha512-NjYvYgp4BPmiwfe31j4gHLa3J7bD2WiBz8Lk2RoSsmX38SVIARZ18VYjxLjAcDsAhA+F4iSEXTSGgjua0rrlgQ==} engines: {node: '>=18'} hasBin: true @@ -9706,6 +9784,14 @@ packages: typescript: optional: true + viem@2.21.40: + resolution: {integrity: sha512-no/mE3l7B0mdUTtvO7z/cTLENttQ/M7+ombqFGXJqsQrxv9wrYsTIGpS3za+FA5a447hY+x9D8Wxny84q1zAaA==} + peerDependencies: + typescript: '>=5.0.4' + peerDependenciesMeta: + typescript: + optional: true + vite-node@2.0.5: resolution: {integrity: sha512-LdsW4pxj0Ot69FAoXZ1yTnA9bjGohr2yNBU7QKRxpz8ITSkhuDl6h3zS/tvgz4qrNjeRnvrWeXQ8ZF7Um4W00Q==} engines: {node: ^18.0.0 || >=20.0.0} @@ -10012,6 +10098,9 @@ packages: resolution: {integrity: sha512-kgJvQZjkmjOEKimx/tJQsqWfRDPTTcBfYPa9XletxuHLpHcXdx67w8EFn5AW3eVxCutE9dTVHgGa9VYe8vgsEA==} engines: {node: '>=8.0.0'} + webauthn-p256@0.0.10: + resolution: {integrity: sha512-EeYD+gmIT80YkSIDb2iWq0lq2zbHo1CxHlQTeJ+KkCILWpVy3zASH3ByD4bopzfk0uCwXxLqKGLqp2W4O28VFA==} + webauthn-p256@0.0.5: resolution: {integrity: sha512-drMGNWKdaixZNobeORVIqq7k5DsRC9FnG201K2QjeOoQLmtSDaSsVZdkg6n5jUALJKcAG++zBPJXmv6hy0nWFg==} @@ -10255,6 +10344,18 @@ packages: utf-8-validate: optional: true + ws@8.18.0: + resolution: {integrity: sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw==} + engines: {node: '>=10.0.0'} + peerDependencies: + bufferutil: ^4.0.1 + utf-8-validate: '>=5.0.2' + peerDependenciesMeta: + bufferutil: + optional: true + utf-8-validate: + optional: true + xhr-request-promise@0.1.3: resolution: {integrity: sha512-YUBytBsuwgitWtdRzXDDkWAXzhdGB8bYm0sSzMPZT7Z2MBjMSTHFsyCT1yCRATY+XC69DUrQraRAEgcoCRaIPg==} @@ -10423,6 +10524,8 @@ snapshots: '@adraffy/ens-normalize@1.10.1': {} + '@adraffy/ens-normalize@1.11.0': {} + '@ampproject/remapping@2.3.0': dependencies: '@jridgewell/gen-mapping': 0.3.5 @@ -12686,7 +12789,7 @@ snapshots: '@motionone/easing': 10.17.0 '@motionone/types': 10.17.0 '@motionone/utils': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/dom@10.17.0': dependencies: @@ -12695,12 +12798,12 @@ snapshots: '@motionone/types': 10.17.0 '@motionone/utils': 10.17.0 hey-listen: 1.0.8 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/easing@10.17.0': dependencies: '@motionone/utils': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/generators@10.17.0': dependencies: @@ -12711,7 +12814,7 @@ snapshots: '@motionone/svelte@10.16.4': dependencies: '@motionone/dom': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/types@10.17.0': {} @@ -12719,12 +12822,12 @@ snapshots: dependencies: '@motionone/types': 10.17.0 hey-listen: 1.0.8 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/vue@10.16.4': dependencies: '@motionone/dom': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@mswjs/cookies@0.2.2': dependencies: @@ -12797,12 +12900,18 @@ snapshots: dependencies: '@noble/hashes': 1.4.0 + '@noble/curves@1.6.0': + dependencies: + '@noble/hashes': 1.5.0 + '@noble/hashes@1.2.0': {} '@noble/hashes@1.3.3': {} '@noble/hashes@1.4.0': {} + '@noble/hashes@1.5.0': {} + '@noble/secp256k1@1.7.1': {} '@nodelib/fs.scandir@2.1.5': @@ -12998,9 +13107,9 @@ snapshots: '@pkgr/core@0.1.1': {} - '@playwright/test@1.48.0': + '@playwright/test@1.48.2': dependencies: - playwright: 1.48.0 + playwright: 1.48.2 '@polka/url@1.0.0-next.25': {} @@ -13415,7 +13524,7 @@ snapshots: '@safe-global/safe-apps-sdk@9.1.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8)': dependencies: '@safe-global/safe-gateway-typescript-sdk': 3.21.1 - viem: 2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) + viem: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) transitivePeerDependencies: - bufferutil - typescript @@ -13426,6 +13535,8 @@ snapshots: '@scure/base@1.1.6': {} + '@scure/base@1.1.9': {} + '@scure/bip32@1.1.5': dependencies: '@noble/hashes': 1.2.0 @@ -13444,6 +13555,12 @@ snapshots: '@noble/hashes': 1.4.0 '@scure/base': 1.1.6 + '@scure/bip32@1.5.0': + dependencies: + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 + '@scure/bip39@1.1.1': dependencies: '@noble/hashes': 1.2.0 @@ -13459,6 +13576,11 @@ snapshots: '@noble/hashes': 1.4.0 '@scure/base': 1.1.6 + '@scure/bip39@1.4.0': + dependencies: + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 + '@sentry/browser@7.43.0': dependencies: '@sentry/core': 7.43.0 @@ -14955,6 +15077,11 @@ snapshots: typescript: 5.4.5 zod: 3.23.8 + abitype@1.0.6(typescript@5.4.5)(zod@3.23.8): + optionalDependencies: + typescript: 5.4.5 + zod: 3.23.8 + abort-controller@3.0.0: dependencies: event-target-shim: 5.0.1 @@ -16326,7 +16453,7 @@ snapshots: dot-case@3.0.4: dependencies: no-case: 3.0.4 - tslib: 2.6.2 + tslib: 2.6.3 dotenv@16.4.5: {} @@ -16657,7 +16784,7 @@ snapshots: dependencies: confusing-browser-globals: 1.0.11 eslint: 8.50.0 - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) object.assign: 4.1.5 object.entries: 1.1.8 semver: 6.3.1 @@ -16668,13 +16795,13 @@ snapshots: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-config-airbnb@19.0.4(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint-plugin-jsx-a11y@6.8.0(eslint@8.50.0))(eslint-plugin-react-hooks@4.6.2(eslint@8.50.0))(eslint-plugin-react@7.34.1(eslint@8.50.0))(eslint@8.50.0): dependencies: eslint: 8.50.0 eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) @@ -16688,8 +16815,8 @@ snapshots: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) @@ -16711,13 +16838,13 @@ snapshots: transitivePeerDependencies: - supports-color - eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0): + eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0): dependencies: debug: 4.3.4(supports-color@5.5.0) enhanced-resolve: 5.16.1 eslint: 8.50.0 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 is-core-module: 2.13.1 @@ -16728,18 +16855,18 @@ snapshots: - eslint-import-resolver-webpack - supports-color - eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0): + eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0): dependencies: debug: 3.2.7 optionalDependencies: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) + eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0) transitivePeerDependencies: - supports-color - eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0): + eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0): dependencies: array-includes: 3.1.8 array.prototype.findlastindex: 1.2.5 @@ -16749,7 +16876,7 @@ snapshots: doctrine: 2.1.0 eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) hasown: 2.0.2 is-core-module: 2.13.1 is-glob: 4.0.3 @@ -18337,6 +18464,10 @@ snapshots: dependencies: ws: 8.17.1(bufferutil@4.0.8)(utf-8-validate@5.0.10) + isows@1.0.6(ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)): + dependencies: + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + isstream@0.1.2: {} istanbul-lib-coverage@3.2.2: {} @@ -19469,7 +19600,7 @@ snapshots: no-case@3.0.4: dependencies: lower-case: 2.0.2 - tslib: 2.6.2 + tslib: 2.6.3 nocache@3.0.4: {} @@ -19951,11 +20082,11 @@ snapshots: mlly: 1.7.0 pathe: 1.1.2 - playwright-core@1.48.0: {} + playwright-core@1.48.2: {} - playwright@1.48.0: + playwright@1.48.2: dependencies: - playwright-core: 1.48.0 + playwright-core: 1.48.2 optionalDependencies: fsevents: 2.3.2 @@ -20486,7 +20617,7 @@ snapshots: regenerator-transform@0.15.2: dependencies: - '@babel/runtime': 7.24.6 + '@babel/runtime': 7.25.0 regexp.prototype.flags@1.5.2: dependencies: @@ -21949,6 +22080,24 @@ snapshots: - utf-8-validate - zod + viem@2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8): + dependencies: + '@adraffy/ens-normalize': 1.11.0 + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/bip32': 1.5.0 + '@scure/bip39': 1.4.0 + abitype: 1.0.6(typescript@5.4.5)(zod@3.23.8) + isows: 1.0.6(ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)) + webauthn-p256: 0.0.10 + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + optionalDependencies: + typescript: 5.4.5 + transitivePeerDependencies: + - bufferutil + - utf-8-validate + - zod + vite-node@2.0.5(@types/node@18.19.33)(terser@5.31.5): dependencies: cac: 6.7.14 @@ -22541,6 +22690,11 @@ snapshots: - supports-color - utf-8-validate + webauthn-p256@0.0.10: + dependencies: + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + webauthn-p256@0.0.5: dependencies: '@noble/curves': 1.4.0 @@ -22812,6 +22966,11 @@ snapshots: bufferutil: 4.0.8 utf-8-validate: 5.0.10 + ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10): + optionalDependencies: + bufferutil: 4.0.8 + utf-8-validate: 5.0.10 + xhr-request-promise@0.1.3: dependencies: xhr-request: 1.1.0 diff --git a/src/components/@atoms/PlusMinusControl/PlusMinusControl.tsx b/src/components/@atoms/PlusMinusControl/PlusMinusControl.tsx index 188bae25b..e83ae7b64 100644 --- a/src/components/@atoms/PlusMinusControl/PlusMinusControl.tsx +++ b/src/components/@atoms/PlusMinusControl/PlusMinusControl.tsx @@ -252,7 +252,7 @@ export const PlusMinusControl = forwardRef( }} onBlur={handleBlur} /> - + } - trailing={ - + + ) +} diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index 7cb839202..c5390aead 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -217,7 +217,7 @@ const Video = styled.video( ) export default function ENSv2() { - const { t } = useTranslation('ensvs2') + const { t } = useTranslation('ensv2') return (
diff --git a/src/pages/index.tsx b/src/pages/index.tsx index 77fccae3c..2df5b1ac1 100644 --- a/src/pages/index.tsx +++ b/src/pages/index.tsx @@ -8,6 +8,7 @@ import FaucetBanner from '@app/components/@molecules/FaucetBanner' import Hamburger from '@app/components/@molecules/Hamburger/Hamburger' import { SearchInput } from '@app/components/@molecules/SearchInput/SearchInput' import { LeadingHeading } from '@app/components/LeadingHeading' +import { AnnouncementBanner } from '@app/components/pages/AnnouncementBanner' import { VerificationErrorDialog } from '@app/components/pages/VerificationErrorDialog' import { useVerificationOAuthHandler } from '@app/hooks/verification/useVerificationOAuthHandler/useVerificationOAuthHandler' @@ -114,6 +115,8 @@ export default function Page() { + + From b5ac81d123633d60ea1d2befa8ccba501dfe3b7c Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Fri, 8 Nov 2024 00:13:54 +0800 Subject: [PATCH 54/75] fix faling tests --- e2e/specs/stateless/extendNames.spec.ts | 10 ++++---- .../ExtendNames/ExtendNames-flow.test.tsx | 23 ++++++++++++++----- 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/e2e/specs/stateless/extendNames.spec.ts b/e2e/specs/stateless/extendNames.spec.ts index 44ae3943c..b13b390ee 100644 --- a/e2e/specs/stateless/extendNames.spec.ts +++ b/e2e/specs/stateless/extendNames.spec.ts @@ -11,7 +11,7 @@ import { daysToSeconds } from '@app/utils/time' import { test } from '../../../playwright' -test('should be able to extend multiple names in grace period on the address page', async ({ +test('should be able to extend multiple names (including names in grace preiod) on the address page', async ({ page, accounts, login, @@ -45,7 +45,6 @@ test('should be able to extend multiple names in grace period on the address pag await addresPage.selectToggle.click() - // await page.pause() await expect(await page.locator('.name-detail-item').count()).toBeGreaterThan(0) const nameItems = await page.locator('.name-detail-item').all() const nameItemTestIds = await Promise.all( @@ -83,11 +82,10 @@ test('should be able to extend multiple names in grace period on the address pag await expect(page.getByTestId('plus-minus-control-label')).toHaveText('2 years') await page.getByTestId('plus-minus-control-plus').click() await expect(page.getByTestId('plus-minus-control-label')).toHaveText('3 years') - await expect(page.getByTestId('invoice-item-0-amount')).not.toBeEmpty() - await expect(page.getByTestId('invoice-item-1-amount')).not.toBeEmpty() + await expect(page.getByTestId('invoice-item-0-amount')).not.toHaveText('0.0000 ETH') + await expect(page.getByTestId('invoice-item-1-amount')).not.toHaveText('0.0000 ETH') await expect(page.getByTestId('invoice-total')).not.toHaveText('0.0000 ETH') - // increment and save await page.getByTestId('extend-names-confirm').click() await expect(transactionModal.transactionModal).toBeVisible({ timeout: 10000 }) await transactionModal.autoComplete() @@ -375,7 +373,7 @@ test('should be able to extend a name by a month', async ({ await test.step('should show the correct price data', async () => { await expect(extendNamesModal.getInvoiceExtensionFee).toContainText('0.0003') await expect(extendNamesModal.getInvoiceTransactionFee).toContainText('0.0001') - await expect(extendNamesModal.getInvoiceTotal).toContainText('0.0004') + await expect(extendNamesModal.getInvoiceTotal).toContainText(/0\.000[3|4]/) await expect(page.getByText(/1 month .* extension/)).toBeVisible() }) diff --git a/src/transaction-flow/input/ExtendNames/ExtendNames-flow.test.tsx b/src/transaction-flow/input/ExtendNames/ExtendNames-flow.test.tsx index 986d1aa23..2ed1ecea3 100644 --- a/src/transaction-flow/input/ExtendNames/ExtendNames-flow.test.tsx +++ b/src/transaction-flow/input/ExtendNames/ExtendNames-flow.test.tsx @@ -1,18 +1,28 @@ import { mockFunction, render, screen } from '@app/test-utils' import { describe, expect, it, vi } from 'vitest' +import { useAccount, useBalance } from 'wagmi' import { useEstimateGasWithStateOverride } from '@app/hooks/chain/useEstimateGasWithStateOverride' +import { useExpiry } from '@app/hooks/ensjs/public/useExpiry' import { usePrice } from '@app/hooks/ensjs/public/usePrice' +import { useEthPrice } from '@app/hooks/useEthPrice' import { makeMockIntersectionObserver } from '../../../../test/mock/makeMockIntersectionObserver' import ExtendNames from './ExtendNames-flow' vi.mock('@app/hooks/chain/useEstimateGasWithStateOverride') vi.mock('@app/hooks/ensjs/public/usePrice') +vi.mock('wagmi') +vi.mock('@app/hooks/ensjs/public/useExpiry') +vi.mock('@app/hooks/useEthPrice') const mockUseEstimateGasWithStateOverride = mockFunction(useEstimateGasWithStateOverride) const mockUsePrice = mockFunction(usePrice) +const mockUseAccount = mockFunction(useAccount) +const mockUseBalance = mockFunction(useBalance) +const mockUseEthPrice = mockFunction(useEthPrice) +const mockUseExpiry = mockFunction(useExpiry) vi.mock('@ensdomains/thorin', async () => { const originalModule = await vi.importActual('@ensdomains/thorin') @@ -45,6 +55,10 @@ describe('Extendnames', () => { }, isLoading: false, }) + mockUseAccount.mockReturnValue({ address: '0x1234', isConnected: true }) + mockUseBalance.mockReturnValue({ data: { balance: 100n }, isLoading: false }) + mockUseEthPrice.mockReturnValue({ data: 100n, isLoading: false }) + mockUseExpiry.mockReturnValue({ data: { expiry: { date: new Date() } }, isLoading: false }) it('should render', async () => { render( { const { parentElement } = optionBar expect(parentElement).toHaveStyle('opacity: 0.5') }) - it('should disabled next button if gas limit estimation is still loading', () => { - mockUseEstimateGasWithStateOverride.mockReturnValueOnce({ - data: { gasEstimate: 21000n, gasCost: 100n }, - gasPrice: 100n, - error: null, + it('should disabled next button if the price data is loading ', () => { + mockUsePrice.mockReturnValueOnce({ isLoading: true, }) render( null, onDismiss: () => null, }} From 3c486bc6ccacf486ee3e9536b1104f477504277e Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Fri, 8 Nov 2024 17:54:37 +0800 Subject: [PATCH 55/75] fix disabling invalid names --- src/components/@molecules/NameListView/NameListView.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/components/@molecules/NameListView/NameListView.tsx b/src/components/@molecules/NameListView/NameListView.tsx index a602c8cc7..553686d2e 100644 --- a/src/components/@molecules/NameListView/NameListView.tsx +++ b/src/components/@molecules/NameListView/NameListView.tsx @@ -150,7 +150,7 @@ export const NameListView = ({ address, selfAddress, setError, setLoading }: Nam }, [stage]) const isNameExtendable = (name: Name) => - name.parentName === 'eth' && !!name.labelName && !name.labelName.includes('Invalid ENS Name') + name.parentName === 'eth' && !!name.name && !name.name.includes('Invalid ENS Name') const isNameDisabled = useCallback( (name: Name) => { From bd2685fed961129b6225ad17364980dc06ccf3bf Mon Sep 17 00:00:00 2001 From: v1rtl Date: Fri, 8 Nov 2024 17:06:37 +0200 Subject: [PATCH 56/75] qa --- public/locales/en/ensv2.json | 9 ++++++-- src/pages/ens-v2.tsx | 42 +++++++++++++++++++++--------------- 2 files changed, 32 insertions(+), 19 deletions(-) diff --git a/public/locales/en/ensv2.json b/public/locales/en/ensv2.json index f0ec9019e..6064ec0a5 100644 --- a/public/locales/en/ensv2.json +++ b/public/locales/en/ensv2.json @@ -1,6 +1,6 @@ { - "title": "ENSv2: The Next Generation of ENS", - "caption": "After seven years at the frontier of web3 naming, we're re-envisioning ENS on L2.", + "title": "Namechain is a Layer 2 designed for onchain identity", + "caption": "Built for everyone tired of addresses, numbers, and complexity. Namechain lets users and developers create onchain identities through the power of names, not numbers.", "accessible": { "title": "Making ENS accessible to more people", "caption": "We're taking our knowledge from the last 7 years at the frontier of web3 naming to re-envision the architecture from the ground up on L2 By utilizing L2s, we're excited to make ENS more accessible to a wider range of users.", @@ -18,6 +18,11 @@ "text": "Layer 2 enables seamless .eth name use across blockchains with trustless connections." } }, + "learn-more": { + "title": "Want to learn more?", + "caption": "If you’re interested in learning more and building on Namechain, join the ENS Developer Telegram.", + "button": "Developer Telegram" + }, "announcement": { "title": "Announcements", "l2": { diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index c5390aead..184fecce8 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -26,15 +26,11 @@ const Title = styled.h1` font-weight: 830; text-align: center; - font-size: 52px; + font-size: 36px; line-height: 104%; @media (min-width: 640px) { - font-size: 60px; - } - - @media (min-width: 1024px) { - font-size: 76px; + font-size: 52px; } ` @@ -46,7 +42,8 @@ const Header = styled.header( justify-content: center; gap: ${theme.space[4]}; padding: ${theme.space[4]}; - min-height: 530px; + min-height: 330px; + text-align: center; `, ) @@ -149,18 +146,15 @@ const TopNav = styled.div( `, ) -const CardWithEmoji = styled(Card)` +const CenteredCard = styled(Card)` display: flex; flex-direction: column; align-items: center; justify-content: center; - padding-top: 83px; - position: relative; +` + +const CardWithEmoji = styled(CenteredCard)` grid-column: 1 / -1; - & > img { - position: absolute; - top: -72px; - } ` const GridOneToThree = styled.div( @@ -212,7 +206,6 @@ const Video = styled.video( height: ${theme.space.full}; width: ${theme.space.full}; border-radius: ${theme.radii.card}; - margin-bottom: ${theme.space[18]}; `, ) @@ -230,14 +223,29 @@ export default function ENSv2() {
{t('title')} - {t('caption')} + {t('caption')}
+ + + {t('learn-more.title')} + + {t('learn-more.caption')} + + - 🎉 {t('accessible.title')} From aea59af95bf6883c87640e0e6c9ff495ea6ceeed Mon Sep 17 00:00:00 2001 From: v1rtl Date: Fri, 8 Nov 2024 18:29:16 +0200 Subject: [PATCH 57/75] `knip --dependencies` --- package.json | 3 --- pnpm-lock.yaml | 14 +------------- 2 files changed, 1 insertion(+), 16 deletions(-) diff --git a/package.json b/package.json index 156a00b13..1e3666f84 100644 --- a/package.json +++ b/package.json @@ -67,8 +67,6 @@ "@tanstack/react-query": "5.22.2", "@tanstack/react-query-persist-client": "5.22.2", "@wagmi/core": "2.13.3", - "@walletconnect/ethereum-provider": "^2.11.1", - "@walletconnect/modal": "^2.6.2", "calendar-link": "^2.2.0", "dns-packet": "^5.4.0", "graphql-request": "5.1.0", @@ -153,7 +151,6 @@ "hardhat-dependency-compiler": "^1.1.3", "hardhat-deploy": "^0.11.12", "husky": "^7.0.4", - "isows": "^1.0.3", "jsdom": "^24.1.0", "knip": "^5.27.2", "lokijs": "^1.5.12", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index b31adf65f..85341bd1f 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -156,12 +156,6 @@ importers: '@wagmi/core': specifier: 2.13.3 version: 2.13.3(@tanstack/query-core@5.22.2)(@types/react@18.2.21)(immer@9.0.21)(react@18.3.1)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8)) - '@walletconnect/ethereum-provider': - specifier: 2.11.1 - version: 2.11.1(@types/react@18.2.21)(bufferutil@4.0.8)(encoding@0.1.13)(react@18.3.1)(utf-8-validate@5.0.10) - '@walletconnect/modal': - specifier: 2.6.2 - version: 2.6.2(@types/react@18.2.21)(react@18.3.1) calendar-link: specifier: ^2.2.0 version: 2.6.0 @@ -397,9 +391,6 @@ importers: husky: specifier: ^7.0.4 version: 7.0.4 - isows: - specifier: ^1.0.3 - version: 1.0.4(ws@8.17.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)) jsdom: specifier: ^24.1.0 version: 24.1.0(bufferutil@4.0.8)(canvas@2.11.2(encoding@0.1.13))(utf-8-validate@5.0.10) @@ -4077,6 +4068,7 @@ packages: acorn-import-assertions@1.9.0: resolution: {integrity: sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==} + deprecated: package has been renamed to acorn-import-attributes peerDependencies: acorn: ^8 @@ -17804,10 +17796,6 @@ snapshots: transitivePeerDependencies: - encoding - isows@1.0.4(ws@8.17.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)): - dependencies: - ws: 8.17.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) - isows@1.0.4(ws@8.17.1(bufferutil@4.0.8)(utf-8-validate@5.0.10)): dependencies: ws: 8.17.1(bufferutil@4.0.8)(utf-8-validate@5.0.10) From a8b7453ef3f49e5029ee33b98a6d741528f59d96 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Fri, 8 Nov 2024 18:31:28 +0200 Subject: [PATCH 58/75] fix lock --- pnpm-lock.yaml | 934 +++++++++++++++++++++++++++++-------------------- 1 file changed, 551 insertions(+), 383 deletions(-) diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 85341bd1f..07d032c32 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -273,7 +273,7 @@ importers: version: 0.5.16(bufferutil@4.0.8)(encoding@0.1.13)(utf-8-validate@5.0.10) '@playwright/test': specifier: ^1.48.0 - version: 1.48.0 + version: 1.48.2 '@testing-library/jest-dom': specifier: ^6.4.2 version: 6.4.5(@types/jest@29.5.12)(vitest@2.0.5(@types/node@18.19.33)(jsdom@24.1.0(bufferutil@4.0.8)(canvas@2.11.2(encoding@0.1.13))(utf-8-validate@5.0.10))(terser@5.31.5)) @@ -490,6 +490,9 @@ packages: '@adraffy/ens-normalize@1.10.1': resolution: {integrity: sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==} + '@adraffy/ens-normalize@1.11.0': + resolution: {integrity: sha512-/3DDPKHqqIqxUULp8yP4zODUY1i+2xvVWsv8A79xGWdCAG+8sb0hRh0Rk2QyOJUnnbyPUAZYcpBuRe3nS2OIUg==} + '@ampproject/remapping@2.3.0': resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} @@ -2382,6 +2385,10 @@ packages: '@noble/curves@1.4.0': resolution: {integrity: sha512-p+4cb332SFCrReJkCYe8Xzm0OWi4Jji5jVdIZRL/PmacmDkFNw6MrrV+gGpiPxLHbV+zKFRywUWbaseT+tZRXg==} + '@noble/curves@1.6.0': + resolution: {integrity: sha512-TlaHRXDehJuRNR9TfZDNQ45mMEd5dwUwmicsafcIX4SsNiqnCHKjE/1alYPd/lDRVhxdhUAlv8uEhMCI5zjIJQ==} + engines: {node: ^14.21.3 || >=16} + '@noble/hashes@1.2.0': resolution: {integrity: sha512-FZfhjEDbT5GRswV3C6uvLPHMiVD6lQBmpoX5+eSiPaMTXte/IKqI5dykDxzZB/WBeK/CDuQRBWarPdi3FNY2zQ==} @@ -2393,6 +2400,10 @@ packages: resolution: {integrity: sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg==} engines: {node: '>= 16'} + '@noble/hashes@1.5.0': + resolution: {integrity: sha512-1j6kQFb7QRru7eKN3ZDvRcP13rugwdxZqCjbiAVZfIJwgj2A65UmT4TgARXGlXgnRkORLTDTrO19ZErt7+QXgA==} + engines: {node: ^14.21.3 || >=16} + '@noble/secp256k1@1.7.1': resolution: {integrity: sha512-hOUk6AyBFmqVrv7k5WAw/LpszxVbj9gGN4JRkIX52fdFAj1UA61KXmZDvqVEm+pOyec3+fIeZB02LYa/pWOArw==} @@ -2632,8 +2643,8 @@ packages: resolution: {integrity: sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==} engines: {node: ^12.20.0 || ^14.18.0 || >=16.0.0} - '@playwright/test@1.48.0': - resolution: {integrity: sha512-W5lhqPUVPqhtc/ySvZI5Q8X2ztBOUgZ8LbAFy0JQgrXZs2xaILrUcNO3rQjwbLPfGK13+rZsDa1FpG+tqYkT5w==} + '@playwright/test@1.48.2': + resolution: {integrity: sha512-54w1xCWfXuax7dz4W2M9uw0gDyh+ti/0K/MxcCUxChFh37kkdxPdfZDw5QBbuPUJHr1CiHJ1hXgSs+GgeQc5Zw==} engines: {node: '>=18'} hasBin: true @@ -2866,6 +2877,9 @@ packages: '@scure/base@1.1.6': resolution: {integrity: sha512-ok9AWwhcgYuGG3Zfhyqg+zwl+Wn5uE+dwC0NV/2qQkx4dABbb/bx96vWu8NSj+BNjjSjno+JRYRjle1jV08k3g==} + '@scure/base@1.1.9': + resolution: {integrity: sha512-8YKhl8GHiNI/pU2VMaofa2Tor7PJRAjwQLBBuilkJ9L5+13yVbC7JO/wS7piioAvPSwR3JKM1IJ/u4xQzbcXKg==} + '@scure/bip32@1.1.5': resolution: {integrity: sha512-XyNh1rB0SkEqd3tXcXMi+Xe1fvg+kUIcoRIEujP1Jgv7DqW2r9lg3Ah0NkFaCs9sTkQAQA8kw7xiRXzENi9Rtw==} @@ -2875,6 +2889,9 @@ packages: '@scure/bip32@1.4.0': resolution: {integrity: sha512-sVUpc0Vq3tXCkDGYVWGIZTRfnvu8LoTDaev7vbwh0omSvVORONr960MQWdKqJDCReIEmTj3PAr73O3aoxz7OPg==} + '@scure/bip32@1.5.0': + resolution: {integrity: sha512-8EnFYkqEQdnkuGBVpCzKxyIwDCBLDVj3oiX0EKUFre/tOjL/Hqba1D6n/8RcmaQy4f95qQFrO2A8Sr6ybh4NRw==} + '@scure/bip39@1.1.1': resolution: {integrity: sha512-t+wDck2rVkh65Hmv280fYdVdY25J9YeEUIgn2LG1WM6gxFkGzcksoDiUkWVpVp3Oex9xGC68JU2dSbUfwZ2jPg==} @@ -2884,6 +2901,9 @@ packages: '@scure/bip39@1.3.0': resolution: {integrity: sha512-disdg7gHuTDZtY+ZdkmLpPCk7fxZSu3gBiEGuoC1XYxv9cGx3Z6cpTggCgW6odSOOIXCiDjuGejW+aJKCY/pIQ==} + '@scure/bip39@1.4.0': + resolution: {integrity: sha512-BEEm6p8IueV/ZTfQLp/0vhw4NPnT9oWf5+28nvmeUICjP99f4vr2d+qc7AVGDDtwRep6ifR43Yed9ERVmiITzw==} + '@sentry/browser@7.43.0': resolution: {integrity: sha512-NlRkBYKb9o5IQdGY8Ktps19Hz9RdSuqS1tlLC7Sjr+MqZqSHmhKq8MWJKciRynxBeMbeGt0smExi9BqpVQdCEg==} engines: {node: '>=8'} @@ -3000,272 +3020,288 @@ packages: '@socket.io/component-emitter@3.1.2': resolution: {integrity: sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==} - '@socketregistry/aggregate-error@1.0.2': - resolution: {integrity: sha512-t/pYgFe0Fu5Xxj/sxeZSN+R+zRJkCapIbbnMmnUaaYMFiGa7F4QEpzfco9SzDsLKCL5KiXPk7eNoq5u+Zb7omQ==} + '@socketregistry/aggregate-error@1.0.6': + resolution: {integrity: sha512-QsK9ig68OfwbISp+P9y8SxbC3I7LGyHuig5/p6qDhIdAyqeyZhWKaqo7Ik8wUx607HaftfWKvcRIBHrM4Svd3A==} + engines: {node: '>=18.20.4'} + + '@socketregistry/array-buffer-byte-length@1.0.5': + resolution: {integrity: sha512-nHUtF1H43uc7NzT6Jy+QVeGtrcnI5nG80kqBXMS2vIIawQC8la5hAlviUKCdQtAdHo2duykmGEteQY6vw0CjkQ==} engines: {node: '>=18.20.4'} - '@socketregistry/array-buffer-byte-length@1.0.2': - resolution: {integrity: sha512-NnEN2yy/+CLT4crAkmVe61TBxCgVvm2Waed592kQ60BkeMQJO/u6NIz5UxIc1doKoMoOtpWFC7BsshdQ8OygdA==} + '@socketregistry/array-flatten@1.0.5': + resolution: {integrity: sha512-UjH1HMUq9csx1SdkHbMQr050mLplRX+5DOxRwigg+q1PuITjZpHs5KtnRapWQbFhNjjAyBwHXBvGHCMHwlb5AA==} engines: {node: '>=18.20.4'} - '@socketregistry/array-flatten@1.0.2': - resolution: {integrity: sha512-PtSpo+Um8t89av01cbNN5wMNt2wwA4Z9iC+VAVTYM+IDJY4edDmvjbT7aLW8RyIX4+iyusrOKRTYArxUKY9tsg==} + '@socketregistry/array-includes@1.0.5': + resolution: {integrity: sha512-z4g/g1t7wrRPQMGbbWGuoDZABiNtB7ALEHv4FPhKpSa+9Gmxj3Dls0RbsmJezBwZGhcQgpXrH7EblvdRDz02Mg==} engines: {node: '>=18.20.4'} - '@socketregistry/array-includes@1.0.2': - resolution: {integrity: sha512-05kt9puYSisQAr5+d4HVKOb/pgC/6gKGxJGkmpPN6xG6x7ZL5hUur+37YKxgC68fdteeBwkfLrPeUM27qd77pg==} + '@socketregistry/array.prototype.findlast@1.0.5': + resolution: {integrity: sha512-R2QBrCoCjNoVAXdu3taABt24axZvPZ17XjjasiprdsfVsOIc7mFbYpyp+g9pOurTfziBH2R3wIoVq7Qdau5Q7A==} engines: {node: '>=18.20.4'} - '@socketregistry/array.prototype.findlast@1.0.2': - resolution: {integrity: sha512-Mx6n+Babc3/JW3GlyGTmef27W1hhGDc/vdxPpNB0N+5KqNgq2shKJtltQtVt3RNaipLQ+8in8c6ssIZOwUs9kg==} + '@socketregistry/array.prototype.findlastindex@1.0.5': + resolution: {integrity: sha512-Qkz+/wRh4rqjWSM0JFxAzI64kQKqh+JpX60+Z5BYvgUSYUMKaOXvpJS7fNrTcmdNiLub/RGDSttnFy54fP/Hiw==} engines: {node: '>=18.20.4'} - '@socketregistry/array.prototype.findlastindex@1.0.2': - resolution: {integrity: sha512-tRT9zZXIzXTzIFCWSEoH9NEU8Q03CynFdwoJghuPHucNtfkZI1k/fUSTJm3D9L7L1lw9x6Sau+dCktRVSflknQ==} + '@socketregistry/array.prototype.flat@1.0.5': + resolution: {integrity: sha512-IpWx6UPDJFIWJkASMTh+NfdWmjOFtx41g5KcfNqCKKkrwvM48KF8ujifIlWwF+hdZu402EM4OhkwY1SV3hrdkA==} engines: {node: '>=18.20.4'} - '@socketregistry/array.prototype.flat@1.0.2': - resolution: {integrity: sha512-wlDtbBiodslkhBUxK3Zm7Y0/4qhLXvz+KAES0I6PZjpplRDQl4ovBO+TsSgw2DG6J04R0sU4GXIk7T8hwq4f/Q==} + '@socketregistry/array.prototype.flatmap@1.0.5': + resolution: {integrity: sha512-grBCFWhMLGA8SUfI0rUjBzECcT4SPkKkSdjIzaAWRGqo1lF7AKL1Y9U3bL4bhr89vatgrisQ3YfuUQWG8x9Eyg==} engines: {node: '>=18.20.4'} - '@socketregistry/array.prototype.flatmap@1.0.2': - resolution: {integrity: sha512-NSfLVhyrne3HQFDmVjFQA0efGw6ffXS89vlxd0MAKDwb69Pm04L9ptcJYpMk5KePy3xHlInLHBcSL0jwK0ivfQ==} + '@socketregistry/arraybuffer.prototype.slice@1.0.5': + resolution: {integrity: sha512-Bu0p9gZKkPUhnZttJ3CYMSSO3yzP5xanQ9mHtu80+ETHU5z5FqiKa6gYHxkQgb7T/LyBfGGoUmMrKGvKhxiT/w==} engines: {node: '>=18.20.4'} - '@socketregistry/arraybuffer.prototype.slice@1.0.2': - resolution: {integrity: sha512-+UxX/TBcH/+2Ne3UrOX2PcHZTnKFVOrP4oeUcJlq6PwVcj7Urjwy4DYmledOQ2wnSE0yPZU1pp5U7JCwRe3F1A==} + '@socketregistry/available-typed-arrays@1.0.5': + resolution: {integrity: sha512-PJmQqWZ3Sf+Et7akfhcD5h1+RyLbsnclwNaHjwVkQQT85DJXRM+V4/e7n/wr+xqtRMOEpMWTTyhubR9VzCGSew==} engines: {node: '>=18.20.4'} - '@socketregistry/available-typed-arrays@1.0.2': - resolution: {integrity: sha512-4vcuP9rNmvvtk8sFbaIqnz5ljTJNxH31hXqt5TBr7v7gzlKgEgY5CYQNXDwTaHih/YfXUKv56NwhQqKVHxPErQ==} + '@socketregistry/deep-equal@1.0.6': + resolution: {integrity: sha512-EqrNjTReRmb9jQKhceqjGaRP3tBetnuI+p8QAXoUvW+HErjRnSf7fjDXFAYTzy2rI9DKUMaK8bU8iubV6HhNfg==} engines: {node: '>=18.20.4'} - '@socketregistry/deep-equal@1.0.3': - resolution: {integrity: sha512-6Ux7SFCn6dFLkGk3CF+83IAU/rbhUrDDxPOGKDhHmIt0u0qpR/ouAEszIDNMrY2mJ086GzDQM+rC5iddk2ue3w==} + '@socketregistry/define-properties@1.0.5': + resolution: {integrity: sha512-IMB5rE7tgw7+TbIz/2NGcZj9NeXNxisXWCxzjElklmSo1vuB536FLQjkXZ7Xbd8DVEXOiR9Lg4Hx+AJ1bUmeFw==} engines: {node: '>=18.20.4'} - '@socketregistry/define-properties@1.0.2': - resolution: {integrity: sha512-5imraGrpdiVWsgbEuNCGeMAexOjquIV3fPWt0+dZnaP0cGG9NKhxz4F+UmcdsNQRhwyZcAijBRETW8rxePxbqw==} + '@socketregistry/es-define-property@1.0.5': + resolution: {integrity: sha512-zipl+Zs/75Fjt7vE3RqbbDNfdIFsvsmd2wLmwoxI1Z/ID28j5dp7ZzaMesQAQqK+zv24a4WTywQVg7f35E3rcw==} engines: {node: '>=18.20.4'} - '@socketregistry/es-define-property@1.0.2': - resolution: {integrity: sha512-PNysoPksplPu4GeaC01R9rM2P10zzijYJPuqF8zbvvTrB8vvCFih0X3IxI2oz2iDWvCasV5upZ3reevR07mt2Q==} + '@socketregistry/es-get-iterator@1.0.5': + resolution: {integrity: sha512-rYAhVok1NWHOD067z4yLYFmsph9X2SP2mEOUbE4zrLSu6xHdmscgsUXTQlv/+9Ns+ShfFe3UufdnuKnwuZT0pA==} engines: {node: '>=18.20.4'} - '@socketregistry/es-set-tostringtag@1.0.2': - resolution: {integrity: sha512-w94rrdD38Op0U1jS2K7DJ7MAaOQAeDGqXVy7J0We7jTNgjtesgO5WQ7n8H9Bl4ApWZq+Egcua+0APore6WCcuQ==} + '@socketregistry/es-set-tostringtag@1.0.5': + resolution: {integrity: sha512-gK/N4x9ScZRTQGF6aIzhBWedQuD7jOEvNxozXQFdB9sOCtgHtHCle0nD3PQ7TsKXQd33RYBECqOpk4POrVSHWQ==} engines: {node: '>=18.20.4'} - '@socketregistry/es6-symbol@1.0.2': - resolution: {integrity: sha512-GOGaWdzCLFqQ4SyJ+UrXbr2b1ScaVELme7YLtFdusomZVipwRIsl6xAKT1dy4lY0dbihSZjudxP8g/cIHafhbQ==} + '@socketregistry/es6-symbol@1.0.5': + resolution: {integrity: sha512-tvshZo3SkuPJ/5Y1mXQlHUP6xIfsoy3W9y8eEVPGcUb6Vvc1v72zRzI+zGB1PI6I1EjtLZLQDEoW7YdvNJdTYQ==} engines: {node: '>=18.20.4'} - '@socketregistry/function-bind@1.0.2': - resolution: {integrity: sha512-LmyqjHMykbzvwXjJmViM/f4hmrnqwUCYEO0FGGenidcxXgO+Yj/gGVAa1Q0x9MWSZTlU06djYeD0ILqynIUoVw==} + '@socketregistry/function-bind@1.0.5': + resolution: {integrity: sha512-G7Z7yVdwQmO5FzNFqdPp8ZvLm9zk5lq7t3r+2IOzBcQVx/qgjYuYPo0fE+kzvQ7u5ApMret2wDnKbCfp4cqnjg==} engines: {node: '>=18.20.4'} - '@socketregistry/function.prototype.name@1.0.2': - resolution: {integrity: sha512-/uHAJXDEQm0LPewU+9RcH9kK8mujh1I0zB6ll3iZ4WZxPYmKgDbUaEJMOL9v1Xv0gj/Awu64hHkGHFRmEkMdxA==} + '@socketregistry/function.prototype.name@1.0.5': + resolution: {integrity: sha512-SoeiaypJYCiJju2eGH0EvW35u2yeuKJ/ll5ScmPR+cYTNEQYnlGPVnsDYIOQ/G/Zq5lvQRhmA6iCShUFskkWcw==} engines: {node: '>=18.20.4'} - '@socketregistry/get-symbol-description@1.0.2': - resolution: {integrity: sha512-plNw/+RUd+yfrbb+WsiRE+hWiPFHg7Wf1FqInQcsUxk39YcNBrB5LdagzxqbXtooYMX8YcZJ0Tzph2o9LhBGsQ==} + '@socketregistry/get-symbol-description@1.0.5': + resolution: {integrity: sha512-G5ceeq3MgKe1/HZL5vc6u/0mSWIdMzce7DHrj8Iw7llEakt5wTksvJ9lhSOBNfpDfnfBrN9EtLLY0RMFNHbpIw==} engines: {node: '>=18.20.4'} - '@socketregistry/globalthis@1.0.2': - resolution: {integrity: sha512-kuSBfiI8Kbp6oUFwWA5X0ZYfBJ3Oc3AG8fqqNCRRsMhJRP7rY8xynFDk5kv6jya+5g8UlKKMh3nBc7+YmEIDWA==} + '@socketregistry/globalthis@1.0.5': + resolution: {integrity: sha512-RY/OxMUrhuU9LO9To76SKwUz4mcdaSwG3rh/lpFN4azdL21XYxhAQ/hS5U+dZVI0ZVAk9AZWsciN8Djsz6LqeA==} engines: {node: '>=18.20.4'} - '@socketregistry/gopd@1.0.2': - resolution: {integrity: sha512-gURoTaVFHcBKOolgWQoy0XdNlAhE/SxgcaaxI9+T22vkaMrmu9IidREocDVjy3hpzjHLRCqT6C9e0p9J5iaq4g==} + '@socketregistry/gopd@1.0.5': + resolution: {integrity: sha512-lJKgypzRLEAonbhl+qk5WH/ILyZipz+8cGcgBjMdNGk5KJdxI+ixLwEpNlEAR5iiR0oOf3DqAcM2ZzuMBjK8ng==} engines: {node: '>=18.20.4'} - '@socketregistry/has-property-descriptors@1.0.2': - resolution: {integrity: sha512-92093fF64g08pgiZCg8FC/jZuoIFeRIsCe89qlj/VFFx35AAzShr4ypOBGy3BoIMbv7z+ooZFiqipkfEYE3Gpw==} + '@socketregistry/has-property-descriptors@1.0.5': + resolution: {integrity: sha512-teGemiZKx3HI1fyCowXYsNhrDPoB45LktCH3BYWrzlvsEL3rT2iTFSc6JPJ4YuLtft1QRkiv/V/8bdGa3qX5Vw==} engines: {node: '>=18.20.4'} - '@socketregistry/has-proto@1.0.2': - resolution: {integrity: sha512-xDqvx1G2q63IHfoalQUJsR3VlSfsn5VRmxV8GepJpPGBJ0qDBZVX9lScieeRFibdhHenGiMGWkg6byukD3puTA==} + '@socketregistry/has-proto@1.0.5': + resolution: {integrity: sha512-z1tmi3xBR/DY40I4Zw8eHCCekWa3OoM7VHeXgSas11vLYPPGstHRMivDOlLzTrggHrLVnbQ25Xpf43TEdM6n0Q==} engines: {node: '>=18.20.4'} - '@socketregistry/has-symbols@1.0.2': - resolution: {integrity: sha512-7AyOmPWvCzQEtRZqRCxKgTrNXusduRSdVfnRsxGYjEycgyhgZivIJU0UrYP6nLX4VMeNjjAYMJP6vdRNxp5IIQ==} + '@socketregistry/has-symbols@1.0.5': + resolution: {integrity: sha512-Vxaly8XG4byS5lSwuv/cOlbFpQINJu4Ce32Ui58rlv+3OL+Eu8EEBHVGR8a0AMr/bOG6fMOWhx5H3CAkxVTbsA==} engines: {node: '>=18.20.4'} - '@socketregistry/hasown@1.0.2': - resolution: {integrity: sha512-xlPs2JPAw3EK9QxY4cQD9clAR2yJvc9dSK4mVw6k0OXyTQMhrzMIJVIVl5swl1rr3AqWv/vEtI4d/y6jj3aXfQ==} + '@socketregistry/hasown@1.0.5': + resolution: {integrity: sha512-xknlSx99HYF6t4cRLVMg9iW1eR8kKG92m/Yz7Bo9pntIpvLlKs3Rm+eCwEzTjp+NZacGTxG0T2IP/vGwGD2d8Q==} engines: {node: '>=18.20.4'} - '@socketregistry/indent-string@1.0.2': - resolution: {integrity: sha512-BFTaibLNPHgdTZjqsO4smcfFYqMw30WbWHYCQcmKHK03QlJxrfy4PaAPifTH1ydtcM+216WjDJIlFviRPN7JBg==} + '@socketregistry/indent-string@1.0.5': + resolution: {integrity: sha512-r4hX/Z7qhKBu0H1XJdOHEa2c51qnIN2AyEcmvyfa3qFk0GLZhzYUdAXXw6w+GtlU4U08wnf7WQGf+btlKmRAcg==} engines: {node: '>=18.20.4'} - '@socketregistry/internal-slot@1.0.2': - resolution: {integrity: sha512-mAbt01fjEs3dFdhIsBHSyvG2xaNMzdE7kUfHX4gbfMPl1myibzo9oVL5hI/OSC8KRfU5+7TE0QO54QRnQusrCw==} + '@socketregistry/internal-slot@1.0.5': + resolution: {integrity: sha512-Xv3M3epptcSCwwRIKHHbLdl9FlQA6qoAnW1Cm5JNBxyLdGs6B5nF/dmhHjf+82BFJEoTAsIGwchMvtNNuJFFGg==} engines: {node: '>=18.20.4'} - '@socketregistry/is-arguments@1.0.2': - resolution: {integrity: sha512-M2zZobk3HdadnnQjjWc9wI5/5ayX0tQ1abZKQFPJb0m+nPQI9pHl5G0sVIpiYTcgR7InSEP2r34/4E8El8y+uA==} + '@socketregistry/is-arguments@1.0.5': + resolution: {integrity: sha512-Iozv0wGyOJdNwaidhIMX556q1fzPVBjv6MJb3B3UBRcMhogRiM09zfYngDLslSsp6aHRpqb8mBGf0v+Huet2/w==} engines: {node: '>=18.20.4'} - '@socketregistry/is-array-buffer@1.0.2': - resolution: {integrity: sha512-6wo4RbTwTBS/moYm7JjX2nC7ogRk4AMKCrCGLbmU6W79ee7PjKAO8KrkwLRbgwDPCMoImVkSQMHq2T2aPisgAQ==} + '@socketregistry/is-array-buffer@1.0.5': + resolution: {integrity: sha512-oeAaXGOAtkQeFS8hpf59cEVID6S+/ueIWGnxbnPhlqgWIDGGQ78VD0pBsppz/gLfdOmM/ykP+/Q82TgMkdMWWg==} engines: {node: '>=18.20.4'} - '@socketregistry/is-core-module@1.0.2': - resolution: {integrity: sha512-uGkXWRY0qh5EMHOohm/wrNP0o3L5m6QjGYZ+gYFmH8gQaIrZTKCgBZKZVB4b0wpuq5mvibYQAW0h/dYsw+SiXg==} + '@socketregistry/is-core-module@1.0.5': + resolution: {integrity: sha512-ABHSA3p056nRvkH+xOIykNEuOt1yRlRN71BxioKalfyXdtxVFyG9JWi55CpWnYkSPUWe1i06HnWE6Ua3o5JXHg==} engines: {node: '>=18.20.4'} - '@socketregistry/is-date-object@1.0.2': - resolution: {integrity: sha512-s7Yfgi4sRxM1PhgA6jgYBxzvO5Gw6NSuOaGnArlaJrXEURNQ4QX5i/8Pm6/9kVzjkD53xL0JxeHTVrwZBFELFQ==} + '@socketregistry/is-date-object@1.0.5': + resolution: {integrity: sha512-nhf56icD/XXPcI5pstdrbn86DCb6nxqtcca8OzdWdyrZnIIYzn9PSl0j5yeDHReZQrhID9CmYpz50nySuxs49w==} engines: {node: '>=18.20.4'} - '@socketregistry/is-generator-function@1.0.2': - resolution: {integrity: sha512-yFErdGF19F/3IeJZPgK3njx8iwAS2+E9sngrfu4NkxodO6Zm0PBAOXg/OSvm5kF++dWDm2mYW4S1AWzDA0S5aQ==} + '@socketregistry/is-generator-function@1.0.5': + resolution: {integrity: sha512-70FLcIfYK/Z6C4cE/1cGw15OBb6NboJ3NmjtFnLmuRVA6sBW8+z8Gl/ikrv91OncNrm95yMJMS0qSJQ4rEIgmA==} engines: {node: '>=18.20.4'} - '@socketregistry/is-negative-zero@1.0.2': - resolution: {integrity: sha512-DDfyjg26fz5PWcot0ukUK/30vQYyaQwku7LZToVld3WolUla6Vl+peA55vL8TojoVl/lUGJh7C8MQ205UU92Aw==} + '@socketregistry/is-negative-zero@1.0.5': + resolution: {integrity: sha512-52LHLZ7I0NAHwsM3Mae09Y5YjCY6GvssbBgs90lCHemwRubzQLYbAoAae/fFlskvQciTx2S7Pm7MmidDOBoIkg==} engines: {node: '>=18.20.4'} - '@socketregistry/is-regex@1.0.2': - resolution: {integrity: sha512-bJQynMk09SMnQYDR8VJotCZUoopVwHaiNS0loKvpQFnvMIRzkelvHolR4y0tlpZOb/arChoC7wEm27ddrXb0eg==} + '@socketregistry/is-regex@1.0.5': + resolution: {integrity: sha512-UplgtvnvnL7lCZWwdi5mdnc3jbyMP8LBOpm+xHpCBGMJzFUl342PENahlVtkgExnueXs21FQbjeBxQeQVfpDvQ==} engines: {node: '>=18.20.4'} - '@socketregistry/is-shared-array-buffer@1.0.2': - resolution: {integrity: sha512-HOcwnXcUZN8a5N0HmfpnLwnxEJbWMoLLil2A6HvKDQ12L7s3fvdkH7gv3Z8Do4qnpiS5I79WkF+372wOtB5uaw==} + '@socketregistry/is-shared-array-buffer@1.0.5': + resolution: {integrity: sha512-duEc4U1Fs9E1yjMdPCwFBlGFtSPSLSUSsT7JnDD7PXdUfF4Iz1u2I3NdnFD8wzhXJr4e42a+y9eTW8ZyRyE1sA==} engines: {node: '>=18.20.4'} - '@socketregistry/is-string@1.0.2': - resolution: {integrity: sha512-Yd10AEWSvW9ZUfNMlaDIpOBr8iP8VPE0vhUE0qZNszIzWnRB0Ups5cNgW+sP3Mt6YjUc213kyqycKxnZ6WoKGQ==} + '@socketregistry/is-string@1.0.5': + resolution: {integrity: sha512-5hrKja9bIiWuZorvg/vUWd8M1VgYukS17MGUY++RJCK754xKsKDyTUog0L8Q/6RP7N4RX1nmdqZlCK1pr1UBXg==} engines: {node: '>=18.20.4'} - '@socketregistry/is-symbol@1.0.2': - resolution: {integrity: sha512-a+K70WtAQjvu3c6eTUXQju70bkQqulfHVnzoBex44gzjEd5Uml+HzisrBGyfsYxAMQbJUh3EPXKaXaLD1172Mg==} + '@socketregistry/is-symbol@1.0.5': + resolution: {integrity: sha512-xLPZY0EI6vFVUpiuAiUAaNl4vxiarm70zESoDyarUW5B5qnnqVoCtevtu42EW3ydwHB6xQdTrfKIKAO3ioaF9g==} engines: {node: '>=18.20.4'} - '@socketregistry/is-typed-array@1.0.2': - resolution: {integrity: sha512-rEkGPV+3urLHAUQ9kvASIE0ZUaNLUJpJVxt77nxcN+2E4KpqTdKGPK0T4wfFMjIMpgEd8LlKnWDmwde5tttI4Q==} + '@socketregistry/is-typed-array@1.0.5': + resolution: {integrity: sha512-HF+CXkeLtPjGSF1p1ML7pj2eaKCCyvn+c2aYLZLHRgojGNlfNdovVilogDVaZgoUVhbFjioONWLGTLfcXH3R5w==} engines: {node: '>=18.20.4'} - '@socketregistry/is-weakref@1.0.2': - resolution: {integrity: sha512-MGJK/ROsfLy7c4l72fZ9Db3ptTjqpAo0OaIEG3Vo2BFjnranFFTFG0EAznmMyDh1fedytVAY143AJSo0Wmhsmg==} + '@socketregistry/is-weakref@1.0.5': + resolution: {integrity: sha512-i+diJaTYee1q6RfTzrc9jnV/nM0lqSmi6QL04+ulZ3wjp0FmyIUUir+pJb5lEj/7N9BhQ9TTq56UL3/hBEE8VQ==} engines: {node: '>=18.20.4'} - '@socketregistry/isarray@1.0.2': - resolution: {integrity: sha512-VmPr36LumrJeLtOcIUbKJWl1KFSEg5R/eAu/WyD43VLHFFwxf3zDXuBvT9e7if76S4UKKyEAKQhJkwHv56/XHA==} + '@socketregistry/isarray@1.0.5': + resolution: {integrity: sha512-ShtX9jbnTiEl2sXAjCS02ihrjiEStKleX4NgOxUu977jX/PRSS7sGuM2ssN3vCeuzmLphzeCeIXExxR5dcw8bA==} engines: {node: '>=18.20.4'} - '@socketregistry/iterator.prototype@1.0.2': - resolution: {integrity: sha512-QPHai4jStUU5ruTx1sZ9cGDwAwEWMl9Svhb/syMDPv5r+vAxosIsmMDieXCFdc9YyP9+CjWHeO2cIHvRez9qsg==} + '@socketregistry/iterator.prototype@1.0.5': + resolution: {integrity: sha512-avT0WCCVMFI+74w64e5an5HSLBYFErcIK4EnAsuRRgn4FCVdwxasIvgFFQnmpmtsEnzTRUYMySQmi3gbYr9ifg==} engines: {node: '>=18.20.4'} - '@socketregistry/number-is-nan@1.0.2': - resolution: {integrity: sha512-8tK8nfk5Q3mHdC+rrKC0Qgj3PBBbXcOFh9XdZ3PGYvHKwk6qI+bbKSzw2RO8llNnzWL2VIfJYolkA/g9L2iRdA==} + '@socketregistry/number-is-nan@1.0.7': + resolution: {integrity: sha512-6BfZedewiaCERKrv/Jfi7++nyWYTKarzoY0Gq+8QsQMmDvZod6pB5Ku8cBniGCB1H8BkvnZQIWESa1kb8mJtJA==} engines: {node: '>=18.20.4'} - '@socketregistry/object-assign@1.0.1': - resolution: {integrity: sha512-XPbWgbq8G1EMh9f6/96tfVp4wKwUOTpLzFPjN/BaB+g3xpF8CzmDBSoTvP/ApNs2dbiK9GOUhQbHlzyW5R/TXw==} + '@socketregistry/object-assign@1.0.3': + resolution: {integrity: sha512-VFUMXtgcqb+A05izEwgTepGsf0rm9UMPTa2KyF5xPiaSuj6nhpZ8+aFQKjJ3NsoZaIGzS2hJfxeVuLV/Zt4eag==} engines: {node: '>=18.20.4'} - '@socketregistry/object-keys@1.0.2': - resolution: {integrity: sha512-cnVFGu/6UQUJZG10PsEevBsnyj39iWe6mCWsBBAjbRAXn5LcUGdnV62jjbSbD/LgPmDJkl0FuT9+C8DPWAt01w==} + '@socketregistry/object-is@1.0.5': + resolution: {integrity: sha512-1wbyo9IBBptFo2TaPgSCDIgqs77zkvCeR+ymUWYEq3O2eB+WdPXOFCcqBKl2fEKbfXNJG4xj4PNd41OF9yu5Fg==} engines: {node: '>=18.20.4'} - '@socketregistry/object.assign@1.0.2': - resolution: {integrity: sha512-ipVCKh88fGA7xTzWcrz4Q9Lne2KeP3XeQ/KGVt7pzg8WTKBK/KdRRRs01uS4slQYFGAnWf8YBh9wdmBYeRB+XQ==} + '@socketregistry/object-keys@1.0.5': + resolution: {integrity: sha512-WnFTS0sWPWutYLuMENJTKBYYX6LYTDfG48V3KdXzNZvwKhl5i3abKKpw3M8NowgrUwfuPSXxwHUZSWEwrxqtbw==} engines: {node: '>=18.20.4'} - '@socketregistry/object.entries@1.0.2': - resolution: {integrity: sha512-i0UY/qE6skVPb6vTnapVFcJj7hzihDoLvjE1zBFUHCcC3cpqDpFSVxQyvNod3vC+Rk3RNYsGVU/ITqTh48KooA==} + '@socketregistry/object.assign@1.0.5': + resolution: {integrity: sha512-fqgSPOiGnHPhKrruvUW61GJzehuguUE01MgaadTOXouRx5TVqsNRGd5oLNhrFNC+HBPacdnposy8xmt1Mh+H7A==} engines: {node: '>=18.20.4'} - '@socketregistry/object.fromentries@1.0.2': - resolution: {integrity: sha512-bETV+GbmvxnsIe7aLtyeXxe4acTrqgQc3P1d9Nmc5ukUbr0yeuPjmawwQMS4o/2YoSiQs/6WdrMJSZH23l3gpQ==} + '@socketregistry/object.entries@1.0.5': + resolution: {integrity: sha512-Qwiwf6Ure9TJdv8bJ8IBuFp+EIO8cyKAu5tk8jTXdAr7/3E6E5dU7D6R+Zc8MpasoDdmZt5V5QuW7wtmEXBwDw==} engines: {node: '>=18.20.4'} - '@socketregistry/object.hasown@1.0.2': - resolution: {integrity: sha512-ntM41w23t9SLbB7sVk+gakO4ghyMhZqiJpXFxvgE9HYNce7LBPwGTtP+xGH90IrDcJd9eHRJ5m0Pwe5V5Yzwmw==} + '@socketregistry/object.fromentries@1.0.5': + resolution: {integrity: sha512-yA35Gkn9cbUyMI4FqEoBqqJCo/dUDY6w6j520WjLitv7nPnQ3KDUzMhprl33N7DTKxq8sYCKNGm/xi0nceb1rA==} engines: {node: '>=18.20.4'} - '@socketregistry/object.values@1.0.2': - resolution: {integrity: sha512-nmjm5+pglSz36PKAsxZBuqKpgMLvcPKLNNbn9FdQcdB4UuyDn82imk7tD0wLc3aZZTiAmKf6JjGEJINJnRYtew==} + '@socketregistry/object.hasown@1.0.5': + resolution: {integrity: sha512-xleWdNU2JPocl5MrkxlS1euDK3xqpzTy0GDsJHmUhWX9R8MpowYa5gSPqASWnLQHN6bNiXyotEixowJdnzm/sA==} engines: {node: '>=18.20.4'} - '@socketregistry/path-parse@1.0.2': - resolution: {integrity: sha512-h0bpAZ06Fb5554kU/Wg31GXBxadfI6gnlprktUmoReJnnn7LactZd8QoxABKWEZf/IMo3/wJnX2iqEHW+8MzFQ==} + '@socketregistry/object.values@1.0.5': + resolution: {integrity: sha512-njASaiJhnm+r/9zhLZZf0rAlNYcOKE5cq47p7fBsW37MlKhuHNCG6HTk7BVqywHhN8CJNQtRd6xYltSiYcoUdw==} engines: {node: '>=18.20.4'} - '@socketregistry/querystringify@1.0.2': - resolution: {integrity: sha512-eHRJGTEtq5uHdR/1FJTl4w5umu+Nd0iWrnENRM7iiGY5z823Bv7zZ+NNyfJJGqDfjAkxSsYQnTXR9/dgPAhKmw==} + '@socketregistry/path-parse@1.0.5': + resolution: {integrity: sha512-e4rAhNrpgWJGGBU3VzmKCV1OBbEiT7h+EwzEd1iwM2rY8C9VrBs0FFFvfOxPkkWm6BXzilpnMgIjqtoBw/dVUg==} engines: {node: '>=18.20.4'} - '@socketregistry/regexp.prototype.flags@1.0.2': - resolution: {integrity: sha512-iIF0omZAYD1Uy+oKJ2z/9qx7yvKGnMRGk333aNNweMpqHNxkrNdat/4h6x5Lr1dZ/j9+2R2ENOxKf2wLJyYSyg==} + '@socketregistry/querystringify@1.0.5': + resolution: {integrity: sha512-s8eqBR4KK32N5nDpaaE7l2XHHJhB+R9CHV11nJiZDAJ4Kxb2qklCL46vdGXDg9a0Ge1kYUlNxPrtv6eC/X5Ctw==} engines: {node: '>=18.20.4'} - '@socketregistry/safe-array-concat@1.0.2': - resolution: {integrity: sha512-TLR/NdMydXmmTpzm4wfTBgOekn43PRg8Dve7g9zYp3qjLevAHkKehYJVy07S8CaVQ6Ro1yLSqadZdobvHb0LGg==} + '@socketregistry/regexp.prototype.flags@1.0.5': + resolution: {integrity: sha512-N8O5vDqix1PLAmJwnvbZzHCzD+912YzKm0YzB6+7GZCp7uL3yagY/aK9sR2Dsk2ASUC+BR1F+ZILbAMvRcsP0Q==} engines: {node: '>=18.20.4'} - '@socketregistry/safe-buffer@1.0.2': - resolution: {integrity: sha512-gxk0KHN9Zze3+y96yCl5QiVXiu6PfIOUlCLTVXwMIEA2UR7E0ITmTwqwN+yTtFNd3LX3LRDmF4gNd6yn6YiYpw==} + '@socketregistry/safe-array-concat@1.0.5': + resolution: {integrity: sha512-cGbuGDw5S3sHnFC5jDQVOoayEqyPT68wTICM6flA/y7woSkjw+ReJ985s57tOZy0isz6HiOOAtX7oveg0gJJWw==} engines: {node: '>=18.20.4'} - '@socketregistry/safe-regex-test@1.0.2': - resolution: {integrity: sha512-U0jxa+n9IS0C0JMlgJPZlEfN9+c1f8D+ezOkWJcu7rBVrkaZlZV2PpqP2IswMEhbuFOKzU0UuvgQDJywWuDGVA==} + '@socketregistry/safe-buffer@1.0.5': + resolution: {integrity: sha512-wOsct2TbdGKvXHRJGKgwWLvs4HqVCVJ/8/saHxjnbR/6uIdb/XYGJcwb+P61SRrW5695bAsIrYFJZbyhTsqLLQ==} engines: {node: '>=18.20.4'} - '@socketregistry/safer-buffer@1.0.2': - resolution: {integrity: sha512-Qvr8L0zr5fuyOZWWM9ABeJxYH99Wk/geBlRzmKPvK074ujLBK+Hn2O5SEbKLqexyIHvHoFKgkaRFZh+PQHAnnA==} + '@socketregistry/safe-regex-test@1.0.5': + resolution: {integrity: sha512-Kgl0XZQLtsEqEOI8SiKPkzwJ6/ZnQniWVtt4hlm+YregIdRz8glqqC152xbPJIKJHYrN5ybr8W3hZN7wgsdnIQ==} engines: {node: '>=18.20.4'} - '@socketregistry/set-function-length@1.0.2': - resolution: {integrity: sha512-ndUGe7a81X+LEzDGSghiARiHM4kQzVrRntkqgllZfDUWQTPZ3CJ1XjnS4pIOf/g/je4GG54okbeeSVog/ffInw==} + '@socketregistry/safer-buffer@1.0.5': + resolution: {integrity: sha512-x6W5FZJwngd3UqOA0TXucXuD/RdGm4NHvnDYC2topSlfyA2vtTff9lcXpuQqzi/TxxlHEfYc0toRA+VDQSdfxw==} engines: {node: '>=18.20.4'} - '@socketregistry/side-channel@1.0.2': - resolution: {integrity: sha512-hG6cCXIU5v5w4PAFrM6j5LWjC4Au3l22FQ7lDhFSRtx2tJv+n0ArhwOJ5YvsVTVAqriu+cV2n5sI6S+JeNg8Gg==} + '@socketregistry/set-function-length@1.0.5': + resolution: {integrity: sha512-QtuipG5L+FLe7gbWBtQnbGAlIA9cjih6WYjrM2vVimSsV4esy/6VepqqYoddSTYka/iL0ynQpR3fRSMsGi9IJA==} engines: {node: '>=18.20.4'} - '@socketregistry/string.prototype.matchall@1.0.2': - resolution: {integrity: sha512-GvDqIcQCTAKEUpjpw0jOA3IHbp/Lczuy0z3JsVXRESb4Pg/PC9WLq5N3JmUj1TaMdgWxHpqe9S2Qfsv6rKgIgQ==} + '@socketregistry/side-channel@1.0.6': + resolution: {integrity: sha512-s5DMU7a192OUMvIU3xjfKCu/kpGuKo0hWtCD6h7fhm0CcHS4NqXeTS5+DjDuRTuUowc4PQXzHRA0OZdKuaRAWQ==} engines: {node: '>=18.20.4'} - '@socketregistry/string.prototype.trim@1.0.2': - resolution: {integrity: sha512-dOFc51euK9xvy6O/Ocsx9ToaxT86Op0PYT8wWn8ZbZvvxcPe8ml3Sv9Ly3f0BbrCIJ9GNhv/TYCTaPqrxeFz0Q==} + '@socketregistry/string.prototype.matchall@1.0.5': + resolution: {integrity: sha512-C0QWN2w8elid6VuIAcU3+fFaNZg6RHPfe8/8C6XukV3d0ZQU2I6za8afb2nOQq3Pknx3F/N+xZXJUPHvucGgLw==} engines: {node: '>=18.20.4'} - '@socketregistry/string.prototype.trimend@1.0.2': - resolution: {integrity: sha512-Itv37wv0f4jy+xrD/4YQxRqzFrrhAnGXhaF+ghmOC0emFAbQtYggijRdiLw1d/C9Uk8j2aSTUPawgh6QH8nCdg==} + '@socketregistry/string.prototype.trim@1.0.5': + resolution: {integrity: sha512-rwXRZVkl7bn1hkMdK3VHuj3VYKsyJi8APB6HCjAZ3M+1fVLIBpYmOIZxkr8fMC0kJmBVRV5u7O+DMW9ZcPSpnQ==} engines: {node: '>=18.20.4'} - '@socketregistry/string.prototype.trimstart@1.0.2': - resolution: {integrity: sha512-YhCLd74AjJpIlssJ+xeYvBs73V8DieKEuP4g+nuZhIwgpiVGRd1P6lKEJEM1yoUUJfxWle+SflKPwN11Vwa+mQ==} + '@socketregistry/string.prototype.trimend@1.0.5': + resolution: {integrity: sha512-cbyNEn8sqHz5VMVgeD6lqFEFeiwy8p66jmWr+sv2V0P3fnJK++pyshv6xcsQvjcxsnrUtXm2KBH6yqEiu4oDrA==} engines: {node: '>=18.20.4'} - '@socketregistry/typed-array-buffer@1.0.2': - resolution: {integrity: sha512-3sCGL5captteofXw7NC7p9aGahsxMmIr8YNpa/6vGx6PDRdWwhGCWWGZ/pOZ0dAPSnaab4dTUeud2PnkTP8I7Q==} + '@socketregistry/string.prototype.trimstart@1.0.5': + resolution: {integrity: sha512-i8Qz5uvdmzSrgOm7fo27wMhiQy5fNMvj0jcW0GZIyybuVyhzDhlm9T2DofxzZwA0OTs3erSBP9elYlzN0O4AdA==} engines: {node: '>=18.20.4'} - '@socketregistry/typed-array-byte-length@1.0.2': - resolution: {integrity: sha512-nc+oaM1ADOr8WEKrs0Hstox4keBM5wUI8j0M5ABHiQeH3anQcklRD0VkMc5s4f2gmEEWgUYIMFNaunzYxrjx/w==} + '@socketregistry/typed-array-buffer@1.0.5': + resolution: {integrity: sha512-UuSwBGTCkFH3prraPnJrhaNsSLY8giXbsQMLMGcz8eCyNBkUg/C73p7tzMKmlk55mtS7BpCBU/O48ogTU1QvhQ==} engines: {node: '>=18.20.4'} - '@socketregistry/typed-array-byte-offset@1.0.2': - resolution: {integrity: sha512-5HwmZxC/h9DhSJSYUma1gO+VAPi5zs5pxT7ryQMusOHUYTef2YoxJhqf1jKYWGmcnXWKD28iot1T9+uj2Lpqng==} + '@socketregistry/typed-array-byte-length@1.0.5': + resolution: {integrity: sha512-+fKTzUzOMM+G7yw5ApIq3KpsFbymqzRSVATeRpJhveiXGNuSy/y46HGQ478DHB3r7RQ6h8PT/J83jEyufSaR/Q==} engines: {node: '>=18.20.4'} - '@socketregistry/typed-array-length@1.0.2': - resolution: {integrity: sha512-97u+OMGh8Qg8i7aaYAhoPO4pWr22jNql9wZfGoPi0fURqoXxUoVSnsC2nkUW26VurXQAdNBGUoRCk8d7Z+3nMg==} + '@socketregistry/typed-array-byte-offset@1.0.5': + resolution: {integrity: sha512-gqNiJ6KyFIsrrbHPPpmoW98QqdHjdwyHjHjfA5aqlWMD9pD+U337m8fAuyUmqwCBVlVsrpDTS9Kk5FmdzaIVLQ==} engines: {node: '>=18.20.4'} - '@socketregistry/unbox-primitive@1.0.2': - resolution: {integrity: sha512-dXm1PDzOz+RhmsCx9mgPSKiKYKda7iDMzro6N9JEQpsIDTBJgGeCN3OaWJc5M8hO2jSupyw0rFyAeuAj2d8/Kw==} + '@socketregistry/typed-array-length@1.0.5': + resolution: {integrity: sha512-1BbchbBzZWeT9XKpus2H573eeBHtwI8ABd9AsKEh0gT+FPQD5Wx3vTvh3JUxxtCIJas2o8k6tH82xXN6TFQj7Q==} engines: {node: '>=18.20.4'} - '@socketregistry/which-typed-array@1.0.2': - resolution: {integrity: sha512-QGW8dtkJplWq93Hj2ZJf+58RFWBMKG8jxLAScahEur7Sk2jOlb8M2ErjwrIpiop3Zrvqm/ko+42i0E3xlbOOuw==} + '@socketregistry/unbox-primitive@1.0.5': + resolution: {integrity: sha512-HTlrRFdxTArSZ0e8BCNBWRKYypSx26Cp3m77/I0L6wH3zypkd04jWfS6LbtqiCzM+ni40ISZULRf/8vaqShCfg==} + engines: {node: '>=18.20.4'} + + '@socketregistry/which-boxed-primitive@1.0.5': + resolution: {integrity: sha512-FF1m2hcRNdMRzsBu0vYtfXu9/9X/HQneamFmtijp0orfDISO5FndtuORqhYixKwUeaZX818FbGY5O5nAW4BR8w==} + engines: {node: '>=18.20.4'} + + '@socketregistry/which-collection@1.0.5': + resolution: {integrity: sha512-Yob5PapcAWuSFt9xuUR5RI7A7VN0iHLlit6rCNnBGmrW3YPGRg8mKLKpV0ULa72r/UggaN1NsqfybcconGaA3A==} + engines: {node: '>=18.20.4'} + + '@socketregistry/which-typed-array@1.0.5': + resolution: {integrity: sha512-ErJqzcM65dVIo9O1d3PcMXc4Vk+5PfdbmF2dfr1GdcULepv0+g2wcLcQ0CF3eNqAf7tGyOPgkYrQifBG7qhseQ==} engines: {node: '>=18.20.4'} '@stablelib/aead@1.0.1': @@ -4055,6 +4091,17 @@ packages: zod: optional: true + abitype@1.0.6: + resolution: {integrity: sha512-MMSqYh4+C/aVqI2RQaWqbvI4Kxo5cQV40WQ4QFtDnNzCkqChm8MuENhElmynZlO0qUy/ObkEUaXtKqYnx1Kp3A==} + peerDependencies: + typescript: '>=5.0.4' + zod: ^3 >=3.22.0 + peerDependenciesMeta: + typescript: + optional: true + zod: + optional: true + abort-controller@3.0.0: resolution: {integrity: sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==} engines: {node: '>=6.5'} @@ -5086,6 +5133,10 @@ packages: resolution: {integrity: sha512-h5k/5U50IJJFpzfL6nO9jaaumfjO/f2NjK/oYB2Djzm4p9L+3T9qWpZqZ2hAbLPuuYq9wrU08WQyBTL5GbPk5Q==} engines: {node: '>=6'} + deep-equal@2.2.3: + resolution: {integrity: sha512-ZIwpnevOurS8bpT4192sqAowWM76JDKSHYzMLty3BZGSswgq6pBaH3DhCSW5xVAZICZyKdOBPjwww5wfgT/6PA==} + engines: {node: '>= 0.4'} + deep-is@0.1.4: resolution: {integrity: sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==} @@ -6540,6 +6591,11 @@ packages: peerDependencies: ws: '*' + isows@1.0.6: + resolution: {integrity: sha512-lPHCayd40oW98/I0uvgaHKWCSvkzY27LjWLbtzOm64yQ+G3Q5npjjbdppU65iZXkK1Zt+kH9pfegli0AYfwYYw==} + peerDependencies: + ws: '*' + isstream@0.1.2: resolution: {integrity: sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==} @@ -7832,13 +7888,13 @@ packages: pkg-types@1.1.1: resolution: {integrity: sha512-ko14TjmDuQJ14zsotODv7dBlwxKhUKQEhuhmbqo1uCi9BB0Z2alo/wAXg6q1dTR5TyuqYyWhjtfe/Tsh+X28jQ==} - playwright-core@1.48.0: - resolution: {integrity: sha512-RBvzjM9rdpP7UUFrQzRwR8L/xR4HyC1QXMzGYTbf1vjw25/ya9NRAVnXi/0fvFopjebvyPzsmoK58xxeEOaVvA==} + playwright-core@1.48.2: + resolution: {integrity: sha512-sjjw+qrLFlriJo64du+EK0kJgZzoQPsabGF4lBvsid+3CNIZIYLgnMj9V6JY5VhM2Peh20DJWIVpVljLLnlawA==} engines: {node: '>=18'} hasBin: true - playwright@1.48.0: - resolution: {integrity: sha512-qPqFaMEHuY/ug8o0uteYJSRfMGFikhUysk8ZvAtfKmUK3kc/6oNl/y3EczF8OFGYIi/Ex2HspMfzYArk6+XQSA==} + playwright@1.48.2: + resolution: {integrity: sha512-NjYvYgp4BPmiwfe31j4gHLa3J7bD2WiBz8Lk2RoSsmX38SVIARZ18VYjxLjAcDsAhA+F4iSEXTSGgjua0rrlgQ==} engines: {node: '>=18'} hasBin: true @@ -9496,6 +9552,14 @@ packages: typescript: optional: true + viem@2.21.40: + resolution: {integrity: sha512-no/mE3l7B0mdUTtvO7z/cTLENttQ/M7+ombqFGXJqsQrxv9wrYsTIGpS3za+FA5a447hY+x9D8Wxny84q1zAaA==} + peerDependencies: + typescript: '>=5.0.4' + peerDependenciesMeta: + typescript: + optional: true + vite-node@2.0.5: resolution: {integrity: sha512-LdsW4pxj0Ot69FAoXZ1yTnA9bjGohr2yNBU7QKRxpz8ITSkhuDl6h3zS/tvgz4qrNjeRnvrWeXQ8ZF7Um4W00Q==} engines: {node: ^18.0.0 || >=20.0.0} @@ -9802,6 +9866,9 @@ packages: resolution: {integrity: sha512-kgJvQZjkmjOEKimx/tJQsqWfRDPTTcBfYPa9XletxuHLpHcXdx67w8EFn5AW3eVxCutE9dTVHgGa9VYe8vgsEA==} engines: {node: '>=8.0.0'} + webauthn-p256@0.0.10: + resolution: {integrity: sha512-EeYD+gmIT80YkSIDb2iWq0lq2zbHo1CxHlQTeJ+KkCILWpVy3zASH3ByD4bopzfk0uCwXxLqKGLqp2W4O28VFA==} + webauthn-p256@0.0.5: resolution: {integrity: sha512-drMGNWKdaixZNobeORVIqq7k5DsRC9FnG201K2QjeOoQLmtSDaSsVZdkg6n5jUALJKcAG++zBPJXmv6hy0nWFg==} @@ -10030,6 +10097,18 @@ packages: utf-8-validate: optional: true + ws@8.18.0: + resolution: {integrity: sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw==} + engines: {node: '>=10.0.0'} + peerDependencies: + bufferutil: ^4.0.1 + utf-8-validate: '>=5.0.2' + peerDependenciesMeta: + bufferutil: + optional: true + utf-8-validate: + optional: true + xhr-request-promise@0.1.3: resolution: {integrity: sha512-YUBytBsuwgitWtdRzXDDkWAXzhdGB8bYm0sSzMPZT7Z2MBjMSTHFsyCT1yCRATY+XC69DUrQraRAEgcoCRaIPg==} @@ -10192,6 +10271,8 @@ snapshots: '@adraffy/ens-normalize@1.10.1': {} + '@adraffy/ens-normalize@1.11.0': {} + '@ampproject/remapping@2.3.0': dependencies: '@jridgewell/gen-mapping': 0.3.5 @@ -12455,7 +12536,7 @@ snapshots: '@motionone/easing': 10.17.0 '@motionone/types': 10.17.0 '@motionone/utils': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/dom@10.17.0': dependencies: @@ -12464,12 +12545,12 @@ snapshots: '@motionone/types': 10.17.0 '@motionone/utils': 10.17.0 hey-listen: 1.0.8 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/easing@10.17.0': dependencies: '@motionone/utils': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/generators@10.17.0': dependencies: @@ -12480,7 +12561,7 @@ snapshots: '@motionone/svelte@10.16.4': dependencies: '@motionone/dom': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/types@10.17.0': {} @@ -12488,12 +12569,12 @@ snapshots: dependencies: '@motionone/types': 10.17.0 hey-listen: 1.0.8 - tslib: 2.6.2 + tslib: 2.6.3 '@motionone/vue@10.16.4': dependencies: '@motionone/dom': 10.17.0 - tslib: 2.6.2 + tslib: 2.6.3 '@mswjs/cookies@0.2.2': dependencies: @@ -12505,7 +12586,7 @@ snapshots: '@open-draft/until': 1.0.3 '@types/debug': 4.1.12 '@xmldom/xmldom': 0.8.10 - debug: 4.3.6 + debug: 4.3.4(supports-color@5.5.0) headers-polyfill: 3.2.5 outvariant: 1.4.2 strict-event-emitter: 0.2.8 @@ -12566,12 +12647,18 @@ snapshots: dependencies: '@noble/hashes': 1.4.0 + '@noble/curves@1.6.0': + dependencies: + '@noble/hashes': 1.5.0 + '@noble/hashes@1.2.0': {} '@noble/hashes@1.3.3': {} '@noble/hashes@1.4.0': {} + '@noble/hashes@1.5.0': {} + '@noble/secp256k1@1.7.1': {} '@nodelib/fs.scandir@2.1.5': @@ -12767,9 +12854,9 @@ snapshots: '@pkgr/core@0.1.1': {} - '@playwright/test@1.48.0': + '@playwright/test@1.48.2': dependencies: - playwright: 1.48.0 + playwright: 1.48.2 '@polka/url@1.0.0-next.25': {} @@ -13171,7 +13258,7 @@ snapshots: '@safe-global/safe-apps-sdk@9.1.0(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8)': dependencies: '@safe-global/safe-gateway-typescript-sdk': 3.21.1 - viem: 2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) + viem: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) transitivePeerDependencies: - bufferutil - typescript @@ -13182,6 +13269,8 @@ snapshots: '@scure/base@1.1.6': {} + '@scure/base@1.1.9': {} + '@scure/bip32@1.1.5': dependencies: '@noble/hashes': 1.2.0 @@ -13200,6 +13289,12 @@ snapshots: '@noble/hashes': 1.4.0 '@scure/base': 1.1.6 + '@scure/bip32@1.5.0': + dependencies: + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 + '@scure/bip39@1.1.1': dependencies: '@noble/hashes': 1.2.0 @@ -13215,6 +13310,11 @@ snapshots: '@noble/hashes': 1.4.0 '@scure/base': 1.1.6 + '@scure/bip39@1.4.0': + dependencies: + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 + '@sentry/browser@7.43.0': dependencies: '@sentry/core': 7.43.0 @@ -13397,139 +13497,149 @@ snapshots: '@socket.io/component-emitter@3.1.2': {} - '@socketregistry/aggregate-error@1.0.2': {} + '@socketregistry/aggregate-error@1.0.6': {} + + '@socketregistry/array-buffer-byte-length@1.0.5': {} - '@socketregistry/array-buffer-byte-length@1.0.2': {} + '@socketregistry/array-flatten@1.0.5': {} - '@socketregistry/array-flatten@1.0.2': {} + '@socketregistry/array-includes@1.0.5': {} - '@socketregistry/array-includes@1.0.2': {} + '@socketregistry/array.prototype.findlast@1.0.5': {} - '@socketregistry/array.prototype.findlast@1.0.2': {} + '@socketregistry/array.prototype.findlastindex@1.0.5': {} - '@socketregistry/array.prototype.findlastindex@1.0.2': {} + '@socketregistry/array.prototype.flat@1.0.5': {} - '@socketregistry/array.prototype.flat@1.0.2': {} + '@socketregistry/array.prototype.flatmap@1.0.5': {} - '@socketregistry/array.prototype.flatmap@1.0.2': {} + '@socketregistry/arraybuffer.prototype.slice@1.0.5': {} - '@socketregistry/arraybuffer.prototype.slice@1.0.2': {} + '@socketregistry/available-typed-arrays@1.0.5': {} + + '@socketregistry/deep-equal@1.0.6': + dependencies: + '@socketregistry/original__deep-equal': deep-equal@2.2.3 - '@socketregistry/available-typed-arrays@1.0.2': {} + '@socketregistry/define-properties@1.0.5': {} - '@socketregistry/deep-equal@1.0.3': {} + '@socketregistry/es-define-property@1.0.5': {} - '@socketregistry/define-properties@1.0.2': {} + '@socketregistry/es-get-iterator@1.0.5': {} - '@socketregistry/es-define-property@1.0.2': {} + '@socketregistry/es-set-tostringtag@1.0.5': {} - '@socketregistry/es-set-tostringtag@1.0.2': {} + '@socketregistry/es6-symbol@1.0.5': {} - '@socketregistry/es6-symbol@1.0.2': {} + '@socketregistry/function-bind@1.0.5': {} - '@socketregistry/function-bind@1.0.2': {} + '@socketregistry/function.prototype.name@1.0.5': {} - '@socketregistry/function.prototype.name@1.0.2': {} + '@socketregistry/get-symbol-description@1.0.5': {} - '@socketregistry/get-symbol-description@1.0.2': {} + '@socketregistry/globalthis@1.0.5': {} - '@socketregistry/globalthis@1.0.2': {} + '@socketregistry/gopd@1.0.5': {} - '@socketregistry/gopd@1.0.2': {} + '@socketregistry/has-property-descriptors@1.0.5': {} - '@socketregistry/has-property-descriptors@1.0.2': {} + '@socketregistry/has-proto@1.0.5': {} - '@socketregistry/has-proto@1.0.2': {} + '@socketregistry/has-symbols@1.0.5': {} - '@socketregistry/has-symbols@1.0.2': {} + '@socketregistry/hasown@1.0.5': {} - '@socketregistry/hasown@1.0.2': {} + '@socketregistry/indent-string@1.0.5': {} - '@socketregistry/indent-string@1.0.2': {} + '@socketregistry/internal-slot@1.0.5': {} - '@socketregistry/internal-slot@1.0.2': {} + '@socketregistry/is-arguments@1.0.5': {} - '@socketregistry/is-arguments@1.0.2': {} + '@socketregistry/is-array-buffer@1.0.5': {} - '@socketregistry/is-array-buffer@1.0.2': {} + '@socketregistry/is-core-module@1.0.5': {} - '@socketregistry/is-core-module@1.0.2': {} + '@socketregistry/is-date-object@1.0.5': {} - '@socketregistry/is-date-object@1.0.2': {} + '@socketregistry/is-generator-function@1.0.5': {} - '@socketregistry/is-generator-function@1.0.2': {} + '@socketregistry/is-negative-zero@1.0.5': {} - '@socketregistry/is-negative-zero@1.0.2': {} + '@socketregistry/is-regex@1.0.5': {} - '@socketregistry/is-regex@1.0.2': {} + '@socketregistry/is-shared-array-buffer@1.0.5': {} - '@socketregistry/is-shared-array-buffer@1.0.2': {} + '@socketregistry/is-string@1.0.5': {} - '@socketregistry/is-string@1.0.2': {} + '@socketregistry/is-symbol@1.0.5': {} - '@socketregistry/is-symbol@1.0.2': {} + '@socketregistry/is-typed-array@1.0.5': {} - '@socketregistry/is-typed-array@1.0.2': {} + '@socketregistry/is-weakref@1.0.5': {} - '@socketregistry/is-weakref@1.0.2': {} + '@socketregistry/isarray@1.0.5': {} - '@socketregistry/isarray@1.0.2': {} + '@socketregistry/iterator.prototype@1.0.5': {} - '@socketregistry/iterator.prototype@1.0.2': {} + '@socketregistry/number-is-nan@1.0.7': {} - '@socketregistry/number-is-nan@1.0.2': {} + '@socketregistry/object-assign@1.0.3': {} - '@socketregistry/object-assign@1.0.1': {} + '@socketregistry/object-is@1.0.5': {} - '@socketregistry/object-keys@1.0.2': {} + '@socketregistry/object-keys@1.0.5': {} - '@socketregistry/object.assign@1.0.2': {} + '@socketregistry/object.assign@1.0.5': {} - '@socketregistry/object.entries@1.0.2': {} + '@socketregistry/object.entries@1.0.5': {} - '@socketregistry/object.fromentries@1.0.2': {} + '@socketregistry/object.fromentries@1.0.5': {} - '@socketregistry/object.hasown@1.0.2': {} + '@socketregistry/object.hasown@1.0.5': {} - '@socketregistry/object.values@1.0.2': {} + '@socketregistry/object.values@1.0.5': {} - '@socketregistry/path-parse@1.0.2': {} + '@socketregistry/path-parse@1.0.5': {} - '@socketregistry/querystringify@1.0.2': {} + '@socketregistry/querystringify@1.0.5': {} - '@socketregistry/regexp.prototype.flags@1.0.2': {} + '@socketregistry/regexp.prototype.flags@1.0.5': {} - '@socketregistry/safe-array-concat@1.0.2': {} + '@socketregistry/safe-array-concat@1.0.5': {} - '@socketregistry/safe-buffer@1.0.2': {} + '@socketregistry/safe-buffer@1.0.5': {} - '@socketregistry/safe-regex-test@1.0.2': {} + '@socketregistry/safe-regex-test@1.0.5': {} - '@socketregistry/safer-buffer@1.0.2': {} + '@socketregistry/safer-buffer@1.0.5': {} - '@socketregistry/set-function-length@1.0.2': {} + '@socketregistry/set-function-length@1.0.5': {} - '@socketregistry/side-channel@1.0.2': {} + '@socketregistry/side-channel@1.0.6': {} - '@socketregistry/string.prototype.matchall@1.0.2': {} + '@socketregistry/string.prototype.matchall@1.0.5': {} - '@socketregistry/string.prototype.trim@1.0.2': {} + '@socketregistry/string.prototype.trim@1.0.5': {} - '@socketregistry/string.prototype.trimend@1.0.2': {} + '@socketregistry/string.prototype.trimend@1.0.5': {} - '@socketregistry/string.prototype.trimstart@1.0.2': {} + '@socketregistry/string.prototype.trimstart@1.0.5': {} - '@socketregistry/typed-array-buffer@1.0.2': {} + '@socketregistry/typed-array-buffer@1.0.5': {} - '@socketregistry/typed-array-byte-length@1.0.2': {} + '@socketregistry/typed-array-byte-length@1.0.5': {} - '@socketregistry/typed-array-byte-offset@1.0.2': {} + '@socketregistry/typed-array-byte-offset@1.0.5': {} - '@socketregistry/typed-array-length@1.0.2': {} + '@socketregistry/typed-array-length@1.0.5': {} - '@socketregistry/unbox-primitive@1.0.2': {} + '@socketregistry/unbox-primitive@1.0.5': {} - '@socketregistry/which-typed-array@1.0.2': {} + '@socketregistry/which-boxed-primitive@1.0.5': {} + + '@socketregistry/which-collection@1.0.5': {} + + '@socketregistry/which-typed-array@1.0.5': {} '@stablelib/aead@1.0.1': {} @@ -13815,7 +13925,7 @@ snapshots: '@truffle/contract-schema@3.4.16': dependencies: ajv: 6.12.6 - debug: 4.3.6 + debug: 4.3.4(supports-color@5.5.0) transitivePeerDependencies: - supports-color @@ -13847,7 +13957,7 @@ snapshots: '@trufflesuite/chromafi': 3.0.0 bn.js: 5.2.1 chalk: 2.4.2 - debug: 4.3.6 + debug: 4.3.4(supports-color@5.5.0) highlightjs-solidity: 2.0.6 transitivePeerDependencies: - supports-color @@ -14172,7 +14282,7 @@ snapshots: dependencies: '@typescript-eslint/types': 7.10.0 '@typescript-eslint/visitor-keys': 7.10.0 - debug: 4.3.6 + debug: 4.3.4(supports-color@5.5.0) globby: 11.1.0 is-glob: 4.0.3 minimatch: 9.0.4 @@ -14800,6 +14910,11 @@ snapshots: typescript: 5.4.5 zod: 3.23.8 + abitype@1.0.6(typescript@5.4.5)(zod@3.23.8): + optionalDependencies: + typescript: 5.4.5 + zod: 3.23.8 + abort-controller@3.0.0: dependencies: event-target-shim: 5.0.1 @@ -14938,7 +15053,7 @@ snapshots: aria-query@5.1.3: dependencies: - deep-equal: '@socketregistry/deep-equal@1.0.3' + deep-equal: '@socketregistry/deep-equal@1.0.6' aria-query@5.3.0: dependencies: @@ -14949,14 +15064,14 @@ snapshots: array.prototype.toreversed@1.1.2: dependencies: call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.2' + define-properties: '@socketregistry/define-properties@1.0.5' es-abstract: 1.23.3 es-shim-unscopables: 1.0.2 array.prototype.tosorted@1.1.3: dependencies: call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.2' + define-properties: '@socketregistry/define-properties@1.0.5' es-abstract: 1.23.3 es-errors: 1.3.0 es-shim-unscopables: 1.0.2 @@ -14971,7 +15086,7 @@ snapshots: asn1@0.2.6: dependencies: - safer-buffer: '@socketregistry/safer-buffer@1.0.2' + safer-buffer: '@socketregistry/safer-buffer@1.0.5' assert-plus@1.0.0: {} @@ -15080,7 +15195,7 @@ snapshots: base-x@3.0.9: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' base64-js@1.5.1: {} @@ -15170,7 +15285,7 @@ snapshots: create-hash: 1.2.0 evp_bytestokey: 1.0.3 inherits: 2.0.4 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' browserslist@4.23.0: dependencies: @@ -15194,7 +15309,7 @@ snapshots: dependencies: bs58: 4.0.1 create-hash: 1.2.0 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' bser@2.1.1: dependencies: @@ -15251,11 +15366,11 @@ snapshots: call-bind@1.0.7: dependencies: - es-define-property: '@socketregistry/es-define-property@1.0.2' + es-define-property: '@socketregistry/es-define-property@1.0.5' es-errors: 1.3.0 - function-bind: '@socketregistry/function-bind@1.0.2' + function-bind: '@socketregistry/function-bind@1.0.5' get-intrinsic: 1.2.4 - set-function-length: '@socketregistry/set-function-length@1.0.2' + set-function-length: '@socketregistry/set-function-length@1.0.5' caller-callsite@2.0.0: dependencies: @@ -15306,7 +15421,7 @@ snapshots: capnp-ts@0.7.0: dependencies: debug: 4.3.6 - tslib: 2.6.3 + tslib: 2.6.2 transitivePeerDependencies: - supports-color @@ -15461,7 +15576,7 @@ snapshots: cipher-base@1.0.4: dependencies: inherits: 2.0.4 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' citty@0.1.6: dependencies: @@ -15582,7 +15697,7 @@ snapshots: compressible: 2.0.18 debug: 2.6.9 on-headers: 1.0.2 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' vary: 1.1.2 transitivePeerDependencies: - supports-color @@ -15625,7 +15740,7 @@ snapshots: content-disposition@0.5.4: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' content-hash@2.5.2: dependencies: @@ -15665,7 +15780,7 @@ snapshots: cors@2.8.5: dependencies: - object-assign: '@socketregistry/object-assign@1.0.1' + object-assign: '@socketregistry/object-assign@1.0.3' vary: 1.1.2 cosmiconfig@5.2.1: @@ -15708,7 +15823,7 @@ snapshots: create-hash: 1.2.0 inherits: 2.0.4 ripemd160: 2.0.2 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' sha.js: 2.4.11 create-require@1.1.1: {} @@ -15746,7 +15861,7 @@ snapshots: blakejs: 1.2.1 bs58: 4.0.1 ripemd160-min: 0.0.6 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' sha3: 2.1.4 css-color-keywords@1.0.0: {} @@ -15907,6 +16022,27 @@ snapshots: deep-eql@5.0.2: {} + deep-equal@2.2.3: + dependencies: + array-buffer-byte-length: '@socketregistry/array-buffer-byte-length@1.0.5' + call-bind: 1.0.7 + es-get-iterator: '@socketregistry/es-get-iterator@1.0.5' + get-intrinsic: 1.2.4 + is-arguments: '@socketregistry/is-arguments@1.0.5' + is-array-buffer: '@socketregistry/is-array-buffer@1.0.5' + is-date-object: '@socketregistry/is-date-object@1.0.5' + is-regex: '@socketregistry/is-regex@1.0.5' + is-shared-array-buffer: '@socketregistry/is-shared-array-buffer@1.0.5' + isarray: '@socketregistry/isarray@1.0.5' + object-is: '@socketregistry/object-is@1.0.5' + object-keys: '@socketregistry/object-keys@1.0.5' + object.assign: '@socketregistry/object.assign@1.0.5' + regexp.prototype.flags: '@socketregistry/regexp.prototype.flags@1.0.5' + side-channel: '@socketregistry/side-channel@1.0.6' + which-boxed-primitive: '@socketregistry/which-boxed-primitive@1.0.5' + which-collection: '@socketregistry/which-collection@1.0.5' + which-typed-array: '@socketregistry/which-typed-array@1.0.5' + deep-is@0.1.4: {} deep-object-diff@1.1.9: {} @@ -16033,7 +16169,7 @@ snapshots: ecc-jsbn@0.1.2: dependencies: jsbn: 0.1.1 - safer-buffer: '@socketregistry/safer-buffer@1.0.2' + safer-buffer: '@socketregistry/safer-buffer@1.0.5' eciesjs@0.3.18: dependencies: @@ -16143,71 +16279,71 @@ snapshots: es-abstract@1.23.3: dependencies: - array-buffer-byte-length: '@socketregistry/array-buffer-byte-length@1.0.2' - arraybuffer.prototype.slice: '@socketregistry/arraybuffer.prototype.slice@1.0.2' - available-typed-arrays: '@socketregistry/available-typed-arrays@1.0.2' + array-buffer-byte-length: '@socketregistry/array-buffer-byte-length@1.0.5' + arraybuffer.prototype.slice: '@socketregistry/arraybuffer.prototype.slice@1.0.5' + available-typed-arrays: '@socketregistry/available-typed-arrays@1.0.5' call-bind: 1.0.7 data-view-buffer: 1.0.1 data-view-byte-length: 1.0.1 data-view-byte-offset: 1.0.0 - es-define-property: '@socketregistry/es-define-property@1.0.2' + es-define-property: '@socketregistry/es-define-property@1.0.5' es-errors: 1.3.0 es-object-atoms: 1.0.0 - es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.2' + es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.5' es-to-primitive: 1.2.1 - function.prototype.name: '@socketregistry/function.prototype.name@1.0.2' + function.prototype.name: '@socketregistry/function.prototype.name@1.0.5' get-intrinsic: 1.2.4 - get-symbol-description: '@socketregistry/get-symbol-description@1.0.2' - globalthis: '@socketregistry/globalthis@1.0.2' - gopd: '@socketregistry/gopd@1.0.2' - has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.2' - has-proto: '@socketregistry/has-proto@1.0.2' - has-symbols: '@socketregistry/has-symbols@1.0.2' - hasown: '@socketregistry/hasown@1.0.2' - internal-slot: '@socketregistry/internal-slot@1.0.2' - is-array-buffer: '@socketregistry/is-array-buffer@1.0.2' + get-symbol-description: '@socketregistry/get-symbol-description@1.0.5' + globalthis: '@socketregistry/globalthis@1.0.5' + gopd: '@socketregistry/gopd@1.0.5' + has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.5' + has-proto: '@socketregistry/has-proto@1.0.5' + has-symbols: '@socketregistry/has-symbols@1.0.5' + hasown: '@socketregistry/hasown@1.0.5' + internal-slot: '@socketregistry/internal-slot@1.0.5' + is-array-buffer: '@socketregistry/is-array-buffer@1.0.5' is-callable: 1.2.7 is-data-view: 1.0.1 - is-negative-zero: '@socketregistry/is-negative-zero@1.0.2' - is-regex: '@socketregistry/is-regex@1.0.2' - is-shared-array-buffer: '@socketregistry/is-shared-array-buffer@1.0.2' - is-string: '@socketregistry/is-string@1.0.2' - is-typed-array: '@socketregistry/is-typed-array@1.0.2' - is-weakref: '@socketregistry/is-weakref@1.0.2' + is-negative-zero: '@socketregistry/is-negative-zero@1.0.5' + is-regex: '@socketregistry/is-regex@1.0.5' + is-shared-array-buffer: '@socketregistry/is-shared-array-buffer@1.0.5' + is-string: '@socketregistry/is-string@1.0.5' + is-typed-array: '@socketregistry/is-typed-array@1.0.5' + is-weakref: '@socketregistry/is-weakref@1.0.5' object-inspect: 1.13.1 - object-keys: '@socketregistry/object-keys@1.0.2' - object.assign: '@socketregistry/object.assign@1.0.2' - regexp.prototype.flags: '@socketregistry/regexp.prototype.flags@1.0.2' - safe-array-concat: '@socketregistry/safe-array-concat@1.0.2' - safe-regex-test: '@socketregistry/safe-regex-test@1.0.2' - string.prototype.trim: '@socketregistry/string.prototype.trim@1.0.2' - string.prototype.trimend: '@socketregistry/string.prototype.trimend@1.0.2' - string.prototype.trimstart: '@socketregistry/string.prototype.trimstart@1.0.2' - typed-array-buffer: '@socketregistry/typed-array-buffer@1.0.2' - typed-array-byte-length: '@socketregistry/typed-array-byte-length@1.0.2' - typed-array-byte-offset: '@socketregistry/typed-array-byte-offset@1.0.2' - typed-array-length: '@socketregistry/typed-array-length@1.0.2' - unbox-primitive: '@socketregistry/unbox-primitive@1.0.2' - which-typed-array: '@socketregistry/which-typed-array@1.0.2' + object-keys: '@socketregistry/object-keys@1.0.5' + object.assign: '@socketregistry/object.assign@1.0.5' + regexp.prototype.flags: '@socketregistry/regexp.prototype.flags@1.0.5' + safe-array-concat: '@socketregistry/safe-array-concat@1.0.5' + safe-regex-test: '@socketregistry/safe-regex-test@1.0.5' + string.prototype.trim: '@socketregistry/string.prototype.trim@1.0.5' + string.prototype.trimend: '@socketregistry/string.prototype.trimend@1.0.5' + string.prototype.trimstart: '@socketregistry/string.prototype.trimstart@1.0.5' + typed-array-buffer: '@socketregistry/typed-array-buffer@1.0.5' + typed-array-byte-length: '@socketregistry/typed-array-byte-length@1.0.5' + typed-array-byte-offset: '@socketregistry/typed-array-byte-offset@1.0.5' + typed-array-length: '@socketregistry/typed-array-length@1.0.5' + unbox-primitive: '@socketregistry/unbox-primitive@1.0.5' + which-typed-array: '@socketregistry/which-typed-array@1.0.5' es-errors@1.3.0: {} es-iterator-helpers@1.0.19: dependencies: call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.2' + define-properties: '@socketregistry/define-properties@1.0.5' es-abstract: 1.23.3 es-errors: 1.3.0 - es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.2' - function-bind: '@socketregistry/function-bind@1.0.2' + es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.5' + function-bind: '@socketregistry/function-bind@1.0.5' get-intrinsic: 1.2.4 - globalthis: '@socketregistry/globalthis@1.0.2' - has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.2' - has-proto: '@socketregistry/has-proto@1.0.2' - has-symbols: '@socketregistry/has-symbols@1.0.2' - internal-slot: '@socketregistry/internal-slot@1.0.2' - iterator.prototype: '@socketregistry/iterator.prototype@1.0.2' - safe-array-concat: '@socketregistry/safe-array-concat@1.0.2' + globalthis: '@socketregistry/globalthis@1.0.5' + has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.5' + has-proto: '@socketregistry/has-proto@1.0.5' + has-symbols: '@socketregistry/has-symbols@1.0.5' + internal-slot: '@socketregistry/internal-slot@1.0.5' + iterator.prototype: '@socketregistry/iterator.prototype@1.0.5' + safe-array-concat: '@socketregistry/safe-array-concat@1.0.5' es-module-lexer@1.5.4: {} @@ -16217,18 +16353,18 @@ snapshots: es-shim-unscopables@1.0.2: dependencies: - hasown: '@socketregistry/hasown@1.0.2' + hasown: '@socketregistry/hasown@1.0.5' es-to-primitive@1.2.1: dependencies: is-callable: 1.2.7 - is-date-object: '@socketregistry/is-date-object@1.0.2' - is-symbol: '@socketregistry/is-symbol@1.0.2' + is-date-object: '@socketregistry/is-date-object@1.0.5' + is-symbol: '@socketregistry/is-symbol@1.0.5' es5-ext@0.10.64: dependencies: es6-iterator: 2.0.3 - es6-symbol: '@socketregistry/es6-symbol@1.0.2' + es6-symbol: '@socketregistry/es6-symbol@1.0.5' esniff: 2.0.1 next-tick: 1.1.0 @@ -16236,7 +16372,7 @@ snapshots: dependencies: d: 1.0.2 es5-ext: 0.10.64 - es6-symbol: '@socketregistry/es6-symbol@1.0.2' + es6-symbol: '@socketregistry/es6-symbol@1.0.5' es6-promise@4.2.8: {} @@ -16306,8 +16442,8 @@ snapshots: confusing-browser-globals: 1.0.11 eslint: 8.50.0 eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) - object.assign: '@socketregistry/object.assign@1.0.2' - object.entries: '@socketregistry/object.entries@1.0.2' + object.assign: '@socketregistry/object.assign@1.0.5' + object.entries: '@socketregistry/object.entries@1.0.5' semver: 6.3.1 eslint-config-airbnb-typescript@17.1.0(@typescript-eslint/eslint-plugin@6.21.0(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0)(typescript@5.4.5))(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0): @@ -16326,8 +16462,8 @@ snapshots: eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) - object.assign: '@socketregistry/object.assign@1.0.2' - object.entries: '@socketregistry/object.entries@1.0.2' + object.assign: '@socketregistry/object.assign@1.0.5' + object.entries: '@socketregistry/object.entries@1.0.5' eslint-config-next@13.5.6(eslint@8.50.0)(typescript@5.4.5): dependencies: @@ -16354,7 +16490,7 @@ snapshots: eslint-import-resolver-node@0.3.9: dependencies: debug: 3.2.7 - is-core-module: '@socketregistry/is-core-module@1.0.2' + is-core-module: '@socketregistry/is-core-module@1.0.5' resolve: 1.22.8 transitivePeerDependencies: - supports-color @@ -16368,7 +16504,7 @@ snapshots: eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 - is-core-module: '@socketregistry/is-core-module@1.0.2' + is-core-module: '@socketregistry/is-core-module@1.0.5' is-glob: 4.0.3 transitivePeerDependencies: - '@typescript-eslint/parser' @@ -16389,22 +16525,22 @@ snapshots: eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0): dependencies: - array-includes: '@socketregistry/array-includes@1.0.2' - array.prototype.findlastindex: '@socketregistry/array.prototype.findlastindex@1.0.2' - array.prototype.flat: '@socketregistry/array.prototype.flat@1.0.2' - array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.2' + array-includes: '@socketregistry/array-includes@1.0.5' + array.prototype.findlastindex: '@socketregistry/array.prototype.findlastindex@1.0.5' + array.prototype.flat: '@socketregistry/array.prototype.flat@1.0.5' + array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.5' debug: 3.2.7 doctrine: 2.1.0 eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) - hasown: '@socketregistry/hasown@1.0.2' - is-core-module: '@socketregistry/is-core-module@1.0.2' + hasown: '@socketregistry/hasown@1.0.5' + is-core-module: '@socketregistry/is-core-module@1.0.5' is-glob: 4.0.3 minimatch: 3.1.2 - object.fromentries: '@socketregistry/object.fromentries@1.0.2' + object.fromentries: '@socketregistry/object.fromentries@1.0.5' object.groupby: 1.0.3 - object.values: '@socketregistry/object.values@1.0.2' + object.values: '@socketregistry/object.values@1.0.5' semver: 6.3.1 tsconfig-paths: 3.15.0 optionalDependencies: @@ -16418,8 +16554,8 @@ snapshots: dependencies: '@babel/runtime': 7.24.6 aria-query: 5.3.0 - array-includes: '@socketregistry/array-includes@1.0.2' - array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.2' + array-includes: '@socketregistry/array-includes@1.0.5' + array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.5' ast-types-flow: 0.0.8 axe-core: 4.7.0 axobject-query: 3.2.1 @@ -16427,12 +16563,12 @@ snapshots: emoji-regex: 9.2.2 es-iterator-helpers: 1.0.19 eslint: 8.50.0 - hasown: '@socketregistry/hasown@1.0.2' + hasown: '@socketregistry/hasown@1.0.5' jsx-ast-utils: 3.3.5 language-tags: 1.0.9 minimatch: 3.1.2 - object.entries: '@socketregistry/object.entries@1.0.2' - object.fromentries: '@socketregistry/object.fromentries@1.0.2' + object.entries: '@socketregistry/object.entries@1.0.5' + object.fromentries: '@socketregistry/object.fromentries@1.0.5' eslint-plugin-prettier@5.1.3(@types/eslint@9.6.0)(eslint-config-prettier@9.1.0(eslint@8.50.0))(eslint@8.50.0)(prettier@3.0.3): dependencies: @@ -16450,9 +16586,9 @@ snapshots: eslint-plugin-react@7.34.1(eslint@8.50.0): dependencies: - array-includes: '@socketregistry/array-includes@1.0.2' - array.prototype.findlast: '@socketregistry/array.prototype.findlast@1.0.2' - array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.2' + array-includes: '@socketregistry/array-includes@1.0.5' + array.prototype.findlast: '@socketregistry/array.prototype.findlast@1.0.5' + array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.5' array.prototype.toreversed: 1.1.2 array.prototype.tosorted: 1.1.3 doctrine: 2.1.0 @@ -16461,14 +16597,14 @@ snapshots: estraverse: 5.3.0 jsx-ast-utils: 3.3.5 minimatch: 3.1.2 - object.entries: '@socketregistry/object.entries@1.0.2' - object.fromentries: '@socketregistry/object.fromentries@1.0.2' - object.hasown: '@socketregistry/object.hasown@1.0.2' - object.values: '@socketregistry/object.values@1.0.2' + object.entries: '@socketregistry/object.entries@1.0.5' + object.fromentries: '@socketregistry/object.fromentries@1.0.5' + object.hasown: '@socketregistry/object.hasown@1.0.5' + object.values: '@socketregistry/object.values@1.0.5' prop-types: 15.8.1 resolve: 2.0.0-next.5 semver: 6.3.1 - string.prototype.matchall: '@socketregistry/string.prototype.matchall@1.0.2' + string.prototype.matchall: '@socketregistry/string.prototype.matchall@1.0.5' eslint-plugin-testing-library@6.2.2(eslint@8.50.0)(typescript@5.4.5): dependencies: @@ -16650,7 +16786,7 @@ snapshots: keccak: 3.0.4 pbkdf2: 3.1.2 randombytes: 2.1.0 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' scrypt-js: 3.0.1 secp256k1: 4.0.3 setimmediate: 1.0.5 @@ -16774,7 +16910,7 @@ snapshots: evp_bytestokey@1.0.3: dependencies: md5.js: 1.3.5 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' execa@5.1.1: dependencies: @@ -16816,7 +16952,7 @@ snapshots: express@4.19.2: dependencies: accepts: 1.3.8 - array-flatten: '@socketregistry/array-flatten@1.0.2' + array-flatten: '@socketregistry/array-flatten@1.0.5' body-parser: 1.20.2 content-disposition: 0.5.4 content-type: 1.0.5 @@ -16838,7 +16974,7 @@ snapshots: proxy-addr: 2.0.7 qs: 6.11.0 range-parser: 1.2.1 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' send: 0.18.0 serve-static: 1.15.0 setprototypeof: 1.2.0 @@ -17107,7 +17243,7 @@ snapshots: color-support: 1.1.3 console-control-strings: 1.1.0 has-unicode: 2.0.1 - object-assign: '@socketregistry/object-assign@1.0.1' + object-assign: '@socketregistry/object-assign@1.0.3' signal-exit: 3.0.7 string-width: 4.2.3 strip-ansi: 6.0.1 @@ -17124,10 +17260,10 @@ snapshots: get-intrinsic@1.2.4: dependencies: es-errors: 1.3.0 - function-bind: '@socketregistry/function-bind@1.0.2' - has-proto: '@socketregistry/has-proto@1.0.2' - has-symbols: '@socketregistry/has-symbols@1.0.2' - hasown: '@socketregistry/hasown@1.0.2' + function-bind: '@socketregistry/function-bind@1.0.5' + has-proto: '@socketregistry/has-proto@1.0.5' + has-symbols: '@socketregistry/has-symbols@1.0.5' + hasown: '@socketregistry/hasown@1.0.5' get-nonce@1.0.1: {} @@ -17375,7 +17511,7 @@ snapshots: '@types/bn.js': 5.1.5 '@types/lru-cache': 5.1.1 adm-zip: 0.4.16 - aggregate-error: '@socketregistry/aggregate-error@1.0.2' + aggregate-error: '@socketregistry/aggregate-error@1.0.6' ansi-escapes: 4.3.2 boxen: 5.1.2 chalk: 2.4.2 @@ -17426,7 +17562,7 @@ snapshots: dependencies: inherits: 2.0.4 readable-stream: 3.6.2 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' hash-test-vectors@1.3.2: {} @@ -17589,11 +17725,11 @@ snapshots: iconv-lite@0.4.24: dependencies: - safer-buffer: '@socketregistry/safer-buffer@1.0.2' + safer-buffer: '@socketregistry/safer-buffer@1.0.5' iconv-lite@0.6.3: dependencies: - safer-buffer: '@socketregistry/safer-buffer@1.0.2' + safer-buffer: '@socketregistry/safer-buffer@1.0.5' idb-keyval@6.2.1: {} @@ -17697,7 +17833,7 @@ snapshots: is-data-view@1.0.1: dependencies: - is-typed-array: '@socketregistry/is-typed-array@1.0.2' + is-typed-array: '@socketregistry/is-typed-array@1.0.5' is-directory@0.3.1: {} @@ -17709,7 +17845,7 @@ snapshots: is-fullwidth-code-point@1.0.0: dependencies: - number-is-nan: '@socketregistry/number-is-nan@1.0.2' + number-is-nan: '@socketregistry/number-is-nan@1.0.7' is-fullwidth-code-point@2.0.0: {} @@ -17800,6 +17936,10 @@ snapshots: dependencies: ws: 8.17.1(bufferutil@4.0.8)(utf-8-validate@5.0.10) + isows@1.0.6(ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)): + dependencies: + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + isstream@0.1.2: {} istanbul-lib-coverage@3.2.2: {} @@ -18001,7 +18141,7 @@ snapshots: whatwg-encoding: 3.1.1 whatwg-mimetype: 4.0.0 whatwg-url: 14.0.0 - ws: 8.17.1(bufferutil@4.0.8)(utf-8-validate@5.0.10) + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) xml-name-validator: 5.0.0 optionalDependencies: canvas: 2.11.2(encoding@0.1.13) @@ -18077,10 +18217,10 @@ snapshots: jsx-ast-utils@3.3.5: dependencies: - array-includes: '@socketregistry/array-includes@1.0.2' - array.prototype.flat: '@socketregistry/array.prototype.flat@1.0.2' - object.assign: '@socketregistry/object.assign@1.0.2' - object.values: '@socketregistry/object.values@1.0.2' + array-includes: '@socketregistry/array-includes@1.0.5' + array.prototype.flat: '@socketregistry/array.prototype.flat@1.0.5' + object.assign: '@socketregistry/object.assign@1.0.5' + object.values: '@socketregistry/object.values@1.0.5' keccak@3.0.4: dependencies: @@ -18357,7 +18497,7 @@ snapshots: dependencies: hash-base: 3.1.0 inherits: 2.0.4 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' mdn-data@2.0.14: {} @@ -18670,7 +18810,7 @@ snapshots: minipass@2.9.0: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' yallist: 3.1.1 minipass@3.3.6: @@ -18979,7 +19119,7 @@ snapshots: normalize-package-data@3.0.3: dependencies: hosted-git-info: 4.1.0 - is-core-module: '@socketregistry/is-core-module@1.0.2' + is-core-module: '@socketregistry/is-core-module@1.0.5' semver: 7.6.2 validate-npm-package-license: 3.0.4 @@ -19045,7 +19185,7 @@ snapshots: object.groupby@1.0.3: dependencies: call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.2' + define-properties: '@socketregistry/define-properties@1.0.5' es-abstract: 1.23.3 obliterator@2.0.4: {} @@ -19168,7 +19308,7 @@ snapshots: p-map@4.0.0: dependencies: - aggregate-error: '@socketregistry/aggregate-error@1.0.2' + aggregate-error: '@socketregistry/aggregate-error@1.0.6' p-try@1.0.0: {} @@ -19268,7 +19408,7 @@ snapshots: create-hash: 1.2.0 create-hmac: 1.1.7 ripemd160: 2.0.2 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' sha.js: 2.4.11 performance-now@2.1.0: {} @@ -19328,11 +19468,11 @@ snapshots: mlly: 1.7.0 pathe: 1.1.2 - playwright-core@1.48.0: {} + playwright-core@1.48.2: {} - playwright@1.48.0: + playwright@1.48.2: dependencies: - playwright-core: 1.48.0 + playwright-core: 1.48.2 optionalDependencies: fsevents: 2.3.2 @@ -19440,7 +19580,7 @@ snapshots: prop-types@15.8.1: dependencies: loose-envify: 1.4.0 - object-assign: '@socketregistry/object-assign@1.0.1' + object-assign: '@socketregistry/object-assign@1.0.3' react-is: 16.13.1 proxy-addr@2.0.7: @@ -19484,18 +19624,18 @@ snapshots: qs@6.11.0: dependencies: - side-channel: '@socketregistry/side-channel@1.0.2' + side-channel: '@socketregistry/side-channel@1.0.6' qs@6.12.1: dependencies: - side-channel: '@socketregistry/side-channel@1.0.2' + side-channel: '@socketregistry/side-channel@1.0.6' qs@6.5.3: {} query-string@5.1.1: dependencies: decode-uri-component: 0.2.2 - object-assign: '@socketregistry/object-assign@1.0.1' + object-assign: '@socketregistry/object-assign@1.0.3' strict-uri-encode: 1.1.0 query-string@6.14.1: @@ -19530,7 +19670,7 @@ snapshots: randombytes@2.1.0: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' range-parser@1.2.1: {} @@ -19648,7 +19788,7 @@ snapshots: dependencies: react: 18.3.1 react-style-singleton: 2.2.1(@types/react@18.2.21)(react@18.3.1) - tslib: 2.6.3 + tslib: 2.6.2 optionalDependencies: '@types/react': 18.2.21 @@ -19657,7 +19797,7 @@ snapshots: react: 18.3.1 react-remove-scroll-bar: 2.3.6(@types/react@18.2.21)(react@18.3.1) react-style-singleton: 2.2.1(@types/react@18.2.21)(react@18.3.1) - tslib: 2.6.3 + tslib: 2.6.2 use-callback-ref: 1.3.2(@types/react@18.2.21)(react@18.3.1) use-sidecar: 1.1.2(@types/react@18.2.21)(react@18.3.1) optionalDependencies: @@ -19665,7 +19805,7 @@ snapshots: react-shallow-renderer@16.15.0(react@18.3.1): dependencies: - object-assign: '@socketregistry/object-assign@1.0.1' + object-assign: '@socketregistry/object-assign@1.0.3' react: 18.3.1 react-is: 18.3.1 @@ -19674,7 +19814,7 @@ snapshots: get-nonce: 1.0.1 invariant: 2.2.4 react: 18.3.1 - tslib: 2.6.3 + tslib: 2.6.2 optionalDependencies: '@types/react': 18.2.21 @@ -19748,9 +19888,9 @@ snapshots: dependencies: core-util-is: 1.0.3 inherits: 2.0.4 - isarray: '@socketregistry/isarray@1.0.2' + isarray: '@socketregistry/isarray@1.0.5' process-nextick-args: 1.0.7 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' string_decoder: 1.0.3 util-deprecate: 1.0.2 @@ -19758,9 +19898,9 @@ snapshots: dependencies: core-util-is: 1.0.3 inherits: 2.0.4 - isarray: '@socketregistry/isarray@1.0.2' + isarray: '@socketregistry/isarray@1.0.5' process-nextick-args: 2.0.1 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' string_decoder: 1.1.1 util-deprecate: 1.0.2 @@ -19795,7 +19935,7 @@ snapshots: redent@3.0.0: dependencies: - indent-string: '@socketregistry/indent-string@1.0.2' + indent-string: '@socketregistry/indent-string@1.0.5' strip-indent: 3.0.0 regenerate-unicode-properties@10.1.1: @@ -19810,7 +19950,7 @@ snapshots: regenerator-transform@0.15.2: dependencies: - '@babel/runtime': 7.24.6 + '@babel/runtime': 7.25.0 regexpu-core@5.3.2: dependencies: @@ -19843,7 +19983,7 @@ snapshots: oauth-sign: 0.9.0 performance-now: 2.1.0 qs: 6.5.3 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' tough-cookie: 2.5.0 tunnel-agent: 0.6.0 uuid: 3.4.0 @@ -19876,18 +20016,18 @@ snapshots: resolve@1.17.0: dependencies: - path-parse: '@socketregistry/path-parse@1.0.2' + path-parse: '@socketregistry/path-parse@1.0.5' resolve@1.22.8: dependencies: - is-core-module: '@socketregistry/is-core-module@1.0.2' - path-parse: '@socketregistry/path-parse@1.0.2' + is-core-module: '@socketregistry/is-core-module@1.0.5' + path-parse: '@socketregistry/path-parse@1.0.5' supports-preserve-symlinks-flag: 1.0.0 resolve@2.0.0-next.5: dependencies: - is-core-module: '@socketregistry/is-core-module@1.0.2' - path-parse: '@socketregistry/path-parse@1.0.2' + is-core-module: '@socketregistry/is-core-module@1.0.5' + path-parse: '@socketregistry/path-parse@1.0.5' supports-preserve-symlinks-flag: 1.0.0 responselike@2.0.1: @@ -20118,7 +20258,7 @@ snapshots: sha.js@2.4.11: dependencies: inherits: 2.0.4 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' sha3@2.1.4: dependencies: @@ -20196,7 +20336,7 @@ snapshots: snake-case@3.0.4: dependencies: dot-case: 3.0.4 - tslib: 2.6.3 + tslib: 2.6.2 socket.io-client@4.7.5(bufferutil@4.0.8)(utf-8-validate@5.0.10): dependencies: @@ -20292,7 +20432,7 @@ snapshots: ecc-jsbn: 0.1.2 getpass: 0.1.7 jsbn: 0.1.1 - safer-buffer: '@socketregistry/safer-buffer@1.0.2' + safer-buffer: '@socketregistry/safer-buffer@1.0.5' tweetnacl: 0.14.5 stack-generator@1.1.0: @@ -20386,15 +20526,15 @@ snapshots: string_decoder@1.0.3: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' string_decoder@1.1.1: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' string_decoder@1.3.0: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' strip-ansi@3.0.1: dependencies: @@ -20676,7 +20816,7 @@ snapshots: minipass: 2.9.0 minizlib: 1.3.3 mkdirp: 0.5.6 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' yallist: 3.1.1 tar@6.2.1: @@ -20845,7 +20985,7 @@ snapshots: tunnel-agent@0.6.0: dependencies: - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' tween-functions@1.2.0: {} @@ -20998,7 +21138,7 @@ snapshots: url-parse@1.5.10: dependencies: - querystringify: '@socketregistry/querystringify@1.0.2' + querystringify: '@socketregistry/querystringify@1.0.5' requires-port: 1.0.0 url-set-query@1.0.0: {} @@ -21006,7 +21146,7 @@ snapshots: use-callback-ref@1.3.2(@types/react@18.2.21)(react@18.3.1): dependencies: react: 18.3.1 - tslib: 2.6.3 + tslib: 2.6.2 optionalDependencies: '@types/react': 18.2.21 @@ -21019,7 +21159,7 @@ snapshots: dependencies: detect-node-es: 1.1.0 react: 18.3.1 - tslib: 2.6.3 + tslib: 2.6.2 optionalDependencies: '@types/react': 18.2.21 @@ -21038,10 +21178,10 @@ snapshots: util@0.12.5: dependencies: inherits: 2.0.4 - is-arguments: '@socketregistry/is-arguments@1.0.2' - is-generator-function: '@socketregistry/is-generator-function@1.0.2' - is-typed-array: '@socketregistry/is-typed-array@1.0.2' - which-typed-array: '@socketregistry/which-typed-array@1.0.2' + is-arguments: '@socketregistry/is-arguments@1.0.5' + is-generator-function: '@socketregistry/is-generator-function@1.0.5' + is-typed-array: '@socketregistry/is-typed-array@1.0.5' + which-typed-array: '@socketregistry/which-typed-array@1.0.5' utils-merge@1.0.1: {} @@ -21098,6 +21238,24 @@ snapshots: - utf-8-validate - zod + viem@2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8): + dependencies: + '@adraffy/ens-normalize': 1.11.0 + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/bip32': 1.5.0 + '@scure/bip39': 1.4.0 + abitype: 1.0.6(typescript@5.4.5)(zod@3.23.8) + isows: 1.0.6(ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10)) + webauthn-p256: 0.0.10 + ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10) + optionalDependencies: + typescript: 5.4.5 + transitivePeerDependencies: + - bufferutil + - utf-8-validate + - zod + vite-node@2.0.5(@types/node@18.19.33)(terser@5.31.5): dependencies: cac: 6.7.14 @@ -21690,6 +21848,11 @@ snapshots: - supports-color - utf-8-validate + webauthn-p256@0.0.10: + dependencies: + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + webauthn-p256@0.0.5: dependencies: '@noble/curves': 1.4.0 @@ -21880,7 +22043,7 @@ snapshots: ws@3.3.3(bufferutil@4.0.8)(utf-8-validate@5.0.10): dependencies: async-limiter: 1.0.1 - safe-buffer: '@socketregistry/safe-buffer@1.0.2' + safe-buffer: '@socketregistry/safe-buffer@1.0.5' ultron: 1.1.1 optionalDependencies: bufferutil: 4.0.8 @@ -21923,6 +22086,11 @@ snapshots: bufferutil: 4.0.8 utf-8-validate: 5.0.10 + ws@8.18.0(bufferutil@4.0.8)(utf-8-validate@5.0.10): + optionalDependencies: + bufferutil: 4.0.8 + utf-8-validate: 5.0.10 + xhr-request-promise@0.1.3: dependencies: xhr-request: 1.1.0 @@ -21930,7 +22098,7 @@ snapshots: xhr-request@1.1.0: dependencies: buffer-to-arraybuffer: 0.0.5 - object-assign: '@socketregistry/object-assign@1.0.1' + object-assign: '@socketregistry/object-assign@1.0.3' query-string: 5.1.1 simple-get: 2.8.2 timed-out: 4.0.1 From a3ef7371db668fbc2555a50255dab0caa570f5f2 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Sat, 9 Nov 2024 21:44:09 +0200 Subject: [PATCH 59/75] responsive banner --- pnpm-lock.yaml | 43 +-------------------- src/components/pages/AnnouncementBanner.tsx | 42 +++++++++++++++----- 2 files changed, 34 insertions(+), 51 deletions(-) diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 193771135..feadf869c 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -427,48 +427,6 @@ importers: specifier: ^1.0.0-pre.53 version: 1.0.0-pre.53 - .yalc/@ensdomains/ens-test-env: - dependencies: - '@ethersproject/wallet': - specifier: ^5.6.0 - version: 5.7.0 - ansi-colors: - specifier: ^4.1.1 - version: 4.1.3 - cli-progress: - specifier: ^3.10.0 - version: 3.12.0 - commander: - specifier: ^9.3.0 - version: 9.5.0 - concurrently: - specifier: ^7.1.0 - version: 7.6.0 - docker-compose: - specifier: ^0.24.7 - version: 0.24.8 - dotenv: - specifier: ^16.0.1 - version: 16.4.5 - js-yaml: - specifier: ^4.1.0 - version: 4.1.0 - lz4: - specifier: ^0.6.5 - version: 0.6.5 - progress-stream: - specifier: ^2.0.0 - version: 2.0.0 - tar-fs: - specifier: ^2.1.1 - version: 2.1.1 - viem: - specifier: ^2.21.37 - version: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) - wait-on: - specifier: ^6.0.1 - version: 6.0.1 - packages: '@adobe/css-tools@4.3.3': @@ -3863,6 +3821,7 @@ packages: acorn-import-assertions@1.9.0: resolution: {integrity: sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==} + deprecated: package has been renamed to acorn-import-attributes peerDependencies: acorn: ^8 diff --git a/src/components/pages/AnnouncementBanner.tsx b/src/components/pages/AnnouncementBanner.tsx index f36fd18c9..42815bf0e 100644 --- a/src/components/pages/AnnouncementBanner.tsx +++ b/src/components/pages/AnnouncementBanner.tsx @@ -7,15 +7,37 @@ import { Button, Typography } from '@ensdomains/thorin' const Container = styled(Link)( ({ theme }) => css` display: flex; - flex-direction: row; + flex-direction: column; width: ${theme.space.full}; max-width: 466px; padding: ${theme.space['4']}; align-items: center; + justify-content: space-between; gap: ${theme.space['4']}; align-self: center; border-radius: ${theme.radii['2xLarge']}; background-color: ${theme.colors.backgroundPrimary}; + + @media (max-width: 640px) { + a { + width: 100%; + } + } + + @media (min-width: 640px) { + flex-direction: row; + } + `, +) + +const TextContainer = styled.div( + ({ theme }) => css` + display: flex; + flex-direction: row; + align-items: center; + gap: ${theme.space['4']}; + + width: ${theme.space.full}; `, ) @@ -30,14 +52,16 @@ export const AnnouncementBanner = () => { return ( - - - {t('banner.title')} - - {t('banner.caption')} - - - From c6d94c2a57839f573bd4e67e3bb19a989454cba7 Mon Sep 17 00:00:00 2001 From: v1rtl Date: Sat, 9 Nov 2024 21:53:01 +0200 Subject: [PATCH 60/75] qa --- src/pages/ens-v2.tsx | 57 ++++++++++++++++++++++++++++---------------- 1 file changed, 37 insertions(+), 20 deletions(-) diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index 184fecce8..8edcefeda 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -7,20 +7,20 @@ import { Button, Card, GasPumpSVG, - InfoCircleSVG, + // InfoCircleSVG, KeySVG, - QuestionBubbleSVG, - QuestionCircleSVG, - RightArrowSVG, - SpannerAltSVG, + // QuestionBubbleSVG, + // QuestionCircleSVG, + // RightArrowSVG, + // SpannerAltSVG, Typography, WalletSVG, } from '@ensdomains/thorin' import { Carousel } from '@app/components/pages/migrate/Carousel' -import DAOSVG from '../assets/DAO.svg' -import SocialX from '../assets/social/SocialX.svg' +// import DAOSVG from '../assets/DAO.svg' +// import SocialX from '../assets/social/SocialX.svg' const Title = styled.h1` font-weight: 830; @@ -55,7 +55,7 @@ const Main = styled.main( `, ) -const PartnershipAnnouncement = styled.div( +/* const PartnershipAnnouncement = styled.div( ({ theme }) => css` width: ${theme.space.full}; padding: ${theme.space['4']}; @@ -79,9 +79,9 @@ const PartnershipAnnouncement = styled.div( border-radius: ${theme.radii['3xLarge']}; } `, -) +) */ -const Footer = styled.div( +/* const Footer = styled.div( ({ theme }) => css` display: flex; flex-direction: column; @@ -116,7 +116,7 @@ const Footer = styled.div( } } `, -) +) */ const AnnouncementBanner = styled.div( ({ theme }) => css` @@ -133,7 +133,7 @@ const AnnouncementBanner = styled.div( `, ) -const TopNav = styled.div( +/* const TopNav = styled.div( ({ theme }) => css` display: flex; flex-direction: column; @@ -144,7 +144,7 @@ const TopNav = styled.div( left: 0; z-index: 1; `, -) +) */ const CenteredCard = styled(Card)` display: flex; @@ -182,9 +182,17 @@ const CardHeader = styled.h3( `, ) -const AnnouncementSlide = ({ title, text }: { title: string; text: string }) => ( +const AnnouncementSlide = ({ + title, + text, + href = '#', +}: { + title: string + text: string + href?: string +}) => ( - + {text} @@ -213,14 +221,14 @@ export default function ENSv2() { const { t } = useTranslation('ensv2') return (
- + {/* {t('partnership.text')} {t('partnership.watch')} - + */}
{t('title')} {t('caption')} @@ -250,7 +258,14 @@ export default function ENSv2() { {t('accessible.title')} {t('accessible.caption')} - @@ -288,14 +303,16 @@ export default function ENSv2() { -
+ {/*
{t('footer.title')} @@ -323,7 +340,7 @@ export default function ENSv2() { -
+
*/}
) } From 1f4358926c792783b325beee2e25ed4ca121ff1c Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Sun, 10 Nov 2024 23:17:05 +0700 Subject: [PATCH 61/75] Fix hydration and pre-load english translation --- src/components/pages/AnnouncementBanner.tsx | 32 +++++++++++---------- src/i18n.ts | 3 ++ src/pages/ens-v2.tsx | 4 +-- 3 files changed, 22 insertions(+), 17 deletions(-) diff --git a/src/components/pages/AnnouncementBanner.tsx b/src/components/pages/AnnouncementBanner.tsx index 42815bf0e..d9e0c2a4d 100644 --- a/src/components/pages/AnnouncementBanner.tsx +++ b/src/components/pages/AnnouncementBanner.tsx @@ -4,7 +4,7 @@ import styled, { css } from 'styled-components' import { Button, Typography } from '@ensdomains/thorin' -const Container = styled(Link)( +const Container = styled.div( ({ theme }) => css` display: flex; flex-direction: column; @@ -51,19 +51,21 @@ export const AnnouncementBanner = () => { const { t } = useTranslation('ensv2') return ( - - - - - {t('banner.title')} - - {t('banner.caption')} - - - - - + + + + + + {t('banner.title')} + + {t('banner.caption')} + + + + + + ) } diff --git a/src/i18n.ts b/src/i18n.ts index 97889272a..ad7d9f964 100644 --- a/src/i18n.ts +++ b/src/i18n.ts @@ -6,6 +6,7 @@ import { initReactI18next } from 'react-i18next' import address from '../public/locales/en/address.json' import common from '../public/locales/en/common.json' import dnssec from '../public/locales/en/dnssec.json' +import ensv2 from '../public/locales/en/ensv2.json' import names from '../public/locales/en/names.json' import profile from '../public/locales/en/profile.json' import register from '../public/locales/en/register.json' @@ -33,6 +34,7 @@ i18n 'register', 'settings', 'transactionFlow', + 'ensv2', ], react: { useSuspense: false, @@ -48,5 +50,6 @@ i18n.addResourceBundle('en', 'profile', profile) i18n.addResourceBundle('en', 'register', register) i18n.addResourceBundle('en', 'settings', settings) i18n.addResourceBundle('en', 'transactionFlow', transactionFlow) +i18n.addResourceBundle('en', 'ensv2', ensv2) export default i18n diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index 8edcefeda..8914398ca 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -296,10 +296,10 @@ export default function ENSv2() { {t('announcement.title')} - + /> */} Date: Sun, 10 Nov 2024 23:59:02 +0700 Subject: [PATCH 62/75] Remove carousel for now --- src/pages/ens-v2.tsx | 58 ++++++++++++++++++++++++++++++++++++++------ 1 file changed, 50 insertions(+), 8 deletions(-) diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index 8914398ca..3e1a7c50f 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -9,6 +9,7 @@ import { GasPumpSVG, // InfoCircleSVG, KeySVG, + mq, // QuestionBubbleSVG, // QuestionCircleSVG, // RightArrowSVG, @@ -17,8 +18,6 @@ import { WalletSVG, } from '@ensdomains/thorin' -import { Carousel } from '@app/components/pages/migrate/Carousel' - // import DAOSVG from '../assets/DAO.svg' // import SocialX from '../assets/social/SocialX.svg' @@ -120,7 +119,8 @@ const Main = styled.main( const AnnouncementBanner = styled.div( ({ theme }) => css` - height: ${theme.space.full}; + width: 312px; + height: 182px; text-align: center; & > a { height: ${theme.space.full}; @@ -182,7 +182,23 @@ const CardHeader = styled.h3( `, ) -const AnnouncementSlide = ({ +// const AnnouncementSlide = ({ +// title, +// text, +// href = '#', +// }: { +// title: string +// text: string +// href?: string +// }) => ( +// +// +// {text} +// +// +// ) + +const AnnouncementSlideTemp = ({ title, text, href = '#', @@ -198,6 +214,20 @@ const AnnouncementSlide = ({ ) +const AnnouncementContainer = styled.div( + ({ theme }) => css` + display: flex; + align-items: center; + justify-content: center; + flex-direction: column; + gap: ${theme.space['4']}; + + ${mq.sm.min(css` + flex-direction: row; + `)} + `, +) + const SlideshowContainer = styled.div( ({ theme }) => css` display: flex; @@ -295,11 +325,11 @@ export default function ENSv2() { {t('announcement.title')} - - {/* + */} + /> - + */} + + + + {/*
From a260c4ba69137dae60c158348ad2452096a44ef9 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 11 Nov 2024 00:20:52 +0700 Subject: [PATCH 63/75] bump ensjs to 4.0.2 --- package.json | 2 +- pnpm-lock.yaml | 93 +++++++++++++++++++++++++++++++++++--------------- 2 files changed, 66 insertions(+), 29 deletions(-) diff --git a/package.json b/package.json index f724b4154..b11a69774 100644 --- a/package.json +++ b/package.json @@ -55,7 +55,7 @@ "@ensdomains/address-encoder": "1.1.1", "@ensdomains/content-hash": "^3.0.0-beta.5", "@ensdomains/ens-contracts": "1.2.0-beta.0", - "@ensdomains/ensjs": "4.0.2-alpha.5", + "@ensdomains/ensjs": "4.0.2", "@ensdomains/thorin": "0.6.50", "@metamask/post-message-stream": "^6.1.2", "@metamask/providers": "^14.0.2", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index ed228aad9..a62913ea3 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -39,8 +39,8 @@ importers: specifier: 1.2.0-beta.0 version: 1.2.0-beta.0 '@ensdomains/ensjs': - specifier: 4.0.2-alpha.5 - version: 4.0.2-alpha.5(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8) + specifier: 4.0.2 + version: 4.0.2(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8) '@ensdomains/thorin': specifier: 0.6.50 version: 0.6.50(react-dom@18.3.1(react@18.3.1))(react-transition-state@1.1.5(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react@18.3.1)(styled-components@5.3.11(@babel/core@7.24.6)(react-dom@18.3.1(react@18.3.1))(react-is@17.0.2)(react@18.3.1)) @@ -299,7 +299,7 @@ importers: version: 0.3.9 eslint-plugin-import: specifier: ^2.28.1 - version: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + version: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: specifier: ^6.7.1 version: 6.8.0(eslint@8.50.0) @@ -469,6 +469,42 @@ importers: specifier: ^6.0.1 version: 6.0.1 + .yalc/@ensdomains/ensjs: + dependencies: + '@adraffy/ens-normalize': + specifier: 1.10.1 + version: 1.10.1 + '@ensdomains/address-encoder': + specifier: 1.1.1 + version: 1.1.1 + '@ensdomains/content-hash': + specifier: 3.1.0-rc.1 + version: 3.1.0-rc.1 + '@ensdomains/dnsprovejs': + specifier: ^0.5.1 + version: 0.5.1 + abitype: + specifier: ^1.0.0 + version: 1.0.6(typescript@5.4.5)(zod@3.23.8) + dns-packet: + specifier: ^5.3.1 + version: 5.6.1 + graphql: + specifier: ^16.3.0 + version: 16.8.1 + graphql-request: + specifier: 6.1.0 + version: 6.1.0(encoding@0.1.13)(graphql@16.8.1) + pako: + specifier: ^2.1.0 + version: 2.1.0 + ts-pattern: + specifier: ^5.4.0 + version: 5.5.0 + viem: + specifier: ^2.9.2 + version: 2.21.40(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8) + packages: '@adobe/css-tools@4.3.3': @@ -1607,8 +1643,8 @@ packages: '@ensdomains/ensjs@2.1.0': resolution: {integrity: sha512-GRbGPT8Z/OJMDuxs75U/jUNEC0tbL0aj7/L/QQznGYKm/tiasp+ndLOaoULy9kKJFC0TBByqfFliEHDgoLhyog==} - '@ensdomains/ensjs@4.0.2-alpha.5': - resolution: {integrity: sha512-xDlnEg+JbZMs+vV5C3v0ks8nBrJciwVD9gYeFH5TzDpSM1zcGxb4KO4vvv0F+f8UI0aZFLLldZ7xyWfn4egjAw==} + '@ensdomains/ensjs@4.0.2': + resolution: {integrity: sha512-4vDIZEFAa1doNA3H9MppUHxflSDYYPVNyaDbdHLksTa4taq3y4dGpletX67Xea8nxI+cMfjEi4nOzLJmPzRE/g==} peerDependencies: viem: ^2.9.2 @@ -3857,6 +3893,7 @@ packages: acorn-import-assertions@1.9.0: resolution: {integrity: sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==} + deprecated: package has been renamed to acorn-import-attributes peerDependencies: acorn: ^8 @@ -11849,15 +11886,15 @@ snapshots: '@ensdomains/address-encoder@1.0.0-rc.3': dependencies: - '@noble/curves': 1.4.0 - '@noble/hashes': 1.4.0 - '@scure/base': 1.1.6 + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 '@ensdomains/address-encoder@1.1.1': dependencies: - '@noble/curves': 1.4.0 - '@noble/hashes': 1.4.0 - '@scure/base': 1.1.6 + '@noble/curves': 1.6.0 + '@noble/hashes': 1.5.0 + '@scure/base': 1.1.9 '@ensdomains/buffer@0.1.1': {} @@ -11869,12 +11906,12 @@ snapshots: '@ensdomains/content-hash@3.1.0-rc.1': dependencies: '@ensdomains/address-encoder': 1.0.0-rc.3 - '@noble/curves': 1.4.0 - '@scure/base': 1.1.6 + '@noble/curves': 1.6.0 + '@scure/base': 1.1.9 '@ensdomains/dnsprovejs@0.5.1': dependencies: - '@noble/hashes': 1.4.0 + '@noble/hashes': 1.5.0 dns-packet: 5.6.1 typescript-logging: 1.0.1 @@ -11924,13 +11961,13 @@ snapshots: - bufferutil - utf-8-validate - '@ensdomains/ensjs@4.0.2-alpha.5(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8)': + '@ensdomains/ensjs@4.0.2(encoding@0.1.13)(typescript@5.4.5)(viem@2.19.4(bufferutil@4.0.8)(typescript@5.4.5)(utf-8-validate@5.0.10)(zod@3.23.8))(zod@3.23.8)': dependencies: '@adraffy/ens-normalize': 1.10.1 '@ensdomains/address-encoder': 1.1.1 '@ensdomains/content-hash': 3.1.0-rc.1 '@ensdomains/dnsprovejs': 0.5.1 - abitype: 1.0.5(typescript@5.4.5)(zod@3.23.8) + abitype: 1.0.6(typescript@5.4.5)(zod@3.23.8) dns-packet: 5.6.1 graphql: 16.8.1 graphql-request: 6.1.0(encoding@0.1.13)(graphql@16.8.1) @@ -16791,7 +16828,7 @@ snapshots: dependencies: confusing-browser-globals: 1.0.11 eslint: 8.50.0 - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) object.assign: 4.1.5 object.entries: 1.1.8 semver: 6.3.1 @@ -16802,13 +16839,13 @@ snapshots: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-config-airbnb@19.0.4(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint-plugin-jsx-a11y@6.8.0(eslint@8.50.0))(eslint-plugin-react-hooks@4.6.2(eslint@8.50.0))(eslint-plugin-react@7.34.1(eslint@8.50.0))(eslint@8.50.0): dependencies: eslint: 8.50.0 eslint-config-airbnb-base: 15.0.0(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) @@ -16822,8 +16859,8 @@ snapshots: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) eslint-plugin-jsx-a11y: 6.8.0(eslint@8.50.0) eslint-plugin-react: 7.34.1(eslint@8.50.0) eslint-plugin-react-hooks: 4.6.2(eslint@8.50.0) @@ -16845,13 +16882,13 @@ snapshots: transitivePeerDependencies: - supports-color - eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0): + eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0): dependencies: debug: 4.3.4(supports-color@5.5.0) enhanced-resolve: 5.16.1 eslint: 8.50.0 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) - eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 is-core-module: 2.13.1 @@ -16862,18 +16899,18 @@ snapshots: - eslint-import-resolver-webpack - supports-color - eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0): + eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0): dependencies: debug: 3.2.7 optionalDependencies: '@typescript-eslint/parser': 6.21.0(eslint@8.50.0)(typescript@5.4.5) eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0) + eslint-import-resolver-typescript: 3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0) transitivePeerDependencies: - supports-color - eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0): + eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-typescript@3.6.1)(eslint@8.50.0): dependencies: array-includes: 3.1.8 array.prototype.findlastindex: 1.2.5 @@ -16883,7 +16920,7 @@ snapshots: doctrine: 2.1.0 eslint: 8.50.0 eslint-import-resolver-node: 0.3.9 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint@8.50.0))(eslint@8.50.0))(eslint@8.50.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@6.21.0(eslint@8.50.0)(typescript@5.4.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.50.0))(eslint@8.50.0) hasown: 2.0.2 is-core-module: 2.13.1 is-glob: 4.0.3 From 83f469eb9e05000be4a0ab25a66b6208054036dd Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 11 Nov 2024 00:30:28 +0700 Subject: [PATCH 64/75] Update resolverAddressData.ts --- src/constants/resolverAddressData.ts | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/src/constants/resolverAddressData.ts b/src/constants/resolverAddressData.ts index 76545ef89..6b8d6da62 100644 --- a/src/constants/resolverAddressData.ts +++ b/src/constants/resolverAddressData.ts @@ -318,6 +318,23 @@ export const KNOWN_RESOLVER_DATA: KnownResolverData = { RESOLVER_INTERFACE_IDS.VersionableResolver, ], }, + { + address: '0x8FADE66B79cC9f707aB26799354482EB93a5B7dD', + deployer: 'ENS Labs', + tag: null, + isNameWrapperAware: true, + supportedInterfaces: [ + RESOLVER_INTERFACE_IDS.AddressResolver, + RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, + RESOLVER_INTERFACE_IDS.NameResolver, + RESOLVER_INTERFACE_IDS.AbiResolver, + RESOLVER_INTERFACE_IDS.TextResolver, + RESOLVER_INTERFACE_IDS.ContentHashResolver, + RESOLVER_INTERFACE_IDS.DnsRecordResolver, + RESOLVER_INTERFACE_IDS.InterfaceResolver, + RESOLVER_INTERFACE_IDS.VersionableResolver, + ], + }, { address: '0x0CeEC524b2807841739D3B5E161F5bf1430FFA48', deployer: 'ENS Labs', From 634cd294efcd4688a058a71155a33176a4e012d0 Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 11 Nov 2024 00:39:45 +0700 Subject: [PATCH 65/75] Update resolverAddressData.ts --- src/constants/resolverAddressData.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/constants/resolverAddressData.ts b/src/constants/resolverAddressData.ts index 6b8d6da62..70b710b82 100644 --- a/src/constants/resolverAddressData.ts +++ b/src/constants/resolverAddressData.ts @@ -302,7 +302,7 @@ export const KNOWN_RESOLVER_DATA: KnownResolverData = { ], '11155111': [ { - address: '0x8FADE66B79cC9f707aB26799354482EB93a5B7dD', + address: '0x8948458626811dd0c23EB25Cc74291247077cC51', deployer: 'ENS Labs', tag: 'latest', isNameWrapperAware: true, From 9de73df715903f7a3dd34b97e3ed43080159cd20 Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Thu, 21 Nov 2024 17:00:38 +0800 Subject: [PATCH 66/75] Add namechain announcement --- src/pages/ens-v2.tsx | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index 3e1a7c50f..420686028 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -41,7 +41,7 @@ const Header = styled.header( justify-content: center; gap: ${theme.space[4]}; padding: ${theme.space[4]}; - min-height: 330px; + padding-top: ${theme.space[16]}; text-align: center; `, ) @@ -239,11 +239,10 @@ const SlideshowContainer = styled.div( `, ) -const Video = styled.video( +const YoutubeEmbed = styled.iframe( ({ theme }) => css` - height: ${theme.space.full}; + aspect-ratio: 16 / 9; width: ${theme.space.full}; - border-radius: ${theme.radii.card}; `, ) @@ -263,9 +262,14 @@ export default function ENSv2() { {t('title')} {t('caption')} - + {t('learn-more.title')} From 1df6db6154eda22b61be2890a0e7b0d9b7da7574 Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Thu, 21 Nov 2024 17:22:02 +0800 Subject: [PATCH 67/75] build fix --- knip.config.ts | 2 ++ src/pages/ens-v2.tsx | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/knip.config.ts b/knip.config.ts index edc38490a..ece2f9479 100644 --- a/knip.config.ts +++ b/knip.config.ts @@ -24,6 +24,8 @@ const config: KnipConfig = { 'src/utils/query/match/matchExactOrNullParamItem.test-d.ts', 'src/utils/query/match/matchQueryKeyMeta.test-d.ts', 'src/utils/query/match/queryKeyToInternalParams.test-d.ts', + // Will need later + 'src/components/pages/migrate/Carousel.tsx', ], } diff --git a/src/pages/ens-v2.tsx b/src/pages/ens-v2.tsx index 420686028..19cbde148 100644 --- a/src/pages/ens-v2.tsx +++ b/src/pages/ens-v2.tsx @@ -268,7 +268,7 @@ export default function ENSv2() { frameBorder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" referrerPolicy="strict-origin-when-cross-origin" - allowfullscreen + allowFullScreen /> From df0b00765f78814b30df269438286478354a07ed Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Thu, 28 Nov 2024 18:05:25 +0800 Subject: [PATCH 68/75] Add dRPC endpoint --- .github/workflows/pages-deployment.yaml | 1 + src/utils/query/wagmi.ts | 17 ++++++++++------- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/.github/workflows/pages-deployment.yaml b/.github/workflows/pages-deployment.yaml index 6aea45954..2a957ae8a 100644 --- a/.github/workflows/pages-deployment.yaml +++ b/.github/workflows/pages-deployment.yaml @@ -3,6 +3,7 @@ name: Cloudflare Pages env: SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} NEXT_PUBLIC_INTERCOM_ID: re9q5yti + NEXT_PUBLIC_DRPC_KEY: AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR on: [push] jobs: diff --git a/src/utils/query/wagmi.ts b/src/utils/query/wagmi.ts index 4799fefbc..0794e847b 100644 --- a/src/utils/query/wagmi.ts +++ b/src/utils/query/wagmi.ts @@ -1,6 +1,6 @@ import { createClient, type FallbackTransport, type HttpTransport, type Transport } from 'viem' import { createConfig, createStorage, fallback, http } from 'wagmi' -import { goerli, holesky, localhost, mainnet, sepolia } from 'wagmi/chains' +import { holesky, localhost, mainnet, sepolia } from 'wagmi/chains' import { ccipRequest } from '@ensdomains/ensjs/utils' @@ -24,12 +24,16 @@ const connectors = getDefaultWallets({ const infuraKey = process.env.NEXT_PUBLIC_INFURA_KEY || 'cfa6ae2501cc4354a74e20432507317c' const tenderlyKey = process.env.NEXT_PUBLIC_TENDERLY_KEY || '4imxc4hQfRjxrVB2kWKvTo' +const drpcKey = process.env.NEXT_PUBLIC_DRPC_KEY || 'AnmpasF2C0JBqeAEzxVO8aRuvzLTrWcR75hmDonbV6cR' export const infuraUrl = (chainName: string) => `https://${chainName}.infura.io/v3/${infuraKey}` -const cloudflareUrl = (chainName: string) => `https://web3.ens.domains/v1/${chainName}` const tenderlyUrl = (chainName: string) => `https://${chainName}.gateway.tenderly.co/${tenderlyKey}` +const drpcUrl = (chainName: string) => + `https://lb.drpc.org/ogrpc?network=${ + chainName === 'mainnet' ? 'ethereum' : chainName + }&dkey=${drpcKey}` -type SupportedUrlFunc = typeof infuraUrl | typeof cloudflareUrl | typeof tenderlyUrl +type SupportedUrlFunc = typeof infuraUrl | typeof dRPCUrl | typeof tenderlyUrl const initialiseTransports = ( chainName: string, @@ -97,10 +101,9 @@ const transports = { // this is a hack to make the types happy, dont remove pls [localhost.id]: HttpTransport })), - [mainnet.id]: initialiseTransports('mainnet', [infuraUrl, cloudflareUrl, tenderlyUrl]), - [sepolia.id]: initialiseTransports('sepolia', [infuraUrl, cloudflareUrl, tenderlyUrl]), - [goerli.id]: initialiseTransports('goerli', [infuraUrl, cloudflareUrl, tenderlyUrl]), - [holesky.id]: initialiseTransports('holesky', [tenderlyUrl]), + [mainnet.id]: initialiseTransports('mainnet', [drpcUrl, infuraUrl, tenderlyUrl]), + [sepolia.id]: initialiseTransports('sepolia', [drpcUrl, infuraUrl, tenderlyUrl]), + [holesky.id]: initialiseTransports('holesky', [drpcUrl, tenderlyUrl]), } as const const wagmiConfig_ = createConfig({ From 4601acb9c8a66c9444407429cc157a50287e2993 Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Thu, 28 Nov 2024 18:17:20 +0800 Subject: [PATCH 69/75] Remove goerli properly --- .../pages/profile/[name]/registration/Registration.tsx | 5 ----- src/constants/chains.ts | 5 +---- src/hooks/useEthPrice.ts | 9 ++------- src/utils/query/wagmi.ts | 4 +--- 4 files changed, 4 insertions(+), 19 deletions(-) diff --git a/src/components/pages/profile/[name]/registration/Registration.tsx b/src/components/pages/profile/[name]/registration/Registration.tsx index 48ce3df24..3294b044d 100644 --- a/src/components/pages/profile/[name]/registration/Registration.tsx +++ b/src/components/pages/profile/[name]/registration/Registration.tsx @@ -359,11 +359,6 @@ const Registration = ({ nameDetails, isLoading }: Props) => { {t('steps.info.moonpayModalHeader')} - {chainId === 5 && ( - - {`${t('steps.info.moonpayTestCard')}: 4000 0209 5159 5032, 12/2030, 123`} - - )} export type SupportedChain = | typeof mainnetWithEns - | typeof goerliWithEns | typeof sepoliaWithEns | typeof holeskyWithEns | typeof localhostWithEns diff --git a/src/hooks/useEthPrice.ts b/src/hooks/useEthPrice.ts index 4fd8cef70..1861ed2a2 100644 --- a/src/hooks/useEthPrice.ts +++ b/src/hooks/useEthPrice.ts @@ -1,21 +1,16 @@ import { Address } from 'viem' -import { useChainId, useReadContract } from 'wagmi' -import { goerli } from 'wagmi/chains' +import { useReadContract } from 'wagmi' import { useAddressRecord } from './ensjs/public/useAddressRecord' const ORACLE_ENS = 'eth-usd.data.eth' -const ORACLE_GOERLI = '0xD4a33860578De61DBAbDc8BFdb98FD742fA7028e' as const export const useEthPrice = () => { - const chainId = useChainId() - const { data: address_ } = useAddressRecord({ name: ORACLE_ENS, - enabled: chainId !== goerli.id, }) - const address = chainId === 5 ? ORACLE_GOERLI : (address_?.value as Address) || undefined + const address = (address_?.value as Address) || undefined return useReadContract({ abi: [ diff --git a/src/utils/query/wagmi.ts b/src/utils/query/wagmi.ts index 0794e847b..31e44228f 100644 --- a/src/utils/query/wagmi.ts +++ b/src/utils/query/wagmi.ts @@ -5,7 +5,6 @@ import { holesky, localhost, mainnet, sepolia } from 'wagmi/chains' import { ccipRequest } from '@ensdomains/ensjs/utils' import { - goerliWithEns, holeskyWithEns, localhostWithEns, mainnetWithEns, @@ -33,7 +32,7 @@ const drpcUrl = (chainName: string) => chainName === 'mainnet' ? 'ethereum' : chainName }&dkey=${drpcKey}` -type SupportedUrlFunc = typeof infuraUrl | typeof dRPCUrl | typeof tenderlyUrl +type SupportedUrlFunc = typeof infuraUrl | typeof drpcUrl | typeof tenderlyUrl const initialiseTransports = ( chainName: string, @@ -87,7 +86,6 @@ const localStorageWithInvertMiddleware = (): Storage | undefined => { const chains = [ ...(isLocalProvider ? ([localhostWithEns] as const) : ([] as const)), mainnetWithEns, - goerliWithEns, sepoliaWithEns, holeskyWithEns, ] as const From ccb7c17676a061fbb547257dcc51b70eb8472b32 Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Thu, 28 Nov 2024 18:33:06 +0800 Subject: [PATCH 70/75] Fix test --- src/constants/resolverAddressData.test.ts | 7 +- src/constants/resolverAddressData.ts | 177 ---------------------- 2 files changed, 2 insertions(+), 182 deletions(-) diff --git a/src/constants/resolverAddressData.test.ts b/src/constants/resolverAddressData.test.ts index 4e9b21134..085912d78 100644 --- a/src/constants/resolverAddressData.test.ts +++ b/src/constants/resolverAddressData.test.ts @@ -1,7 +1,7 @@ import { getChainContractAddress } from 'viem/utils' -import { describe, expect, it } from 'vitest' +import { expect, it } from 'vitest' -import { goerliWithEns, localhostWithEns, mainnetWithEns, sepoliaWithEns } from './chains' +import { mainnetWithEns, sepoliaWithEns } from './chains' ;(process.env as any).NODE_ENV = 'development' @@ -12,9 +12,6 @@ it('should have the most recent resolver as the first address', async () => { expect(KNOWN_RESOLVER_DATA['1']![0].address).toEqual( getChainContractAddress({ chain: mainnetWithEns, contract: 'ensPublicResolver' }), ) - expect(KNOWN_RESOLVER_DATA['5']![0].address).toEqual( - getChainContractAddress({ chain: goerliWithEns, contract: 'ensPublicResolver' }), - ) expect(KNOWN_RESOLVER_DATA['11155111']![0].address).toEqual( getChainContractAddress({ chain: sepoliaWithEns, contract: 'ensPublicResolver' }), ) diff --git a/src/constants/resolverAddressData.ts b/src/constants/resolverAddressData.ts index 70b710b82..eecb73d9d 100644 --- a/src/constants/resolverAddressData.ts +++ b/src/constants/resolverAddressData.ts @@ -123,183 +123,6 @@ export const KNOWN_RESOLVER_DATA: KnownResolverData = { ], }, ], - '5': [ - { - address: '0xd7a4F6473f32aC2Af804B3686AE8F1932bC35750', - deployer: 'ENS Labs', - tag: 'latest', - isNameWrapperAware: true, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - RESOLVER_INTERFACE_IDS.VersionableResolver, - ], - }, - { - address: '0x342cf18D3e41DE491aa1a3067574C849AdA6a2Ad', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - RESOLVER_INTERFACE_IDS.VersionableResolver, - ], - }, - { - address: '0x19c2d5D0f035563344dBB7bE5fD09c8dad62b001', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - RESOLVER_INTERFACE_IDS.VersionableResolver, - ], - }, - { - address: '0x2800Ec5BAB9CE9226d19E0ad5BC607e3cfC4347E', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - RESOLVER_INTERFACE_IDS.VersionableResolver, - ], - }, - { - address: '0x121304143ea8101E69335F309e2062d299A234B5', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - ], - }, - { - address: '0x4B1488B7a6B320d2D721406204aBc3eeAa9AD329', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - ], - }, - { - address: '0xfF77b96d6bafCec0D684bB528b22e0Ab09C70663', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - ], - }, - { - address: '0x6e1b40ed2d626b97A43d2c12e48a6De49A03c7A4', - deployer: 'ENS Labs', - tag: null, - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - ], - }, - { - address: '0xc1EA41786094D1fBE5aded033B5370d51F7a3F96', - deployer: 'ENS Labs', - tag: 'outdated', - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - ], - }, - { - address: '0xBbe3fD189D18C8b73BA54e9dD01F89E6b3Ee71f0', - deployer: 'ENS Labs', - tag: 'outdated', - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - ], - }, - { - address: '0x4B1488B7a6B320d2D721406204aBc3eeAa9AD329', - deployer: 'ENS Labs', - tag: 'outdated', - isNameWrapperAware: false, - supportedInterfaces: [ - RESOLVER_INTERFACE_IDS.AddressResolver, - RESOLVER_INTERFACE_IDS.NameResolver, - RESOLVER_INTERFACE_IDS.AbiResolver, - RESOLVER_INTERFACE_IDS.TextResolver, - RESOLVER_INTERFACE_IDS.ContentHashResolver, - RESOLVER_INTERFACE_IDS.DnsRecordResolver, - RESOLVER_INTERFACE_IDS.InterfaceResolver, - RESOLVER_INTERFACE_IDS.MultiCoinAddressResolver, - ], - }, - ], '11155111': [ { address: '0x8948458626811dd0c23EB25Cc74291247077cC51', From 97c347129f7faac23d5a7aa04a2d4b3b998d65da Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Thu, 28 Nov 2024 19:01:08 +0800 Subject: [PATCH 71/75] Only use paid endpoint in prod --- .github/workflows/pages-deployment.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pages-deployment.yaml b/.github/workflows/pages-deployment.yaml index 2a957ae8a..f92265db5 100644 --- a/.github/workflows/pages-deployment.yaml +++ b/.github/workflows/pages-deployment.yaml @@ -3,7 +3,7 @@ name: Cloudflare Pages env: SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} NEXT_PUBLIC_INTERCOM_ID: re9q5yti - NEXT_PUBLIC_DRPC_KEY: AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR + NEXT_PUBLIC_DRPC_KEY: ${{ github.ref == 'refs/heads/main' && AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR || '' }} on: [push] jobs: From fc5d16a8f8f8f14aa23c5e36922de945fd26fad1 Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Fri, 29 Nov 2024 15:08:43 +0800 Subject: [PATCH 72/75] yaml fix --- .github/workflows/pages-deployment.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pages-deployment.yaml b/.github/workflows/pages-deployment.yaml index f92265db5..9b01895cd 100644 --- a/.github/workflows/pages-deployment.yaml +++ b/.github/workflows/pages-deployment.yaml @@ -3,7 +3,7 @@ name: Cloudflare Pages env: SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} NEXT_PUBLIC_INTERCOM_ID: re9q5yti - NEXT_PUBLIC_DRPC_KEY: ${{ github.ref == 'refs/heads/main' && AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR || '' }} + NEXT_PUBLIC_DRPC_KEY: ${{ github.ref == 'refs/heads/main' && 'AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR' || '' }} on: [push] jobs: From 0a28d4f531e8bc5f7e93d69e34ef02883672e142 Mon Sep 17 00:00:00 2001 From: Leon Talbert Date: Fri, 29 Nov 2024 15:19:12 +0800 Subject: [PATCH 73/75] Key should work on staging now --- .github/workflows/pages-deployment.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/pages-deployment.yaml b/.github/workflows/pages-deployment.yaml index 9b01895cd..2a957ae8a 100644 --- a/.github/workflows/pages-deployment.yaml +++ b/.github/workflows/pages-deployment.yaml @@ -3,7 +3,7 @@ name: Cloudflare Pages env: SENTRY_AUTH_TOKEN: ${{ secrets.SENTRY_AUTH_TOKEN }} NEXT_PUBLIC_INTERCOM_ID: re9q5yti - NEXT_PUBLIC_DRPC_KEY: ${{ github.ref == 'refs/heads/main' && 'AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR' || '' }} + NEXT_PUBLIC_DRPC_KEY: AnmpasF2C0JBqeAEzxVO8aTteiMlrW4R75hpDonbV6cR on: [push] jobs: From da16a7169cdf50e244f0d5af3db701013c8a045b Mon Sep 17 00:00:00 2001 From: v1rtl Date: Sat, 30 Nov 2024 03:53:46 +0200 Subject: [PATCH 74/75] rerun socket --- package.json | 4 + pnpm-lock.yaml | 349 ++++--------------------------------------------- 2 files changed, 28 insertions(+), 325 deletions(-) diff --git a/package.json b/package.json index 328e491e8..924500452 100644 --- a/package.json +++ b/package.json @@ -198,6 +198,8 @@ "array.prototype.findlastindex": "npm:@socketregistry/array.prototype.findlastindex@^1", "array.prototype.flat": "npm:@socketregistry/array.prototype.flat@^1", "array.prototype.flatmap": "npm:@socketregistry/array.prototype.flatmap@^1", + "array.prototype.toreversed": "npm:@socketregistry/array.prototype.toreversed@^1", + "array.prototype.tosorted": "npm:@socketregistry/array.prototype.tosorted@^1", "arraybuffer.prototype.slice": "npm:@socketregistry/arraybuffer.prototype.slice@^1", "available-typed-arrays": "npm:@socketregistry/available-typed-arrays@^1", "bn.js": "npm:bn.js@^5.2.0", @@ -205,6 +207,7 @@ "define-properties": "npm:@socketregistry/define-properties@^1", "es-define-property": "npm:@socketregistry/es-define-property@^1", "es-get-iterator": "npm:@socketregistry/es-get-iterator@^1", + "es-iterator-helpers": "npm:@socketregistry/es-iterator-helpers@^1", "es-set-tostringtag": "npm:@socketregistry/es-set-tostringtag@^1", "es6-symbol": "npm:@socketregistry/es6-symbol@^1", "for-each": "npm:@socketregistry/for-each@^1", @@ -249,6 +252,7 @@ "object.assign": "npm:@socketregistry/object.assign@^1", "object.entries": "npm:@socketregistry/object.entries@^1", "object.fromentries": "npm:@socketregistry/object.fromentries@^1", + "object.groupby": "npm:@socketregistry/object.groupby@^1", "object.hasown": "npm:@socketregistry/object.hasown@^1", "object.values": "npm:@socketregistry/object.values@^1", "path-parse": "npm:@socketregistry/path-parse@^1", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 318e9d40a..f5bc20d3f 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -17,6 +17,8 @@ overrides: array.prototype.findlastindex: npm:@socketregistry/array.prototype.findlastindex@^1 array.prototype.flat: npm:@socketregistry/array.prototype.flat@^1 array.prototype.flatmap: npm:@socketregistry/array.prototype.flatmap@^1 + array.prototype.toreversed: npm:@socketregistry/array.prototype.toreversed@^1 + array.prototype.tosorted: npm:@socketregistry/array.prototype.tosorted@^1 arraybuffer.prototype.slice: npm:@socketregistry/arraybuffer.prototype.slice@^1 available-typed-arrays: npm:@socketregistry/available-typed-arrays@^1 bn.js: npm:bn.js@^5.2.0 @@ -24,6 +26,7 @@ overrides: define-properties: npm:@socketregistry/define-properties@^1 es-define-property: npm:@socketregistry/es-define-property@^1 es-get-iterator: npm:@socketregistry/es-get-iterator@^1 + es-iterator-helpers: npm:@socketregistry/es-iterator-helpers@^1 es-set-tostringtag: npm:@socketregistry/es-set-tostringtag@^1 es6-symbol: npm:@socketregistry/es6-symbol@^1 for-each: npm:@socketregistry/for-each@^1 @@ -68,6 +71,7 @@ overrides: object.assign: npm:@socketregistry/object.assign@^1 object.entries: npm:@socketregistry/object.entries@^1 object.fromentries: npm:@socketregistry/object.fromentries@^1 + object.groupby: npm:@socketregistry/object.groupby@^1 object.hasown: npm:@socketregistry/object.hasown@^1 object.values: npm:@socketregistry/object.values@^1 path-parse: npm:@socketregistry/path-parse@^1 @@ -3061,22 +3065,18 @@ packages: resolution: {integrity: sha512-grBCFWhMLGA8SUfI0rUjBzECcT4SPkKkSdjIzaAWRGqo1lF7AKL1Y9U3bL4bhr89vatgrisQ3YfuUQWG8x9Eyg==} engines: {node: '>=18.20.4'} - '@socketregistry/arraybuffer.prototype.slice@1.0.5': - resolution: {integrity: sha512-Bu0p9gZKkPUhnZttJ3CYMSSO3yzP5xanQ9mHtu80+ETHU5z5FqiKa6gYHxkQgb7T/LyBfGGoUmMrKGvKhxiT/w==} + '@socketregistry/array.prototype.toreversed@1.0.5': + resolution: {integrity: sha512-cWaQUBNeQfBSE8C16nbqh4vKJ6WM/WMP9U3p++32mN26Bmrlq0BDJfs8P2Hl7nvBlm1D7c/eFZZWUfNmOdMFxw==} engines: {node: '>=18.20.4'} - '@socketregistry/available-typed-arrays@1.0.5': - resolution: {integrity: sha512-PJmQqWZ3Sf+Et7akfhcD5h1+RyLbsnclwNaHjwVkQQT85DJXRM+V4/e7n/wr+xqtRMOEpMWTTyhubR9VzCGSew==} + '@socketregistry/array.prototype.tosorted@1.0.5': + resolution: {integrity: sha512-cfmeRNb4bVNL6+awnfSIDkyU0HUO71QL2euaCvnFXYikcdaB+ZOpCR4jINIP2dF11RRoWgJVHG/NkjIV8YWvyA==} engines: {node: '>=18.20.4'} '@socketregistry/deep-equal@1.0.6': resolution: {integrity: sha512-EqrNjTReRmb9jQKhceqjGaRP3tBetnuI+p8QAXoUvW+HErjRnSf7fjDXFAYTzy2rI9DKUMaK8bU8iubV6HhNfg==} engines: {node: '>=18.20.4'} - '@socketregistry/define-properties@1.0.5': - resolution: {integrity: sha512-IMB5rE7tgw7+TbIz/2NGcZj9NeXNxisXWCxzjElklmSo1vuB536FLQjkXZ7Xbd8DVEXOiR9Lg4Hx+AJ1bUmeFw==} - engines: {node: '>=18.20.4'} - '@socketregistry/es-define-property@1.0.5': resolution: {integrity: sha512-zipl+Zs/75Fjt7vE3RqbbDNfdIFsvsmd2wLmwoxI1Z/ID28j5dp7ZzaMesQAQqK+zv24a4WTywQVg7f35E3rcw==} engines: {node: '>=18.20.4'} @@ -3085,8 +3085,8 @@ packages: resolution: {integrity: sha512-rYAhVok1NWHOD067z4yLYFmsph9X2SP2mEOUbE4zrLSu6xHdmscgsUXTQlv/+9Ns+ShfFe3UufdnuKnwuZT0pA==} engines: {node: '>=18.20.4'} - '@socketregistry/es-set-tostringtag@1.0.5': - resolution: {integrity: sha512-gK/N4x9ScZRTQGF6aIzhBWedQuD7jOEvNxozXQFdB9sOCtgHtHCle0nD3PQ7TsKXQd33RYBECqOpk4POrVSHWQ==} + '@socketregistry/es-iterator-helpers@1.0.7': + resolution: {integrity: sha512-8aVI4HRtdVhdiIL9PG2P9hitf6SMdg5eH/2Q98iBgLB1HgPA7jNSoQm4GKDoFQBynyt4h3Rm3IVk7p1HqT0X2w==} engines: {node: '>=18.20.4'} '@socketregistry/es6-symbol@1.0.5': @@ -3097,26 +3097,6 @@ packages: resolution: {integrity: sha512-G7Z7yVdwQmO5FzNFqdPp8ZvLm9zk5lq7t3r+2IOzBcQVx/qgjYuYPo0fE+kzvQ7u5ApMret2wDnKbCfp4cqnjg==} engines: {node: '>=18.20.4'} - '@socketregistry/function.prototype.name@1.0.5': - resolution: {integrity: sha512-SoeiaypJYCiJju2eGH0EvW35u2yeuKJ/ll5ScmPR+cYTNEQYnlGPVnsDYIOQ/G/Zq5lvQRhmA6iCShUFskkWcw==} - engines: {node: '>=18.20.4'} - - '@socketregistry/get-symbol-description@1.0.5': - resolution: {integrity: sha512-G5ceeq3MgKe1/HZL5vc6u/0mSWIdMzce7DHrj8Iw7llEakt5wTksvJ9lhSOBNfpDfnfBrN9EtLLY0RMFNHbpIw==} - engines: {node: '>=18.20.4'} - - '@socketregistry/globalthis@1.0.5': - resolution: {integrity: sha512-RY/OxMUrhuU9LO9To76SKwUz4mcdaSwG3rh/lpFN4azdL21XYxhAQ/hS5U+dZVI0ZVAk9AZWsciN8Djsz6LqeA==} - engines: {node: '>=18.20.4'} - - '@socketregistry/gopd@1.0.5': - resolution: {integrity: sha512-lJKgypzRLEAonbhl+qk5WH/ILyZipz+8cGcgBjMdNGk5KJdxI+ixLwEpNlEAR5iiR0oOf3DqAcM2ZzuMBjK8ng==} - engines: {node: '>=18.20.4'} - - '@socketregistry/has-property-descriptors@1.0.5': - resolution: {integrity: sha512-teGemiZKx3HI1fyCowXYsNhrDPoB45LktCH3BYWrzlvsEL3rT2iTFSc6JPJ4YuLtft1QRkiv/V/8bdGa3qX5Vw==} - engines: {node: '>=18.20.4'} - '@socketregistry/has-proto@1.0.5': resolution: {integrity: sha512-z1tmi3xBR/DY40I4Zw8eHCCekWa3OoM7VHeXgSas11vLYPPGstHRMivDOlLzTrggHrLVnbQ25Xpf43TEdM6n0Q==} engines: {node: '>=18.20.4'} @@ -3133,10 +3113,6 @@ packages: resolution: {integrity: sha512-WdAA0PW4h/sIIciGPby09LHaq+a9c7S+wZIn/YvhWdqC0GJGvzfiVSqQFSLuk1+NDvnhSVd64w/6MXjjuRs+mg==} engines: {node: '>=18.20.4'} - '@socketregistry/internal-slot@1.0.5': - resolution: {integrity: sha512-Xv3M3epptcSCwwRIKHHbLdl9FlQA6qoAnW1Cm5JNBxyLdGs6B5nF/dmhHjf+82BFJEoTAsIGwchMvtNNuJFFGg==} - engines: {node: '>=18.20.4'} - '@socketregistry/is-arguments@1.0.5': resolution: {integrity: sha512-Iozv0wGyOJdNwaidhIMX556q1fzPVBjv6MJb3B3UBRcMhogRiM09zfYngDLslSsp6aHRpqb8mBGf0v+Huet2/w==} engines: {node: '>=18.20.4'} @@ -3157,10 +3133,6 @@ packages: resolution: {integrity: sha512-70FLcIfYK/Z6C4cE/1cGw15OBb6NboJ3NmjtFnLmuRVA6sBW8+z8Gl/ikrv91OncNrm95yMJMS0qSJQ4rEIgmA==} engines: {node: '>=18.20.4'} - '@socketregistry/is-negative-zero@1.0.5': - resolution: {integrity: sha512-52LHLZ7I0NAHwsM3Mae09Y5YjCY6GvssbBgs90lCHemwRubzQLYbAoAae/fFlskvQciTx2S7Pm7MmidDOBoIkg==} - engines: {node: '>=18.20.4'} - '@socketregistry/is-regex@1.0.5': resolution: {integrity: sha512-UplgtvnvnL7lCZWwdi5mdnc3jbyMP8LBOpm+xHpCBGMJzFUl342PENahlVtkgExnueXs21FQbjeBxQeQVfpDvQ==} engines: {node: '>=18.20.4'} @@ -3169,30 +3141,14 @@ packages: resolution: {integrity: sha512-duEc4U1Fs9E1yjMdPCwFBlGFtSPSLSUSsT7JnDD7PXdUfF4Iz1u2I3NdnFD8wzhXJr4e42a+y9eTW8ZyRyE1sA==} engines: {node: '>=18.20.4'} - '@socketregistry/is-string@1.0.5': - resolution: {integrity: sha512-5hrKja9bIiWuZorvg/vUWd8M1VgYukS17MGUY++RJCK754xKsKDyTUog0L8Q/6RP7N4RX1nmdqZlCK1pr1UBXg==} - engines: {node: '>=18.20.4'} - - '@socketregistry/is-symbol@1.0.5': - resolution: {integrity: sha512-xLPZY0EI6vFVUpiuAiUAaNl4vxiarm70zESoDyarUW5B5qnnqVoCtevtu42EW3ydwHB6xQdTrfKIKAO3ioaF9g==} - engines: {node: '>=18.20.4'} - '@socketregistry/is-typed-array@1.0.5': resolution: {integrity: sha512-HF+CXkeLtPjGSF1p1ML7pj2eaKCCyvn+c2aYLZLHRgojGNlfNdovVilogDVaZgoUVhbFjioONWLGTLfcXH3R5w==} engines: {node: '>=18.20.4'} - '@socketregistry/is-weakref@1.0.5': - resolution: {integrity: sha512-i+diJaTYee1q6RfTzrc9jnV/nM0lqSmi6QL04+ulZ3wjp0FmyIUUir+pJb5lEj/7N9BhQ9TTq56UL3/hBEE8VQ==} - engines: {node: '>=18.20.4'} - '@socketregistry/isarray@1.0.5': resolution: {integrity: sha512-ShtX9jbnTiEl2sXAjCS02ihrjiEStKleX4NgOxUu977jX/PRSS7sGuM2ssN3vCeuzmLphzeCeIXExxR5dcw8bA==} engines: {node: '>=18.20.4'} - '@socketregistry/iterator.prototype@1.0.5': - resolution: {integrity: sha512-avT0WCCVMFI+74w64e5an5HSLBYFErcIK4EnAsuRRgn4FCVdwxasIvgFFQnmpmtsEnzTRUYMySQmi3gbYr9ifg==} - engines: {node: '>=18.20.4'} - '@socketregistry/number-is-nan@1.0.7': resolution: {integrity: sha512-6BfZedewiaCERKrv/Jfi7++nyWYTKarzoY0Gq+8QsQMmDvZod6pB5Ku8cBniGCB1H8BkvnZQIWESa1kb8mJtJA==} engines: {node: '>=18.20.4'} @@ -3221,6 +3177,10 @@ packages: resolution: {integrity: sha512-yA35Gkn9cbUyMI4FqEoBqqJCo/dUDY6w6j520WjLitv7nPnQ3KDUzMhprl33N7DTKxq8sYCKNGm/xi0nceb1rA==} engines: {node: '>=18.20.4'} + '@socketregistry/object.groupby@1.0.5': + resolution: {integrity: sha512-AbUaYRNfT5UKA/1TjA2ZD6l6BQFqbwSXBwxEtWpTun7sU97FRPPgKBb5Y0/dyZcVrx7Pw/ygt4I0CEQBjkAmYg==} + engines: {node: '>=18.20.4'} + '@socketregistry/object.hasown@1.0.5': resolution: {integrity: sha512-xleWdNU2JPocl5MrkxlS1euDK3xqpzTy0GDsJHmUhWX9R8MpowYa5gSPqASWnLQHN6bNiXyotEixowJdnzm/sA==} engines: {node: '>=18.20.4'} @@ -3241,18 +3201,10 @@ packages: resolution: {integrity: sha512-N8O5vDqix1PLAmJwnvbZzHCzD+912YzKm0YzB6+7GZCp7uL3yagY/aK9sR2Dsk2ASUC+BR1F+ZILbAMvRcsP0Q==} engines: {node: '>=18.20.4'} - '@socketregistry/safe-array-concat@1.0.5': - resolution: {integrity: sha512-cGbuGDw5S3sHnFC5jDQVOoayEqyPT68wTICM6flA/y7woSkjw+ReJ985s57tOZy0isz6HiOOAtX7oveg0gJJWw==} - engines: {node: '>=18.20.4'} - '@socketregistry/safe-buffer@1.0.5': resolution: {integrity: sha512-wOsct2TbdGKvXHRJGKgwWLvs4HqVCVJ/8/saHxjnbR/6uIdb/XYGJcwb+P61SRrW5695bAsIrYFJZbyhTsqLLQ==} engines: {node: '>=18.20.4'} - '@socketregistry/safe-regex-test@1.0.5': - resolution: {integrity: sha512-Kgl0XZQLtsEqEOI8SiKPkzwJ6/ZnQniWVtt4hlm+YregIdRz8glqqC152xbPJIKJHYrN5ybr8W3hZN7wgsdnIQ==} - engines: {node: '>=18.20.4'} - '@socketregistry/safer-buffer@1.0.5': resolution: {integrity: sha512-x6W5FZJwngd3UqOA0TXucXuD/RdGm4NHvnDYC2topSlfyA2vtTff9lcXpuQqzi/TxxlHEfYc0toRA+VDQSdfxw==} engines: {node: '>=18.20.4'} @@ -3269,38 +3221,6 @@ packages: resolution: {integrity: sha512-C0QWN2w8elid6VuIAcU3+fFaNZg6RHPfe8/8C6XukV3d0ZQU2I6za8afb2nOQq3Pknx3F/N+xZXJUPHvucGgLw==} engines: {node: '>=18.20.4'} - '@socketregistry/string.prototype.trim@1.0.5': - resolution: {integrity: sha512-rwXRZVkl7bn1hkMdK3VHuj3VYKsyJi8APB6HCjAZ3M+1fVLIBpYmOIZxkr8fMC0kJmBVRV5u7O+DMW9ZcPSpnQ==} - engines: {node: '>=18.20.4'} - - '@socketregistry/string.prototype.trimend@1.0.5': - resolution: {integrity: sha512-cbyNEn8sqHz5VMVgeD6lqFEFeiwy8p66jmWr+sv2V0P3fnJK++pyshv6xcsQvjcxsnrUtXm2KBH6yqEiu4oDrA==} - engines: {node: '>=18.20.4'} - - '@socketregistry/string.prototype.trimstart@1.0.5': - resolution: {integrity: sha512-i8Qz5uvdmzSrgOm7fo27wMhiQy5fNMvj0jcW0GZIyybuVyhzDhlm9T2DofxzZwA0OTs3erSBP9elYlzN0O4AdA==} - engines: {node: '>=18.20.4'} - - '@socketregistry/typed-array-buffer@1.0.5': - resolution: {integrity: sha512-UuSwBGTCkFH3prraPnJrhaNsSLY8giXbsQMLMGcz8eCyNBkUg/C73p7tzMKmlk55mtS7BpCBU/O48ogTU1QvhQ==} - engines: {node: '>=18.20.4'} - - '@socketregistry/typed-array-byte-length@1.0.5': - resolution: {integrity: sha512-+fKTzUzOMM+G7yw5ApIq3KpsFbymqzRSVATeRpJhveiXGNuSy/y46HGQ478DHB3r7RQ6h8PT/J83jEyufSaR/Q==} - engines: {node: '>=18.20.4'} - - '@socketregistry/typed-array-byte-offset@1.0.5': - resolution: {integrity: sha512-gqNiJ6KyFIsrrbHPPpmoW98QqdHjdwyHjHjfA5aqlWMD9pD+U337m8fAuyUmqwCBVlVsrpDTS9Kk5FmdzaIVLQ==} - engines: {node: '>=18.20.4'} - - '@socketregistry/typed-array-length@1.0.5': - resolution: {integrity: sha512-1BbchbBzZWeT9XKpus2H573eeBHtwI8ABd9AsKEh0gT+FPQD5Wx3vTvh3JUxxtCIJas2o8k6tH82xXN6TFQj7Q==} - engines: {node: '>=18.20.4'} - - '@socketregistry/unbox-primitive@1.0.5': - resolution: {integrity: sha512-HTlrRFdxTArSZ0e8BCNBWRKYypSx26Cp3m77/I0L6wH3zypkd04jWfS6LbtqiCzM+ni40ISZULRf/8vaqShCfg==} - engines: {node: '>=18.20.4'} - '@socketregistry/which-boxed-primitive@1.0.5': resolution: {integrity: sha512-FF1m2hcRNdMRzsBu0vYtfXu9/9X/HQneamFmtijp0orfDISO5FndtuORqhYixKwUeaZX818FbGY5O5nAW4BR8w==} engines: {node: '>=18.20.4'} @@ -4299,12 +4219,6 @@ packages: resolution: {integrity: sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==} engines: {node: '>=8'} - array.prototype.toreversed@1.1.2: - resolution: {integrity: sha512-wwDCoT4Ck4Cz7sLtgUmzR5UV3YF5mFHUlbChCzZBQZ+0m2cl/DH3tKgvphv1nKgFsJ48oCSg6p91q2Vm0I/ZMA==} - - array.prototype.tosorted@1.1.3: - resolution: {integrity: sha512-/DdH4TiTmOKzyQbp/eadcCVexiCb36xJg7HshYOYJnNZFDj33GEv0P7GxsynpShhq4OLYJzbGcBDkLsDt7MnNg==} - arrify@1.0.1: resolution: {integrity: sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==} engines: {node: '>=0.10.0'} @@ -5062,18 +4976,6 @@ packages: resolution: {integrity: sha512-ZYP5VBHshaDAiVZxjbRVcFJpc+4xGgT0bK3vzy1HLN8jTO975HEbuYzZJcHoQEY5K1a0z8YayJkyVETa08eNTg==} engines: {node: '>=18'} - data-view-buffer@1.0.1: - resolution: {integrity: sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==} - engines: {node: '>= 0.4'} - - data-view-byte-length@1.0.1: - resolution: {integrity: sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==} - engines: {node: '>= 0.4'} - - data-view-byte-offset@1.0.0: - resolution: {integrity: sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==} - engines: {node: '>= 0.4'} - date-fns@2.30.0: resolution: {integrity: sha512-fnULvOpxnC5/Vg3NCiWelDsLiUc9bRwAPs/+LfTLNvetFCtCTN+yQz15C/fs4AwX1R9K5GLtLfn8QW+dWisaAw==} engines: {node: '>=0.11'} @@ -5400,32 +5302,13 @@ packages: resolution: {integrity: sha512-rcOwbfvP1WTViVoUjcfZicVzjhjTuhSMntHh6mW3IrEiyE6mJyXvsToJUJGlGlw/2xU9P5whlWNGlIDVeCiT4A==} engines: {node: '>= 0.8'} - es-abstract@1.23.3: - resolution: {integrity: sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==} - engines: {node: '>= 0.4'} - es-errors@1.3.0: resolution: {integrity: sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==} engines: {node: '>= 0.4'} - es-iterator-helpers@1.0.19: - resolution: {integrity: sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==} - engines: {node: '>= 0.4'} - es-module-lexer@1.5.4: resolution: {integrity: sha512-MVNK56NiMrOwitFB7cqDwq0CQutbw+0BvLshJSse0MUNU+y1FC3bUS/AQg7oUng+/wKrrki7JfmwtVHkVfPLlw==} - es-object-atoms@1.0.0: - resolution: {integrity: sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==} - engines: {node: '>= 0.4'} - - es-shim-unscopables@1.0.2: - resolution: {integrity: sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==} - - es-to-primitive@1.2.1: - resolution: {integrity: sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==} - engines: {node: '>= 0.4'} - es5-ext@0.10.64: resolution: {integrity: sha512-p2snDhiLaXe6dahss1LddxqEm+SkuDvV8dnIQG0MWjyHpcMNfXKPE+/Cc0y+PhxJX3A4xGNeFCj5oc0BUh6deg==} engines: {node: '>=0.10'} @@ -6465,14 +6348,6 @@ packages: resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==} engines: {node: '>=8'} - is-callable@1.2.7: - resolution: {integrity: sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==} - engines: {node: '>= 0.4'} - - is-data-view@1.0.1: - resolution: {integrity: sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==} - engines: {node: '>= 0.4'} - is-directory@0.3.1: resolution: {integrity: sha512-yVChGzahRFvbkscn2MlwGismPO12i9+znNruC5gVEntG3qu0xQMzsGg/JFbrsqDOHtHFPci+V5aP5T9I+yeKqw==} engines: {node: '>=0.10.0'} @@ -7615,13 +7490,6 @@ packages: obj-multiplex@1.0.0: resolution: {integrity: sha512-0GNJAOsHoBHeNTvl5Vt6IWnpUEcc3uSRxzBri7EDyIcMgYvnY2JL2qdeV5zTMjWQX5OHcD5amcW2HFfDh0gjIA==} - object-inspect@1.13.1: - resolution: {integrity: sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==} - - object.groupby@1.0.3: - resolution: {integrity: sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ==} - engines: {node: '>= 0.4'} - obliterator@2.0.4: resolution: {integrity: sha512-lgHwxlxV1qIg1Eap7LgIeoBWIMFibOjbrYPIPJZcI1mmGAI2m3lNYpK12Y+GBdPQ0U1hRwSord7GIaawz962qQ==} @@ -13541,36 +13409,24 @@ snapshots: '@socketregistry/array.prototype.flatmap@1.0.5': {} - '@socketregistry/arraybuffer.prototype.slice@1.0.5': {} + '@socketregistry/array.prototype.toreversed@1.0.5': {} - '@socketregistry/available-typed-arrays@1.0.5': {} + '@socketregistry/array.prototype.tosorted@1.0.5': {} '@socketregistry/deep-equal@1.0.6': dependencies: '@socketregistry/original__deep-equal': deep-equal@2.2.3 - '@socketregistry/define-properties@1.0.5': {} - '@socketregistry/es-define-property@1.0.5': {} '@socketregistry/es-get-iterator@1.0.5': {} - '@socketregistry/es-set-tostringtag@1.0.5': {} + '@socketregistry/es-iterator-helpers@1.0.7': {} '@socketregistry/es6-symbol@1.0.5': {} '@socketregistry/function-bind@1.0.5': {} - '@socketregistry/function.prototype.name@1.0.5': {} - - '@socketregistry/get-symbol-description@1.0.5': {} - - '@socketregistry/globalthis@1.0.5': {} - - '@socketregistry/gopd@1.0.5': {} - - '@socketregistry/has-property-descriptors@1.0.5': {} - '@socketregistry/has-proto@1.0.5': {} '@socketregistry/has-symbols@1.0.5': {} @@ -13579,8 +13435,6 @@ snapshots: '@socketregistry/indent-string@1.0.6': {} - '@socketregistry/internal-slot@1.0.5': {} - '@socketregistry/is-arguments@1.0.5': {} '@socketregistry/is-array-buffer@1.0.5': {} @@ -13591,24 +13445,14 @@ snapshots: '@socketregistry/is-generator-function@1.0.5': {} - '@socketregistry/is-negative-zero@1.0.5': {} - '@socketregistry/is-regex@1.0.5': {} '@socketregistry/is-shared-array-buffer@1.0.5': {} - '@socketregistry/is-string@1.0.5': {} - - '@socketregistry/is-symbol@1.0.5': {} - '@socketregistry/is-typed-array@1.0.5': {} - '@socketregistry/is-weakref@1.0.5': {} - '@socketregistry/isarray@1.0.5': {} - '@socketregistry/iterator.prototype@1.0.5': {} - '@socketregistry/number-is-nan@1.0.7': {} '@socketregistry/object-assign@1.0.3': {} @@ -13623,6 +13467,8 @@ snapshots: '@socketregistry/object.fromentries@1.0.5': {} + '@socketregistry/object.groupby@1.0.5': {} + '@socketregistry/object.hasown@1.0.5': {} '@socketregistry/object.values@1.0.5': {} @@ -13633,12 +13479,8 @@ snapshots: '@socketregistry/regexp.prototype.flags@1.0.5': {} - '@socketregistry/safe-array-concat@1.0.5': {} - '@socketregistry/safe-buffer@1.0.5': {} - '@socketregistry/safe-regex-test@1.0.5': {} - '@socketregistry/safer-buffer@1.0.5': {} '@socketregistry/set-function-length@1.0.5': {} @@ -13647,22 +13489,6 @@ snapshots: '@socketregistry/string.prototype.matchall@1.0.5': {} - '@socketregistry/string.prototype.trim@1.0.5': {} - - '@socketregistry/string.prototype.trimend@1.0.5': {} - - '@socketregistry/string.prototype.trimstart@1.0.5': {} - - '@socketregistry/typed-array-buffer@1.0.5': {} - - '@socketregistry/typed-array-byte-length@1.0.5': {} - - '@socketregistry/typed-array-byte-offset@1.0.5': {} - - '@socketregistry/typed-array-length@1.0.5': {} - - '@socketregistry/unbox-primitive@1.0.5': {} - '@socketregistry/which-boxed-primitive@1.0.5': {} '@socketregistry/which-collection@1.0.5': {} @@ -15103,21 +14929,6 @@ snapshots: array-union@2.1.0: {} - array.prototype.toreversed@1.1.2: - dependencies: - call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.5' - es-abstract: 1.23.3 - es-shim-unscopables: 1.0.2 - - array.prototype.tosorted@1.1.3: - dependencies: - call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.5' - es-abstract: 1.23.3 - es-errors: 1.3.0 - es-shim-unscopables: 1.0.2 - arrify@1.0.1: {} as-table@1.0.55: @@ -15983,24 +15794,6 @@ snapshots: whatwg-mimetype: 4.0.0 whatwg-url: 14.0.0 - data-view-buffer@1.0.1: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - is-data-view: 1.0.1 - - data-view-byte-length@1.0.1: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - is-data-view: 1.0.1 - - data-view-byte-offset@1.0.0: - dependencies: - call-bind: 1.0.7 - es-errors: 1.3.0 - is-data-view: 1.0.1 - date-fns@2.30.0: dependencies: '@babel/runtime': 7.25.0 @@ -16315,90 +16108,10 @@ snapshots: accepts: 1.3.8 escape-html: 1.0.3 - es-abstract@1.23.3: - dependencies: - array-buffer-byte-length: '@socketregistry/array-buffer-byte-length@1.0.5' - arraybuffer.prototype.slice: '@socketregistry/arraybuffer.prototype.slice@1.0.5' - available-typed-arrays: '@socketregistry/available-typed-arrays@1.0.5' - call-bind: 1.0.7 - data-view-buffer: 1.0.1 - data-view-byte-length: 1.0.1 - data-view-byte-offset: 1.0.0 - es-define-property: '@socketregistry/es-define-property@1.0.5' - es-errors: 1.3.0 - es-object-atoms: 1.0.0 - es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.5' - es-to-primitive: 1.2.1 - function.prototype.name: '@socketregistry/function.prototype.name@1.0.5' - get-intrinsic: 1.2.4 - get-symbol-description: '@socketregistry/get-symbol-description@1.0.5' - globalthis: '@socketregistry/globalthis@1.0.5' - gopd: '@socketregistry/gopd@1.0.5' - has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.5' - has-proto: '@socketregistry/has-proto@1.0.5' - has-symbols: '@socketregistry/has-symbols@1.0.5' - hasown: '@socketregistry/hasown@1.0.5' - internal-slot: '@socketregistry/internal-slot@1.0.5' - is-array-buffer: '@socketregistry/is-array-buffer@1.0.5' - is-callable: 1.2.7 - is-data-view: 1.0.1 - is-negative-zero: '@socketregistry/is-negative-zero@1.0.5' - is-regex: '@socketregistry/is-regex@1.0.5' - is-shared-array-buffer: '@socketregistry/is-shared-array-buffer@1.0.5' - is-string: '@socketregistry/is-string@1.0.5' - is-typed-array: '@socketregistry/is-typed-array@1.0.5' - is-weakref: '@socketregistry/is-weakref@1.0.5' - object-inspect: 1.13.1 - object-keys: '@socketregistry/object-keys@1.0.5' - object.assign: '@socketregistry/object.assign@1.0.5' - regexp.prototype.flags: '@socketregistry/regexp.prototype.flags@1.0.5' - safe-array-concat: '@socketregistry/safe-array-concat@1.0.5' - safe-regex-test: '@socketregistry/safe-regex-test@1.0.5' - string.prototype.trim: '@socketregistry/string.prototype.trim@1.0.5' - string.prototype.trimend: '@socketregistry/string.prototype.trimend@1.0.5' - string.prototype.trimstart: '@socketregistry/string.prototype.trimstart@1.0.5' - typed-array-buffer: '@socketregistry/typed-array-buffer@1.0.5' - typed-array-byte-length: '@socketregistry/typed-array-byte-length@1.0.5' - typed-array-byte-offset: '@socketregistry/typed-array-byte-offset@1.0.5' - typed-array-length: '@socketregistry/typed-array-length@1.0.5' - unbox-primitive: '@socketregistry/unbox-primitive@1.0.5' - which-typed-array: '@socketregistry/which-typed-array@1.0.5' - es-errors@1.3.0: {} - es-iterator-helpers@1.0.19: - dependencies: - call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.5' - es-abstract: 1.23.3 - es-errors: 1.3.0 - es-set-tostringtag: '@socketregistry/es-set-tostringtag@1.0.5' - function-bind: '@socketregistry/function-bind@1.0.5' - get-intrinsic: 1.2.4 - globalthis: '@socketregistry/globalthis@1.0.5' - has-property-descriptors: '@socketregistry/has-property-descriptors@1.0.5' - has-proto: '@socketregistry/has-proto@1.0.5' - has-symbols: '@socketregistry/has-symbols@1.0.5' - internal-slot: '@socketregistry/internal-slot@1.0.5' - iterator.prototype: '@socketregistry/iterator.prototype@1.0.5' - safe-array-concat: '@socketregistry/safe-array-concat@1.0.5' - es-module-lexer@1.5.4: {} - es-object-atoms@1.0.0: - dependencies: - es-errors: 1.3.0 - - es-shim-unscopables@1.0.2: - dependencies: - hasown: '@socketregistry/hasown@1.0.5' - - es-to-primitive@1.2.1: - dependencies: - is-callable: 1.2.7 - is-date-object: '@socketregistry/is-date-object@1.0.5' - is-symbol: '@socketregistry/is-symbol@1.0.5' - es5-ext@0.10.64: dependencies: es6-iterator: 2.0.3 @@ -16577,7 +16290,7 @@ snapshots: is-glob: 4.0.3 minimatch: 3.1.2 object.fromentries: '@socketregistry/object.fromentries@1.0.5' - object.groupby: 1.0.3 + object.groupby: '@socketregistry/object.groupby@1.0.5' object.values: '@socketregistry/object.values@1.0.5' semver: 6.3.1 tsconfig-paths: 3.15.0 @@ -16599,7 +16312,7 @@ snapshots: axobject-query: 3.2.1 damerau-levenshtein: 1.0.8 emoji-regex: 9.2.2 - es-iterator-helpers: 1.0.19 + es-iterator-helpers: '@socketregistry/es-iterator-helpers@1.0.7' eslint: 8.50.0 hasown: '@socketregistry/hasown@1.0.5' jsx-ast-utils: 3.3.5 @@ -16627,10 +16340,10 @@ snapshots: array-includes: '@socketregistry/array-includes@1.0.5' array.prototype.findlast: '@socketregistry/array.prototype.findlast@1.0.5' array.prototype.flatmap: '@socketregistry/array.prototype.flatmap@1.0.5' - array.prototype.toreversed: 1.1.2 - array.prototype.tosorted: 1.1.3 + array.prototype.toreversed: '@socketregistry/array.prototype.toreversed@1.0.5' + array.prototype.tosorted: '@socketregistry/array.prototype.tosorted@1.0.5' doctrine: 2.1.0 - es-iterator-helpers: 1.0.19 + es-iterator-helpers: '@socketregistry/es-iterator-helpers@1.0.7' eslint: 8.50.0 estraverse: 5.3.0 jsx-ast-utils: 3.3.5 @@ -17867,12 +17580,6 @@ snapshots: dependencies: binary-extensions: 2.3.0 - is-callable@1.2.7: {} - - is-data-view@1.0.1: - dependencies: - is-typed-array: '@socketregistry/is-typed-array@1.0.5' - is-directory@0.3.1: {} is-docker@2.2.1: {} @@ -19218,14 +18925,6 @@ snapshots: once: 1.4.0 readable-stream: 2.3.8 - object-inspect@1.13.1: {} - - object.groupby@1.0.3: - dependencies: - call-bind: 1.0.7 - define-properties: '@socketregistry/define-properties@1.0.5' - es-abstract: 1.23.3 - obliterator@2.0.4: {} oboe@2.1.5: From b4e136051a1e7955469fa705fc722abc15381dcf Mon Sep 17 00:00:00 2001 From: storywithoutend Date: Mon, 2 Dec 2024 10:13:40 +0800 Subject: [PATCH 75/75] Update registerName.spec.ts --- e2e/specs/stateless/registerName.spec.ts | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/e2e/specs/stateless/registerName.spec.ts b/e2e/specs/stateless/registerName.spec.ts index d4ccb4326..38d86e3d5 100644 --- a/e2e/specs/stateless/registerName.spec.ts +++ b/e2e/specs/stateless/registerName.spec.ts @@ -204,11 +204,10 @@ test.describe.serial('normal registration', () => { }) await test.step('should be able to start registration step', async () => { - await expect( - page.getByText( - 'Your name is not registered until you’ve completed the second transaction. You have 23 hours remaining to complete it.', - ), - ).toBeVisible() + await expect(page.getByTestId('transactions-subheading')).toBeVisible() + await expect(page.getByTestId('transactions-subheading')).toHaveText( + /Your name is not registered until you’ve completed the second transaction. You have (23 hours|1 day) remaining to complete it./, + ) await page.getByTestId('finish-button').click() })
+ + + {t('partnership.text')} + + {t('partnership.watch')} + + + +
+ {t('title')} + {t('caption')} +
+
video
+ + + 🎉 + + {t('accessible.title')} + + {t('accessible.caption')} + + + + + + {t('accessible.gas.title')} + + {t('accessible.gas.text')} + + + + + {t('accessible.control.title')} + + {t('accessible.control.text')} + + + + + {t('accessible.multichain.title')} + + {t('accessible.multichain.text')} + + + + + {t('announcement.title')} + + + + + + + +