/** Support for quoting other users. **/ var esc = Handlebars.Utils.escapeExpression; Discourse.Dialect.replaceBlock({ start: new RegExp("\\[quote=?([^\\[\\]]+)?\\]([\\s\\S]*)", "igm"), stop: '[/quote]', emitter: function(blockContents, matches, options) { var params = {'class': 'quote'}, username; if (matches[1]) { var paramsString = matches[1].replace(/\"/g, ''), paramsSplit = paramsString.split(/\, */); username = paramsSplit[0]; paramsSplit.forEach(function(p,i) { if (i > 0) { var assignment = p.split(':'); if (assignment[0] && assignment[1]) { params['data-' + esc(assignment[0])] = esc(assignment[1].trim()); } } }); } var avatarImg; if (options.lookupAvatarByPostNumber) { // client-side, we can retrieve the avatar from the post var postNumber = parseInt(params['data-post'], 10); avatarImg = options.lookupAvatarByPostNumber(postNumber); } else if (options.lookupAvatar) { // server-side, we need to lookup the avatar from the username avatarImg = options.lookupAvatar(username); } var contents = ['blockquote']; if (blockContents.length) { var self = this; if (blockContents && (typeof blockContents[0] === "string")) { blockContents[0] = blockContents[0].replace(/^[\s]*/, ''); } blockContents.forEach(function (bc) { var processed = self.processInline(bc); if (processed.length) { contents.push(['p'].concat(processed)); } }); } // If there's no username just return a simple quote if (!username) { return ['p', ['aside', params, contents ]]; } return ['p', ['aside', params, ['div', {'class': 'title'}, ['div', {'class': 'quote-controls'}], avatarImg ? ['__RAW', avatarImg] : "", username ? I18n.t('user.said', {username: username}) : "" ], contents ]]; } }); Discourse.Dialect.on("parseNode", function(event) { var node = event.node, path = event.path; // Make sure any quotes are followed by a
. The formatting looks weird otherwise. if (node[0] === 'aside' && node[1] && node[1]['class'] === 'quote') { var parent = path[path.length - 1], location = parent.indexOf(node)+1, trailing = parent.slice(location); if (trailing.length) { parent.splice(location, 0, ['br']); } } });