diff --git a/Client/Gui/Inventory/inventory.js b/Client/Gui/Inventory/inventory.js index 4764460a..4e61f72e 100644 --- a/Client/Gui/Inventory/inventory.js +++ b/Client/Gui/Inventory/inventory.js @@ -2,10 +2,9 @@ var show = false; var showAdmin = false; -var trading = false; const { x: screenX, y: screenY } = mp.game.graphics.getScreenActiveResolution(0, 0); let rxC = 0.5; -let ryC = 0.5; +let ryC = 0.4; let rWidth = 0.4; let sX = (screenX * 0.1 / 1000); let sY = (screenY * 0.1 / 1000); @@ -15,6 +14,7 @@ let sizeMul = 0.08; let yMul = 1.8; var targetPlayerName; let closePos = [0.7125, 0.17] +let tradeBoxPos = [0.7125, 0.82] var clickTime; var itemRadial = false; var hoverGrid; @@ -26,31 +26,46 @@ var downRColor = 222; var leftRColor = 222; var rightRColor = 222; var radialDescription; +var tradePartner = "Keinem"; +var tradePrize = 0; +var tradeConfirm = false; +var isTrading = false; +var isTradingResult = false; +var dragTradeItem = null; var inventoryWeight; var items = [[]]; +var tradeItems = []; +var tradeResultItems = [[]]; var grid = []; -grid[0] = [0.3375, 0.305] -grid[1] = [0.4195, 0.305] -grid[2] = [0.5015, 0.305] -grid[3] = [0.5835, 0.305] -grid[4] = [0.6655, 0.305] -grid[5] = [0.3375, 0.455] -grid[6] = [0.4195, 0.455] -grid[7] = [0.5015, 0.455] -grid[8] = [0.5835, 0.455] -grid[9] = [0.6655, 0.455] -grid[10] = [0.3375, 0.605] -grid[11] = [0.4195, 0.605] -grid[12] = [0.5015, 0.605] -grid[13] = [0.5835, 0.605] -grid[14] = [0.6655, 0.605] -grid[15] = [0.3375, 0.755] -grid[16] = [0.4195, 0.755] -grid[17] = [0.5015, 0.755] -grid[18] = [0.5835, 0.755] -grid[19] = [0.6655, 0.755] +grid[0] = [0.3375, 0.205] +grid[1] = [0.4195, 0.205] +grid[2] = [0.5015, 0.205] +grid[3] = [0.5835, 0.205] +grid[4] = [0.6655, 0.205] +grid[5] = [0.3375, 0.355] +grid[6] = [0.4195, 0.355] +grid[7] = [0.5015, 0.355] +grid[8] = [0.5835, 0.355] +grid[9] = [0.6655, 0.355] +grid[10] = [0.3375, 0.505] +grid[11] = [0.4195, 0.505] +grid[12] = [0.5015, 0.505] +grid[13] = [0.5835, 0.505] +grid[14] = [0.6655, 0.505] +grid[15] = [0.3375, 0.655] +grid[16] = [0.4195, 0.655] +grid[17] = [0.5015, 0.655] +grid[18] = [0.5835, 0.655] +grid[19] = [0.6655, 0.655] + +var tradeGrid = []; +tradeGrid[0] = [0.3375, 0.925] +tradeGrid[1] = [0.4195, 0.925] +tradeGrid[2] = [0.5015, 0.925] +tradeGrid[3] = [0.5835, 0.925] +tradeGrid[4] = [0.6655, 0.925] var mouseLDown = false; var mouseRDown = false; @@ -58,8 +73,10 @@ var hoverItem; var dragItem = null; var oldDragSlot; var actFreeSlot; +var actFreeTradeSlot; var bufferItem = []; var stackToItem; +var stackToTradeItem; mp.events.add("showInventory", (invWeight, itemArr) => { if (show === false) { @@ -79,9 +96,17 @@ mp.events.add("showInventory", (invWeight, itemArr) => { inventoryWeight = 0; items = null; itemRadial = false; + if (tradeItems.length === 0) { + isTrading = false; + } } }); +mp.events.add("openTradeMenu", (tradePartnerName) => { + tradePartner = tradePartnerName; + isTrading = true; +}); + mp.events.add("showInventoryToAdmin", (pName, invWeight, itemArr) => { if (showAdmin === false) { targetPlayerName = pName; @@ -100,6 +125,25 @@ mp.events.add("addItem", (item) => { } }); +mp.events.add("clearTradeItems", () => { + tradeConfirm = false; + tradeItems = [[]]; + tradePrize = 0; +}); + +mp.events.add("unlockTradeItems", () => { + tradeConfirm = false; +}); + +mp.events.add("showTradeItems", (tradeResultItemArray) => { + //for (var i = 0; i < tradeResultItemArray.length; i++) { + + // tradeItems.push(tradeResultItemArray[i]); + //} + tradeItems = JSON.parse(tradeResultItemArray); + isTrading = true; +}); + mp.events.add("removeItem", (userItemId, amount) => { if (show) { var arrIndex; @@ -122,16 +166,16 @@ mp.events.add("render", () => { mp.game.graphics.set2dLayer(1); //INVENTARHINTERGRUND - mp.game.graphics.drawRect(rxC, ryC, 0.45, 0.7, 255, 255, 255, 200); - + mp.game.graphics.drawRect(rxC, ryC, 0.45, 0.7, 255, 255, 255, 200); //inventar mp.game.graphics.set2dLayer(2); + //INVENTARÜBERSCHRIFT mp.game.graphics.drawText("Inventar ~g~" + inventoryWeight + "/40000g", [rxC, ryC - (rWidth / 1.20)], { font: 7, color: [112, 128, 144, 254], scale: [0.7, 0.7], outline: true, - }); + }); //SLOTS [RECHTECKE] [SLOTZAHLEN] var tempSlot; @@ -144,7 +188,7 @@ mp.events.add("render", () => { outline: true, }); } - + mp.game.graphics.set2dLayer(3); //SPRITES + ITEMANZAHL for (var currentItem = 0; currentItem < items.length; currentItem++) { @@ -193,12 +237,20 @@ mp.events.add("render", () => { //WENN MOUSE DOWN if (mouseLDown && dragItem !== null || mouseRDown && dragItem !== null) { - if (isMouseOverFreeSlot(pos[0], pos[1]) || isItemOverSameItem(pos[0], pos[1])) { - mp.game.graphics.drawSprite("itemimages", items[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 100, 255, 100, 255); - } else { - mp.game.graphics.drawSprite("itemimages", items[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 255, 100, 100, 255); - } + if (isMouseOverFreeSlot(pos[0], pos[1]) || isMouseOverFreeTradeSlot(pos[0], pos[1]) || isItemOverSameItem(pos[0], pos[1]) || isItemOverSameTradeItem(pos[0], pos[1])) { + if (dragTradeItem === false) { + mp.game.graphics.drawSprite("itemimages", items[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 100, 255, 100, 255); + } else { + mp.game.graphics.drawSprite("itemimages", tradeItems[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 100, 255, 100, 255); + } + } else { + if (dragTradeItem === false) { + mp.game.graphics.drawSprite("itemimages", items[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 255, 100, 100, 255); + } else { + mp.game.graphics.drawSprite("itemimages", tradeItems[dragItem][0].toLowerCase(), pos[0] / screenX, pos[1] / screenY, rWidth / 8, rWidth / 5, 0, 255, 100, 100, 255); + } + } } mp.game.graphics.set2dLayer(5); if (itemRadial === true) { @@ -218,10 +270,123 @@ mp.events.add("render", () => { mp.game.graphics.drawText("~g~" + radialDescription, [pos[0] / screenX, pos[1] / screenY - 0.033], { font: 4, color: [255, 255, 255, 255], - scale: [0.4, 0.4], + scale: [0.5, 0.5], outline: true, }); } + if (isTrading) { + mp.game.graphics.set2dLayer(1); + mp.game.graphics.drawRect(rxC, 0.925, 0.45, 0.25, 255, 255, 255, 200); + mp.game.graphics.set2dLayer(2); + var tempSlot2; + for (var slots = 0; slots < tradeGrid.length; slots++) { + mp.game.graphics.drawRect(tradeGrid[slots][0], tradeGrid[slots][1], sizeMul, sizeMul * yMul, 112, 128, 144, 254); + mp.game.graphics.drawText(tempSlot2 = slots + 1, [tradeGrid[slots][0] - (sizeMul / 2) + 0.006, tradeGrid[slots][1] - (sizeMul / 2 * yMul)], { + font: 7, + color: [69, 255, 0, 254], + scale: [0.3, 0.3], + outline: true, + }); + } + + mp.game.graphics.set2dLayer(3); + + //SPRITES + ITEMANZAHL + if (tradeItems.length !== 0) { + for (var currentItem = 0; currentItem < tradeItems.length; currentItem++) { + if (tradeItems[currentItem][4] !== "-1") { + mp.game.graphics.drawSprite("itemimages", tradeItems[currentItem][0].toLowerCase(), tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][0], tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); + mp.game.graphics.drawText("(~y~" + tradeItems[currentItem][3] + "~s~)", [tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][1] + 0.05], { + font: 0, + color: [255, 255, 255, 255], + scale: [0.25, 0.25], + outline: true, + }); + if (tradeConfirm === true) { + mp.game.graphics.drawSprite("itemimages", "lock", tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][0], tradeGrid[parseInt(tradeItems[currentItem][4] - 1)][1], rWidth / 8 / 2, rWidth / 5 / 2, 0, 255, 255, 255, 255); + } + } + } + } + //} else { + // if (tradeResultItems.length !== 0) { + // for (var currentItem = 0; currentItem < tradeResultItems.length; currentItem++) { + // mp.game.graphics.drawSprite("itemimages", tradeResultItems[currentItem][0].toLowerCase(), tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][0], tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); + // mp.game.graphics.drawText("(~y~" + tradeResultItems[currentItem][3] + "~s~)", [tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, tradeGrid[parseInt(tradeResultItems[currentItem][4] - 1)][1] + 0.05], { + // font: 0, + // color: [255, 255, 255, 255], + // scale: [0.25, 0.25], + // outline: true, + // }); + // } + // } + //} + + mp.game.graphics.drawText("Handel mit ~y~" + tradePartner + " ~s~ für ~g~ " + tradePrize + "$", [rxC, 0.81], { + font: 7, + color: [112, 128, 144, 254], + scale: [0.6, 0.6], + outline: true, + }); + mp.game.graphics.set2dLayer(4); + if (tradeConfirm === false) { + mp.game.graphics.drawSprite("itemimages", "box", tradeBoxPos[0], tradeBoxPos[1], 0.02, 0.035, 0, 255, 255, 255, 255); + } else { + mp.game.graphics.drawSprite("itemimages", "boxticked", tradeBoxPos[0], tradeBoxPos[1], 0.02, 0.035, 0, 255, 255, 255, 255); + } + mp.game.graphics.drawSprite("itemimages", "dollar", tradeBoxPos[0] - 0.025, tradeBoxPos[1], 0.02, 0.035, 0, 255, 255, 255, 255); + + if (isMouseOverTradeDollar(pos[0], pos[1])) { + mp.game.graphics.drawText("~g~ Preis festlegen", [pos[0] / screenX, pos[1] / screenY - 0.033], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.5, 0.5], + outline: true, + }); + } + if (isMouseOverTradeBox(pos[0], pos[1])) { + mp.game.graphics.drawText("~g~Handelsanfrage absenden", [pos[0] / screenX, pos[1] / screenY - 0.033], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.5, 0.5], + outline: true, + }); + } + + mp.game.graphics.set2dLayer(5); + if (isMouseOverTradeItem(pos[0], pos[1]) && dragItem === null && itemRadial === false) { + mp.game.graphics.drawRect(pos[0] / screenX, pos[1] / screenY + 0.055, 0.14, 0.08, 0, 0, 0, 220); + + var hoverItemP = [tradeItems[hoverItem][0], tradeItems[hoverItem][1], tradeItems[hoverItem][2], tradeItems[hoverItem][3]]; + + //NAME + mp.game.graphics.drawText("~g~" + hoverItemP[0], [pos[0] / screenX, pos[1] / screenY + 0.02], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.4, 0.4], + outline: true, + }); + + //BESCHREIBUNG + mp.game.graphics.drawText(hoverItemP[1], [pos[0] / screenX, pos[1] / screenY + 0.04], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.35, 0.35], + outline: true, + }); + + //EINZELGEWICHT + mp.game.graphics.drawText("~y~" + hoverItemP[2] + "g~s~ * " + hoverItemP[3] + "~s~ = ~y~" + hoverItemP[2] * hoverItemP[3] + "g", [pos[0] / screenX, pos[1] / screenY + 0.06], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.35, 0.35], + outline: true, + }); + } + } + + + ////--------------------------------------------------------------DEBUG //mp.game.graphics.drawText(itemRadial.toString() + " ~y~" + radialSelect, [0.5, 0.05], { // font: 7, @@ -230,14 +395,12 @@ mp.events.add("render", () => { // outline: true, //}); ////KOORDINATEN - //if (ifMouseSelectRadial(pos[0], pos[1])) { - // mp.game.graphics.drawText((pos[0] / screenX).toFixed(3) + " / " + (pos[1] / screenY).toFixed(3), [pos[0] / screenX, pos[1] / screenY - 0.02], { - // font: 4, - // color: [255, 255, 255, 255], - // scale: [0.4, 0.4], - // outline: true, - // }); - //} + //mp.game.graphics.drawText((pos[0] / screenX).toFixed(3) + " / " + (pos[1] / screenY).toFixed(3) + " " + tradeItems.length, [pos[0] / screenX, pos[1] / screenY - 0.02], { + // font: 4, + // color: [255, 255, 255, 255], + // scale: [0.4, 0.4], + // outline: true, + //}); ////----------------------------------------------------------DEBUG END } if (showAdmin === true) { @@ -266,7 +429,7 @@ mp.events.add("render", () => { scale: [0.3, 0.3], outline: true, }); - } + } mp.game.graphics.set2dLayer(3); //SPRITES + ITEMANZAHL @@ -313,6 +476,7 @@ mp.events.add("render", () => { outline: true, }); } + if (isMouseOverX(pos[0], pos[1])) { mp.game.graphics.drawSprite("itemimages", "x", closePos[0], closePos[1], 0.02, 0.035, 0, 220, 20, 60, 255); } else { @@ -375,25 +539,45 @@ function isMouseOverItem(cX, cY) { } } } +function isMouseOverTradeItem(cX, cY) { + + if (dragItem === null && isTrading) { + + var x = cX / screenX; + var y = cY / screenY; + var a; + var b; + var c; + + for (var s = 0; s < 5; s++) { + a = tradeGrid[s][0] - x; + b = tradeGrid[s][1] - y; + c = Math.sqrt(a * a + b * b); + + var invSlot = (s + 1); + + if (c < sizeMul / 2) { + for (i = 0; i < tradeItems.length; i++) { + if (parseInt(tradeItems[i][4]) === invSlot) { + hoverItem = i; + return true; + } + } + } + } + } +} function isMouseOverFreeSlot(cX2, cY2) { var x = cX2 / screenX; var y = cY2 / screenY; - var a; - var b; - var c; - var isItemOnSlot = 0; for (var s = 0; s < 20; s++) { - a = grid[s][0] - x; - b = grid[s][1] - y; - c = Math.sqrt(a * a + b * b); - var invSlot = (s + 1); - if (c < sizeMul / 2) { + if (x > grid[s][0] - sizeMul / 2 && x < grid[s][0] + sizeMul / 2 && y > grid[s][1] - sizeMul / 2 * aspectRatioFactor && y < grid[s][1] + sizeMul / 2 * aspectRatioFactor) { for (i = 0; i < items.length; i++) { if (parseInt(items[i][4]) === invSlot) { isItemOnSlot++; @@ -407,28 +591,81 @@ function isMouseOverFreeSlot(cX2, cY2) { } } -function isItemOverSameItem(cX2, cY2) { - - if (dragItem !== null) { +function isMouseOverFreeTradeSlot(cX2, cY2) { + if (tradeConfirm === false) { var x = cX2 / screenX; var y = cY2 / screenY; - var a; - var b; - var c; - - for (var s = 0; s < 20; s++) { - a = grid[s][0] - x; - b = grid[s][1] - y; - c = Math.sqrt(a * a + b * b); + var isItemOnSlot = 0; + for (var s = 0; s < 5; s++) { var invSlot = (s + 1); - if (c < sizeMul / 2) { + if (x > tradeGrid[s][0] - sizeMul / 2 && x < tradeGrid[s][0] + sizeMul / 2 && y > tradeGrid[s][1] - sizeMul / 2 * aspectRatioFactor && y < tradeGrid[s][1] + sizeMul / 2 * aspectRatioFactor) { + for (i = 0; i < tradeItems.length; i++) { + if (parseInt(tradeItems[i][4]) === invSlot) { + isItemOnSlot++; + } + } + if (isItemOnSlot === 0) { + actFreeTradeSlot = s + 1; + return true; + } + } + } + } +} + +function isItemOverSameItem(cX2, cY2) { + + if (dragItem !== null && items.length > 0) { + var x = cX2 / screenX; + var y = cY2 / screenY; + + for (var s = 0; s < 20; s++) { + var invSlot = (s + 1); + + if (x > grid[s][0] - sizeMul / 2 && x < grid[s][0] + sizeMul / 2 && y > grid[s][1] - sizeMul / 2 * aspectRatioFactor && y < grid[s][1] + sizeMul / 2 * aspectRatioFactor) { + for (i = 0; i < items.length; i++) { - if (items[dragItem][0] === items[i][0] && parseInt(items[i][4]) === invSlot && items[hoverItem][4] !== items[i][4]) { - stackToItem = i; - return true; + if (dragTradeItem === false) { + if (items[dragItem][0] === items[i][0] && parseInt(items[i][4]) === invSlot && items[hoverItem][4] !== items[i][4]) { + stackToItem = i; + return true; + } + } else { + if (tradeItems[dragItem][0] === items[i][0] && parseInt(items[i][4]) === invSlot) { + stackToItem = i; + return true; + } + } + } + } + } + } +} + +function isItemOverSameTradeItem(cX2, cY2) { + + if (dragItem !== null && tradeItems.length > 0) { + var x = cX2 / screenX; + var y = cY2 / screenY; + for (var s = 0; s < 5; s++) { + var invSlot = (s + 1); + + if (x > tradeGrid[s][0] - sizeMul / 2 && x < tradeGrid[s][0] + sizeMul / 2 && y > tradeGrid[s][1] - sizeMul / 2 * aspectRatioFactor && y < tradeGrid[s][1] + sizeMul / 2 * aspectRatioFactor) { + + for (i = 0; i < tradeItems.length; i++) { + if (dragTradeItem === false) { + if (items[dragItem][0] === tradeItems[i][0] && parseInt(tradeItems[i][4]) === invSlot) { + stackToTradeItem = i; + return true; + } + } else { + if (tradeItems[dragItem][0] === tradeItems[i][0] && parseInt(tradeItems[i][4]) === invSlot && tradeItems[hoverItem][4] !== tradeItems[i][4]) { + stackToTradeItem = i; + return true; + } } } } @@ -440,14 +677,30 @@ function isMouseOverX(cX2, cY2) { if (showAdmin) { var x = cX2 / screenX; var y = cY2 / screenY; - var a; - var b; - var c; - a = closePos[0] - x; - b = closePos[1] - y; - c = Math.sqrt(a * a + b * b); - if (c < 0.018) { + if (x > closePos[0] - 0.01 && x < closePos[0] + 0.01 && y > closePos[1] - 0.0175 && y < closePos[1] + 0.0175) { + return true; + } + } +} + +function isMouseOverTradeBox(cX2, cY2) { + if (show && tradeConfirm === false) { + var x = cX2 / screenX; + var y = cY2 / screenY; + + if (x > tradeBoxPos[0] - 0.01 && x < tradeBoxPos[0] + 0.01 && y > tradeBoxPos[1] - 0.0175 && y < tradeBoxPos[1] + 0.0175) { + return true; + } + } +} + +function isMouseOverTradeDollar(cX2, cY2) { + if (show && tradeConfirm === false) { + var x = cX2 / screenX; + var y = cY2 / screenY; + + if (x > (tradeBoxPos[0] - 0.025) - 0.01 && x < (tradeBoxPos[0] - 0.025) + 0.01 && y > tradeBoxPos[1] - 0.0175 && y < tradeBoxPos[1] + 0.0175) { return true; } } @@ -500,57 +753,34 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world var cX = x / screenX; var cY = y / screenY; - //if (upOrDown === "down" && leftOrRight === "left") { - // clickTimeL = Date.now(); - // if (mouseActive === false) { - // if (clickTimeR !== null && Date.now() - clickTimeR < 100) { - // mouseActive = true; - // mp.gui.cursor.show(true, true); - // clickTimeL = null; - // clickTimeR = null; - // } - // } - // else { - // if (clickTimeR !== null && Date.now() - clickTimeR < 100) { - // mouseActive = false; - // mp.gui.cursor.show(false, false); - // clickTimeL = null; - // clickTimeR = null; - // } else { - // mp.gui.chat.push("~r~" + worldPosition.x.toFixed(3).toString() + ", ~g~" + worldPosition.y.toFixed(3).toString() + ", ~b~" + worldPosition.z.toFixed(3).toString()); - // } - // } - //} - //if (upOrDown === "down" && leftOrRight === "right") { - // clickTimeR = Date.now(); - // if (mouseActive === false) { - // if (clickTimeL !== null && Date.now() - clickTimeL < 100) { - // mouseActive = true; - // mp.gui.cursor.show(true, true); - // clickTimeL = null; - // clickTimeR = null; - // } - // } else { - // if (clickTimeL !== null && Date.now() - clickTimeL < 100) { - // mouseActive = false; - // mp.gui.cursor.show(false, false); - // clickTimeL = null; - // clickTimeR = null; - // } - // } - //} - if (show) { //LINKE MAUSTASTE //RUNTER if (upOrDown === "down" && leftOrRight === "left" && mouseLDown === false && mouseRDown === false) { + if (isTrading && isMouseOverTradeBox(x, y) && tradePrize > 0) { + tradeConfirm = true; + mp.events.callRemote('sendTradeItemsToPartner', JSON.stringify(tradeItems), tradePrize, tradePartner); + } + if (isTrading && isMouseOverTradeDollar(x, y)) { + var tradeMoney = new InputHelper("Wie viel $ möchtest du für deine Items haben?"); + tradeMoney.show(); + tradeMoney.getValue((data) => { + var amount = parseInt(data); + if (isNaN(amount) || amount < 0) { + mp.game.graphics.notify('~r~Du musst eine Zahl größer als 0 eingeben!'); + return; + } + tradePrize = amount; + }) + } mouseLDown = true; if (isMouseOverItem(x, y) && dragItem === null && itemRadial === false) { dragItem = hoverItem; oldDragSlot = items[dragItem][4]; items[dragItem][4] = "-1"; + dragTradeItem = false; } else if (ifMouseSelectRadial(x, y)) { switch (radialSelect) { case "up": @@ -566,8 +796,8 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world return; } mp.events.callRemote('itemInteract', "drop", items[clickedItem][5], parseInt(amount)); - }); - + }); + itemRadial = false; break; case "down": @@ -580,7 +810,12 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world case "right": itemRadial = false; break; - } + } + } else if (isMouseOverTradeItem(x, y) && dragItem === null && itemRadial === false && tradeConfirm === false) { + dragItem = hoverItem; + oldDragSlot = tradeItems[dragItem][4]; + tradeItems[dragItem][4] = "-1"; + dragTradeItem = true; } } @@ -591,18 +826,55 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world if (dragItem !== null) { if (isMouseOverFreeSlot(x, y)) { - items[dragItem][4] = actFreeSlot; + if (dragTradeItem === false) { + items[dragItem][4] = actFreeSlot; + } else { + items.push([tradeItems[dragItem][0], tradeItems[dragItem][1], tradeItems[dragItem][2], tradeItems[dragItem][3], actFreeSlot.toString(), tradeItems[dragItem][5]]); + tradeItems.splice(dragItem, 1); + } oldDragSlot = null; dragItem = null; hoverItem = null; } else if (isItemOverSameItem(x, y)) { - var newAmount = parseInt(items[stackToItem][3]) + parseInt(items[dragItem][3]); - items[stackToItem][3] = newAmount.toString(); - items[dragItem][4] = "-1"; + if (dragTradeItem === false) { + var newAmount = parseInt(items[stackToItem][3]) + parseInt(items[dragItem][3]); + items[stackToItem][3] = newAmount.toString(); + items[dragItem][4] = "-1"; + } else { + var newAmount = parseInt(items[stackToItem][3]) + parseInt(tradeItems[dragItem][3]); + items[stackToItem][3] = newAmount.toString(); + tradeItems.splice(dragItem,1); + } dragItem = null; - hoverItem = null; + hoverItem = null; + } else if (isItemOverSameTradeItem(x, y)) { + if (dragTradeItem === false) { + var newAmount = parseInt(tradeItems[stackToTradeItem][3]) + parseInt(items[dragItem][3]); + tradeItems[stackToTradeItem][3] = newAmount.toString(); + items[dragItem][4] = "-1"; + } else { + var newAmount = parseInt(tradeItems[stackToTradeItem][3]) + parseInt(tradeItems[dragItem][3]); + tradeItems[stackToTradeItem][3] = newAmount.toString(); + tradeItems[dragItem][4] = "-1"; + } + dragItem = null; + hoverItem = null; + } else if (isMouseOverFreeTradeSlot(x, y)) { + if (dragTradeItem === false) { + tradeItems.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], items[dragItem][3], actFreeTradeSlot.toString(), items[dragItem][5]]); + items.splice(dragItem, 1); + } else { + tradeItems[dragItem][4] = actFreeTradeSlot; + } + oldDragSlot = null; + dragItem = null; + hoverItem = null; } else { - items[dragItem][4] = oldDragSlot; + if (dragTradeItem === false) { + items[dragItem][4] = oldDragSlot; + } else { + tradeItems[dragItem][4] = oldDragSlot; + } dragItem = null; hoverItem = null; } @@ -616,17 +888,24 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world mouseRDown = true; if (isMouseOverItem(x, y) && dragItem === null) { - dragItem = hoverItem; + dragItem = hoverItem; oldDragSlot = items[hoverItem][4]; bufferItem = [items[hoverItem][0], items[hoverItem][1], items[hoverItem][2], items[hoverItem][3], items[hoverItem][4], items[hoverItem][5]]; - items[hoverItem][3]--; + items[hoverItem][3]--; + dragTradeItem = false; + } else if (isMouseOverTradeItem(x, y) && dragItem === null && tradeConfirm === false) { + dragItem = hoverItem; + oldDragSlot = tradeItems[hoverItem][4]; + bufferItem = [tradeItems[hoverItem][0], tradeItems[hoverItem][1], tradeItems[hoverItem][2], tradeItems[hoverItem][3], tradeItems[hoverItem][4], tradeItems[hoverItem][5]]; + tradeItems[hoverItem][3]--; + dragTradeItem = true; } } //HOCH if (upOrDown === "up" && leftOrRight === "right" && mouseRDown === true && itemRadial === false) { mouseRDown = false; - if (Date.now() - clickTime < 300 && isMouseOverItem(x, y)) { + if (Date.now() - clickTime < 100 && isMouseOverItem(x, y)) { clickedItem = hoverItem; items[hoverItem][3]++; itemRadial = true; @@ -636,23 +915,67 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world } else { if (dragItem !== null) { if (isMouseOverFreeSlot(x, y)) { - - items.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], "1", actFreeSlot.toString(), "-1"]); - if (items[hoverItem][3] === 0) { - items[hoverItem][4] = "-1"; + if (dragTradeItem === false) { + items.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], "1", actFreeSlot.toString(), "-1"]); + if (items[hoverItem][3] === 0) { + items[hoverItem][4] = "-1"; + } + } else { + items.push([tradeItems[dragItem][0], tradeItems[dragItem][1], tradeItems[dragItem][2], "1", actFreeSlot.toString(), "-1"]); + if (tradeItems[hoverItem][3] === 0) { + tradeItems.splice(hoverItem, 1); + } } dragItem = null; hoverItem = null; } else if (isItemOverSameItem(x, y)) { items[stackToItem][3]++; - if (items[hoverItem][3] === 0) { - items[hoverItem][4] = "-1"; + if (dragTradeItem === false) { + if (items[hoverItem][3] === 0) { + items[hoverItem][4] = "-1"; + } + } else { + if (tradeItems[hoverItem][3] === 0) { + tradeItems.splice(hoverItem, 1); + } } bufferItem = null; dragItem = null; hoverItem = null; + } else if (isItemOverSameTradeItem(x, y)) { + tradeItems[stackToTradeItem][3]++; + if (dragTradeItem === false) { + if (items[hoverItem][3] === 0) { + items[hoverItem][4] = "-1"; + } + } else { + if (tradeItems[hoverItem][3] === 0) { + tradeItems[hoverItem][4] = "-1"; + } + } + bufferItem = null; + dragItem = null; + hoverItem = null; + } else if (isMouseOverFreeTradeSlot(x, y)) { + if (dragTradeItem === false) { + tradeItems.push([items[dragItem][0], items[dragItem][1], items[dragItem][2], "1", actFreeTradeSlot.toString(), "-1"]); + if (items[hoverItem][3] === 0) { + items[hoverItem][4] = "-1"; + } + } else { + tradeItems.push([tradeItems[dragItem][0], tradeItems[dragItem][1], tradeItems[dragItem][2], "1", actFreeTradeSlot.toString(), "-1"]); + if (tradeItems[hoverItem][3] === 0) { + tradeItems[hoverItem][4] = "-1"; + } + } + dragItem = null; + hoverItem = null; } else { - items[hoverItem][3]++; + if (dragTradeItem === false) { + items[hoverItem][3]++; + } else { + tradeItems[hoverItem][3]++; + } bufferItem = null; dragItem = null; hoverItem = null; @@ -673,7 +996,7 @@ mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, world } } - //RECHTE MAUSTASTEshowAdmin = true; + //RECHTE MAUSTASTE //RUNTER if (upOrDown === "down" && leftOrRight === "right" && mouseLDown === false && mouseRDown === false) { diff --git a/Client/Interaction/interaction.js b/Client/Interaction/interaction.js new file mode 100644 index 00000000..731aefb3 --- /dev/null +++ b/Client/Interaction/interaction.js @@ -0,0 +1,266 @@ +var nearbyPlayers = []; +let screenRes = mp.game.graphics.getScreenResolution(0, 0); +var tradeRequest; +var tradeRequester; +var timerBarSize = 0.5; +var tradeTimeLeft; +var tradeSelection = "none"; +var tradeSelectHover = "none"; +var acceptColor = 100; +var declineColor = 100; + +const { x: screenX, y: screenY } = mp.game.graphics.getScreenActiveResolution(0, 0); +let rxC = 0.5; +let ryC = 0.4; +let rWidth = 0.4; +let sX = (screenX * 0.1 / 1000); +let sY = (screenY * 0.1 / 1000); +let eX = sX - 0.1; +let eY = sY - 0.1; +let sizeMul = 0.08; +let yMul = 1.8; + +var receivedTradePrize; +var receivedTradeItems = [[]]; +var receivedTradeGrid = []; +receivedTradeGrid[0] = [0.3375, 0.5] +receivedTradeGrid[1] = [0.4195, 0.5] +receivedTradeGrid[2] = [0.5015, 0.5] +receivedTradeGrid[3] = [0.5835, 0.5] +receivedTradeGrid[4] = [0.6655, 0.5] + +const NativeUI = require("nativeui"); +const Menu = NativeUI.Menu; +const UIMenuItem = NativeUI.UIMenuItem; +const UIMenuListItem = NativeUI.UIMenuListItem; +const UIMenuCheckboxItem = NativeUI.UIMenuCheckboxItem; +const BadgeStyle = NativeUI.BadgeStyle; +const Point = NativeUI.Point; +const ItemsCollection = NativeUI.ItemsCollection; +const Color = NativeUI.Color; + +mp.events.add("showPlayerInteraction", (nearPlayerArr) => { + mp.gui.chat.activate(false); + nearbyPlayers = JSON.parse(nearPlayerArr); + + let playerInteractionMenu = new Menu("Spielerinteraktion", "", new Point(0, screenRes.y / 2)); + let playerSelect = new UIMenuListItem("Mit", "~y~W\u00e4hle den Spieler aus.", new ItemsCollection(nearbyPlayers)); + playerInteractionMenu.AddItem(playerSelect); + playerInteractionMenu.AddItem(new UIMenuItem("Handeln", "Sende dem Spieler eine Handlungsanfrage")); + + let cancelItem = new UIMenuItem("Schlie\u00dfen", "Schlie\u00dft die Spielerinteraktion"); + cancelItem.BackColor = new Color(213, 0, 0); + cancelItem.HighlightedBackColor = new Color(229, 57, 53); + playerInteractionMenu.AddItem(cancelItem); + + playerInteractionMenu.Visible = true; + + playerInteractionMenu.ItemSelect.on((item) => { + if (item.Text === "Handeln") { + mp.events.callRemote("openTradeInventory", playerSelect.SelectedValue); + playerInteractionMenu.Visible = false; + mp.gui.chat.activate(true); + globalData.PlayerInteraction = false; + } else if (item.Text === "Abbrechen") { + globalData.PlayerInteraction = false; + playerInteractionMenu.Visible = false; + mp.gui.chat.activate(true); + globalData.PlayerInteraction = false; + } + }); +}); + +mp.events.add("showTradeRequest", (tradeRequesterName, tradeItemsArr, tradePrizeSent) => { + receivedTradeItems = tradeItemsArr; + receivedTradePrize = tradePrizeSent; + mp.gui.cursor.show(true, true); + tradeRequester = tradeRequesterName; + tradeRequest = true; + tradeTime = new Date().getTime(); + tradeTimeEnd = tradeTime + 30000; +}); + +mp.events.add("render", () => { + if (tradeRequest) { + var pos = mp.gui.cursor.position; + var actualTime = new Date().getTime(); + + tradeTimeLeft = (tradeTimeEnd - actualTime) / 1000; + + mp.game.graphics.set2dLayer(1); + mp.game.graphics.drawRect(0.5, 0.5, 0.5, 0.3, 255, 255, 255, 200); + + mp.game.graphics.drawText("Handelsanfrage von ~y~" + tradeRequester + " ~s~ für ~g~" + receivedTradePrize + "$", [0.5, 0.5 - 0.13], { + font: 7, + color: [112, 128, 144, 254], + scale: [0.7, 0.7], + outline: true, + }); + + mp.game.graphics.set2dLayer(2); + for (var slots = 0; slots < receivedTradeGrid.length; slots++) { + mp.game.graphics.drawRect(receivedTradeGrid[slots][0], receivedTradeGrid[slots][1], sizeMul, sizeMul * yMul, 112, 128, 144, 254); + mp.game.graphics.drawText(tempSlot2 = slots + 1, [receivedTradeGrid[slots][0] - (sizeMul / 2) + 0.006, receivedTradeGrid[slots][1] - (sizeMul / 2 * yMul)], { + font: 7, + color: [69, 255, 0, 254], + scale: [0.3, 0.3], + outline: true, + }); + } + + mp.game.graphics.set2dLayer(3); + //SPRITES + ITEMANZAHL + if (receivedTradeItems.length !== 0) { + for (var currentItem = 0; currentItem < receivedTradeItems.length; currentItem++) { + if (receivedTradeItems[currentItem][4] !== "-1") { + mp.game.graphics.drawSprite("itemimages", receivedTradeItems[currentItem][0].toLowerCase(), receivedTradeGrid[parseInt(receivedTradeItems[currentItem][4] - 1)][0], receivedTradeGrid[parseInt(receivedTradeItems[currentItem][4] - 1)][1], rWidth / 8, rWidth / 5, 0, 255, 255, 255, 255); + mp.game.graphics.drawText("(~y~" + receivedTradeItems[currentItem][3] + "~s~)", [receivedTradeGrid[parseInt(receivedTradeItems[currentItem][4] - 1)][0] + (sizeMul / 2) - 0.008, receivedTradeGrid[parseInt(receivedTradeItems[currentItem][4] - 1)][1] + 0.05], { + font: 0, + color: [255, 255, 255, 255], + scale: [0.25, 0.25], + outline: true, + }); + } + } + } + mp.game.graphics.set2dLayer(4); + if (isMouseOverTradeItem(pos[0], pos[1])) { + mp.game.graphics.drawRect(pos[0] / screenX, pos[1] / screenY + 0.055, 0.14, 0.08, 0, 0, 0, 220); + + var hoverItemP = [receivedTradeItems[hoverItem][0], receivedTradeItems[hoverItem][1], receivedTradeItems[hoverItem][2], receivedTradeItems[hoverItem][3]]; + + //NAME + mp.game.graphics.drawText("~g~" + hoverItemP[0], [pos[0] / screenX, pos[1] / screenY + 0.02], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.4, 0.4], + outline: true, + }); + + //BESCHREIBUNG + mp.game.graphics.drawText(hoverItemP[1], [pos[0] / screenX, pos[1] / screenY + 0.04], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.35, 0.35], + outline: true, + }); + + //EINZELGEWICHT + mp.game.graphics.drawText("~y~" + hoverItemP[2] + "g~s~ * " + hoverItemP[3] + "~s~ = ~y~" + hoverItemP[2] * hoverItemP[3] + "g", [pos[0] / screenX, pos[1] / screenY + 0.06], { + font: 4, + color: [255, 255, 255, 255], + scale: [0.35, 0.35], + outline: true, + }); + } + isMouseOverButton(pos[0], pos[1]); + mp.game.graphics.set2dLayer(5); + mp.game.graphics.drawRect(0.5 - 0.07, 0.5 + 0.1, 0.06, 0.04, 100, acceptColor, 100, 250); + mp.game.graphics.drawRect(0.5 + 0.07, 0.5 + 0.1, 0.06, 0.04, declineColor, 100, 100, 250); + + mp.game.graphics.set2dLayer(6); + + mp.game.graphics.drawText("~g~Annehmen", [0.5 - 0.07, 0.5 + 0.08], { + font: 4, + color: [112, 128, 144, 254], + scale: [0.6, 0.6], + outline: true, + }); + mp.game.graphics.drawText("~r~Ablehnen", [0.5 + 0.07, 0.5 + 0.08], { + font: 4, + color: [112, 128, 144, 254], + scale: [0.6, 0.6], + outline: true, + }); + + mp.game.graphics.set2dLayer(7); + timerBarSize = tradeTimeLeft / 30 * 0.5; + if (tradeTimeLeft > 0) { + mp.game.graphics.drawText(tradeTimeLeft.toFixed(0), [0.5, 0.5 + 0.1312], { + font: 7, + color: [255, 255, 255, 255], + scale: [0.35, 0.35], + outline: true, + }); + mp.game.graphics.drawRect(0.5, 0.5 + 0.1412, timerBarSize, 0.018, 255, 0, 0, 250); + } else { + mp.events.callRemote('tradeDecision', tradeSelection, JSON.stringify(receivedTradeItems), tradeRequester); + tradeSelection = "timeup"; + tradeRequest = false; + mp.gui.cursor.show(false, false); + } + } +}); +function isMouseOverButton(cX, cY) { + + if (tradeRequest) { + var x = cX / screenX; + var y = cY / screenY; + + if (x > 0.5 - 0.07 - 0.03 && x < 0.5 - 0.07 + 0.03 && y > 0.5 + 0.1 - 0.02 && y < 0.5 + 0.1 + 0.02) { + acceptColor = 255; + tradeSelectHover = "accept"; + return true; + } else if (x > 0.5 + 0.07 - 0.03 && x < 0.5 + 0.07 + 0.03 && y > 0.5 + 0.1 - 0.02 && y < 0.5 + 0.1 + 0.02) { + declineColor = 255; + tradeSelectHover = "decline"; + return true; + } else { + acceptColor = 100; + declineColor = 100; + return false; + } + } +} + +function isMouseOverTradeItem(cX, cY) { + + if (tradeRequest) { + + var x = cX / screenX; + var y = cY / screenY; + var a; + var b; + var c; + + for (var s = 0; s < 5; s++) { + a = receivedTradeGrid[s][0] - x; + b = receivedTradeGrid[s][1] - y; + c = Math.sqrt(a * a + b * b); + + var invSlot = (s + 1); + + if (c < sizeMul / 2) { + for (i = 0; i < receivedTradeItems.length; i++) { + if (parseInt(receivedTradeItems[i][4]) === invSlot) { + hoverItem = i; + return true; + } + } + } + } + } +} + +mp.events.add('click', (x, y, upOrDown, leftOrRight, relativeX, relativeY, worldPosition, hitEntity) => { + + var cX = x / screenX; + var cY = y / screenY; + + if (tradeRequest) { + //LINKE MAUSTASTE + //RUNTER + if (upOrDown === "down" && leftOrRight === "left") { + if (isMouseOverButton(x, y)) { + if (tradeSelectHover === "accept") { + tradeSelection = "accept"; + } else if (tradeSelectHover === "decline") { + tradeSelection = "decline"; + } + mp.events.callRemote('tradeDecision', tradeSelection, JSON.stringify(receivedTradeItems), tradeRequester); + tradeRequest = false; + mp.gui.cursor.show(false, false); + } + } + } +}); \ No newline at end of file diff --git a/Client/Player/keys.js b/Client/Player/keys.js index a5d2f403..04974e77 100644 --- a/Client/Player/keys.js +++ b/Client/Player/keys.js @@ -20,6 +20,14 @@ mp.keys.bind(0x0D, false, function () { } }); +//LEFT ARROW (Interaktion mit anderen Spielern) +mp.keys.bind(0x25, false, function () { + if (!chat && !showInv && !globalData.PlayerInteraction) { + mp.events.callRemote("keyPress:LEFT_ARROW"); + globalData.PlayerInteraction = true; + } +}); + //F7 //Unshowalles mp.keys.bind(0x76, false, function () { diff --git a/Client/dlcpacks/itemimages/dlc.rpf b/Client/dlcpacks/itemimages/dlc.rpf index 32f0198b..4aa64675 100644 --- a/Client/dlcpacks/itemimages/dlc.rpf +++ b/Client/dlcpacks/itemimages/dlc.rpf @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:7ff24e43dc8dba5207214613cb949c6a5a8ac29bfa90ae40a985e9c82a8cde43 -size 69632 +oid sha256:ad67a68580431746ceea4e52b889f694ce7521430d0d6c6a6cf3582db450f97a +size 76800 diff --git a/Client/index.js b/Client/index.js index 2012f973..e33be7fa 100644 --- a/Client/index.js +++ b/Client/index.js @@ -6,19 +6,24 @@ let globalData = { InTuning: false, - HideGui: false + HideGui: false, + PlayerInteraction: false }; mp.game.gameplay.enableMpDlcMaps(true); -require('./CharCreator/index.js'); +//ALPHABETISCH SORTIERT UND ZUSAMMENGEFÜGT +require('./Business/main.js'); +require('./Business/cardealer.js'); + +require('./CharCreator/index.js'); require('./coloredhlights'); -require('./FactionManagement/main.js'); - require('./DoorManager/doormanager.js'); +require('./FactionManagement/main.js'); + require('./Gui/deathscreen.js'); require('./Gui/infobox.js'); require('./Gui/nametags.js'); @@ -26,6 +31,8 @@ require('./Gui/playerlist.js'); require('./Gui/Inventory/inventory.js'); require('./Gui/vehiclemenu/main.js'); +require('./Interaction/interaction.js'); + require('./Login/main.js'); require('./Player/dutycloth.js'); @@ -33,15 +40,11 @@ require('./Player/keys.js'); require('./Player/quit.js'); require('./Player/freecam.js'); -require('./vehiclesync/vehiclesync.js'); - require('./Save/main.js'); - require('./Speedometer/index.js'); require('./Tuning/main.js'); require('./Tuning/sync.js'); require('./Tuning/sirensilence.js'); -require('./Business/main.js'); -require('./Business/cardealer.js'); +require('./vehiclesync/vehiclesync.js'); \ No newline at end of file diff --git a/Server/Events/Key.cs b/Server/Events/Key.cs index fe4f75ff..31309f43 100644 --- a/Server/Events/Key.cs +++ b/Server/Events/Key.cs @@ -38,7 +38,35 @@ namespace reallife_gamemode.Server.Events GroundItem.PickUpGroundItem(player); } - [RemoteEvent("keyPress:E")] + [RemoteEvent("keyPress:LEFT_ARROW")] + public void KeyPressLeftArrow(Client player) + { + if (!player.IsLoggedIn()) return; + List nearbyPlayers = NAPI.Player.GetPlayersInRadiusOfPlayer(3, player); + + if (nearbyPlayers.Count > 0) + { + List nearbyPlayerList = new List(); + foreach (Client nearPlayer in nearbyPlayers) + { + if (nearPlayer.Name != player.Name) + { + nearbyPlayerList.Add(nearPlayer.Name); + } + else + { + continue; + } + } + player.TriggerEvent("showPlayerInteraction", JsonConvert.SerializeObject(nearbyPlayerList)); + } + else + { + player.SendNotification("~r~Es ist niemand in deiner N\u00e4he!", false); + } + } + + [RemoteEvent("keyPress:E")] public void KeyPressE(Client player) { if (!player.IsLoggedIn()) return; diff --git a/Server/Managers/InteractionManager.cs b/Server/Managers/InteractionManager.cs new file mode 100644 index 00000000..85604307 --- /dev/null +++ b/Server/Managers/InteractionManager.cs @@ -0,0 +1,57 @@ +using GTANetworkAPI; +using Newtonsoft.Json; +using reallife_gamemode.Server.Extensions; +using reallife_gamemode.Server.Services; +using System; +using System.Collections.Generic; +using System.Text; + +/** +* @overview Life of German Reallife - Managers Interaction (InteractionManager.cs) +* @author VegaZ +* @copyright (c) 2008 - 2018 Life of German +*/ + +namespace reallife_gamemode.Server.Managers +{ + public class InteractionManager : Script + { + [RemoteEvent("openTradeInventory")] + public void OpenTradeInventory(Client player, string targetPlayer) + { + InventoryManager.GetUserItems(player); + player.TriggerEvent("openTradeMenu", targetPlayer); + } + + [RemoteEvent("sendTradeItemsToPartner")] + public void SendTradeItemsToPartner(Client player, string tradeItemArray, int tradePrize, string tradePartnerName) + { + var tradeItems = JsonConvert.DeserializeObject(tradeItemArray); + Client tradePartner = ClientService.GetClientByNameOrId(tradePartnerName); + InventoryManager.GetUserItems(player); + tradePartner.TriggerEvent("showTradeRequest", player.Name, tradeItems, tradePrize); + player.TriggerEvent("startTradeRequestTimer"); + //player.TriggerEvent("openTradeMenu", targetPlayer); + } + + [RemoteEvent("tradeDecision")] + public void TradeDecision(Client player, string tradeSelection, string tradeItemArray, string tradeRequesterName) + { + var tradeItems = JsonConvert.DeserializeObject(tradeItemArray); + Client tradeRequester = ClientService.GetClientByNameOrId(tradeRequesterName); + //player.SendChatMessage(tradeItemArray); + //player.SendChatMessage(tradeSelection); + if (tradeSelection == "accept") + { + InventoryManager.GetUserItems(player); + tradeRequester.TriggerEvent("clearTradeItems"); + player.TriggerEvent("showTradeItems", tradeItemArray); + } + else + { + tradeRequester.TriggerEvent("unlockTradeItems"); + } + + } + } +}