2021-06-18 22:22:12 +02:00
|
|
|
import * as React from "react";
|
|
|
|
import {
|
|
|
|
formatNumber,
|
|
|
|
convertTimeMsToTimeElapsedString,
|
|
|
|
} from "../../../utils/StringHelperFunctions";
|
|
|
|
import { ActionTypes } from "../data/ActionTypes";
|
|
|
|
import { createProgressBarText } from "../../../utils/helpers/createProgressBarText";
|
|
|
|
import { stealthIcon, killIcon } from "../data/Icons";
|
|
|
|
import { BlackOperations } from "../BlackOperations";
|
|
|
|
import { BlackOperation } from "../BlackOperation";
|
|
|
|
import { BlackOpElem } from "./BlackOpElem";
|
2021-08-16 04:35:43 +02:00
|
|
|
import { IBladeburner } from "../IBladeburner";
|
2021-06-18 22:22:12 +02:00
|
|
|
|
|
|
|
interface IProps {
|
2021-08-16 04:35:43 +02:00
|
|
|
bladeburner: IBladeburner;
|
2021-06-18 22:22:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export function BlackOpList(props: IProps): React.ReactElement {
|
|
|
|
let blackops: BlackOperation[] = [];
|
|
|
|
for (const blackopName in BlackOperations) {
|
|
|
|
if (BlackOperations.hasOwnProperty(blackopName)) {
|
|
|
|
blackops.push(BlackOperations[blackopName]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
blackops.sort(function(a, b) {
|
|
|
|
return (a.reqdRank - b.reqdRank);
|
|
|
|
});
|
|
|
|
|
2021-08-16 03:49:08 +02:00
|
|
|
blackops = blackops.filter((blackop: BlackOperation, i: number) => !(props.bladeburner.blackops[blackops[i].name] == null &&
|
2021-06-18 22:22:12 +02:00
|
|
|
i !== 0 &&
|
|
|
|
props.bladeburner.blackops[blackops[i-1].name] == null));
|
|
|
|
|
|
|
|
blackops = blackops.reverse();
|
|
|
|
|
|
|
|
return (<>
|
2021-08-16 03:49:08 +02:00
|
|
|
{blackops.map((blackop: BlackOperation) => <li key={blackop.name} className="bladeburner-action">
|
2021-06-18 22:22:12 +02:00
|
|
|
<BlackOpElem bladeburner={props.bladeburner} action={blackop} />
|
2021-08-16 03:49:08 +02:00
|
|
|
</li>,
|
2021-06-18 22:22:12 +02:00
|
|
|
)}
|
|
|
|
</>);
|
|
|
|
}
|