2024-10-24 13:12:21 +00:00
|
|
|
import type { Building, Production } from "./types";
|
2024-10-22 15:15:35 +00:00
|
|
|
import type { VillageState } from "./village";
|
|
|
|
|
|
|
|
|
|
|
|
function _reduceResources(acc: Production, item: Production): Production {
|
|
|
|
return {
|
|
|
|
wood: acc.wood + item.wood,
|
|
|
|
stone: acc.stone + item.stone,
|
|
|
|
iron: acc.iron + item.iron,
|
|
|
|
food: acc.food + item.food,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
export function getEmptyResources(): Production {
|
|
|
|
return {
|
|
|
|
wood: 0,
|
|
|
|
stone: 0,
|
|
|
|
iron: 0,
|
|
|
|
food: 0,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
export function getProduction(villageState: VillageState): Production {
|
|
|
|
return villageState.buildings
|
2024-10-24 17:27:33 +00:00
|
|
|
.filter(b => b.behavior.production && b.level > 0)
|
2024-10-22 15:15:35 +00:00
|
|
|
.map(b => {
|
|
|
|
if (b.behavior.production) {
|
|
|
|
return b.behavior.production(villageState, b);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.reduce(_reduceResources, getEmptyResources());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
export function getStorage(villageState: VillageState): Production {
|
|
|
|
return villageState.buildings
|
2024-10-24 17:27:33 +00:00
|
|
|
.filter(b => b.behavior.storage && b.level > 0)
|
2024-10-22 15:15:35 +00:00
|
|
|
.map(b => {
|
|
|
|
if (b.behavior.storage) {
|
|
|
|
return b.behavior.storage(villageState, b);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.reduce(_reduceResources, getEmptyResources());
|
|
|
|
}
|
2024-10-24 09:32:31 +00:00
|
|
|
|
|
|
|
|
2024-10-24 13:12:21 +00:00
|
|
|
export function getBuilding(V: VillageState, buildingId: number): Building {
|
|
|
|
const building = V.buildings.find(b => b.id === buildingId);
|
|
|
|
if (!building) {
|
|
|
|
throw new Error(`Cannot find building with id "${buildingId}"`);
|
|
|
|
}
|
|
|
|
return building;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2024-10-24 09:32:31 +00:00
|
|
|
export function getKeysAsNumbers(dict: Object): Array<number> {
|
|
|
|
return Object.keys(dict).map(i => parseInt(i)).sort((a, b) => a - b);
|
|
|
|
}
|
2024-10-24 13:31:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an array of shuffled values, using a version of the
|
|
|
|
* [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).
|
|
|
|
*
|
|
|
|
* @since 0.1.0
|
|
|
|
* @category Array
|
|
|
|
* @param {Array} array The array to shuffle.
|
|
|
|
* @returns {Array} Returns the new shuffled array.
|
|
|
|
* @example
|
|
|
|
*
|
|
|
|
* shuffle([1, 2, 3, 4])
|
|
|
|
* // => [4, 1, 3, 2]
|
|
|
|
*/
|
|
|
|
export function shuffle<T>(array: Array<T>): Array<T> {
|
|
|
|
const length = array.length;
|
|
|
|
if (!length) {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
let index = -1;
|
|
|
|
const lastIndex = length - 1;
|
|
|
|
const result = [ ...array ];
|
|
|
|
while (++index < length) {
|
|
|
|
const rand = index + Math.floor(Math.random() * (lastIndex - index + 1));
|
|
|
|
[ result[rand], result[index] ] = [ result[index], result[rand] ];
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2024-10-24 17:27:33 +00:00
|
|
|
|
|
|
|
|
|
|
|
export function enqueueBuilding(V: VillageState, building: Building) {
|
|
|
|
const ongoingUpgrades = V.queue.filter(q => q.id === building.id);
|
|
|
|
const level = building.level + 1 + ongoingUpgrades.length;
|
|
|
|
const remainingTime = 1000 * level;
|
|
|
|
|
|
|
|
V.queue.push({
|
|
|
|
id: building.id,
|
|
|
|
remainingTime,
|
|
|
|
});
|
|
|
|
}
|