import {LitElement, html, unsafeHTML} from './lit-all.min.js'; import * as tfrpc from '/static/tfrpc.js'; import {styles} from './tf-styles.js'; class TfTabQueryElement extends LitElement { static get properties() { return { whoami: {type: String}, users: {type: Object}, following: {type: Array}, query: {type: String}, expanded: {type: Object}, results: {type: Array}, error: {type: Object}, duration: {type: Number}, }; } static styles = styles; constructor() { super(); let self = this; this.whoami = null; this.users = {}; this.following = []; this.expanded = {}; this.duration = undefined; } async search(query) { console.log('Searching...', this.whoami, query); this.results = []; this.error = undefined; this.duration = undefined; let search = this.renderRoot.getElementById('search'); if (search) { search.value = query; search.focus(); } await tfrpc.rpc.setHash('#sql=' + encodeURIComponent(query)); let start_time = new Date(); try { this.results = await tfrpc.rpc.query(query, []) } catch (error) { this.error = error; } let end_time = new Date(); this.duration = (end_time - start_time).valueOf(); console.log('Done.'); search = this.renderRoot.getElementById('search'); if (search) { search.value = query; search.focus(); } } search_keydown(event) { if (event.keyCode == 13 && event.ctrlKey) { this.query = this.renderRoot.getElementById('search').value; event.preventDefault(); } } 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_results() { if (!this.results?.length) { return html`
No results.
`; } else { let keys = Object.keys(this.results[0]).sort(); return html`${keys.map(key => html``)} ${this.results.map(row => html`${keys.map(key => html``)}`)}
${key}
${row[key]}
`; } } render_error() { return html`
${JSON.stringify(this.error, null, 2)}
`; } render() { if (this.query !== this.last_query) { this.last_query = this.query; this.search(this.query); } let self = this; return html`
self.search(self.renderRoot.getElementById('search').value)}>
Took ${this.duration / 1000.0} seconds.
Executing...
${this.render_error()} ${this.render_results()} `; } } customElements.define('tf-tab-query', TfTabQueryElement);