mirror of
https://github.com/bitburner-official/bitburner-src.git
synced 2024-11-18 05:33:54 +01:00
CORPORATION: UI to display production and sales multipliers (#838)
This commit is contained in:
parent
269a74d5c0
commit
2f40b66789
@ -3,11 +3,11 @@
|
|||||||
import React, { useState } from "react";
|
import React, { useState } from "react";
|
||||||
|
|
||||||
import { OfficeSpace } from "../OfficeSpace";
|
import { OfficeSpace } from "../OfficeSpace";
|
||||||
import { CorpUnlockName, CorpEmployeeJob } from "@enums";
|
import { CorpUnlockName, CorpEmployeeJob, CorpUpgradeName, CorpProductResearchName } from "@enums";
|
||||||
import { BuyTea } from "../Actions";
|
import { BuyTea } from "../Actions";
|
||||||
|
|
||||||
import { MoneyCost } from "./MoneyCost";
|
import { MoneyCost } from "./MoneyCost";
|
||||||
import { formatCorpStat } from "../../ui/formatNumber";
|
import { formatBigNumber, formatCorpStat, formatCorpMultiplier } from "../../ui/formatNumber";
|
||||||
|
|
||||||
import { UpgradeOfficeSizeModal } from "./modals/UpgradeOfficeSizeModal";
|
import { UpgradeOfficeSizeModal } from "./modals/UpgradeOfficeSizeModal";
|
||||||
import { ThrowPartyModal } from "./modals/ThrowPartyModal";
|
import { ThrowPartyModal } from "./modals/ThrowPartyModal";
|
||||||
@ -27,6 +27,7 @@ import TableBody from "@mui/material/TableBody";
|
|||||||
import TableRow from "@mui/material/TableRow";
|
import TableRow from "@mui/material/TableRow";
|
||||||
import { TableCell } from "../../ui/React/Table";
|
import { TableCell } from "../../ui/React/Table";
|
||||||
import { Box } from "@mui/material";
|
import { Box } from "@mui/material";
|
||||||
|
import { StatsTable } from "../../ui/React/StatsTable";
|
||||||
|
|
||||||
interface OfficeProps {
|
interface OfficeProps {
|
||||||
office: OfficeSpace;
|
office: OfficeSpace;
|
||||||
@ -98,6 +99,60 @@ function AutoManagement(props: OfficeProps): React.ReactElement {
|
|||||||
const currUna = props.office.employeeJobs[CorpEmployeeJob.Unassigned];
|
const currUna = props.office.employeeJobs[CorpEmployeeJob.Unassigned];
|
||||||
const nextUna = props.office.employeeNextJobs[CorpEmployeeJob.Unassigned];
|
const nextUna = props.office.employeeNextJobs[CorpEmployeeJob.Unassigned];
|
||||||
|
|
||||||
|
const totalMaterialProduction =
|
||||||
|
division.getOfficeProductivity(props.office) *
|
||||||
|
corp.getProductionMultiplier() *
|
||||||
|
division.productionMult *
|
||||||
|
division.getProductionMultiplier();
|
||||||
|
const materialBreakdown = (
|
||||||
|
<StatsTable
|
||||||
|
rows={[
|
||||||
|
["Employee Production:", formatBigNumber(division.getOfficeProductivity(props.office, { forProduct: false }))],
|
||||||
|
["Boosting Materials:", formatCorpMultiplier(division.productionMult)],
|
||||||
|
["Research:", formatCorpMultiplier(division.getProductionMultiplier())],
|
||||||
|
[`${CorpUpgradeName.SmartFactories}:`, formatCorpMultiplier(corp.getProductionMultiplier())],
|
||||||
|
[<b key={1}>Total Material Production:</b>, <b key={2}>{formatCorpStat(totalMaterialProduction)}</b>],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
|
||||||
|
const totalProductProduction =
|
||||||
|
division.getOfficeProductivity(props.office, { forProduct: true }) *
|
||||||
|
corp.getProductionMultiplier() *
|
||||||
|
division.productionMult *
|
||||||
|
division.getProductionMultiplier() *
|
||||||
|
division.getProductProductionMultiplier();
|
||||||
|
const productBreakdown = (
|
||||||
|
<StatsTable
|
||||||
|
rows={[
|
||||||
|
["Employee Production:", formatBigNumber(division.getOfficeProductivity(props.office, { forProduct: true }))],
|
||||||
|
["Boosting Materials:", formatCorpMultiplier(division.productionMult)],
|
||||||
|
["Research:", formatCorpMultiplier(division.getProductionMultiplier())],
|
||||||
|
[`${CorpProductResearchName.Fulcrum}:`, formatCorpMultiplier(division.getProductProductionMultiplier())],
|
||||||
|
[`${CorpUpgradeName.SmartFactories}:`, formatCorpMultiplier(corp.getProductionMultiplier())],
|
||||||
|
[<b key={1}>Total Product Production:</b>, <b key={2}>{formatCorpStat(totalProductProduction)}</b>],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
|
||||||
|
// Sale multipliers
|
||||||
|
const businessFactor = division.getBusinessFactor(props.office); //Business employee productivity
|
||||||
|
const [adsTotal] = division.getAdvertisingFactors(); //Awareness + popularity
|
||||||
|
const researchMult = division.getSalesMultiplier();
|
||||||
|
const upgradeMult = corp.getSalesMult();
|
||||||
|
const totalSaleMultiplier = businessFactor * adsTotal * researchMult * upgradeMult;
|
||||||
|
const salesBreakdown = (
|
||||||
|
<StatsTable
|
||||||
|
rows={[
|
||||||
|
["Business Employees:", formatCorpMultiplier(businessFactor)],
|
||||||
|
["Advertising:", formatCorpMultiplier(adsTotal)],
|
||||||
|
researchMult !== 1 ? ["Research:", formatCorpMultiplier(researchMult)] : [],
|
||||||
|
[`${CorpUpgradeName.ABCSalesBots}:`, formatCorpMultiplier(upgradeMult)],
|
||||||
|
[<b key={1}>Total Sales Multiplier:</b>, <b key={2}>{formatCorpMultiplier(totalSaleMultiplier)}</b>],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Table padding="none">
|
<Table padding="none">
|
||||||
<TableBody>
|
<TableBody>
|
||||||
@ -149,10 +204,12 @@ function AutoManagement(props: OfficeProps): React.ReactElement {
|
|||||||
<TableCell>
|
<TableCell>
|
||||||
<Tooltip
|
<Tooltip
|
||||||
title={
|
title={
|
||||||
<Typography>
|
<Typography component="div">
|
||||||
The base amount of material this office can produce. Does not include production multipliers from
|
The amount of material this office can produce.
|
||||||
upgrades and materials. This value is based off the productivity of your Operations, Engineering,
|
<br />
|
||||||
and Management employees
|
This value is based off the productivity of your
|
||||||
|
<br />
|
||||||
|
Operations, Engineering, and Management employees.
|
||||||
</Typography>
|
</Typography>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
@ -160,39 +217,55 @@ function AutoManagement(props: OfficeProps): React.ReactElement {
|
|||||||
</Tooltip>
|
</Tooltip>
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell>
|
<TableCell>
|
||||||
<Typography align="right">{formatCorpStat(division.getOfficeProductivity(props.office))}</Typography>
|
<Tooltip title={materialBreakdown}>
|
||||||
|
<Typography align="right">{formatCorpStat(totalMaterialProduction)}</Typography>
|
||||||
|
</Tooltip>
|
||||||
</TableCell>
|
</TableCell>
|
||||||
</TableRow>
|
</TableRow>
|
||||||
|
{division.makesProducts ? (
|
||||||
|
<TableRow>
|
||||||
|
<TableCell>
|
||||||
|
<Tooltip
|
||||||
|
title={
|
||||||
|
<Typography component="div">
|
||||||
|
The amount of any given Product this office can produce.
|
||||||
|
<br />
|
||||||
|
This value is based off the productivity of your
|
||||||
|
<br />
|
||||||
|
Operations, Engineering, and Management employees.
|
||||||
|
</Typography>
|
||||||
|
}
|
||||||
|
>
|
||||||
|
<Typography>Product Production:</Typography>
|
||||||
|
</Tooltip>
|
||||||
|
</TableCell>
|
||||||
|
<TableCell>
|
||||||
|
<Tooltip title={productBreakdown}>
|
||||||
|
<Typography align="right">{formatCorpStat(totalProductProduction)}</Typography>
|
||||||
|
</Tooltip>
|
||||||
|
</TableCell>
|
||||||
|
</TableRow>
|
||||||
|
) : null}
|
||||||
<TableRow>
|
<TableRow>
|
||||||
<TableCell>
|
<TableCell>
|
||||||
<Tooltip
|
<Tooltip
|
||||||
title={
|
title={
|
||||||
<Typography>
|
<Typography>
|
||||||
The base amount of any given Product this office can produce. Does not include production
|
This office's sales effectivity for all materials and products.
|
||||||
multipliers from upgrades and materials. This value is based off the productivity of your
|
<br />
|
||||||
Operations, Engineering, and Management employees
|
It is based on your Business employees and your advertising.
|
||||||
|
<br />
|
||||||
|
This will be further modified by demand and competition for each item.
|
||||||
</Typography>
|
</Typography>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
<Typography>Product Production:</Typography>
|
<Typography>Sales Multiplier:</Typography>
|
||||||
</Tooltip>
|
|
||||||
</TableCell>
|
|
||||||
<TableCell>
|
|
||||||
<Typography align="right">
|
|
||||||
{formatCorpStat(division.getOfficeProductivity(props.office, { forProduct: true }))}
|
|
||||||
</Typography>
|
|
||||||
</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell>
|
|
||||||
<Tooltip
|
|
||||||
title={<Typography>The effect this office's 'Business' employees has on boosting sales</Typography>}
|
|
||||||
>
|
|
||||||
<Typography> Business Multiplier:</Typography>
|
|
||||||
</Tooltip>
|
</Tooltip>
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell align="right">
|
<TableCell align="right">
|
||||||
<Typography>x{formatCorpStat(division.getBusinessFactor(props.office))}</Typography>
|
<Tooltip title={salesBreakdown}>
|
||||||
|
<Typography>{formatCorpMultiplier(totalSaleMultiplier)}</Typography>
|
||||||
|
</Tooltip>
|
||||||
</TableCell>
|
</TableCell>
|
||||||
</TableRow>
|
</TableRow>
|
||||||
</>
|
</>
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
// React Component for displaying an Division's overview information
|
// React Component for displaying an Division's overview information
|
||||||
// (top-left panel in the Division UI)
|
// (top-left panel in the Division UI)
|
||||||
import React, { useState } from "react";
|
import React, { useState } from "react";
|
||||||
|
import { MathJax } from "better-react-mathjax";
|
||||||
|
|
||||||
import { CorpUnlockName, IndustryType } from "@enums";
|
import { CorpUnlockName, IndustryType } from "@enums";
|
||||||
import { HireAdVert } from "../Actions";
|
import { HireAdVert } from "../Actions";
|
||||||
import { formatBigNumber } from "../../ui/formatNumber";
|
import { formatBigNumber, formatCorpMultiplier } from "../../ui/formatNumber";
|
||||||
import { createProgressBarText } from "../../utils/helpers/createProgressBarText";
|
import { createProgressBarText } from "../../utils/helpers/createProgressBarText";
|
||||||
import { MakeProductModal } from "./modals/MakeProductModal";
|
import { MakeProductModal } from "./modals/MakeProductModal";
|
||||||
import { ResearchModal } from "./modals/ResearchModal";
|
import { ResearchModal } from "./modals/ResearchModal";
|
||||||
@ -134,18 +135,23 @@ export function DivisionOverview(props: DivisionOverviewProps): React.ReactEleme
|
|||||||
<Tooltip
|
<Tooltip
|
||||||
title={
|
title={
|
||||||
<>
|
<>
|
||||||
<Typography>Total multiplier for this industry's sales due to its awareness and popularity</Typography>
|
<Typography>Multiplier for this industry's sales due to its awareness and popularity.</Typography>
|
||||||
|
<br />
|
||||||
|
<MathJax>{`\\(\\text{${division.type} Industry: }\\alpha = ${division.advertisingFactor}\\)`}</MathJax>
|
||||||
|
<MathJax>{`\\(\\text{multiplier} = \\left((\\text{awareness}+1)^{\\alpha} \\times (\\text{popularity}+1)^{\\alpha} \\times \\frac{\\text{popularity}+0.001}{\\text{awareness}}\\right)^{0.85}\\)`}</MathJax>
|
||||||
|
<br />
|
||||||
<StatsTable
|
<StatsTable
|
||||||
rows={[
|
rows={[
|
||||||
["Awareness Bonus:", "x" + formatBigNumber(Math.pow(awarenessFac, 0.85))],
|
["Awareness Bonus:", formatCorpMultiplier(Math.pow(awarenessFac, 0.85))],
|
||||||
["Popularity Bonus:", "x" + formatBigNumber(Math.pow(popularityFac, 0.85))],
|
["Popularity Bonus:", formatCorpMultiplier(Math.pow(popularityFac, 0.85))],
|
||||||
["Ratio Multiplier:", "x" + formatBigNumber(Math.pow(ratioFac, 0.85))],
|
["Ratio Multiplier:", formatCorpMultiplier(Math.pow(ratioFac, 0.85))],
|
||||||
|
[<b key={1}>Total:</b>, <b key={2}>{formatCorpMultiplier(totalAdvertisingFac)}</b>],
|
||||||
]}
|
]}
|
||||||
/>
|
/>
|
||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
<Typography>Advertising Multiplier: x{formatBigNumber(totalAdvertisingFac)}</Typography>
|
<Typography>Advertising Multiplier: {formatCorpMultiplier(totalAdvertisingFac)}</Typography>
|
||||||
</Tooltip>
|
</Tooltip>
|
||||||
)}
|
)}
|
||||||
<br />
|
<br />
|
||||||
@ -161,12 +167,13 @@ export function DivisionOverview(props: DivisionOverviewProps): React.ReactEleme
|
|||||||
<Tooltip
|
<Tooltip
|
||||||
title={
|
title={
|
||||||
<>
|
<>
|
||||||
Production gain from owning production-boosting materials such as hardware, Robots, AI Cores, and Real
|
Production gain from owning production-boosting materials such as
|
||||||
Estate.
|
<br />
|
||||||
|
hardware, Robots, AI Cores, and Real Estate.
|
||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
<Typography>Production Multiplier: {formatBigNumber(division.productionMult)}</Typography>
|
<Typography>Production Multiplier: {formatCorpMultiplier(division.productionMult)}</Typography>
|
||||||
</Tooltip>
|
</Tooltip>
|
||||||
<IconButton onClick={() => setHelpOpen(true)}>
|
<IconButton onClick={() => setHelpOpen(true)}>
|
||||||
<HelpIcon />
|
<HelpIcon />
|
||||||
@ -211,10 +218,10 @@ export function DivisionOverview(props: DivisionOverviewProps): React.ReactEleme
|
|||||||
<ButtonWithTooltip
|
<ButtonWithTooltip
|
||||||
normalTooltip={
|
normalTooltip={
|
||||||
<>
|
<>
|
||||||
Hire AdVert.Inc to advertise your company. Each level of this upgrade grants your company a static
|
Hire <b>AdVert.Inc</b> to advertise your company. Each level of this upgrade grants your company a static
|
||||||
increase of 3 and 1 to its awareness and popularity, respectively. It will then increase your company's" +
|
increase of 3 and 1 to its awareness and popularity, respectively. It will then increase your company's
|
||||||
awareness by 1%, and its popularity by a random percentage between 1% and 3%. These effects are increased
|
awareness by 0.5%, and its popularity by a random percentage between 0.5% and 1.5%. These effects are
|
||||||
by other upgrades that increase the power of your advertising.
|
increased by other upgrades that increase the power of your advertising.
|
||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
disabledTooltip={division.getAdVertCost() > corp.funds ? "Insufficient corporation funds" : ""}
|
disabledTooltip={division.getAdVertCost() > corp.funds ? "Insufficient corporation funds" : ""}
|
||||||
|
@ -13,6 +13,7 @@ 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";
|
||||||
|
import { StatsTable } from "../../ui/React/StatsTable";
|
||||||
|
|
||||||
interface IMaterialProps {
|
interface IMaterialProps {
|
||||||
warehouse: Warehouse;
|
warehouse: Warehouse;
|
||||||
@ -79,33 +80,26 @@ export function MaterialElem(props: IMaterialProps): React.ReactElement {
|
|||||||
limitMaterialButtonText += " (" + formatCorpStat(mat.productionLimit) + ")";
|
limitMaterialButtonText += " (" + formatCorpStat(mat.productionLimit) + ")";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Material Gain details
|
||||||
|
const gainBreakdown = [
|
||||||
|
["Buy:", mat.buyAmount >= 1e33 ? mat.buyAmount.toExponential(3) : formatBigNumber(mat.buyAmount)],
|
||||||
|
["Prod:", formatBigNumber(mat.productionAmount)],
|
||||||
|
["Import:", formatBigNumber(mat.importAmount)],
|
||||||
|
["Export:", formatBigNumber(-mat.exportedLastCycle || 0)],
|
||||||
|
["Sell:", formatBigNumber(-mat.actualSellAmount || 0)],
|
||||||
|
];
|
||||||
|
if (corp.unlocks.has(CorpUnlockName.MarketResearchDemand)) {
|
||||||
|
gainBreakdown.push(["Demand:", formatCorpStat(mat.demand)]);
|
||||||
|
}
|
||||||
|
if (corp.unlocks.has(CorpUnlockName.MarketDataCompetition)) {
|
||||||
|
gainBreakdown.push(["Competition:", formatCorpStat(mat.competition)]);
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Paper>
|
<Paper>
|
||||||
<Box sx={{ display: "grid", gridTemplateColumns: "2fr 1fr", m: "5px" }}>
|
<Box sx={{ display: "grid", gridTemplateColumns: "2fr 1fr", m: "5px" }}>
|
||||||
<Box>
|
<Box>
|
||||||
<Tooltip
|
<Tooltip title={<StatsTable rows={gainBreakdown} />}>
|
||||||
title={
|
|
||||||
<Typography>
|
|
||||||
Buy: {mat.buyAmount >= 1e33 ? mat.buyAmount.toExponential(3) : formatBigNumber(mat.buyAmount)} <br />
|
|
||||||
Prod: {formatBigNumber(mat.productionAmount)} <br />
|
|
||||||
Sell: {formatBigNumber(mat.actualSellAmount)} <br />
|
|
||||||
Export: {formatBigNumber(mat.exportedLastCycle)} <br />
|
|
||||||
Import: {formatBigNumber(mat.importAmount)}
|
|
||||||
{corp.unlocks.has(CorpUnlockName.MarketResearchDemand) && (
|
|
||||||
<>
|
|
||||||
<br />
|
|
||||||
Demand: {formatCorpStat(mat.demand)}
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
{corp.unlocks.has(CorpUnlockName.MarketDataCompetition) && (
|
|
||||||
<>
|
|
||||||
<br />
|
|
||||||
Competition: {formatCorpStat(mat.competition)}
|
|
||||||
</>
|
|
||||||
)}
|
|
||||||
</Typography>
|
|
||||||
}
|
|
||||||
>
|
|
||||||
<Typography>
|
<Typography>
|
||||||
{mat.name}: {formatBigNumber(mat.stored)} (
|
{mat.name}: {formatBigNumber(mat.stored)} (
|
||||||
{totalGain >= 1e33 ? totalGain.toExponential(3) : formatBigNumber(totalGain)}/s)
|
{totalGain >= 1e33 ? totalGain.toExponential(3) : formatBigNumber(totalGain)}/s)
|
||||||
|
@ -15,7 +15,7 @@ import * as corpConstants from "../data/Constants";
|
|||||||
import { CorpUnlocks } from "../data/CorporationUnlocks";
|
import { CorpUnlocks } from "../data/CorporationUnlocks";
|
||||||
|
|
||||||
import { CONSTANTS } from "../../Constants";
|
import { CONSTANTS } from "../../Constants";
|
||||||
import { formatCorpStat, formatPercent, formatShares } from "../../ui/formatNumber";
|
import { formatCorpMultiplier, formatPercent, formatShares } from "../../ui/formatNumber";
|
||||||
import { convertTimeMsToTimeElapsedString } from "../../utils/StringHelperFunctions";
|
import { convertTimeMsToTimeElapsedString } from "../../utils/StringHelperFunctions";
|
||||||
import { Money } from "../../ui/React/Money";
|
import { Money } from "../../ui/React/Money";
|
||||||
import { MoneyRate } from "../../ui/React/MoneyRate";
|
import { MoneyRate } from "../../ui/React/MoneyRate";
|
||||||
@ -45,7 +45,7 @@ export function Overview({ rerender }: IProps): React.ReactElement {
|
|||||||
const multRows: string[][] = [];
|
const multRows: string[][] = [];
|
||||||
function appendMult(name: string, value: number): void {
|
function appendMult(name: string, value: number): void {
|
||||||
if (value === 1) return;
|
if (value === 1) return;
|
||||||
multRows.push([name, formatCorpStat(value)]);
|
multRows.push([name, formatCorpMultiplier(value)]);
|
||||||
}
|
}
|
||||||
appendMult("Production Multiplier: ", corp.getProductionMultiplier());
|
appendMult("Production Multiplier: ", corp.getProductionMultiplier());
|
||||||
appendMult("Storage Multiplier: ", corp.getStorageMultiplier());
|
appendMult("Storage Multiplier: ", corp.getStorageMultiplier());
|
||||||
@ -79,18 +79,18 @@ export function Overview({ rerender }: IProps): React.ReactElement {
|
|||||||
rows={[
|
rows={[
|
||||||
[
|
[
|
||||||
"Owned Stock Shares:",
|
"Owned Stock Shares:",
|
||||||
<> {formatShares(corp.numShares)} </>,
|
formatShares(corp.numShares),
|
||||||
<>({formatPercent(corp.numShares / corp.totalShares)})</>,
|
`(${formatPercent(corp.numShares / corp.totalShares)})`,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
"Outstanding Shares:",
|
"Outstanding Shares:",
|
||||||
<> {formatShares(corp.issuedShares)} </>,
|
formatShares(corp.issuedShares),
|
||||||
<>({formatPercent(corp.issuedShares / corp.totalShares)})</>,
|
`(${formatPercent(corp.issuedShares / corp.totalShares)})`,
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
"Private Shares:",
|
"Private Shares:",
|
||||||
<> {formatShares(corp.investorShares)} </>,
|
formatShares(corp.investorShares),
|
||||||
<>({formatPercent(corp.investorShares / corp.totalShares)})</>,
|
`(${formatPercent(corp.investorShares / corp.totalShares)})`,
|
||||||
],
|
],
|
||||||
]}
|
]}
|
||||||
/>
|
/>
|
||||||
|
@ -13,6 +13,7 @@ import { formatBigNumber, formatPercent } from "../../ui/formatNumber";
|
|||||||
import { isString } from "../../utils/helpers/string";
|
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";
|
||||||
|
|
||||||
interface IProductProps {
|
interface IProductProps {
|
||||||
city: CityName;
|
city: CityName;
|
||||||
@ -89,11 +90,12 @@ export function ProductElem(props: IProductProps): React.ReactElement {
|
|||||||
<Box display="flex">
|
<Box display="flex">
|
||||||
<Tooltip
|
<Tooltip
|
||||||
title={
|
title={
|
||||||
<Typography>
|
<StatsTable
|
||||||
Prod: {formatBigNumber(product.cityData[city].productionAmount)}/s
|
rows={[
|
||||||
<br />
|
["Prod:", formatBigNumber(product.cityData[city].productionAmount)],
|
||||||
Sell: {formatBigNumber(product.cityData[city].actualSellAmount)} /s
|
["Sell:", formatBigNumber(-product.cityData[city].actualSellAmount || 0)],
|
||||||
</Typography>
|
]}
|
||||||
|
/>
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
<Typography>
|
<Typography>
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
import React, { useState } from "react";
|
import React, { useState } from "react";
|
||||||
import { Modal } from "../../../ui/React/Modal";
|
import { Modal } from "../../../ui/React/Modal";
|
||||||
|
import { StatsTable } from "../../../ui/React/StatsTable";
|
||||||
|
import { dialogBoxCreate } from "../../../ui/React/DialogBox";
|
||||||
|
import { formatCorpMultiplier } from "../../../ui/formatNumber";
|
||||||
import { IndustryResearchTrees } from "../../data/IndustryData";
|
import { IndustryResearchTrees } from "../../data/IndustryData";
|
||||||
import * as corpConstants from "../../data/Constants";
|
import * as corpConstants from "../../data/Constants";
|
||||||
import { Division } from "../../Division";
|
import { Division } from "../../Division";
|
||||||
@ -7,7 +10,7 @@ import { Research } from "../../Actions";
|
|||||||
import { Node } from "../../ResearchTree";
|
import { Node } from "../../ResearchTree";
|
||||||
import { ResearchMap } from "../../ResearchMap";
|
import { ResearchMap } from "../../ResearchMap";
|
||||||
import { Settings } from "../../../Settings/Settings";
|
import { Settings } from "../../../Settings/Settings";
|
||||||
import { dialogBoxCreate } from "../../../ui/React/DialogBox";
|
|
||||||
import Typography from "@mui/material/Typography";
|
import Typography from "@mui/material/Typography";
|
||||||
import Tooltip from "@mui/material/Tooltip";
|
import Tooltip from "@mui/material/Tooltip";
|
||||||
import Button from "@mui/material/Button";
|
import Button from "@mui/material/Button";
|
||||||
@ -144,15 +147,19 @@ export function ResearchModal(props: IProps): React.ReactElement {
|
|||||||
Research points: {props.industry.researchPoints.toFixed(3)}
|
Research points: {props.industry.researchPoints.toFixed(3)}
|
||||||
<br />
|
<br />
|
||||||
Multipliers from research:
|
Multipliers from research:
|
||||||
<br />* Advertising Multiplier: x{researchTree.getAdvertisingMultiplier()}
|
<StatsTable
|
||||||
<br />* Employee Charisma Multiplier: x{researchTree.getEmployeeChaMultiplier()}
|
rows={[
|
||||||
<br />* Employee Creativity Multiplier: x{researchTree.getEmployeeCreMultiplier()}
|
["Advertising Multiplier:", formatCorpMultiplier(researchTree.getAdvertisingMultiplier())],
|
||||||
<br />* Employee Efficiency Multiplier: x{researchTree.getEmployeeEffMultiplier()}
|
["Employee Charisma Multiplier:", formatCorpMultiplier(researchTree.getEmployeeChaMultiplier())],
|
||||||
<br />* Employee Intelligence Multiplier: x{researchTree.getEmployeeIntMultiplier()}
|
["Employee Creativity Multiplier:", formatCorpMultiplier(researchTree.getEmployeeCreMultiplier())],
|
||||||
<br />* Production Multiplier: x{researchTree.getProductionMultiplier()}
|
["Employee Efficiency Multiplier:", formatCorpMultiplier(researchTree.getEmployeeEffMultiplier())],
|
||||||
<br />* Sales Multiplier: x{researchTree.getSalesMultiplier()}
|
["Employee Intelligence Multiplier:", formatCorpMultiplier(researchTree.getEmployeeIntMultiplier())],
|
||||||
<br />* Scientific Research Multiplier: x{researchTree.getScientificResearchMultiplier()}
|
["Production Multiplier:", formatCorpMultiplier(researchTree.getProductionMultiplier())],
|
||||||
<br />* Storage Multiplier: x{researchTree.getStorageMultiplier()}
|
["Sales Multiplier:", formatCorpMultiplier(researchTree.getSalesMultiplier())],
|
||||||
|
["Scientific Research Multiplier:", formatCorpMultiplier(researchTree.getScientificResearchMultiplier())],
|
||||||
|
["Storage Multiplier:", formatCorpMultiplier(researchTree.getStorageMultiplier())],
|
||||||
|
]}
|
||||||
|
/>
|
||||||
</Typography>
|
</Typography>
|
||||||
</Modal>
|
</Modal>
|
||||||
);
|
);
|
||||||
|
@ -1,29 +1,33 @@
|
|||||||
import React from "react";
|
import React, { ReactNode, ReactElement } from "react";
|
||||||
|
|
||||||
import { Table, TableCell } from "./Table";
|
import { Table, TableCell } from "./Table";
|
||||||
import TableBody from "@mui/material/TableBody";
|
import { TableBody, TableRow, Table as MuiTable, Typography } from "@mui/material";
|
||||||
import { Table as MuiTable } from "@mui/material";
|
import { makeStyles } from "@mui/styles";
|
||||||
import TableRow from "@mui/material/TableRow";
|
|
||||||
import Typography from "@mui/material/Typography";
|
|
||||||
|
|
||||||
interface IProps {
|
interface StatsTableProps {
|
||||||
rows: React.ReactNode[][];
|
rows: ReactNode[][];
|
||||||
title?: string;
|
title?: string;
|
||||||
wide?: boolean;
|
wide?: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function StatsTable({ rows, title, wide }: IProps): React.ReactElement {
|
const useStyles = makeStyles({
|
||||||
|
firstCell: { textAlign: "left" },
|
||||||
|
nonFirstCell: { textAlign: "right", paddingLeft: "0.5em" },
|
||||||
|
});
|
||||||
|
|
||||||
|
export function StatsTable({ rows, title, wide }: StatsTableProps): ReactElement {
|
||||||
const T = wide ? MuiTable : Table;
|
const T = wide ? MuiTable : Table;
|
||||||
|
const classes = useStyles();
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
{title && <Typography>{title}</Typography>}
|
{title && <Typography>{title}</Typography>}
|
||||||
<T size="small" padding="none">
|
<T size="small" padding="none">
|
||||||
<TableBody>
|
<TableBody>
|
||||||
{rows.map((row: React.ReactNode[], i: number) => (
|
{rows.map((row, rowIndex) => (
|
||||||
<TableRow key={i}>
|
<TableRow key={rowIndex}>
|
||||||
{row.map((elem: React.ReactNode, i: number) => (
|
{row.map((cell, cellIndex) => (
|
||||||
<TableCell key={i} align={i !== 0 ? "right" : "left"}>
|
<TableCell key={cellIndex} className={cellIndex === 0 ? classes.firstCell : classes.nonFirstCell}>
|
||||||
<Typography noWrap>{elem}</Typography>
|
<Typography noWrap>{cell}</Typography>
|
||||||
</TableCell>
|
</TableCell>
|
||||||
))}
|
))}
|
||||||
</TableRow>
|
</TableRow>
|
||||||
|
@ -151,6 +151,7 @@ export const formatPopulation = formatBigNumber;
|
|||||||
export const formatSecurity = formatBigNumber;
|
export const formatSecurity = formatBigNumber;
|
||||||
export const formatStamina = formatBigNumber;
|
export const formatStamina = formatBigNumber;
|
||||||
export const formatStaneksGiftCharge = formatBigNumber;
|
export const formatStaneksGiftCharge = formatBigNumber;
|
||||||
|
export const formatCorpMultiplier = (n: number) => "×" + formatBigNumber(n);
|
||||||
|
|
||||||
/** Format a number with suffixes starting at 1000 and 2 fractional digits */
|
/** Format a number with suffixes starting at 1000 and 2 fractional digits */
|
||||||
export const formatQuality = (n: number) => formatNumber(n, 2);
|
export const formatQuality = (n: number) => formatNumber(n, 2);
|
||||||
|
Loading…
Reference in New Issue
Block a user