aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorcel <cel@f/6sQ6d2CMxRUhLpspgGIulDxDCwYD7DzFzPNr7u5AU=.ed25519>2017-04-18 22:39:48 -0700
committercel <cel@f/6sQ6d2CMxRUhLpspgGIulDxDCwYD7DzFzPNr7u5AU=.ed25519>2017-04-18 22:56:18 -0700
commit8c9c632d317ee272b1ad900eece3fb1aeaa003e8 (patch)
tree44bca69cb26a135faf3d17e0fa8c40b6982ffb68 /lib
parent3c9f0621cd6d605de9beeacfc4703539f1590ab4 (diff)
downloadpatchfoo-8c9c632d317ee272b1ad900eece3fb1aeaa003e8.tar.gz
patchfoo-8c9c632d317ee272b1ad900eece3fb1aeaa003e8.zip
Move name fields next to the composer textarea
instead of in the preview area. This is to clarify that the name completions are part of what is being composed.
Diffstat (limited to 'lib')
-rw-r--r--lib/serve.js50
1 files changed, 31 insertions, 19 deletions
diff --git a/lib/serve.js b/lib/serve.js
index 68eebda..d3a1a6b 100644
--- a/lib/serve.js
+++ b/lib/serve.js
@@ -1177,6 +1177,24 @@ Serve.prototype.composer = function (opts, cb) {
+ '[' + data.upload.name + '](' + data.upload.link + ')'
}
+ // get bare feed names
+ var unknownMentionNames = {}
+ var unknownMentions = ssbMentions(data.text, {bareFeedNames: true})
+ .filter(function (mention) {
+ return mention.link === '@'
+ })
+ .filter(function (mention) {
+ if (unknownMentionNames[mention.name]) return false
+ unknownMentionNames[mention.name] = true
+ return true
+ })
+ .map(function (mention) {
+ var name = mention.name
+ var fullName = mention.link + name
+ var id = formNames[name] || self.app.getReverseNameSync(fullName)
+ return {name: name, fullName: fullName, id: id}
+ })
+
var done = multicb({pluck: 1, spread: true})
done()(null, h('section.composer',
h('form', {method: 'post', action: opts.id ? '#' + opts.id : '',
@@ -1196,6 +1214,17 @@ Serve.prototype.composer = function (opts, cb) {
cols: 70,
placeholder: opts.placeholder || 'public message',
}, data.text || ''),
+ unknownMentions.length > 0 ? [
+ h('div', h('em', 'names:')),
+ h('ul.mentions', unknownMentions.map(function (mention) {
+ return h('li',
+ h('code', mention.fullName), ': ',
+ h('input', {name: 'mention_name', type: 'hidden',
+ value: mention.name}),
+ h('input.mention-id-input', {name: 'mention_id',
+ value: mention.id, placeholder: 'id'}))
+ }))
+ ] : '',
h('table.ssb-msgs',
h('tr.msg-row',
h('td.msg-left', {colspan: 2},
@@ -1216,8 +1245,6 @@ Serve.prototype.composer = function (opts, cb) {
function preview(raw, cb) {
var myId = self.app.sbot.id
var content
- var unknownMentions = []
- var unknownMentionNames = {}
try {
content = JSON.parse(data.text)
} catch (err) {
@@ -1227,8 +1254,7 @@ Serve.prototype.composer = function (opts, cb) {
text: data.text,
}
var mentions = ssbMentions(data.text, {bareFeedNames: true})
- if (mentions.length) {
- content.mentions = mentions.filter(function (mention) {
+ .filter(function (mention) {
var blob = blobs[mention.link]
if (blob) {
if (!isNaN(blob.size))
@@ -1238,17 +1264,14 @@ Serve.prototype.composer = function (opts, cb) {
} else if (mention.link === '@') {
// bare feed name
var name = mention.name
- if (unknownMentionNames[name]) return false
- unknownMentionNames[name] = true
var fullName = mention.link + name
var id = formNames[name] || self.app.getReverseNameSync(fullName)
- unknownMentions.push({name: name, fullName: fullName, id: id})
if (id) mention.link = id
else return false
}
return true
})
- }
+ if (mentions.length) content.mentions = mentions
if (data.recps != null) {
if (opts.recps) return cb(new Error('got recps in opts and data'))
content.recps = [myId]
@@ -1284,17 +1307,6 @@ Serve.prototype.composer = function (opts, cb) {
value: JSON.stringify(content)}),
h('div', h('em', 'draft:')),
msgContainer,
- unknownMentions.length > 0 ? [
- h('div', h('em', 'names:')),
- h('ul', unknownMentions.map(function (mention) {
- return h('li',
- h('code', mention.fullName), ': ',
- h('input', {name: 'mention_name', type: 'hidden',
- value: mention.name}),
- h('input.mention-id-input', {name: 'mention_id',
- value: mention.id, placeholder: 'id'}))
- }))
- ] : '',
h('div.composer-actions',
h('input', {type: 'submit', name: 'action', value: 'publish'})
)