refactoring: eleanup part I

Styled profile image to be aligned at the top together with the
event metadata and content.

Still need to decide on which relays to enable.

JavaScript lint fixes.
OFF0 2 years ago
parent b2ad1d4c60
commit a2a5cfa341
Signed by: offbyn
GPG Key ID: 94A2F643C51F37FA

@ -12,10 +12,11 @@
} }
.mbox .mbox-img { .mbox .mbox-img {
align-self: center; align-self: start;
flex-basis: 4ch; flex-basis: 4ch;
height: 4ch; height: 4ch;
margin-right: 1rem; margin-right: 1rem;
margin-top: .5ch;
max-width: 4ch; max-width: 4ch;
} }

@ -3,7 +3,7 @@ import {elem} from './domutil.js';
// curl -H 'accept: application/nostr+json' https://nostr.x1ddos.ch // curl -H 'accept: application/nostr+json' https://nostr.x1ddos.ch
const pool = relayPool(); const pool = relayPool();
pool.addRelay('wss://nostr.x1ddos.ch', {read: true, write: true}); pool.addRelay('wss://nostr.x1ddos.ch', {read: true, write: true});
// pool.addRelay('wss://nostr.bitcoiner.social/', {read: true, write: true}); pool.addRelay('wss://nostr.bitcoiner.social/', {read: true, write: true});
// pool.addRelay('wss://nostr.openchain.fr', {read: true, write: true}); // pool.addRelay('wss://nostr.openchain.fr', {read: true, write: true});
// pool.addRelay('wss://relay.nostr.info', {read: true, write: true}); // pool.addRelay('wss://relay.nostr.info', {read: true, write: true});
// pool.addRelay('wss://relay.damus.io', {read: true, write: true}); // pool.addRelay('wss://relay.damus.io', {read: true, write: true});
@ -35,7 +35,7 @@ function onEvent(evt, relay) {
updateContactList(evt, relay); updateContactList(evt, relay);
break; break;
default: default:
// console.log(`TODO: add support for event kind ${evt.kind}`, evt) console.log(`TODO: add support for event kind ${evt.kind}`, evt)
} }
} }
@ -67,7 +67,7 @@ function handleTextNote(evt, relay) {
} else { } else {
eventRelayMap[evt.id] = [relay]; eventRelayMap[evt.id] = [relay];
(evt.tags.some(hasEventTag) ? replyList : textNoteList).push(evt); (evt.tags.some(hasEventTag) ? replyList : textNoteList).push(evt);
renderFeed() renderFeed();
} }
} }
@ -76,18 +76,18 @@ const feedContainer = document.querySelector('#feed');
const feedDomMap = {}; const feedDomMap = {};
const sortByCreatedAt = (evt1, evt2) => { const sortByCreatedAt = (evt1, evt2) => {
if (evt1.created_at === evt2.created_at) { if (evt1.created_at === evt2.created_at) {
//console.log('OMG exactly at the same time', evt1, evt2); // console.log('TODO: OMG exactly at the same time, figure out how to sort then', evt1, evt2);
} }
return evt1.created_at > evt2.created_at ? -1 : 1; return evt1.created_at > evt2.created_at ? -1 : 1;
}; };
let debounceDebugMessageTimer; // let debounceDebugMessageTimer;
function renderFeed() { function renderFeed() {
const sortedFeeds = textNoteList.sort(sortByCreatedAt).reverse(); const sortedFeeds = textNoteList.sort(sortByCreatedAt).reverse();
clearTimeout(debounceDebugMessageTimer); // clearTimeout(debounceDebugMessageTimer);
debounceDebugMessageTimer = setTimeout(() => { // debounceDebugMessageTimer = setTimeout(() => {
console.log(`${sortedFeeds.map(e => dateTime.format(e.created_at * 1000)).join('\n')}`) // console.log(`${sortedFeeds.map(e => dateTime.format(e.created_at * 1000)).join('\n')}`)
}, 2000); // }, 2000);
sortedFeeds.forEach((textNoteEvent, i) => { sortedFeeds.forEach((textNoteEvent, i) => {
if (feedDomMap[textNoteEvent.id]) { if (feedDomMap[textNoteEvent.id]) {
// TODO check eventRelayMap if event was published to different relays // TODO check eventRelayMap if event was published to different relays
@ -99,13 +99,6 @@ function renderFeed() {
feedContainer.append(art); feedContainer.append(art);
} else { } else {
feedDomMap[sortedFeeds[i - 1].id].before(art); feedDomMap[sortedFeeds[i - 1].id].before(art);
console.log(
dateTime.format(sortedFeeds[i - 1].created_at * 1000),
' > ',
dateTime.format(textNoteEvent.created_at * 1000),
)
// feedContainer.insertBefore(art, feedDomMap[sortedFeeds[i - 1].id]);
//feedDomMap[sortedFeeds[i - 1].id].after(art);
} }
}); });
} }
@ -133,7 +126,6 @@ function handleRecommendServer(evt, relay) {
} }
const art = renderRecommendServer(evt, relay); const art = renderRecommendServer(evt, relay);
if (textNoteList.length < 2) { if (textNoteList.length < 2) {
console.log('prob does happen often')
feedContainer.append(art); feedContainer.append(art);
return; return;
} }
@ -152,7 +144,7 @@ function renderRecommendServer(evt, relay) {
const [host, img, time, userName] = getMetadata(evt, relay); const [host, img, time, userName] = getMetadata(evt, relay);
const body = elem('div', {className: 'mbox-body', title: dateTime.format(time)}, [ const body = elem('div', {className: 'mbox-body', title: dateTime.format(time)}, [
renderProfile(userName, host), renderProfile(userName, host),
`recommends server: ${evt.content}` `recommends server: ${evt.content}`,
]); ]);
return rendernArticle([img, body], {className: 'mbox-recommend-server'}); return rendernArticle([img, body], {className: 'mbox-recommend-server'});
} }
@ -208,7 +200,7 @@ function setMetadata(evt, relay, content) {
function getMetadata(evt, relay) { function getMetadata(evt, relay) {
const {host} = new URL(relay); const {host} = new URL(relay);
const user = userList.find(user => user.pubkey === evt.pubkey); const user = userList.find(user => user.pubkey === evt.pubkey);
const userImg = /*user?.metadata[relay]?.picture || */'bubble.svg'; // enable pic once we have proxy const userImg = /*user?.metadata[relay]?.picture || */'bubble.svg'; // TODO: enable pic once we have proxy
const userName = user?.metadata[relay]?.name || evt.pubkey.slice(0, 8); const userName = user?.metadata[relay]?.name || evt.pubkey.slice(0, 8);
const userAbout = user?.metadata[relay]?.about || ''; const userAbout = user?.metadata[relay]?.about || '';
const img = elem('img', { const img = elem('img', {
@ -274,9 +266,7 @@ publish.addEventListener('click', async () => {
}); });
const input = document.querySelector('input[name="message"]'); const input = document.querySelector('input[name="message"]');
input.addEventListener('input', () => { input.addEventListener('input', () => publish.disabled = !input.value);
publish.disabled = !input.value;
});
// settings // settings
const form = document.querySelector('form[name="settings"]'); const form = document.querySelector('form[name="settings"]');
@ -285,7 +275,7 @@ const pubKeyInput = form.querySelector('#pubkey');
const statusMessage = form.querySelector('#keystatus'); const statusMessage = form.querySelector('#keystatus');
const generateBtn = form.querySelector('button[name="generate"]'); const generateBtn = form.querySelector('button[name="generate"]');
const importBtn = form.querySelector('button[name="import"]'); const importBtn = form.querySelector('button[name="import"]');
const privateTgl = form.querySelector('button[name="privatekey-toggle"]') const privateTgl = form.querySelector('button[name="privatekey-toggle"]');
generateBtn.addEventListener('click', () => { generateBtn.addEventListener('click', () => {
const privatekey = generatePrivateKey(); const privatekey = generatePrivateKey();

Loading…
Cancel
Save