mirror of
https://github.com/Spythere/pojazdownik.git
synced 2026-05-03 11:45:34 +00:00
code adaptation for API changes; tons changed to kilos
This commit is contained in:
+87
-35
@@ -1,8 +1,21 @@
|
||||
import { EVehicleUseType } from '../enums/EVehicleUseType';
|
||||
import { ICarWagon, ILocomotive, IStore, TCarWagonGroup, TLocoGroup } from '../types';
|
||||
import { MassLimitLocoType, SpeedLimitLocoType, calculateMassLimit, calculateSpeedLimit } from './vehicleLimitsUtils';
|
||||
import { EVehicleUseType } from "../enums/EVehicleUseType";
|
||||
import {
|
||||
ICarWagon,
|
||||
ILocomotive,
|
||||
IStore,
|
||||
TCarWagonGroup,
|
||||
TLocoGroup,
|
||||
} from "../types";
|
||||
import {
|
||||
MassLimitLocoType,
|
||||
SpeedLimitLocoType,
|
||||
calculateMassLimit,
|
||||
calculateSpeedLimit,
|
||||
} from "./vehicleLimitsUtils";
|
||||
|
||||
export function isLocomotive(vehicle: ILocomotive | ICarWagon): vehicle is ILocomotive {
|
||||
export function isLocomotive(
|
||||
vehicle: ILocomotive | ICarWagon,
|
||||
): vehicle is ILocomotive {
|
||||
return (vehicle as ILocomotive).power !== undefined;
|
||||
}
|
||||
|
||||
@@ -12,15 +25,18 @@ export function locoDataList(state: IStore) {
|
||||
const stockData = state.stockData;
|
||||
|
||||
return Object.keys(stockData.info).reduce((acc, vehiclePower) => {
|
||||
if (!vehiclePower.startsWith('loco')) return acc;
|
||||
if (!vehiclePower.startsWith("loco")) return acc;
|
||||
|
||||
const locoVehiclesData = stockData.info[vehiclePower as TLocoGroup];
|
||||
|
||||
locoVehiclesData.forEach((loco) => {
|
||||
if (state.showSupporter && !loco[4]) return;
|
||||
|
||||
const [type, constructionType, cabinType, maxSpeed, sponsorsTimestamp] = loco;
|
||||
const locoProps = stockData.props.find((prop) => constructionType == prop.type);
|
||||
const [type, constructionType, cabinType, maxSpeed, sponsorsTimestamp] =
|
||||
loco;
|
||||
const locoProps = stockData.props.find(
|
||||
(prop) => constructionType == prop.type,
|
||||
);
|
||||
|
||||
acc.push({
|
||||
power: vehiclePower as TLocoGroup,
|
||||
@@ -31,10 +47,16 @@ export function locoDataList(state: IStore) {
|
||||
maxSpeed: Number(maxSpeed),
|
||||
isSponsorsOnly: Number(sponsorsTimestamp) > Date.now(),
|
||||
sponsorsOnlyTimestamp: Number(sponsorsTimestamp),
|
||||
imageSrc: '',
|
||||
imageSrc: "",
|
||||
|
||||
length: locoProps?.length && type.startsWith('2EN') ? locoProps.length * 2 : locoProps?.length ?? 0,
|
||||
mass: locoProps?.mass && type.startsWith('2EN') ? 253 : locoProps?.mass ?? 0,
|
||||
length:
|
||||
locoProps?.length && type.startsWith("2EN")
|
||||
? locoProps.length * 2
|
||||
: locoProps?.length ?? 0,
|
||||
weight:
|
||||
locoProps?.weight && type.startsWith("2EN")
|
||||
? 253000
|
||||
: locoProps?.weight ?? 0,
|
||||
|
||||
coldStart: locoProps?.coldStart ?? false,
|
||||
doubleManned: locoProps?.doubleManned ?? false,
|
||||
@@ -51,16 +73,25 @@ export function carDataList(state: IStore) {
|
||||
const stockData = state.stockData;
|
||||
|
||||
return Object.keys(stockData.info).reduce((acc, vehicleUseType) => {
|
||||
if (!vehicleUseType.startsWith('car')) return acc;
|
||||
if (!vehicleUseType.startsWith("car")) return acc;
|
||||
|
||||
const carVehiclesData = stockData.info[vehicleUseType as TCarWagonGroup];
|
||||
|
||||
carVehiclesData.forEach((car) => {
|
||||
const [type, constructionType, loadable, sponsorsOnlyTimestamp, maxSpeed] = car;
|
||||
const [
|
||||
type,
|
||||
constructionType,
|
||||
loadable,
|
||||
sponsorsOnlyTimestamp,
|
||||
maxSpeed,
|
||||
] = car;
|
||||
|
||||
if (state.showSupporter && Number(sponsorsOnlyTimestamp) <= Date.now()) return;
|
||||
if (state.showSupporter && Number(sponsorsOnlyTimestamp) <= Date.now())
|
||||
return;
|
||||
|
||||
const carPropsData = stockData.props.find((v) => type.toString().startsWith(v.type));
|
||||
const carPropsData = stockData.props.find((v) =>
|
||||
type.toString().startsWith(v.type),
|
||||
);
|
||||
|
||||
acc.push({
|
||||
useType: vehicleUseType as TCarWagonGroup,
|
||||
@@ -71,14 +102,10 @@ export function carDataList(state: IStore) {
|
||||
isSponsorsOnly: Number(sponsorsOnlyTimestamp) > Date.now(),
|
||||
sponsorsOnlyTimestamp: Number(sponsorsOnlyTimestamp),
|
||||
maxSpeed: Number(maxSpeed),
|
||||
imageSrc: '',
|
||||
cargoList:
|
||||
carPropsData?.cargo?.split(';').map((cargo) => ({
|
||||
id: cargo.split(':')[0],
|
||||
totalMass: Number(cargo.split(':')[1]),
|
||||
})) || [],
|
||||
imageSrc: "",
|
||||
cargoTypes: carPropsData?.cargoTypes ?? [],
|
||||
|
||||
mass: carPropsData?.mass || 0,
|
||||
weight: carPropsData?.weight || 0,
|
||||
length: carPropsData?.length || 0,
|
||||
});
|
||||
});
|
||||
@@ -87,37 +114,58 @@ export function carDataList(state: IStore) {
|
||||
}, [] as ICarWagon[]);
|
||||
}
|
||||
|
||||
export function totalMass(state: IStore) {
|
||||
return ~~state.stockList.reduce((acc, stock) => acc + (stock.cargo ? stock.cargo.totalMass : stock.mass) * stock.count, 0);
|
||||
export function totalWeight(state: IStore) {
|
||||
return state.stockList.reduce(
|
||||
(acc, stock) =>
|
||||
acc + (stock.weight + (stock.cargo?.weight ?? 0)) * stock.count,
|
||||
0,
|
||||
);
|
||||
}
|
||||
|
||||
export function totalLength(state: IStore) {
|
||||
return state.stockList.reduce((acc, stock) => acc + stock.length * stock.count, 0);
|
||||
return state.stockList.reduce(
|
||||
(acc, stock) => acc + stock.length * stock.count,
|
||||
0,
|
||||
);
|
||||
}
|
||||
|
||||
export function maxStockSpeed(state: IStore) {
|
||||
const stockSpeedLimit = state.stockList.reduce((acc, stock) => (stock.maxSpeed < acc || acc == 0 ? stock.maxSpeed : acc), 0);
|
||||
const headingLoco = state.stockList[0]?.isLoco ? state.stockList[0] : undefined;
|
||||
const stockSpeedLimit = state.stockList.reduce(
|
||||
(acc, stock) => (stock.maxSpeed < acc || acc == 0 ? stock.maxSpeed : acc),
|
||||
0,
|
||||
);
|
||||
const headingLoco = state.stockList[0]?.isLoco
|
||||
? state.stockList[0]
|
||||
: undefined;
|
||||
|
||||
if (!headingLoco) return stockSpeedLimit;
|
||||
|
||||
const locoType = headingLoco.type.split('-')[0];
|
||||
const locoType = headingLoco.type.split("-")[0];
|
||||
|
||||
if (/^(EN|2EN|SN)/.test(locoType)) return stockSpeedLimit;
|
||||
|
||||
const stockMass = totalMass(state);
|
||||
const stockTotalWeight = totalWeight(state);
|
||||
|
||||
const speedLimitByMass = calculateSpeedLimit(locoType as SpeedLimitLocoType, stockMass, isTrainPassenger(state));
|
||||
const speedLimitByMass = calculateSpeedLimit(
|
||||
locoType as SpeedLimitLocoType,
|
||||
stockTotalWeight,
|
||||
isTrainPassenger(state),
|
||||
);
|
||||
|
||||
return speedLimitByMass ? Math.min(stockSpeedLimit, speedLimitByMass) : stockSpeedLimit;
|
||||
return speedLimitByMass
|
||||
? Math.min(stockSpeedLimit, speedLimitByMass)
|
||||
: stockSpeedLimit;
|
||||
}
|
||||
|
||||
export function acceptableMass(state: IStore) {
|
||||
if (state.stockList.length == 0 || !state.stockList[0].isLoco) return 0;
|
||||
|
||||
const activeLocomotiveType = state.stockList[0].type.split('-')[0];
|
||||
const activeLocomotiveType = state.stockList[0].type.split("-")[0];
|
||||
|
||||
const locoMassLimit = calculateMassLimit(activeLocomotiveType as MassLimitLocoType, isTrainPassenger(state));
|
||||
const locoMassLimit = calculateMassLimit(
|
||||
activeLocomotiveType as MassLimitLocoType,
|
||||
isTrainPassenger(state),
|
||||
);
|
||||
|
||||
return locoMassLimit;
|
||||
}
|
||||
@@ -126,7 +174,9 @@ export function isTrainPassenger(state: IStore) {
|
||||
if (state.stockList.length == 0) return false;
|
||||
if (state.stockList.every((stock) => stock.isLoco)) return false;
|
||||
|
||||
return state.stockList.filter((stock) => !stock.isLoco).every((stock) => stock.useType === EVehicleUseType.CAR_PASSENGER);
|
||||
return state.stockList
|
||||
.filter((stock) => !stock.isLoco)
|
||||
.every((stock) => stock.useType === EVehicleUseType.CAR_PASSENGER);
|
||||
}
|
||||
|
||||
export function chosenRealStock(state: IStore) {
|
||||
@@ -135,9 +185,11 @@ export function chosenRealStock(state: IStore) {
|
||||
for (let i = 0; i < stock.count; i++) acc.push(stock.type);
|
||||
return acc;
|
||||
}, [] as string[])
|
||||
.join(';');
|
||||
.join(";");
|
||||
|
||||
const realStockObj = state.readyStockList.find((readyStock) => readyStock.stockString == currentStockString);
|
||||
const realStockObj = state.readyStockList.find(
|
||||
(readyStock) => readyStock.stockString == currentStockString,
|
||||
);
|
||||
|
||||
state.chosenRealStockName = realStockObj?.stockId ?? undefined;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user