import {LitElement, html, until, unsafeHTML} from './lit-all.min.js'; import * as tfrpc from '/static/tfrpc.js'; import * as tfutils from './tf-utils.js'; import {styles, generate_theme} from './tf-styles.js'; class TfProfileElement extends LitElement { static get properties() { return { editing: {type: Object}, whoami: {type: String}, id: {type: String}, users: {type: Object}, size: {type: Number}, sequence: {type: Number}, following: {type: Boolean}, blocking: {type: Boolean}, show_followed: {type: Boolean}, }; } static styles = styles; constructor() { super(); let self = this; this.editing = null; this.whoami = null; this.id = null; this.users = {}; this.size = 0; this.sequence = 0; } async load() { if (this.whoami !== this._follow_whoami) { this._follow_whoami = this.whoami; this.following = undefined; this.blocking = undefined; let result = await tfrpc.rpc.query( ` SELECT json_extract(content, '$.following') AS following FROM messages WHERE author = ? AND json_extract(content, '$.type') = 'contact' AND json_extract(content, '$.contact') = ? AND following IS NOT NULL ORDER BY sequence DESC LIMIT 1 `, [this.whoami, this.id] ); this.following = result?.[0]?.following ?? false; result = await tfrpc.rpc.query( ` SELECT json_extract(content, '$.blocking') AS blocking FROM messages WHERE author = ? AND json_extract(content, '$.type') = 'contact' AND json_extract(content, '$.contact') = ? AND blocking IS NOT NULL ORDER BY sequence DESC LIMIT 1 `, [this.whoami, this.id] ); this.blocking = result?.[0]?.blocking ?? false; } } modify(change) { let self = this; tfrpc.rpc .appendMessage( this.whoami, Object.assign( { type: 'contact', contact: this.id, }, change ) ) .then(function () { self._follow_whoami = undefined; self.load(); }) .catch(function (error) { alert(error?.message); }); } follow() { this.modify({following: true}); } unfollow() { this.modify({following: false}); } block() { this.modify({blocking: true}); } unblock() { this.modify({blocking: false}); } edit() { let original = this.users[this.id]; this.editing = { name: original.name, description: original.description, image: original.image, publicWebHosting: original.publicWebHosting, }; console.log(this.editing); } save_edits() { let self = this; let message = { type: 'about', about: this.whoami, }; for (let key of Object.keys(this.editing)) { if (this.editing[key] !== this.users[this.id][key]) { message[key] = this.editing[key]; } } tfrpc.rpc .appendMessage(this.whoami, message) .then(function () { self.editing = null; }) .catch(function (error) { alert(error?.message); }); } discard_edits() { this.editing = null; } attach_image() { let self = this; let input = document.createElement('input'); input.type = 'file'; input.addEventListener('change', function (event) { input.parentNode.removeChild(input); let file = event.target.files[0]; file .arrayBuffer() .then(function (buffer) { let bin = Array.from(new Uint8Array(buffer)); return tfrpc.rpc.store_blob(bin); }) .then(function (id) { self.editing = Object.assign({}, self.editing, {image: id}); console.log(self.editing); }) .catch(function (e) { alert(e.message); }); }); document.body.appendChild(input); input.click(); } copy_id() { navigator.clipboard.writeText(this.id); } show_image(link) { let div = document.createElement('div'); div.style.left = 0; div.style.top = 0; div.style.width = '100%'; div.style.height = '100%'; div.style.position = 'fixed'; div.style.background = '#000'; div.style.zIndex = 100; div.style.display = 'grid'; let img = document.createElement('img'); img.src = link; img.style.maxWidth = '100vw'; img.style.maxHeight = '100vh'; img.style.display = 'block'; img.style.margin = 'auto'; img.style.objectFit = 'contain'; img.style.width = '100vw'; div.appendChild(img); function image_close(event) { document.body.removeChild(div); window.removeEventListener('keydown', image_close); } div.onclick = image_close; window.addEventListener('keydown', image_close); document.body.appendChild(div); } body_click(event) { if (event.srcElement.tagName == 'IMG') { this.show_image(event.srcElement.src); } } toggle_account_list(event) { let content = event.srcElement.nextElementSibling; this.show_followed = !this.show_followed; } async load_follows() { let accounts = await tfrpc.rpc.following([this.id], 1); return html`
Loading accounts followed...
`)}