diff --git a/apps/cory/ssblit.json b/apps/cory/ssblit.json index 7b955ccd6..55afbce48 100644 --- a/apps/cory/ssblit.json +++ b/apps/cory/ssblit.json @@ -1 +1 @@ -{"type":"tildefriends-app","files":{"app.js":"&XCpiJOtpMzQz5Zo+Hu9f3ppQON9PxFdV4XnS2Ae+Ye8=.sha256","lit-all.min.js":"&N4A12AsifdQgwdpII0SFtG513BfoLpmPjdJ9VTDftpg=.sha256","index.html":"&Vpp3ezlQiD5guf1P6yZhpcNMnO0u+uQoil3hNkwiIp4=.sha256","script.js":"&G8puK9Q4MngHy3D4ppcKyT49WKbHD2OCeUcAw2ghTDE=.sha256","lit-all.min.js.map":"&oFY9wO4MnujgfGNGv4VggHc5V5JwX4C8csqKZ6KJYbE=.sha256","tf-id-picker.js":"&9BDffV4HY9FqhL7XI4it+UQJB4cYwbDNsY3S1cxy2vw=.sha256","tf-app.js":"&qqpOZHnkJQevhLGPUEJ7br2S/LNH+nQtC91vz3CrYrE=.sha256","tf-message.js":"&fFCn+5+eRe552tiiESswbXVU2oEfibb+w0gzZKKGWkk=.sha256","tf-user.js":"&bXTedgBudTQLXEBPY9R8OLfQ/ZLpo8YRU9Oq/wuGG3Y=.sha256","tf-utils.js":"&N2yKZwFnb2GbPeipgQtu6xFvezENNOgud9G7EhCQ/K0=.sha256","commonmark.min.js":"&bfBaMLU19d1p/vPBF9hlARqDX002KXG/UOfxOahZhe4=.sha256","tf-compose.js":"&b/mMiihhTtPEmLC7qUnd9P1UY4+UR7wq+YKwRK1SU9A=.sha256","emojis.json":"&h3P4pez+AI4aYdsN0dJ3pbUEFR0276t9AM20caj/W/s=.sha256","emojis.js":"&pqYLDE/13PyEt2ceeFqvnwZ8NqWfPfpDBt4vP8SeHbs=.sha256","tf-styles.js":"&Zw90HptAvGwX/vBnEhRVfNrYjMSssFnnKpp8bzwXQH0=.sha256","tf-profile.js":"&vRKjsnYvOiHCQahzEfznCvP5YDwUPtltlpWf+pxwZ1Y=.sha256","commonmark-linkify.js":"&X+hNNkmSRvKY86khyAun+cXksquXbMakZdINbGbx30g=.sha256","tf-tab-search.js":"&ESt2vMG19sH5j6ungKua/ZuvIGslyuWyb3juXdOCecg=.sha256","tf-tab-news.js":"&6ialbh/M2eBCDH6wFyoOHyDqG9QHbyIrzvRK+CgeyRc=.sha256","tf-tab-connections.js":"&jSnF/5NmgqxRze1XQAEGOW5mPzOV1/8aCyrDRZu34IQ=.sha256","tf-news.js":"&K3azL6eFcgbM9xpLHU3L5oSOApi1fXEvJZrhPkZgDpQ=.sha256","tribute.css":"&9FogMzZHKXCfGb7mlh7z+/wiNZzBsOB/tKoh6MfYJno=.sha256","tribute.esm.js":"&P1wKqCfYULpR/ahSB98JP8xaxfikuZwwtT6I/SAo7/Y=.sha256"}} \ No newline at end of file +{"type":"tildefriends-app","files":{"app.js":"&XCpiJOtpMzQz5Zo+Hu9f3ppQON9PxFdV4XnS2Ae+Ye8=.sha256","lit-all.min.js":"&N4A12AsifdQgwdpII0SFtG513BfoLpmPjdJ9VTDftpg=.sha256","index.html":"&Vpp3ezlQiD5guf1P6yZhpcNMnO0u+uQoil3hNkwiIp4=.sha256","script.js":"&G8puK9Q4MngHy3D4ppcKyT49WKbHD2OCeUcAw2ghTDE=.sha256","lit-all.min.js.map":"&oFY9wO4MnujgfGNGv4VggHc5V5JwX4C8csqKZ6KJYbE=.sha256","tf-id-picker.js":"&9BDffV4HY9FqhL7XI4it+UQJB4cYwbDNsY3S1cxy2vw=.sha256","tf-app.js":"&qqpOZHnkJQevhLGPUEJ7br2S/LNH+nQtC91vz3CrYrE=.sha256","tf-message.js":"&fFCn+5+eRe552tiiESswbXVU2oEfibb+w0gzZKKGWkk=.sha256","tf-user.js":"&bXTedgBudTQLXEBPY9R8OLfQ/ZLpo8YRU9Oq/wuGG3Y=.sha256","tf-utils.js":"&N2yKZwFnb2GbPeipgQtu6xFvezENNOgud9G7EhCQ/K0=.sha256","commonmark.min.js":"&bfBaMLU19d1p/vPBF9hlARqDX002KXG/UOfxOahZhe4=.sha256","tf-compose.js":"&QTKDJcbhLICwXdBQKD1v26NziF9QnSJtcaD1vEKGaag=.sha256","emojis.json":"&h3P4pez+AI4aYdsN0dJ3pbUEFR0276t9AM20caj/W/s=.sha256","emojis.js":"&pqYLDE/13PyEt2ceeFqvnwZ8NqWfPfpDBt4vP8SeHbs=.sha256","tf-styles.js":"&Zw90HptAvGwX/vBnEhRVfNrYjMSssFnnKpp8bzwXQH0=.sha256","tf-profile.js":"&vRKjsnYvOiHCQahzEfznCvP5YDwUPtltlpWf+pxwZ1Y=.sha256","commonmark-linkify.js":"&X+hNNkmSRvKY86khyAun+cXksquXbMakZdINbGbx30g=.sha256","tf-tab-search.js":"&ESt2vMG19sH5j6ungKua/ZuvIGslyuWyb3juXdOCecg=.sha256","tf-tab-news.js":"&6ialbh/M2eBCDH6wFyoOHyDqG9QHbyIrzvRK+CgeyRc=.sha256","tf-tab-connections.js":"&jSnF/5NmgqxRze1XQAEGOW5mPzOV1/8aCyrDRZu34IQ=.sha256","tf-news.js":"&K3azL6eFcgbM9xpLHU3L5oSOApi1fXEvJZrhPkZgDpQ=.sha256","tribute.css":"&9FogMzZHKXCfGb7mlh7z+/wiNZzBsOB/tKoh6MfYJno=.sha256","tribute.esm.js":"&P1wKqCfYULpR/ahSB98JP8xaxfikuZwwtT6I/SAo7/Y=.sha256"}} \ No newline at end of file diff --git a/apps/cory/ssblit/tf-compose.js b/apps/cory/ssblit/tf-compose.js index f5562dd43..e314de8df 100644 --- a/apps/cory/ssblit/tf-compose.js +++ b/apps/cory/ssblit/tf-compose.js @@ -11,6 +11,7 @@ class TfComposeElement extends LitElement { users: {type: Object}, root: {type: String}, branch: {type: String}, + mentions: {type: Object}, } } @@ -21,12 +22,62 @@ class TfComposeElement extends LitElement { this.users = {}; this.root = undefined; this.branch = undefined; + this.mentions = {}; } changed(event) { let edit = this.renderRoot.getElementById('edit'); let preview = this.renderRoot.getElementById('preview'); - preview.innerHTML = tfutils.markdown(edit.value); + let text = edit.value; + + /* Update mentions. */ + for (let match of text.matchAll(/\[([^\[]+)]\(([@&%][^\)]+)/g)) { + let name = match[1]; + let link = match[2]; + let balance = 0; + let bracket_end = match.index + match[1].length + '[]'.length - 1; + for (let i = bracket_end; i >= 0; i--) { + if (text.charAt(i) == ']') { + balance++; + } else if (text.charAt(i) == '[') { + balance--; + } + if (balance <= 0) { + name = text.substring(i + 1, bracket_end); + break; + } + } + if (!this.mentions[link]) { + this.mentions[link] = { + link: link, + } + } + this.mentions[link].name = name.startsWith('@') ? name.substring(1) : name; + this.mentions = Object.assign({}, this.mentions); + } + + preview.innerHTML = tfutils.markdown(text); + } + + add_file(file) { + let self = this; + file.arrayBuffer().then(function(buffer) { + let bin = Array.from(new Uint8Array(buffer)); + return Promise.all([tfrpc.rpc.store_blob(bin), bin]); + }).then(function([id, bin]) { + self.mentions[id] = { + link: id, + name: file.name, + type: file.type, + size: bin.length, + }; + self.mentions = Object.assign({}, self.mentions); + let edit = self.renderRoot.getElementById('edit'); + edit.value += `\n![${file.name}](${id})`; + self.changed(); + }).catch(function(e) { + alert(e.message); + }); } paste(event) { @@ -37,16 +88,7 @@ class TfComposeElement extends LitElement { if (!file) { continue; } - file.arrayBuffer().then(function(buffer) { - let bin = Array.from(new Uint8Array(buffer)); - return tfrpc.rpc.store_blob(bin); - }).then(function(id) { - let edit = self.renderRoot.getElementById('edit'); - edit.value += `\n![${file.name}](${id})`; - self.changed(); - }).catch(function(e) { - alert(e.message); - }); + self.add_file(file); break; } } @@ -63,28 +105,8 @@ class TfComposeElement extends LitElement { message.root = this.root; message.branch = this.branch; } - for (let match of message.text.matchAll(/\[([^\[]+)]\((@[^\)]+)/g)) { - if (!message.mentions) { - message.mentions = []; - } - let name = match[1].length; - let balance = 0; - let bracket_end = match.index + match[1].length + '[]'.length - 1; - for (let i = bracket_end; i >= 0; i--) { - if (message.text.charAt(i) == ']') { - balance++; - } else if (message.text.charAt(i) == '[') { - balance--; - } - if (balance <= 0) { - name = message.text.substring(i + 1, bracket_end - i); - break; - } - } - message.mentions.push({ - link: match[2], - name: name.charAt(0) == '@' ? name.substring(1) : name, - }); + if (Object.values(this.mentions).length) { + message.mentions = Object.values(this.mentions); } console.log('Would post:', message); tfrpc.rpc.appendMessage(this.whoami, message).then(function() { @@ -109,15 +131,7 @@ class TfComposeElement extends LitElement { input.type = 'file'; input.onchange = function(event) { 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) { - edit.value += `\n![${file.name}](${id})`; - self.changed(); - }).catch(function(e) { - alert(e.message); - }); + self.add_file(file); }; input.click(); } @@ -132,12 +146,28 @@ class TfComposeElement extends LitElement { tribute.attach(this.renderRoot.getElementById('edit')); } + remove_mention(id) { + delete this.mentions[id]; + this.mentions = Object.assign({}, this.mentions); + } + + render_mention(mention) { + let self = this; + return html` +
+
${JSON.stringify(mention, null, 2)}
+ self.remove_mention(mention.link)}> +
`; + } + render() { + let self = this; let result = html`
+ ${Object.values(this.mentions).map(x => self.render_mention(x))}