A player in the video game foxhole, firing a storm cannon at enemy positions.

The Making of Foxhole Logistics Calculator

A technical breakdown of how and why the Foxhole Logistics Calculator came to be, and where it will end up. Follow the journey from design, to prototype, to a minimum viable product in production. You will learn the drawbacks of a logistics player in the game Foxhole, and why this utility was created for the community.

The Backstory

In the game Foxhole, I found myself in the muddy trenches defending against the Wardens, alongside other Colonial players. As the Wardens were pushing into the town of Longstone in the Westgate region, we found ourselves low of supplies, ammunition, and our morals low.

A lot of talk in chat had been made about requesting logistics to the region to help defend against the Wardens. And it made myself and several other players around me thing, what would it take to make our supplies.

Soon after I found myself in the pits, mining scrap to be processed into basic materials, a core item in crafting. During this time, I quickly came to realize that there wasn't too many quality-of-life tools for players who solely played as logistics.

Foxhole player adds two orders of 7.62mm ammo to factory.
A player drives up to a factory and places and order of 2 crates of 7.62mm ammo.

An issue that I had with that was when traveling long distances with these materials to create items, you would spend a long time looking at the game wiki calculating these costs before traveling to not waste time by being off on crafting prices.

Understanding the Problem

For a player to do logistics and deliver viable items to the front, they would have to go through several steps. This can be broken down into the process of gathering scrap, refining it, and then crafting the materials into items at factories that they got from the refinery. After waiting some time at the factory, they could collect these items and deliver them to the front.

The issue in my opinion lies between getting the basic materials together, and placing the factory order. This is because the map changes from war to war, and often times you will find the storage or refinery separated by a sizable distance to the factory. This time of travel can take between 5 minutes to 20 minutes depending on the time and place.

In order to be efficient with a time constrained role, you want to be precise and not wasteful. You definitely don't want to backtrack your route either to obtain more materials that you could be lacking.

The MPF Formula

A large portion of the website hinges on a mathematical formula the developers use for a discount found in the mass production factory (MPF). The only thing that gives any hint to how this formula works is a small description found within the items description cards when you're viewing them inside the MPF, which was -

10% discount per crate up to 50%

To help me figure this out and visualize the formula, I created a table that showed what values were at each step of adding a crate of items to the MPF order. The important fields to pay attention to are the Discount Cost Cumulative and Applied Discount. Applied discount is based on the individual base cost, in this case, 60 basic materials.

Table for 120mm Artillery Shells
Number of Crates Bmat Cost Cumulative Discount Cost Cumulative Applied Discount (60) Discount
1 60 54 54 10%
2 120 102 48 20%
3 180 144 42 30%
4 240 180 36 40%
5 300 210 30 50%
6 360 240 30 50%
7 420 270 30 50%
8 480 300 30 50%
9 540 330 30 50%

So We've Cracked the Formula?

Not exactly, take a close look at the table for explosive material costs for 120mm artillery shells.

Table for 120mm Artillery Shells
Number of Crates Emat Cost Cumulative Discount Cost Cumulative Applied Discount (15) Discount
1 15 13.5 13.5 10%
2 30 25.5 12 20%
3 45 36 10.5 30%
4 60 45 9 40%
5 75 52.5 7.5 50%
6 90 60 7.5 50%
7 105 67.5 7.5 50%
8 120 75 7.5 50%
9 135 82.5 7.5 50%

The results state that it should be 82.5 explosive materials. The two issues with that a full factory order in-game actually costs 79 explosive materials, and there is no such thing as 1/2 a material. This was clear evidence of a rounding point error, and I used Math.Floor() on the cumulative cost per iteration to fix that. This can be seen on the function table of the cumulative costs for explosive materials.

Function Table for 120mm Artillery Shells
Number of Crates Formula Applied Discount (15)
1 15 - (15 * .1) 13
2 15 - (15 * .2) 12
3 15 - (15 * .3) 10
4 15 - (15 * .4) 9
5 15 - (15 * .5) 7
6 15 - (15 * .5) 7
7 15 - (15 * .5) 7
8 15 - (15 * .5) 7
9 15 - (15 * .5) 7
Total: 79

This function tabled helped me visualize that I needed to iterate through all crates keeping in minds the 10%-50% discount per crate while minding the Math.floor() math function. This would take the number_of_crates and resource_base_cost as arguments and would return a resource_total_cost. The loop variable would have to be checked if it is past 5 total crates to apply the flat discount rate of 50%. This is the math function that I would be using inside Foxhole Logi.

    
                getItemDiscountCosts(number_of_crates, resource_base_cost) {
        
                    let resource_total_cost = 0
        
                    for(let i = 1; i <= number_of_crates; i++) {
                        if(i > 5) resource_total_cost += Math.floor(resource_base_cost - (resource_base_cost * (5/10)))
                        if(i <= 5) resource_total_cost += Math.floor(resource_base_cost - (resource_base_cost * (i/10)))
                    }
        
                    return resource_total_cost
                }
            
        

Application Flow & Design Considerations

Before starting this project, I had to consider what language or framework I would choose. The options were standard html/css/js or a framework to help this development. I knew going into this project I would have to have a state management for global settings such as a factory or mass production, colonial or warden, and even a system for order management. I went with VueJS for its event emitters and the ability to add a store for state management.

UML Diagram of FoxholeLogi.com
UML Diagram of FoxholeLogi.com

I ended up creating enough of a minimum viable product with only event emitters, but would later find out that this is hard to maintain and expand on functionality as it made a mess of my code.

There's a fake "state" found at the root of the page, and is sent information via emitters on items, settings, removing an order, and adding an order. These events are processed at the root component, and are passed down to components via props.

If I were to recreate an application to this size again, I would proceed with using Vuex as a state management instead of relying on emitters/props. Although messy, it was a learning experience as I had never built with framework with the mindset of reactive programming.

Game Data

Unlike the War Api provided by Clapfoot, which gives information about in-game activities to create applications like FoxholeStats. There are no APIs to obtain information about item data such as names, descriptions, costs, and more.

This is why I meticulously collected, recorded, and maintain a single JSON file containing this information for the general public which you can view on the website.

Menu Structure & Design

Since I did not plan to initially include localization for other languages due to costs, the next thing that was needed was a system to replicate in-game menu structure with their icons. This way the user will be able to recognize these icons and be able to more reliably use this application without too much need for relying on text.

Menu comparison of Foxholelogi.com & in-game
Menu comparison between site and in-game
Factory order comparison of Foxholelogi.com & in-game
Factory order comparison between site and in-game

Take Away from Project

What I learned

Overall, I'm happy with myself and am proud of my work. It was a learning experience as it was my first time working with VueJS or any reactive programming language. Although some mistakes were made, and the minimal viable product's code is a bit messy to maintain, I'm still very proud of FoxholeLogi.

How I can Improve

Here's some things that I will be working on to further improve this application.