Searching counterparts glitchy when includes @ (nip05) #273

Merged
b merged 6 commits from issue-270 into staging 2024-12-10 15:37:00 +00:00
3 changed files with 36 additions and 18 deletions

View File

@ -125,7 +125,7 @@ export const AppBar = () => {
src="/logo.svg" src="/logo.svg"
alt="Logo" alt="Logo"
onClick={() => { onClick={() => {
if (window.location.pathname === '/') { if (['', '#/'].includes(window.location.hash)) {
m marked this conversation as resolved
Review

We should apply this hash check instead of pathname to the Footer.tsx as well.

We should apply this hash check instead of pathname to the `Footer.tsx` as well.
location.reload() location.reload()
} else { } else {
navigate('/') navigate('/')

View File

@ -69,7 +69,7 @@ export const Footer = () =>
component={Link} component={Link}
to={'/'} to={'/'}
onClick={(event) => { onClick={(event) => {
if (window.location.pathname === '/') { if (['', '#/'].includes(window.location.hash)) {
event.preventDefault() event.preventDefault()
window.scrollTo(0, 0) window.scrollTo(0, 0)
} }

View File

@ -148,6 +148,17 @@ export const CreatePage = () => {
[setUserInput] [setUserInput]
) )
const handleSearchUserNip05 = async (
nip05: string
): Promise<string | null> => {
const { pubkey } = await queryNip05(nip05).catch((err) => {
console.error(err)
return { pubkey: null }
})
return pubkey
}
const handleSearchUsers = async (searchValue?: string) => { const handleSearchUsers = async (searchValue?: string) => {
const searchString = searchValue || userSearchInput || undefined const searchString = searchValue || userSearchInput || undefined
@ -224,7 +235,9 @@ export const CreatePage = () => {
}) })
}, [foundUsers]) }, [foundUsers])
const handleInputKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => { const handleInputKeyDown = async (
event: React.KeyboardEvent<HTMLDivElement>
) => {
if ( if (
event.code === KeyboardCode.Enter || event.code === KeyboardCode.Enter ||
event.code === KeyboardCode.NumpadEnter event.code === KeyboardCode.NumpadEnter
@ -238,11 +251,27 @@ export const CreatePage = () => {
} else { } else {
// Otherwize if search already provided some results, user must manually click the search button // Otherwize if search already provided some results, user must manually click the search button
if (!foundUsers.length) { if (!foundUsers.length) {
// If it's NIP05 (includes @ or is a valid domain) send request to .well-known
const domainRegex = /^[a-zA-Z0-9@.-]+\.[a-zA-Z]{2,}$/
if (domainRegex.test(userSearchInput)) {
setSearchUsersLoading(true)
const pubkey = await handleSearchUserNip05(userSearchInput)
setSearchUsersLoading(false)
if (pubkey) {
setUserInput(userSearchInput)
} else {
toast.error(`No user found with the NIP05: ${userSearchInput}`)
}
} else {
handleSearchUsers() handleSearchUsers()
} }
} }
} }
} }
}
useEffect(() => { useEffect(() => {
if (selectedFiles) { if (selectedFiles) {
@ -959,19 +988,6 @@ export const CreatePage = () => {
} else { } else {
disarmAddOnEnter() disarmAddOnEnter()
} }
} else if (value.includes('@')) {
// Seems like it's nip05 format
const { pubkey } = await queryNip05(value).catch((err) => {
console.error(err)
return { pubkey: null }
})
if (pubkey) {
// Arm the manual user npub add after enter is hit, we don't want to trigger search
setPastedUserNpubOrNip05(hexToNpub(pubkey))
} else {
disarmAddOnEnter()
}
} else { } else {
// Disarm the add user on enter hit, and trigger search after 1 second // Disarm the add user on enter hit, and trigger search after 1 second
disarmAddOnEnter() disarmAddOnEnter()
@ -1146,7 +1162,9 @@ export const CreatePage = () => {
</Button> </Button>
) : ( ) : (
<Button <Button
onClick={handleAddUser} onClick={() => {
setUserInput(userSearchInput)
}}
variant="contained" variant="contained"
aria-label="Add" aria-label="Add"
className={styles.counterpartToggleButton} className={styles.counterpartToggleButton}