From c4e3017d1e36243b6446e865aad37610e97e5cd7 Mon Sep 17 00:00:00 2001 From: jojobyte <184880+jojobyte@users.noreply.github.com> Date: Sat, 6 Apr 2024 14:32:49 -0600 Subject: [PATCH] fix(ui): fix jankiness from re-rendering everything in contacts --- src/components/contacts-list.js | 129 ++++++++++++++++++-------------- src/main.js | 16 ++-- 2 files changed, 80 insertions(+), 65 deletions(-) diff --git a/src/components/contacts-list.js b/src/components/contacts-list.js index 143123a..bdce221 100644 --- a/src/components/contacts-list.js +++ b/src/components/contacts-list.js @@ -57,30 +57,29 @@ const initialState = { `, + list: async state => { + if (state.contacts?.length === 0) { + return html`No Contacts found` + } + + return ( + await Promise.all( + state.contacts + .filter( + state.showUnpaired + ? filterUnpairedContacts + : filterPairedContacts + ) + .sort(sortContactsByAlias) + .map(async c => await state.item(c)), + ) + ).join('') + }, content: async state => html` ${state.header(state)}
- ${ - state.contacts?.length > 0 - ? ( - await Promise.all( - state.contacts - .filter( - state.showUnpaired - ? filterUnpairedContacts - : filterPairedContacts - ) - .sort(sortContactsByAlias) - .map(async c => await state.item(c)), - ) - ).join('') - : '' - } - ${ - state.contacts.length === 0 ? - html`No Contacts found` : '' - } + ${await state.list(state)}
${await state.footer(state)} @@ -158,47 +157,36 @@ const initialState = { ` }, + datalist: async (state, direction = 'outgoing') => { + if (state.contacts?.length === 0) { + return '' + } + + return ( + await Promise.all( + state.contacts + .filter( + c => c.alias && + Object.keys(c[direction] || {}).length > 0 + ).map(contact => { + return html`` + }) + ) + ).join('') + }, footer: async state => html` ${ - state.contacts.length > 0 - ? ( - await Promise.all( - state.contacts - .filter( - c => c.alias && - Object.keys(c.outgoing || {}).length > 0 - ).map(contact => { - return html`` - }) - ) - ).join('') - : '' + await state.datalist(state, 'outgoing') } ${ - state.contacts.length > 0 - ? ( - await Promise.all( - state.contacts - .filter( - c => c.alias && - Object.keys(c.incoming || {}).length > 0 - ).map(contact => { - return html`` - }) - ) - ).join('') - : '' + await state.datalist(state, 'incoming') } `, @@ -247,6 +235,22 @@ export async function setupContactsList( state.elements.section = section + const list = section.querySelector('& > div') + const sendDataList = section.querySelector('#contactSendAliases') + const receiveDataList = section.querySelector('#contactReceiveAliases') + const hdrPaired = section.querySelector('#paired_contacts') + const hdrUnpaired = section.querySelector('#unpaired_contacts') + const hdrPairedIndicator = hdrPaired.querySelector('.indicator') + const hdrUnpairedIndicator = hdrUnpaired.querySelector('.indicator') + + state.elements.list = list + state.elements.sendDataList = sendDataList + state.elements.receiveDataList = receiveDataList + state.elements.hdrPaired = hdrPaired + state.elements.hdrUnpaired = hdrUnpaired + state.elements.hdrPairedIndicator = hdrPairedIndicator + state.elements.hdrUnpairedIndicator = hdrUnpairedIndicator + function addListener( node, event, @@ -288,7 +292,22 @@ export async function setupContactsList( await restate(state, renderState) state.elements.section.id = state.slugs.section - state.elements.section.innerHTML = await state.content(state) + // state.elements.section.innerHTML = await state.content(state) + + state.elements.list.innerHTML = await state.list(state) + state.elements.sendDataList.innerHTML = await state.datalist(state, 'outgoing') + state.elements.receiveDataList.innerHTML = await state.datalist(state, 'incoming') + + if (state.showUnpaired) { + state.elements.hdrPaired.classList.remove('active') + state.elements.hdrUnpaired.classList.add('active') + } else { + state.elements.hdrPaired.classList.add('active') + state.elements.hdrUnpaired.classList.remove('active') + } + + state.elements.hdrPairedIndicator.innerText = state.contacts.filter(filterPairedContacts).length + state.elements.hdrUnpairedIndicator.innerText = state.contacts.filter(filterUnpairedContacts).length state.removeAllListeners() state.addListeners() diff --git a/src/main.js b/src/main.js index 3a5347e..859bffb 100644 --- a/src/main.js +++ b/src/main.js @@ -222,11 +222,6 @@ let contactsList = await setupContactsList( event.preventDefault() event.stopPropagation() - // console.log( - // 'paired_contacts', - // event - // ) - await contactsList.render({ userInfo, contacts: appState.contacts, @@ -240,11 +235,6 @@ let contactsList = await setupContactsList( event.preventDefault() event.stopPropagation() - // console.log( - // 'unpaired_contacts', - // event - // ) - await contactsList.render({ userInfo, contacts: appState.contacts, @@ -442,6 +432,8 @@ function getTarget(event, selector) { id, // @ts-ignore parentElement, + // @ts-ignore + parentNode, } = event?.target let target @@ -454,6 +446,10 @@ function getTarget(event, selector) { target = parentElement } + if (parentNode?.id === selector) { + target = parentNode + } + return target }