From 69735b5037bf9a2ac1a9562108b0ba88ac4b4ec2 Mon Sep 17 00:00:00 2001 From: Dev Date: Wed, 31 Jan 2024 23:39:01 +0000 Subject: [PATCH] Check inventory has space before adding bitcoins from craft --- project/src/helpers/HideoutHelper.ts | 37 +++++++++++----- project/src/helpers/InventoryHelper.ts | 60 ++++++++++++++++++++++++++ 2 files changed, 86 insertions(+), 11 deletions(-) diff --git a/project/src/helpers/HideoutHelper.ts b/project/src/helpers/HideoutHelper.ts index b4cd5ba4..5ea21469 100644 --- a/project/src/helpers/HideoutHelper.ts +++ b/project/src/helpers/HideoutHelper.ts @@ -968,20 +968,35 @@ export class HideoutHelper return this.httpResponse.appendErrorToOutput(output, errorMsg); } - - // Add each coin individually to player + + const itemsToAdd: Item[][] = []; for (let index = 0; index < craftedCoinCount; index++) { - const request = { - itemWithModsToAdd: [ - { - _id: this.hashUtil.generate(), - _tpl: HideoutHelper.bitcoinTpl, - upd: { - StackObjectsCount: 1 - } + itemsToAdd.push( + [{ + _id: this.hashUtil.generate(), + _tpl: HideoutHelper.bitcoinTpl, + upd: { + StackObjectsCount: 1 } - ], + }] + ) + } + + // Add each coin individually to player + if (!this.inventoryHelper.canPlaceItemsInInventory(sessionId, itemsToAdd)) + { + // no space, exit + return this.httpResponse.appendErrorToOutput( + output, + this.localisationService.getText("inventory-no_stash_space"), + ) + } + + for (const itemToAdd of itemsToAdd) + { + const request: IAddItemDirectRequest = { + itemWithModsToAdd: itemToAdd, foundInRaid: true, useSortingTable: false, callback: null diff --git a/project/src/helpers/InventoryHelper.ts b/project/src/helpers/InventoryHelper.ts index f2d4847a..9a8e47af 100644 --- a/project/src/helpers/InventoryHelper.ts +++ b/project/src/helpers/InventoryHelper.ts @@ -498,6 +498,66 @@ export class InventoryHelper } } + public canPlaceItemsInInventory( + sessionId: string, + itemsWithChildren: Item[][] + ): boolean + { + const pmcData = this.profileHelper.getPmcProfile(sessionId); + + const stashFS2D = this.getStashSlotMap(pmcData, sessionId); + for (const itemWithChildren of itemsWithChildren) + { + if (this.canPlaceItemInInventory(stashFS2D, itemWithChildren)) + { + return false; + } + } + + return true; + } + + public canPlaceItemInInventory( + stashFS2D: number[][], + itemWithChildren: Item[] + ): boolean + { + // Get x/y size of item + const rootItem = itemWithChildren[0]; + const itemSize = this.getItemSize(rootItem._tpl, rootItem._id, itemWithChildren); + + // Look for a place to slot item into + const findSlotResult = this.containerHelper.findSlotForItem(stashFS2D, itemSize[0], itemSize[1]); + if (findSlotResult.success) + { + /* Fill in the StashFS_2D with an imaginary item, to simulate it already being added + * so the next item to search for a free slot won't find the same one */ + const itemSizeX = findSlotResult.rotation ? itemSize[1] : itemSize[0]; + const itemSizeY = findSlotResult.rotation ? itemSize[0] : itemSize[1]; + + try + { + stashFS2D = this.containerHelper.fillContainerMapWithItem( + stashFS2D, + findSlotResult.x, + findSlotResult.y, + itemSizeX, + itemSizeY, + false, + ); // TODO: rotation not passed in, bad? + } + catch (err) + { + return false; + } + + // Success! exit + return; + } + + return true; + } + protected placeItemInInventory( stashFS2D: number[][], sortingTableFS2D: number[][],