mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2025-01-05 12:57:35 +01:00
MISC: Remove isString utility function (#1185)
This commit is contained in:
parent
c5581e92bc
commit
db226ce0b8
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user