import React, { useState } from "react"; import { formatNumber, convertTimeMsToTimeElapsedString } from "../../utils/StringHelperFunctions"; import { ActionTypes } from "../data/ActionTypes"; import { createProgressBarText } from "../../utils/helpers/createProgressBarText"; import { TeamSizeButton } from "./TeamSizeButton"; import { IBladeburner } from "../IBladeburner"; import { BlackOperation } from "../BlackOperation"; import { BlackOperations } from "../data/BlackOperations"; import { IPlayer } from "../../PersonObjects/IPlayer"; import { CopyableText } from "../../ui/React/CopyableText"; import { SuccessChance } from "./SuccessChance"; import { StartButton } from "./StartButton"; import Typography from "@mui/material/Typography"; import Paper from "@mui/material/Paper"; interface IProps { bladeburner: IBladeburner; player: IPlayer; action: BlackOperation; } export function BlackOpElem(props: IProps): React.ReactElement { const setRerender = useState(false)[1]; function rerender(): void { setRerender((old) => !old); } const isCompleted = props.bladeburner.blackops[props.action.name] != null; if (isCompleted) { return ( {props.action.name} (COMPLETED) ); } const isActive = props.bladeburner.action.type === ActionTypes["BlackOperation"] && props.action.name === props.bladeburner.action.name; const actionTime = props.action.getActionTime(props.bladeburner); const hasReqdRank = props.bladeburner.rank >= props.action.reqdRank; const computedActionTimeCurrent = Math.min( props.bladeburner.actionTimeCurrent + props.bladeburner.actionTimeOverflow, props.bladeburner.actionTimeToComplete, ); const actionData = BlackOperations[props.action.name]; if (actionData === undefined) { throw new Error(`Cannot find data for ${props.action.name}`); } return ( {isActive ? ( <> <> (IN PROGRESS - {formatNumber(computedActionTimeCurrent, 0)} /{" "} {formatNumber(props.bladeburner.actionTimeToComplete, 0)}) {createProgressBarText({ progress: computedActionTimeCurrent / props.bladeburner.actionTimeToComplete, })} ) : ( <> )}

{actionData.desc}

Required Rank: {formatNumber(props.action.reqdRank, 0)}

Time Required: {convertTimeMsToTimeElapsedString(actionTime * 1000)}
); }