bitburner-src/src/Bladeburner/ui/BlackOpList.tsx

36 lines
1.2 KiB
TypeScript
Raw Normal View History

2021-08-19 07:45:26 +02:00
import React from "react";
2021-06-18 22:22:12 +02:00
import { BlackOperations } from "../BlackOperations";
import { BlackOperation } from "../BlackOperation";
import { BlackOpElem } from "./BlackOpElem";
import { IBladeburner } from "../IBladeburner";
2021-08-16 07:35:05 +02:00
import { IPlayer } from "../../PersonObjects/IPlayer";
2021-06-18 22:22:12 +02:00
interface IProps {
bladeburner: IBladeburner;
2021-08-16 07:35:05 +02:00
player: IPlayer;
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-08-16 07:35:05 +02:00
<BlackOpElem bladeburner={props.bladeburner} action={blackop} player={props.player} />
2021-08-16 03:49:08 +02:00
</li>,
2021-06-18 22:22:12 +02:00
)}
</>);
}