From 130bfc9c8bbd6decf85fa5f1d18275cdc831cc9e Mon Sep 17 00:00:00 2001 From: Dessalines Date: Wed, 27 Apr 2022 16:57:55 -0400 Subject: [PATCH] Properly debouncing tribute mentions. Fixes #633 (#639) --- src/shared/components/person/settings.tsx | 4 +- src/shared/components/post/post-form.tsx | 2 +- src/shared/components/search.tsx | 4 +- src/shared/utils.ts | 106 +++++----------------- 4 files changed, 29 insertions(+), 87 deletions(-) diff --git a/src/shared/components/person/settings.tsx b/src/shared/components/person/settings.tsx index 9e045e4d..6008edbf 100644 --- a/src/shared/components/person/settings.tsx +++ b/src/shared/components/person/settings.tsx @@ -799,7 +799,7 @@ export class Settings extends Component { } catch (err) { console.error(err); } - }, 400), + }), false ); } @@ -834,7 +834,7 @@ export class Settings extends Component { } catch (err) { console.log(err); } - }, 400), + }), false ); } diff --git a/src/shared/components/post/post-form.tsx b/src/shared/components/post/post-form.tsx index 9badb746..e9c22189 100644 --- a/src/shared/components/post/post-form.tsx +++ b/src/shared/components/post/post-form.tsx @@ -600,7 +600,7 @@ export class PostForm extends Component { } catch (err) { console.log(err); } - }, 400), + }), false ); } diff --git a/src/shared/components/search.tsx b/src/shared/components/search.tsx index f4c78503..f049f1c5 100644 --- a/src/shared/components/search.tsx +++ b/src/shared/components/search.tsx @@ -778,7 +778,7 @@ export class Search extends Component { } catch (err) { console.error(err); } - }, 400), + }), false ); } @@ -808,7 +808,7 @@ export class Search extends Component { } catch (err) { console.log(err); } - }, 400), + }), false ); } diff --git a/src/shared/utils.ts b/src/shared/utils.ts index df26970d..bf0a6d81 100644 --- a/src/shared/utils.ts +++ b/src/shared/utils.ts @@ -20,7 +20,6 @@ import { PrivateMessageView, RegistrationApplicationView, Search, - SearchResponse, SearchType, SortType, UserOperation, @@ -585,9 +584,9 @@ export function setupTribute() { let it: PersonTribute = item.original; return `[${it.key}](${it.view.person.actor_id})`; }, - values: (text: string, cb: (persons: PersonTribute[]) => any) => { - personSearch(text, (persons: PersonTribute[]) => cb(persons)); - }, + values: debounce(async (text: string, cb: any) => { + cb(await personSearch(text)); + }), allowSpaces: false, autocompleteMode: true, // TODO @@ -602,11 +601,9 @@ export function setupTribute() { let it: CommunityTribute = item.original; return `[${it.key}](${it.view.community.actor_id})`; }, - values: (text: string, cb: any) => { - communitySearch(text, (communities: CommunityTribute[]) => - cb(communities) - ); - }, + values: debounce(async (text: string, cb: any) => { + cb(await communitySearch(text)); + }), allowSpaces: false, autocompleteMode: true, // TODO @@ -638,42 +635,16 @@ interface PersonTribute { view: PersonViewSafe; } -function personSearch(text: string, cb: (persons: PersonTribute[]) => any) { - if (text) { - let form: Search = { - q: text, - type_: SearchType.Users, - sort: SortType.TopAll, - listing_type: ListingType.All, - page: 1, - limit: mentionDropdownFetchLimit, - auth: authField(false), +async function personSearch(text: string): Promise { + let users = (await fetchUsers(text)).users; + let persons: PersonTribute[] = users.map(pv => { + let tribute: PersonTribute = { + key: `@${pv.person.name}@${hostname(pv.person.actor_id)}`, + view: pv, }; - - WebSocketService.Instance.send(wsClient.search(form)); - - let personSub = WebSocketService.Instance.subject.subscribe( - msg => { - let res = wsJsonToRes(msg); - if (res.op == UserOperation.Search) { - let data = res.data as SearchResponse; - let persons: PersonTribute[] = data.users.map(pv => { - let tribute: PersonTribute = { - key: `@${pv.person.name}@${hostname(pv.person.actor_id)}`, - view: pv, - }; - return tribute; - }); - cb(persons); - personSub.unsubscribe(); - } - }, - err => console.error(err), - () => console.log("complete") - ); - } else { - cb([]); - } + return tribute; + }); + return persons; } interface CommunityTribute { @@ -681,45 +652,16 @@ interface CommunityTribute { view: CommunityView; } -function communitySearch( - text: string, - cb: (communities: CommunityTribute[]) => any -) { - if (text) { - let form: Search = { - q: text, - type_: SearchType.Communities, - sort: SortType.TopAll, - listing_type: ListingType.All, - page: 1, - limit: mentionDropdownFetchLimit, - auth: authField(false), +async function communitySearch(text: string): Promise { + let comms = (await fetchCommunities(text)).communities; + let communities: CommunityTribute[] = comms.map(cv => { + let tribute: CommunityTribute = { + key: `!${cv.community.name}@${hostname(cv.community.actor_id)}`, + view: cv, }; - - WebSocketService.Instance.send(wsClient.search(form)); - - let communitySub = WebSocketService.Instance.subject.subscribe( - msg => { - let res = wsJsonToRes(msg); - if (res.op == UserOperation.Search) { - let data = res.data as SearchResponse; - let communities: CommunityTribute[] = data.communities.map(cv => { - let tribute: CommunityTribute = { - key: `!${cv.community.name}@${hostname(cv.community.actor_id)}`, - view: cv, - }; - return tribute; - }); - cb(communities); - communitySub.unsubscribe(); - } - }, - err => console.error(err), - () => console.log("complete") - ); - } else { - cb([]); - } + return tribute; + }); + return communities; } export function getListingTypeFromProps(props: any): ListingType {