ssb: Load and show new messages as they arrive.
Some checks failed
Build Tilde Friends / Build-All (push) Has been cancelled

This commit is contained in:
Cory McWilliams 2024-12-29 13:32:37 -05:00
parent baf125c450
commit eca8726909
4 changed files with 22 additions and 46 deletions

View File

@ -1,5 +1,5 @@
{ {
"type": "tildefriends-app", "type": "tildefriends-app",
"emoji": "🦀", "emoji": "🦀",
"previous": "&b7bvRAB4MWWsJvmyi3G+TG/eseQGUBsO4BZ1qiu8nQc=.sha256" "previous": "&yapJ13Gt1EBAoNfcjqen0o7c4wSjjRSQSxZFFtPDHps=.sha256"
} }

View File

@ -7,7 +7,6 @@ class TfElement extends LitElement {
return { return {
whoami: {type: String}, whoami: {type: String},
hash: {type: String}, hash: {type: String},
unread: {type: Array},
tab: {type: String}, tab: {type: String},
broadcasts: {type: Array}, broadcasts: {type: Array},
connections: {type: Array}, connections: {type: Array},
@ -28,7 +27,6 @@ class TfElement extends LitElement {
super(); super();
let self = this; let self = this;
this.hash = '#'; this.hash = '#';
this.unread = [];
this.tab = 'news'; this.tab = 'news';
this.broadcasts = []; this.broadcasts = [];
this.connections = []; this.connections = [];
@ -239,17 +237,13 @@ class TfElement extends LitElement {
[JSON.stringify(this.following), id] [JSON.stringify(this.following), id]
); );
for (let message of messages) { for (let message of messages) {
if (message.author == this.whoami) { if (
let content = JSON.parse(message.content); message.author == this.whoami &&
if (content?.type == 'channel') { JSON.parse(message.content)?.type == 'channel'
this.load_channels(); ) {
} this.load_channels();
} }
} }
if (messages && messages.length) {
this.unread = [...this.unread, ...messages];
this.unread = this.unread.slice(this.unread.length - 1024);
}
this.schedule_load_channels_latest(); this.schedule_load_channels_latest();
} }
@ -363,6 +357,7 @@ class TfElement extends LitElement {
schedule_load_channels_latest() { schedule_load_channels_latest() {
if (!this.loading_channels_latest) { if (!this.loading_channels_latest) {
this.shadowRoot.getElementById('tf-tab-news')?.load_latest();
this.load_channels_latest(this.following); this.load_channels_latest(this.following);
} else if (!this.loading_channels_latest_scheduled) { } else if (!this.loading_channels_latest_scheduled) {
this.loading_channels_latest_scheduled++; this.loading_channels_latest_scheduled++;
@ -449,8 +444,6 @@ class TfElement extends LitElement {
whoami=${this.whoami} whoami=${this.whoami}
.users=${this.users} .users=${this.users}
hash=${this.hash} hash=${this.hash}
.unread=${this.unread}
@refresh=${() => (this.unread = [])}
?loading=${this.loading} ?loading=${this.loading}
.channels=${this.channels} .channels=${this.channels}
.channels_latest=${this.channels_latest} .channels_latest=${this.channels_latest}
@ -567,7 +560,9 @@ class TfElement extends LitElement {
class="w3-theme-dark" class="w3-theme-dark"
> >
<div style="flex: 0 0">${tabs}</div> <div style="flex: 0 0">${tabs}</div>
<div style="flex: 1 1; overflow: scroll; contain: layout">${contents}</div> <div style="flex: 1 1; overflow: scroll; contain: layout">
${contents}
</div>
</div> </div>
`; `;
} }

View File

@ -294,7 +294,12 @@ class TfTabNewsFeedElement extends LitElement {
this.loading--; this.loading--;
} }
this.messages = Object.values( this.messages = Object.values(
Object.fromEntries([...this.messages, ...messages].map((x) => [x.id, x])) Object.fromEntries(
[...this.messages, ...messages]
.sort((x, y) => x.timestamp - y.timestamp)
.slice(-1024)
.map((x) => [x.id, x])
)
); );
console.log('done loading latest messages.'); console.log('done loading latest messages.');
} }

View File

@ -8,7 +8,6 @@ class TfTabNewsElement extends LitElement {
whoami: {type: String}, whoami: {type: String},
users: {type: Object}, users: {type: Object},
hash: {type: String}, hash: {type: String},
unread: {type: Array},
following: {type: Array}, following: {type: Array},
drafts: {type: Object}, drafts: {type: Object},
expanded: {type: Object}, expanded: {type: Object},
@ -27,7 +26,6 @@ class TfTabNewsElement extends LitElement {
this.whoami = null; this.whoami = null;
this.users = {}; this.users = {};
this.hash = '#'; this.hash = '#';
this.unread = [];
this.following = []; this.following = [];
this.cache = {}; this.cache = {};
this.drafts = {}; this.drafts = {};
@ -50,36 +48,13 @@ class TfTabNewsElement extends LitElement {
document.body.removeEventListener('keypress', this.on_keypress.bind(this)); document.body.removeEventListener('keypress', this.on_keypress.bind(this));
} }
show_more() { load_latest() {
let unread = this.unread;
let news = this.shadowRoot?.getElementById('news'); let news = this.shadowRoot?.getElementById('news');
if (news) { if (news) {
news.load_latest(); news.load_latest();
this.dispatchEvent(new CustomEvent('refresh'));
} }
} }
new_messages_text() {
if (!this.unread?.length) {
return 'No new messages.';
}
let counts = {};
for (let message of this.unread) {
let type = 'private';
try {
type = JSON.parse(message.content).type || type;
} catch {}
counts[type] = (counts[type] || 0) + 1;
}
return (
'↻ Show New: ' +
Object.keys(counts)
.sort()
.map((x) => counts[x].toString() + ' ' + x + 's')
.join(', ')
);
}
draft(event) { draft(event) {
let id = event.detail.id || ''; let id = event.detail.id || '';
let previous = this.drafts[id]; let previous = this.drafts[id];
@ -245,7 +220,11 @@ class TfTabNewsElement extends LitElement {
id="sidebar_overlay" id="sidebar_overlay"
@click=${this.hide_sidebar} @click=${this.hide_sidebar}
></div> ></div>
<div style="margin-left: 2in; padding: 0px; top: 0; max-height: 100%; overflow: scroll" id="main" class="w3-main"> <div
style="margin-left: 2in; padding: 0px; top: 0; max-height: 100%; overflow: scroll"
id="main"
class="w3-main"
>
<div style="padding: 8px"> <div style="padding: 8px">
<div <div
id="show_sidebar" id="show_sidebar"
@ -255,9 +234,6 @@ class TfTabNewsElement extends LitElement {
&#9776; &#9776;
</div> </div>
<p> <p>
<button class="w3-button w3-theme-d1" @click=${this.show_more}>
${this.new_messages_text()}
</button>
${this.hash.startsWith('##') ${this.hash.startsWith('##')
? html` ? html`
<button <button