From 51b317233af0b6d89d1f923cd614941087b6cdb7 Mon Sep 17 00:00:00 2001 From: Cory McWilliams Date: Wed, 14 Jun 2023 22:51:58 +0000 Subject: [PATCH] First rough-out of a mentions tab in the SSB app. git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@4324 ed5197a5-7fde-0310-b194-c3ffbd925b24 --- apps/ssb/script.js | 3 +- apps/ssb/tf-app.js | 9 +++++ apps/ssb/tf-tab-mentions.js | 65 +++++++++++++++++++++++++++++++++++++ 3 files changed, 76 insertions(+), 1 deletion(-) create mode 100644 apps/ssb/tf-tab-mentions.js diff --git a/apps/ssb/script.js b/apps/ssb/script.js index b6c18721..d1696c01 100644 --- a/apps/ssb/script.js +++ b/apps/ssb/script.js @@ -8,7 +8,8 @@ import * as tf_user from './tf-user.js'; import * as tf_compose from './tf-compose.js'; import * as tf_news from './tf-news.js'; import * as tf_profile from './tf-profile.js'; +import * as tf_tab_mentions from './tf-tab-mentions.js'; import * as tf_tab_news from './tf-tab-news.js'; import * as tf_tab_news_feed from './tf-tab-news-feed.js'; import * as tf_tab_search from './tf-tab-search.js'; -import * as tf_tab_connections from './tf-tab-connections.js'; +import * as tf_tab_connections from './tf-tab-connections.js'; \ No newline at end of file diff --git a/apps/ssb/tf-app.js b/apps/ssb/tf-app.js index 2be0bf5d..8cd38743 100644 --- a/apps/ssb/tf-app.js +++ b/apps/ssb/tf-app.js @@ -64,6 +64,8 @@ class TfElement extends LitElement { this.tab = 'search'; } else if (this.hash === '#connections') { this.tab = 'connections'; + } else if (this.hash === '#mentions') { + this.tab = 'mentions'; } else { this.tab = 'news'; } @@ -273,6 +275,10 @@ class TfElement extends LitElement { return html` `; + } else if (this.tab === 'mentions') { + return html` + + `; } else if (this.tab === 'search') { return html` @@ -286,6 +292,8 @@ class TfElement extends LitElement { await tfrpc.rpc.setHash('#'); } else if (tab === 'connections') { await tfrpc.rpc.setHash('#connections'); + } else if (tab === 'mentions') { + await tfrpc.rpc.setHash('#mentions'); } } @@ -304,6 +312,7 @@ class TfElement extends LitElement {
self.set_tab('news')}> self.set_tab('connections')}> + self.set_tab('mentions')}> self.set_tab('search')}>
`; diff --git a/apps/ssb/tf-tab-mentions.js b/apps/ssb/tf-tab-mentions.js new file mode 100644 index 00000000..3d6924b2 --- /dev/null +++ b/apps/ssb/tf-tab-mentions.js @@ -0,0 +1,65 @@ +import {LitElement, html, unsafeHTML} from './lit-all.min.js'; +import * as tfrpc from '/static/tfrpc.js'; +import {styles} from './tf-styles.js'; + +class TfTabMentionsElement extends LitElement { + static get properties() { + return { + whoami: {type: String}, + users: {type: Object}, + following: {type: Array}, + expanded: {type: Object}, + messages: {type: Array}, + }; + } + + static styles = styles; + + constructor() { + super(); + let self = this; + this.whoami = null; + this.users = {}; + this.following = []; + this.expanded = {}; + this.messages = []; + } + + async load() { + console.log('Loading...', this.whoami); + let results = await tfrpc.rpc.query(` + SELECT messages.* + FROM messages_fts(?) + JOIN messages ON messages.rowid = messages_fts.rowid + JOIN json_each(?) AS following ON messages.author = following.value + WHERE messages.author != ? + ORDER BY timestamp DESC limit 20 + `, + ['"' + this.whoami.replace('"', '""') + '"', JSON.stringify(this.following), this.whoami]); + console.log('Done.'); + this.messages = results; + } + + on_expand(event) { + if (event.detail.expanded) { + let expand = {}; + expand[event.detail.id] = true; + this.expanded = Object.assign({}, this.expanded, expand); + } else { + delete this.expanded[event.detail.id]; + this.expanded = Object.assign({}, this.expanded); + } + } + + render() { + let self = this; + if (!this.loading) { + this.loading = true; + this.load(); + } + return html` + + `; + } +} +customElements.define('tf-tab-mentions', TfTabMentionsElement); \ No newline at end of file