2024-07-05 01:27:29 +00:00
|
|
|
import util from "./util"
|
|
|
|
import { Message, Author } from "./message"
|
2024-07-16 19:43:35 +00:00
|
|
|
import { AdapterState } from "./adapter"
|
2024-07-05 01:27:29 +00:00
|
|
|
|
|
|
|
export class ThreadSummaryElement extends HTMLElement {
|
2024-07-05 05:23:56 +00:00
|
|
|
static observedAttributes = [ "data-len", "data-author", "data-latest", "data-new" ];
|
2024-07-05 01:27:29 +00:00
|
|
|
|
|
|
|
private _len: number = 0;;
|
|
|
|
private _msg: Message | null = null;;
|
|
|
|
private _author: Author | null = null;
|
|
|
|
private _adapter: string = "";
|
2024-07-16 19:43:35 +00:00
|
|
|
private _created: number = 0;
|
|
|
|
private _latest: number = 0;
|
2024-07-05 01:27:29 +00:00
|
|
|
private _new: boolean = false;
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
}
|
|
|
|
|
|
|
|
connectedCallback() {
|
|
|
|
this.innerHTML = "<div class='thread_summary'><div class='thread_author'></div><div class='thread_text'></div><div class='thread_metadata'></div></div>"
|
|
|
|
|
|
|
|
// adapter shouldn't change, just set it here
|
|
|
|
this._adapter = this.getAttribute("data-adapter") ?? "";
|
|
|
|
this.attributeChangedCallback();
|
|
|
|
if (this._msg) {
|
|
|
|
this.addEventListener("click", this.viewThread(this), false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
attributeChangedCallback() {
|
2024-07-16 19:43:35 +00:00
|
|
|
const datastore = AdapterState._instance.data.get(this._adapter);
|
2024-07-05 01:27:29 +00:00
|
|
|
const msgId = this.getAttribute("data-msg");
|
2024-07-05 05:23:56 +00:00
|
|
|
if (msgId && datastore && !this._msg) {
|
2024-07-16 19:43:35 +00:00
|
|
|
this._msg = datastore.messages.get(msgId) || null;
|
2024-07-05 01:27:29 +00:00
|
|
|
if (this._msg) {
|
|
|
|
const threadText = this.querySelector(".thread_text");
|
|
|
|
if (threadText) {
|
|
|
|
threadText.innerHTML = this._msg.content;
|
|
|
|
}
|
|
|
|
let author = datastore.profileCache.get(this._msg.author);
|
|
|
|
if (!author) {
|
2024-07-07 03:13:18 +00:00
|
|
|
util.authorizedFetch(
|
|
|
|
"GET",
|
|
|
|
`/api/adapters/${this._adapter}/fetch?entity_type=author&entity_id=${this._msg.author}`,
|
|
|
|
null);
|
2024-07-05 01:27:29 +00:00
|
|
|
}
|
|
|
|
this._author = author || <Author>{ id: this._msg.author };
|
|
|
|
const threadAuthor = this.querySelector(".thread_author");
|
|
|
|
if (threadAuthor && this._author) {
|
|
|
|
threadAuthor.innerHTML = this._author.profilePic
|
2024-07-05 05:23:56 +00:00
|
|
|
? `<img src="${this._author.profilePic}" alt="${this._author.id}"/> <a id="thread_${this._adapter}_${this._msg.id}_${this._author.id}" href="#author?id=${this._author.id}">${this._author.id}</a>`
|
|
|
|
: `<a id="thread_${this._adapter}_${this._msg.id}_${this._author.id}" href="#author?id=${this._author.id}">${this._author.id}</a>`;
|
2024-07-05 01:27:29 +00:00
|
|
|
}
|
2024-07-05 05:23:56 +00:00
|
|
|
}
|
|
|
|
}
|
2024-07-05 01:27:29 +00:00
|
|
|
|
2024-07-05 05:23:56 +00:00
|
|
|
// update author if it's passed in the attribute
|
|
|
|
const authorId = this.getAttribute("data-author");
|
|
|
|
if (authorId) {
|
2024-07-16 19:43:35 +00:00
|
|
|
let author = datastore?.profileCache?.get(this._msg?.author || "");
|
2024-07-05 05:23:56 +00:00
|
|
|
if (author) {
|
|
|
|
this._author = author;
|
|
|
|
const threadAuthor = this.querySelector(".thread_author");
|
|
|
|
if (threadAuthor && this._author && this._msg) {
|
|
|
|
threadAuthor.innerHTML = this._author.profilePic
|
2024-07-16 19:43:35 +00:00
|
|
|
? `<img src="${this._author.profilePic}" alt="${this._author.id}"/> <a id="thread_${this._adapter}_${this._msg.id}_${this._author.id}" href="#author?id=${this._author.id}">${this._author.id}</a>`
|
|
|
|
: `<a id="thread_${this._adapter}_${this._msg.id}_${this._author.id}" href="#author?id=${author.id}">${this._author.id}</a>` ;
|
2024-07-05 01:27:29 +00:00
|
|
|
}
|
2024-07-05 05:23:56 +00:00
|
|
|
}
|
|
|
|
}
|
2024-07-05 01:27:29 +00:00
|
|
|
|
|
|
|
const l = parseInt(this.getAttribute("data-len") ?? "0");
|
2024-07-05 05:49:51 +00:00
|
|
|
const latest = this.getAttribute("data-latest") ;
|
|
|
|
const created = this.getAttribute("data-created");
|
2024-07-05 01:27:29 +00:00
|
|
|
const newness = this.getAttribute("data-new") ? true : false;
|
|
|
|
|
|
|
|
let metadataChanged = false;
|
|
|
|
|
2024-07-05 05:23:56 +00:00
|
|
|
if (l && l != this._len) {
|
2024-07-05 01:27:29 +00:00
|
|
|
metadataChanged = true;
|
|
|
|
this._len = l;
|
|
|
|
}
|
2024-07-16 19:43:35 +00:00
|
|
|
if (created && parseInt(created) != this._created) {
|
2024-07-05 01:27:29 +00:00
|
|
|
metadataChanged = true;
|
2024-07-16 19:43:35 +00:00
|
|
|
this._created = parseInt(created);
|
2024-07-05 05:49:51 +00:00
|
|
|
this._latest = this._created;
|
2024-07-05 01:27:29 +00:00
|
|
|
}
|
2024-07-16 19:43:35 +00:00
|
|
|
if (latest && parseInt(latest) != this._latest) {
|
2024-07-05 01:27:29 +00:00
|
|
|
metadataChanged = true;
|
2024-07-16 19:43:35 +00:00
|
|
|
this._latest = parseInt(latest);
|
2024-07-05 01:27:29 +00:00
|
|
|
}
|
2024-07-05 05:23:56 +00:00
|
|
|
|
2024-07-05 01:27:29 +00:00
|
|
|
if (newness != this._new) {
|
|
|
|
metadataChanged = true;
|
|
|
|
this._new = newness;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (metadataChanged) {
|
|
|
|
const threadMeta = this.querySelector(".thread_metadata");
|
|
|
|
if (threadMeta) {
|
|
|
|
threadMeta.innerHTML = `<span>${this._new ? "!" : ""}[${this._len}] created: ${this._created}, updated: ${this._latest}</span>`;
|
|
|
|
}
|
|
|
|
}
|
2024-07-05 05:23:56 +00:00
|
|
|
}
|
2024-07-05 01:27:29 +00:00
|
|
|
viewThread(self: ThreadSummaryElement) {
|
|
|
|
return () => {
|
2024-07-16 19:43:35 +00:00
|
|
|
const a = util.$(`adapter_${self._adapter}`);
|
2024-07-05 01:27:29 +00:00
|
|
|
if (a && self._msg) {
|
|
|
|
a.setAttribute("data-view", "thread");
|
|
|
|
a.setAttribute("data-viewing", self._msg.id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|