chore: do addItem on inventory document, not accountId #699

Merged
Sainan merged 11 commits from additem-inplace into main 2025-01-03 15:25:09 -08:00
Showing only changes of commit f6afdd4869 - Show all commits

View File

@ -143,11 +143,10 @@ export const addItem = async (
} }
}; };
} else if (ExportResources[typeName].productCategory == "CrewShips") { } else if (ExportResources[typeName].productCategory == "CrewShips") {
return { const inventory = await getInventory(accountId);
InventoryChanges: { const inventoryChanges = addCrewShip(inventory, typeName);
CrewShips: [await addCrewShip(typeName, accountId)] await inventory.save();
} return { InventoryChanges: inventoryChanges };
};
} else { } else {
const miscItemChanges = [ const miscItemChanges = [
{ {
@ -590,11 +589,15 @@ export const addSkin = async (typeName: string, accountId: string): Promise<IWea
return changedInventory.WeaponSkins[index].toJSON() as object as IWeaponSkinClient; return changedInventory.WeaponSkins[index].toJSON() as object as IWeaponSkinClient;
}; };
const addCrewShip = async (typeName: string, accountId: string) => { const addCrewShip = (
const inventory = await getInventory(accountId); inventory: TInventoryDatabaseDocument,
typeName: string,
inventoryChanges: IInventoryChanges = {}
): IInventoryChanges => {
const index = inventory.CrewShips.push({ ItemType: typeName }) - 1; const index = inventory.CrewShips.push({ ItemType: typeName }) - 1;
const changedInventory = await inventory.save(); inventoryChanges.CrewShips ??= [];
return changedInventory.CrewShips[index].toJSON(); (inventoryChanges.CrewShips as object[]).push(inventory.CrewShips[index].toJSON());
return inventoryChanges;
}; };
const addGearExpByCategory = ( const addGearExpByCategory = (