Inventory system changes

This commit is contained in:
2023-11-02 17:12:24 +01:00
parent 8b55039972
commit 4e2eedda49
13 changed files with 100 additions and 160 deletions

View File

@@ -1,15 +0,0 @@
import { playerData } from "../Classes/playerData";
export function delete1(socket, data){
if(!socket.hasOwnProperty("user")) return;
let buff = Buffer.from(data, 'base64');
let data1 = Number(buff.toString('utf-8'));
let player : playerData = socket.player
let item = player.inventory.items.findIndex(i=>i.id == data1);
if(item == -1){
console.log("Error! Item " + item + " not found!")
}
player.inventory.items.splice(item, 1)
}

View File

@@ -1,22 +0,0 @@
import { inventoryItemTransaction } from "../Classes/inventoryItemTransaction";
import { playerData } from "../Classes/playerData";
export function deleteMany(socket, data){
if(!socket.hasOwnProperty("user")) return;
let buff = Buffer.from(data, 'base64');
let data1 : inventoryItemTransaction[] = JSON.parse(buff.toString('utf-8'));
let player : playerData = socket.player
data1.forEach(t=>{
switch(t.type){
case 0:
player.inventory.items.find(i=>i.id == t.itemId).count += t.amount;
break;
case 2:
let item = player.inventory.items.findIndex(i=>i.id == t.itemId);
player.inventory.items.splice(item, 1)
break;
}
})
}

View File

@@ -1,70 +0,0 @@
import { itemData } from "../Classes/itemData";
import { lobbyMessage } from "../Classes/lobbyMessage";
import { playerData } from "../Classes/playerData";
import { game } from "../game";
export function pickup(socket, data){
if(!socket.hasOwnProperty("user")) return;
let buff = Buffer.from(data, 'base64');
let data1 : itemData = JSON.parse(buff.toString('utf-8'));
let player : playerData = socket.player
if(player != null){
let inventory = player.inventory
let template = game.getItemTemplate(data1.templateId)
let items = inventory.items.filter(i=>i.templateId == data1.templateId)
let totalAdded = 0
if(data1.count > template.maxCount)
{
console.log("ERROR ERROR ITEM ERROR")
return;
}
items.forEach(item=>{
var maxAmount = Math.min(template.maxCount - item.count, data1.count - totalAdded);
if (maxAmount > 0)
{
item.count += maxAmount;
totalAdded += maxAmount;
}
})
if(totalAdded < data1.count)
{
let maxAmount = data1.count - totalAdded
let itemCopy = itemData.copy(data1);
itemCopy.count = maxAmount;
totalAdded += maxAmount;
inventory.items.push(itemCopy);
}
if (totalAdded == data1.count)
{
if(data1.rarity >= 75){
let message = socket.user.login + " picked up "
if(data1.rarity >= 95){
message += "<color=purple>" + data1.name + "</color> (epic)"
}
else if(data1.rarity >= 75){
message += "<color=red>" + data1.name + "</color> (rare)"
}
else if(data1.rarity >= 60){
message += "<color=yellow>" + data1.name + "</color> (uncommon)"
}
else
message += data1.name;
game.addMessage(new lobbyMessage(message))
}
}
else
{
console.log("ERROR ERROR ITEM ERROR")
}
}
}

View File

@@ -1,16 +0,0 @@
import { itemGenerated } from "../Classes/itemGenerated";
import { itemRequest } from "../Classes/itemRequest";
import { generateItemByType } from "./itemGeneration";
export function request(socket, data){
if(!socket.hasOwnProperty("user")) return;
let buff = Buffer.from(data, 'base64');
let data1 : itemRequest = JSON.parse(buff.toString('utf-8'));
let response = new itemGenerated()
response.instanceId = data1.instanceId
response.item = generateItemByType(data1.itemType)
socket.emit("item/generated", JSON.stringify(response))
}

49
Items/_updateInventory.ts Normal file
View File

@@ -0,0 +1,49 @@
import { inventoryChange } from "../Classes/Incoming/inventoryChange";
import { itemData } from "../Classes/itemData";
import { playerData } from "../Classes/playerData";
export function updateInventory(socket, data){
if(!socket.hasOwnProperty("player")) return;
let buff = Buffer.from(data, 'base64');
let data1 : inventoryChange[] = JSON.parse(buff.toString('utf-8'));
let player : playerData = socket.player
let inventory = player.inventory
data1.forEach(change=>{
switch(change.operation){
case 0: //None
break;
case 1: //ItemAdd
{
let item = itemData.fromChange(change)
inventory.items.push(item)
break;
}
case 2: //ItemAddToStack
{
let itemStack = inventory.items.find(i=>i.id == change.id)
itemStack.count += change.change
break;
}
case 3: //ItemRemove
{
let itemStack = inventory.items.findIndex(i=>i.id == change.id)
inventory.items.splice(itemStack, 1)
break;
}
case 4: //ItemRemoveFromStack
{
let itemStack = inventory.items.find(i=>i.id == change.id)
itemStack.count -= change.change
break;
}
case 5: //EquipmentChange
{
inventory.equipment = change.equipment
break;
}
}
})
}

View File

@@ -1,22 +1,7 @@
import { delete1 } from "./_delete1";
import { deleteMany } from "./_deleteMany";
import { pickup } from "./_pickup";
import { request } from "./_request";
import { updateInventory } from "./_updateInventory";
export function registerItemCallbacks(socket){
socket.on('item/pickup', (data) => {
pickup(socket, data)
});
socket.on('item/delete', (data) => {
delete1(socket, data)
});
socket.on('item/deleteMany', (data) => {
deleteMany(socket, data)
});
socket.on('item/request', (data) => {
request(socket, data)
socket.on('item/updateInventory', (data) => {
updateInventory(socket, data)
});
}