mirror of
https://github.com/Ratstail91/SANCTUM.git
synced 2025-11-29 02:24:27 +11:00
Working Mori's heal/revive command
This commit is contained in:
@@ -25,7 +25,18 @@ dialog = function(baseDialog) {
|
|||||||
}(dialog);
|
}(dialog);
|
||||||
|
|
||||||
//global settings
|
//global settings
|
||||||
let itemCount = 3;
|
const itemCount = 3;
|
||||||
|
const treatments = [
|
||||||
|
// Name | Crystals | HP | Revive | Description
|
||||||
|
["Patch", 10, "50", false, "Heals 50HP immediately. Must have more than 0HP."],
|
||||||
|
["PatchV2", 15, "50%", false, "Heals to 50% HP immediately. Must have more than 0HP."],
|
||||||
|
["Regen", 20, "100", false, "Heals 100HP immediately. Must have more than 0HP."],
|
||||||
|
["RegenV2", 25, "100%", false, "Heals all HP to maximum immediately. Must have more than 0HP."],
|
||||||
|
["Revive", 20, "25", true, "Brings a traveler back from a KO (0HP) to 25HP immediately."],
|
||||||
|
["ReviveV2", 25, "50%", true, "Brings a traveler back from a KO (0HP) to 50% HP immediately."],
|
||||||
|
["ReviveV3", 30, "100%", true, "Brings a traveler back from a KO (0HP) to 100% HP immediately."]
|
||||||
|
];
|
||||||
|
let availableTreatments = [];
|
||||||
|
|
||||||
//handle errors
|
//handle errors
|
||||||
client.on('error', console.error);
|
client.on('error', console.error);
|
||||||
@@ -114,8 +125,12 @@ function processBasicCommands(client, message) {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
case "heal": //TODO: wrap this in a function
|
case "heal":
|
||||||
//TODO: write this
|
if (!args[0]) {
|
||||||
|
printTreatments(message.author, message.channel);
|
||||||
|
} else {
|
||||||
|
processHealCommand(message.author, message.channel, args);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -128,5 +143,62 @@ function processBasicCommands(client, message) {
|
|||||||
|
|
||||||
//only certain items will be available each day
|
//only certain items will be available each day
|
||||||
function resetInventory(itemCount) {
|
function resetInventory(itemCount) {
|
||||||
//TODO
|
console.log("resetting inventory...");
|
||||||
|
|
||||||
|
//generate random numbers to select treatments to use
|
||||||
|
let randomNumbers = [];
|
||||||
|
do {
|
||||||
|
let num = shared.Random(0, treatments.length - 1); //there's probably a more efficient way to do this
|
||||||
|
if (!randomNumbers.includes(num)) {
|
||||||
|
randomNumbers.push(num);
|
||||||
|
}
|
||||||
|
} while (randomNumbers.length < itemCount);
|
||||||
|
randomNumbers.sort((a, b) => a - b);
|
||||||
|
|
||||||
|
//actually select the randomized treatments
|
||||||
|
availableTreatments = [];
|
||||||
|
for (let i = 0; i < randomNumbers.length; i++) {
|
||||||
|
availableTreatments.push( treatments[randomNumbers[i]] );
|
||||||
|
|
||||||
|
//shuffle the cost a little
|
||||||
|
if (shared.Random(0, 1) === 1) {
|
||||||
|
availableTreatments[i][1] += Math.floor( parseFloat(availableTreatments[i][1]) / 6);
|
||||||
|
} else {
|
||||||
|
availableTreatments[i][1] -= Math.floor( parseFloat(availableTreatments[i][1]) / 6);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function printTreatments(user, channel) {
|
||||||
|
let handleResponse = function(stats) {
|
||||||
|
//build the treatment message
|
||||||
|
let treatmentMessage = "";
|
||||||
|
for (let i = 0; i < availableTreatments.length; i++) {
|
||||||
|
treatmentMessage += `${availableTreatments[i][0]} - :crystals: **${availableTreatments[i][1]}**\n` + "```" + availableTreatments[i][4] + "```\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
//create the embed
|
||||||
|
let embed = new discord.RichEmbed()
|
||||||
|
.setAuthor(client.user.username, client.user.avatarURL)
|
||||||
|
.setColor(client.guilds.get(process.env.SANCTUM_ID).roles.find(role => role.name === "NPC").color) //NOTE: probably a better way to do this
|
||||||
|
.setTitle("Biotech Healing")
|
||||||
|
.setDescription(treatmentMessage)
|
||||||
|
.setFooter(`${user.username}, you have ${stats.wallet} crystals. Use !heal [OPTION] to buy.`);
|
||||||
|
|
||||||
|
shared.SendPublicMessage(client, user, channel, dialog("heal"));
|
||||||
|
channel.send({ embed });
|
||||||
|
}
|
||||||
|
|
||||||
|
shared.OnServerData("userStats", handleResponse, user.id);
|
||||||
|
}
|
||||||
|
|
||||||
|
function processHealCommand(user, channel, args) {
|
||||||
|
//get the selected treatment
|
||||||
|
let selectedTreatment = availableTreatments.filter((treatment) => treatment[0].toLowerCase() === args[0].toLowerCase())[0];
|
||||||
|
|
||||||
|
if (selectedTreatment[3]) { //should it be a revive command?
|
||||||
|
shared.OnServerData("revive", handleResponse, user.id, selectedTreatment[1], selectedTreatment[2]);
|
||||||
|
} else {
|
||||||
|
shared.OnServerData("heal", handleResponse, user.id, selectedTreatment[1], selectedTreatment[2]);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"name": "Librarian",
|
"name": "Mori",
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"description": "",
|
"description": "",
|
||||||
"main": "server.js",
|
"main": "server.js",
|
||||||
|
|||||||
@@ -50,6 +50,9 @@ io.on("connection", async (socket) => {
|
|||||||
socket.on("userStats", handleUserStats);
|
socket.on("userStats", handleUserStats);
|
||||||
socket.on("addXP", handleAddXP);
|
socket.on("addXP", handleAddXP);
|
||||||
socket.on("levelUp", handleLevelUp);
|
socket.on("levelUp", handleLevelUp);
|
||||||
|
socket.on("reviveAll", handleReviveAll);
|
||||||
|
socket.on("revive", handleRevive);
|
||||||
|
socket.on("heal", handleHeal);
|
||||||
});
|
});
|
||||||
|
|
||||||
//listen
|
//listen
|
||||||
@@ -291,6 +294,40 @@ async function handleLevelUp({ data }, fn) {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//handle the daily revives
|
||||||
|
async function handleReviveAll({ data }, fn) {
|
||||||
|
console.log("received a reviveAll request...");
|
||||||
|
|
||||||
|
//parameters to fn: none
|
||||||
|
|
||||||
|
let query = `UPDATE users SET health = maxHealth;`;
|
||||||
|
return dbConnection.query(query, (err, result) => {
|
||||||
|
if (err) throw err;
|
||||||
|
|
||||||
|
return fn();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
//handle reviving a specific player
|
||||||
|
async function handleRevive({ data }, fn) {
|
||||||
|
console.log("received a revive request...");
|
||||||
|
//data[0] = user ID
|
||||||
|
//data[1] = cost
|
||||||
|
//data[2] = amount (potentially percentage)
|
||||||
|
|
||||||
|
//TODO
|
||||||
|
}
|
||||||
|
|
||||||
|
//handle healing a specific player
|
||||||
|
async function handleHeal({ data }, fn) {
|
||||||
|
console.log("received a heal request...");
|
||||||
|
//data[0] = user ID
|
||||||
|
//data[1] = cost
|
||||||
|
//data[2] = amount (potentially percentage)
|
||||||
|
|
||||||
|
//TODO
|
||||||
|
}
|
||||||
|
|
||||||
//utility functions
|
//utility functions
|
||||||
function calculateLevel(experience) {
|
function calculateLevel(experience) {
|
||||||
const levelBase = 1.2;
|
const levelBase = 1.2;
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ exports.ConnectToServer = function(username, address, port, pass) { //NOTE: this
|
|||||||
io.on("connect", () => io.emit("authentication", {SERVER_PASS_KEY: pass, username: username}) );
|
io.on("connect", () => io.emit("authentication", {SERVER_PASS_KEY: pass, username: username}) );
|
||||||
io.on("authenticated", () => console.log("Authenticated with server: " + `${address}:${port}`));
|
io.on("authenticated", () => console.log("Authenticated with server: " + `${address}:${port}`));
|
||||||
io.on("disconnect", () => console.log("disconnected from server: " + `${address}:${port}`));
|
io.on("disconnect", () => console.log("disconnected from server: " + `${address}:${port}`));
|
||||||
io.on("error", (err) => { throw err; } );
|
// io.on("error", (err) => { throw err; } );
|
||||||
|
|
||||||
initialized = true;
|
initialized = true;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user