serialize outgoing searches returning out of order

This commit is contained in:
Kaity A 2023-02-12 01:51:26 +00:00
parent b30814913f
commit 3fbeaf0e9e

View file

@ -50,11 +50,14 @@ let instances: Instance[] = $ref([]);
let selected: Instance | null = $ref(null); let selected: Instance | null = $ref(null);
let dialogEl = $ref<InstanceType<typeof XModalWindow>>(); let dialogEl = $ref<InstanceType<typeof XModalWindow>>();
let searchOrderLatch = 0;
const search = () => { const search = () => {
if (hostname === '') { if (hostname === '') {
instances = []; instances = [];
return; return;
} }
const searchId = ++searchOrderLatch;
os.api('federation/instances', { os.api('federation/instances', {
host: hostname, host: hostname,
limit: 10, limit: 10,
@ -62,6 +65,7 @@ const search = () => {
suspended: false, suspended: false,
sort: '+pubSub', sort: '+pubSub',
}).then(_instances => { }).then(_instances => {
if (searchId !== searchOrderLatch) return;
instances = _instances.map(x => ({ instances = _instances.map(x => ({
id: x.id, id: x.id,
host: x.host, host: x.host,