mirror of
https://github.com/danbulant/flying-squid
synced 2026-07-05 19:20:54 +00:00
Added colors, made some fixes to command.js
This commit is contained in:
parent
08015d3bac
commit
c13c901279
5 changed files with 132 additions and 12 deletions
|
|
@ -36,8 +36,11 @@ class Command {
|
||||||
pars = pars.match(parse);
|
pars = pars.match(parse);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var val = res[0].params.action(res[1])
|
||||||
|
if (val && val.catch) res = await val.catch((err)=> setTimeout(() => {throw err;},0));
|
||||||
|
else res = val;
|
||||||
|
|
||||||
res = await com.params.action(pars);
|
|
||||||
if(res) return '' + res;
|
if(res) return '' + res;
|
||||||
} else {
|
} else {
|
||||||
return 'Command not found';
|
return 'Command not found';
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,120 @@
|
||||||
module.exports.server=function(serv)
|
module.exports.server=function(serv)
|
||||||
{
|
{
|
||||||
serv.broadcast = (message, color) =>
|
serv.broadcast = (message, {whitelist=serv.players,blacklist=[],system=false}={}) => {
|
||||||
serv.players.forEach(player => player.chat({
|
if (whitelist.type == 'player') whitelist = [whitelist];
|
||||||
"text": message,
|
|
||||||
"color": color
|
if (typeof message == 'string') message = serv.parseClassic(message);
|
||||||
}));
|
|
||||||
|
whitelist.filter(w => blacklist.indexOf(w) == 0).forEach(player => {
|
||||||
|
if (!system) player.chat(message);
|
||||||
|
else player.system(message);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
serv.color = {
|
||||||
|
'black': '&0',
|
||||||
|
'dark_blue': '&1',
|
||||||
|
'dark_green': '&2',
|
||||||
|
'dark_cyan': '&3',
|
||||||
|
'dark_red': '&4',
|
||||||
|
'purple': '&5',
|
||||||
|
'dark_purple': '&5',
|
||||||
|
'gold': '&6',
|
||||||
|
'gray': '&7',
|
||||||
|
'grey': '&7',
|
||||||
|
'dark_gray': '&8',
|
||||||
|
'dark_grey': '&8',
|
||||||
|
'blue': '&9',
|
||||||
|
'green': '&a',
|
||||||
|
'aqua': '&b',
|
||||||
|
'cyan': '&b',
|
||||||
|
'red': '&c',
|
||||||
|
'pink': '&d',
|
||||||
|
'light_purple': '&d',
|
||||||
|
'yellow': '&e',
|
||||||
|
'white': '&f',
|
||||||
|
'random': '&k',
|
||||||
|
'obfuscated': '&k',
|
||||||
|
'bold': '&l',
|
||||||
|
'strikethrough': '&m',
|
||||||
|
'underlined': '&n',
|
||||||
|
'underline': '&n',
|
||||||
|
'italic': '&o',
|
||||||
|
'italics': '&o',
|
||||||
|
'reset': '&r'
|
||||||
|
};
|
||||||
|
|
||||||
|
serv.parseClassic = (message) => {
|
||||||
|
var messageList = [];
|
||||||
|
var text = '';
|
||||||
|
var nextChanged = false;
|
||||||
|
var color = 'white';
|
||||||
|
var bold = false;
|
||||||
|
var italic = false;
|
||||||
|
var underlined = false;
|
||||||
|
var strikethrough = false;
|
||||||
|
var random = false;
|
||||||
|
var colors = ['0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f', 'k','l','m','n','o','r','&']
|
||||||
|
var convertColor = ['black', 'dark_blue','dark_green','dark_cyan','dark_red','dark_purple','gold',
|
||||||
|
'gray', 'dark_gray', 'blue', 'green', 'aqua', 'red', 'light_purple', 'yellow', 'white',
|
||||||
|
'random', 'bold', 'strikethrough', 'underlined', 'italic', 'reset', '&'];
|
||||||
|
|
||||||
|
function createJSON() {
|
||||||
|
if (!text.trim()) return;
|
||||||
|
messageList.push({
|
||||||
|
text: text,
|
||||||
|
color: color,
|
||||||
|
bold: bold,
|
||||||
|
italic: italic,
|
||||||
|
underlined: underlined,
|
||||||
|
strikethrough: strikethrough,
|
||||||
|
obfuscated: random
|
||||||
|
});
|
||||||
|
text = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
while (message != '') {
|
||||||
|
var currChar = message[0];
|
||||||
|
if (nextChanged) {
|
||||||
|
var newColor = convertColor[colors.indexOf(currChar)];
|
||||||
|
if (newColor) {
|
||||||
|
if (newColor == 'bold') bold = true;
|
||||||
|
else if (newColor == 'strikethrough') strikethrough = true;
|
||||||
|
else if (newColor == 'underlined') underlined = true;
|
||||||
|
else if (newColor == 'italic') italic = true;
|
||||||
|
else if (newColor == 'random') random = true;
|
||||||
|
else if (newColor == '&') text += '&';
|
||||||
|
else if (newColor == 'reset') {
|
||||||
|
strikethrough = false;
|
||||||
|
bold = false;
|
||||||
|
underlined = false;
|
||||||
|
random = false;
|
||||||
|
italic = false;
|
||||||
|
color = 'white';
|
||||||
|
} else color = newColor;
|
||||||
|
}
|
||||||
|
nextChanged = false;
|
||||||
|
} else if (currChar == '&') {
|
||||||
|
if (nextChanged) {
|
||||||
|
text += '&';
|
||||||
|
nextChanged = false;
|
||||||
|
} else {
|
||||||
|
nextChanged = true;
|
||||||
|
createJSON();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
text += currChar;
|
||||||
|
}
|
||||||
|
|
||||||
|
message = message.slice(1, message.length);
|
||||||
|
}
|
||||||
|
createJSON();
|
||||||
|
|
||||||
|
return {
|
||||||
|
text: '',
|
||||||
|
extra: messageList
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports.player=function(player,serv)
|
module.exports.player=function(player,serv)
|
||||||
|
|
@ -24,10 +134,12 @@ module.exports.player=function(player,serv)
|
||||||
});
|
});
|
||||||
|
|
||||||
player.chat = message => {
|
player.chat = message => {
|
||||||
|
if (typeof message == 'string') message = serv.parseClassic(message);
|
||||||
player._client.write('chat', { message: JSON.stringify(message), position: 0 });
|
player._client.write('chat', { message: JSON.stringify(message), position: 0 });
|
||||||
};
|
};
|
||||||
|
|
||||||
player.system = message => {
|
player.system = message => {
|
||||||
|
if (typeof message == 'string') message = serv.parseClassic(message);
|
||||||
player._client.write('chat', { message: JSON.stringify(message), position: 2 });
|
player._client.write('chat', { message: JSON.stringify(message), position: 2 });
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
@ -1,5 +1,3 @@
|
||||||
var fs = require('fs');
|
|
||||||
|
|
||||||
module.exports.server = function(serv, settings) {
|
module.exports.server = function(serv, settings) {
|
||||||
serv.plugins = {};
|
serv.plugins = {};
|
||||||
serv.pluginCount = 0;
|
serv.pluginCount = 0;
|
||||||
|
|
@ -26,12 +24,12 @@ module.exports.server = function(serv, settings) {
|
||||||
require.resolve(p); // Check if it exists, if not do catch, otherwise jump to bottom
|
require.resolve(p); // Check if it exists, if not do catch, otherwise jump to bottom
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
try { // Throw error if cannot find plugin
|
try { // Throw error if cannot find plugin
|
||||||
fs.accessSync('./dist/plugins/' + p);
|
require.resolve('../../plugins/' + p);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
throw new Error('Cannot find plugin "' + p + '"');
|
throw new Error('Cannot find plugin "' + p + '"');
|
||||||
}
|
}
|
||||||
serv.addPlugin(p, require('../../plugins/' + p), settings.plugins[p]);
|
serv.addPlugin(p, require('../../plugins/' + p), settings.plugins[p]);
|
||||||
return;
|
continue;
|
||||||
}
|
}
|
||||||
serv.addPlugin(p, require(p), settings.plugins[p]);
|
serv.addPlugin(p, require(p), settings.plugins[p]);
|
||||||
});
|
});
|
||||||
|
|
@ -39,6 +37,13 @@ module.exports.server = function(serv, settings) {
|
||||||
Object.keys(serv.plugins).forEach((p) =>{
|
Object.keys(serv.plugins).forEach((p) =>{
|
||||||
if (serv.plugins[p].server) serv.plugins[p].server.call(serv.plugins[p], serv, settings);
|
if (serv.plugins[p].server) serv.plugins[p].server.call(serv.plugins[p], serv, settings);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
serv.on('asap', () => {
|
||||||
|
for (var p in serv.plugins) {
|
||||||
|
serv.log('[PLUGINS] Loaded "' + serv.plugins[p].name + '"');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
serv.externalPluginsLoaded = true;
|
serv.externalPluginsLoaded = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -124,7 +124,7 @@ module.exports.player=function(player,serv)
|
||||||
|
|
||||||
function announceJoin()
|
function announceJoin()
|
||||||
{
|
{
|
||||||
serv.broadcast(player.username + ' joined the game.', "yellow");
|
serv.broadcast(serv.color.yellow + player.username + ' joined the game.');
|
||||||
player.emit("connected");
|
player.emit("connected");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,7 @@ module.exports.player=function(player,serv)
|
||||||
|
|
||||||
player._client.on('end', () => {
|
player._client.on('end', () => {
|
||||||
if(player) {
|
if(player) {
|
||||||
serv.broadcast(player.username + ' quit the game.', "yellow");
|
serv.broadcast(serv.color.yellow + player.username + ' quit the game.');
|
||||||
player._writeOthers('player_info', {
|
player._writeOthers('player_info', {
|
||||||
action: 4,
|
action: 4,
|
||||||
data: [{
|
data: [{
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue