2023-06-14 22:51:58 +00:00
|
|
|
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);
|
2024-02-24 11:09:34 -05:00
|
|
|
let results = await tfrpc.rpc.query(
|
|
|
|
`
|
2024-02-28 20:41:27 -05:00
|
|
|
SELECT messages.id, messages.previous, messages.author, messages.sequence, messages.timestamp, messages.hash, json(messages.content) AS content, messages.signature
|
2023-06-14 22:51:58 +00:00
|
|
|
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
|
|
|
|
`,
|
2024-02-24 11:09:34 -05:00
|
|
|
[
|
|
|
|
'"' + this.whoami.replace('"', '""') + '"',
|
|
|
|
JSON.stringify(this.following),
|
|
|
|
this.whoami,
|
|
|
|
]
|
|
|
|
);
|
2023-06-14 22:51:58 +00:00
|
|
|
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`
|
2024-02-24 11:09:34 -05:00
|
|
|
<tf-news
|
|
|
|
id="news"
|
|
|
|
whoami=${this.whoami}
|
|
|
|
.messages=${this.messages}
|
|
|
|
.users=${this.users}
|
|
|
|
.expanded=${this.expanded}
|
|
|
|
@tf-expand=${this.on_expand}
|
|
|
|
></tf-news>
|
2023-06-14 22:51:58 +00:00
|
|
|
`;
|
|
|
|
}
|
|
|
|
}
|
2024-02-24 11:09:34 -05:00
|
|
|
customElements.define('tf-tab-mentions', TfTabMentionsElement);
|