From 330e1efa781544d96bec3552f9b478d25747f51c Mon Sep 17 00:00:00 2001 From: Bryan Ashby Date: Tue, 13 Nov 2018 21:11:33 -0700 Subject: [PATCH] Updates to user interruptions & node-to-node message module * Can now have header/footer art on node-to-node messages * 'text' and more advanced 'contents' fields * format via 'messageFormat' --- core/node_msg.js | 86 ++++++++++++++++++++++++++++++------ core/user_interrupt_queue.js | 15 +++++-- 2 files changed, 85 insertions(+), 16 deletions(-) diff --git a/core/node_msg.js b/core/node_msg.js index 276dae2f..fde5f35e 100644 --- a/core/node_msg.js +++ b/core/node_msg.js @@ -9,10 +9,14 @@ const { getConnectionByNodeId, } = require('./client_connections.js'); const UserInterruptQueue = require('./user_interrupt_queue.js'); +const { getThemeArt } = require('./theme.js'); +const { pipeToAnsi } = require('./color_codes.js'); +const stringFormat = require('./string_format.js'); // deps -const series = require('async/series'); -const _ = require('lodash'); +const series = require('async/series'); +const _ = require('lodash'); +const async = require('async'); exports.moduleInfo = { name : 'Node Message', @@ -44,18 +48,16 @@ exports.getModule = class NodeMessageModule extends MenuModule { const nodeId = formData.value.node; const message = formData.value.message; - const interruptItem = { - contents : message, - } + this.createInterruptItem(message, (err, interruptItem) => { + if(0 === nodeId) { + // ALL nodes + UserInterruptQueue.queueGlobalOtherActive(interruptItem, this.client); + } else { + UserInterruptQueue.queueGlobal(interruptItem, [ getConnectionByNodeId(nodeId) ]); + } - if(0 === nodeId) { - // ALL nodes - UserInterruptQueue.queueGlobalOtherActive(interruptItem, this.client); - } else { - UserInterruptQueue.queueGlobal(interruptItem, [ getConnectionByNodeId(nodeId) ]); - } - - return this.prevMenu(cb); + return this.prevMenu(cb); + }); }, } } @@ -96,6 +98,64 @@ exports.getModule = class NodeMessageModule extends MenuModule { }); } + createInterruptItem(message, cb) { + const textFormatObj = { + fromUserName : this.client.user.username, + fromRealName : this.client.user.properties.real_name, + fromNodeId : this.client.node, + message : message, + }; + + const messageFormat = + this.config.messageFormat || + 'Message from {fromUserName} on node {fromNodeId}:\r\n{message}'; + + const item = { + text : stringFormat(messageFormat, textFormatObj), + pause : true, + }; + + const getArt = (name, callback) => { + const spec = _.get(this.config, `art.${name}`); + if(!spec) { + return callback(null); + } + const getArtOpts = { + name : spec, + client : this.client, + random : false, + }; + getThemeArt(getArtOpts, (err, artInfo) => { + // ignore errors + return callback(artInfo ? artInfo.data : null); + }); + }; + + async.waterfall( + [ + (callback) => { + getArt('header', headerArt => { + return callback(null, headerArt); + }); + }, + (headerArt, callback) => { + getArt('footer', footerArt => { + return callback(null, headerArt, footerArt); + }); + }, + (headerArt, footerArt, callback) => { + if(headerArt || footerArt) { + item.contents = `${headerArt || ''}\r\n${pipeToAnsi(item.text)}\r\n${footerArt || ''}`; + } + return callback(null); + } + ], + err => { + return cb(err, item); + } + ); + } + prepareNodeList() { // standard node list with {text} field added for compliance this.nodeList = [{ diff --git a/core/user_interrupt_queue.js b/core/user_interrupt_queue.js index a29fd4df..be6767d5 100644 --- a/core/user_interrupt_queue.js +++ b/core/user_interrupt_queue.js @@ -7,6 +7,7 @@ const { getActiveConnections } = require('./client_connections.js'); const ANSI = require('./ansi_term.js'); +const { pipeToAnsi } = require('./color_codes.js'); // deps const _ = require('lodash'); @@ -31,6 +32,9 @@ module.exports = class UserInterruptQueue } queueItem(interruptItem) { + if(!_.isString(interruptItem.contents) && !_.isString(interruptItem.text)) { + return; + } interruptItem.pause = _.get(interruptItem, 'pause', true); this.queue.push(interruptItem); } @@ -51,8 +55,13 @@ module.exports = class UserInterruptQueue this.client.term.rawWrite('\r\n\r\n'); } - Art.display(this.client, interruptItem.contents, err => { - return cb(err, interruptItem); - }); + if(interruptItem.contents) { + Art.display(this.client, interruptItem.contents, err => { + this.client.term.rawWrite('\r\n\r\n'); + return cb(err, interruptItem); + }); + } else { + return this.client.term.write(pipeToAnsi(`${interruptItem.text}\r\n\r\n`, this.client), cb); + } } }; \ No newline at end of file