MISC: Remove isString utility function (#1185)

This commit is contained in:
catloversg 2024-03-23 16:46:52 +07:00 committed by GitHub
parent c5581e92bc
commit db226ce0b8
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 7 additions and 21 deletions

@ -8,7 +8,6 @@ import { calculateEffectWithFactors } from "../utils/calculateEffectWithFactors"
import { OfficeSpace } from "./OfficeSpace"; import { OfficeSpace } from "./OfficeSpace";
import { Product } from "./Product"; import { Product } from "./Product";
import { dialogBoxCreate } from "../ui/React/DialogBox"; import { dialogBoxCreate } from "../ui/React/DialogBox";
import { isString } from "../utils/helpers/string";
import { MaterialInfo } from "./MaterialInfo"; import { MaterialInfo } from "./MaterialInfo";
import { Warehouse } from "./Warehouse"; import { Warehouse } from "./Warehouse";
import { Corporation } from "./Corporation"; import { Corporation } from "./Corporation";
@ -522,7 +521,7 @@ export class Division {
// The amount gets re-multiplied later, so this is the correct // The amount gets re-multiplied later, so this is the correct
// amount to calculate with for "MAX". // amount to calculate with for "MAX".
const adjustedQty = mat.stored / (corpConstants.secondsPerMarketCycle * marketCycles); const adjustedQty = mat.stored / (corpConstants.secondsPerMarketCycle * marketCycles);
if (isString(mat.desiredSellAmount)) { if (typeof mat.desiredSellAmount === "string") {
//Dynamically evaluated //Dynamically evaluated
let tmp = mat.desiredSellAmount.replace(/MAX/g, adjustedQty.toString()); let tmp = mat.desiredSellAmount.replace(/MAX/g, adjustedQty.toString());
tmp = tmp.replace(/PROD/g, mat.productionAmount.toString()); tmp = tmp.replace(/PROD/g, mat.productionAmount.toString());
@ -575,7 +574,7 @@ export class Division {
} else if (mat.marketTa1) { } else if (mat.marketTa1) {
sCost = mat.marketPrice + markupLimit; sCost = mat.marketPrice + markupLimit;
// check truthyness to avoid unnecessary eval // check truthyness to avoid unnecessary eval
} else if (isString(mat.desiredSellPrice) && mat.desiredSellPrice) { } else if (typeof mat.desiredSellPrice === "string" && mat.desiredSellPrice) {
sCost = mat.desiredSellPrice.replace(/MP/g, mat.marketPrice.toString()); sCost = mat.desiredSellPrice.replace(/MP/g, mat.marketPrice.toString());
sCost = eval(sCost); sCost = eval(sCost);
} else { } else {
@ -853,7 +852,7 @@ export class Division {
// amount to calculate with for "MAX". // amount to calculate with for "MAX".
const adjustedQty = product.cityData[city].stored / (corpConstants.secondsPerMarketCycle * marketCycles); const adjustedQty = product.cityData[city].stored / (corpConstants.secondsPerMarketCycle * marketCycles);
const desiredSellAmount = product.cityData[city].desiredSellAmount; const desiredSellAmount = product.cityData[city].desiredSellAmount;
if (isString(desiredSellAmount)) { if (typeof desiredSellAmount === "string") {
//Sell amount is dynamically evaluated //Sell amount is dynamically evaluated
let tmp: number | string = desiredSellAmount.replace(/MAX/g, adjustedQty.toString()); let tmp: number | string = desiredSellAmount.replace(/MAX/g, adjustedQty.toString());
tmp = tmp.replace(/PROD/g, product.cityData[city].productionAmount.toString()); tmp = tmp.replace(/PROD/g, product.cityData[city].productionAmount.toString());
@ -909,7 +908,7 @@ export class Division {
sCost = optimalPrice; sCost = optimalPrice;
} else if (product.marketTa1) { } else if (product.marketTa1) {
sCost = product.cityData[city].productionCost + markupLimit; sCost = product.cityData[city].productionCost + markupLimit;
} else if (isString(sellPrice)) { } else if (typeof sellPrice === "string") {
let sCostString = sellPrice; let sCostString = sellPrice;
if (product.markup === 0) { if (product.markup === 0) {
console.error(`mku is zero, reverting to 1 to avoid Infinity`); console.error(`mku is zero, reverting to 1 to avoid Infinity`);

@ -9,7 +9,6 @@ import { ExportModal } from "./modals/ExportModal";
import { SellMaterialModal } from "./modals/SellMaterialModal"; import { SellMaterialModal } from "./modals/SellMaterialModal";
import { PurchaseMaterialModal } from "./modals/PurchaseMaterialModal"; import { PurchaseMaterialModal } from "./modals/PurchaseMaterialModal";
import { formatBigNumber, formatCorpStat, formatQuality } from "../../ui/formatNumber"; import { formatBigNumber, formatCorpStat, formatQuality } from "../../ui/formatNumber";
import { isString } from "../../utils/helpers/string";
import { Money } from "../../ui/React/Money"; import { Money } from "../../ui/React/Money";
import { useCorporation, useDivision } from "./Context"; import { useCorporation, useDivision } from "./Context";
import { LimitMaterialProductionModal } from "./modals/LimitMaterialProductionModal"; import { LimitMaterialProductionModal } from "./modals/LimitMaterialProductionModal";
@ -54,7 +53,7 @@ export function MaterialElem(props: IMaterialProps): React.ReactElement {
// Sell material button // Sell material button
let sellButtonText: JSX.Element; let sellButtonText: JSX.Element;
if (mat.desiredSellAmount) { if (mat.desiredSellAmount) {
if (isString(mat.desiredSellAmount)) { if (typeof mat.desiredSellAmount === "string") {
sellButtonText = ( sellButtonText = (
<> <>
Sell ({formatBigNumber(mat.actualSellAmount)}/{mat.desiredSellAmount}) Sell ({formatBigNumber(mat.actualSellAmount)}/{mat.desiredSellAmount})

@ -10,7 +10,6 @@ import { CancelProductModal } from "./modals/CancelProductModal";
import { formatBigNumber, formatPercent } from "../../ui/formatNumber"; import { formatBigNumber, formatPercent } from "../../ui/formatNumber";
import { isString } from "../../utils/helpers/string";
import { Money } from "../../ui/React/Money"; import { Money } from "../../ui/React/Money";
import { useCorporation, useDivision } from "./Context"; import { useCorporation, useDivision } from "./Context";
import { StatsTable } from "../../ui/React/StatsTable"; import { StatsTable } from "../../ui/React/StatsTable";
@ -41,7 +40,7 @@ export function ProductElem(props: IProductProps): React.ReactElement {
let sellButtonText: JSX.Element; let sellButtonText: JSX.Element;
const desiredSellAmount = cityData.desiredSellAmount; const desiredSellAmount = cityData.desiredSellAmount;
if (desiredSellAmount !== null) { if (desiredSellAmount !== null) {
if (isString(desiredSellAmount)) { if (typeof desiredSellAmount === "string") {
sellButtonText = ( sellButtonText = (
<> <>
Sell ({formatBigNumber(cityData.actualSellAmount)}/{desiredSellAmount}) Sell ({formatBigNumber(cityData.actualSellAmount)}/{desiredSellAmount})

@ -1,5 +1,4 @@
import { Settings } from "../Settings/Settings"; import { Settings } from "../Settings/Settings";
import { isString } from "./helpers/string";
/* /*
Converts a date representing time in milliseconds to a string with the format H hours M minutes and S seconds Converts a date representing time in milliseconds to a string with the format H hours M minutes and S seconds
@ -75,7 +74,7 @@ function longestCommonStart(strings: string[]): string {
// Returns whether an array contains entirely of string objects // Returns whether an array contains entirely of string objects
function containsAllStrings(arr: string[]): boolean { function containsAllStrings(arr: string[]): boolean {
return arr.every(isString); return arr.every((value) => typeof value === "string");
} }
// Generates a random alphanumeric string with N characters // Generates a random alphanumeric string with N characters

@ -1,13 +1,3 @@
// We can probably get rid of isString in favor of just checking typeof value==="string".
// We are not and should not ever be using `new String()` for anything. Will remove in 2.3.1
/**
* Checks whether the value passed in can be considered a string.
* @param value The value to check if it is a string.
*/
export function isString(value: unknown): value is string {
return typeof value === "string" || value instanceof String;
}
/** Removes a single layer of matching single or double quotes, if present. */ /** Removes a single layer of matching single or double quotes, if present. */
export function trimQuotes(value: string): string { export function trimQuotes(value: string): string {
if (value.length < 2) return value; if (value.length < 2) return value;