Skip to content

Commit

Permalink
[kbss-cvut#226] Additional props for nodes
Browse files Browse the repository at this point in the history
  • Loading branch information
Kasmadei committed Apr 30, 2024
1 parent 39283c1 commit e91c5e1
Show file tree
Hide file tree
Showing 5 changed files with 148 additions and 4 deletions.
10 changes: 10 additions & 0 deletions public/locales/cs/translation.json
Original file line number Diff line number Diff line change
Expand Up @@ -80,5 +80,15 @@
"lastEditor": "Poslední editor",
"status": "Stav",
"edit": "Upravit"
},
"faultEventMenu": {
"criticality": "Kritičnost",
"fhaBasedFailureRate": "Intenzita poruch založená na FHA",
"predictedFailureRate": "Predikovaná intenzita poruch",
"ataSystem": "ATA systém",
"partNumber": "Číslo součásti",
"stock": "Zásoba",
"quantity": "Množství"

}
}
9 changes: 9 additions & 0 deletions public/locales/en/translation.json
Original file line number Diff line number Diff line change
Expand Up @@ -80,5 +80,14 @@
"lastEditor": "Last editor",
"status": "Status",
"edit": "Edit"
},
"faultEventMenu": {
"criticality": "Criticality",
"fhaBasedFailureRate": "FHA based failure rate",
"predictedFailureRate": "Predicted failure rate",
"ataSystem": "ATA System",
"partNumber": "Part number",
"stock": "Stock",
"quantity": "Quantity"
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { Theme } from "@mui/material";
import { makeStyles } from "tss-react/mui";

const useStyles = makeStyles()((theme: Theme) => ({
label: {
fontWeight: "500",
color: "#00000080",
},
}));

export default useStyles;
103 changes: 99 additions & 4 deletions src/components/editor/faultTree/menu/faultEvent/FaultEventMenu.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
import { Button, Divider, Paper, Typography } from "@mui/material";
import { Button, Divider, Paper, Typography, Box } from "@mui/material";
import FaultEventShapeToolPane from "./FaultEventShapeToolPane";
import { EventType, FaultEvent } from "../../../../../models/eventModel";
import * as React from "react";
import FailureModeDialog from "../../../../dialog/failureMode/create/FailureModeDialog";
import { useState } from "react";
import { EventFailureModeProvider, useEventFailureMode } from "../../../../../hooks/useEventFailureMode";
import { useState, useEffect } from "react";
import { EventFailureModeProvider } from "../../../../../hooks/useEventFailureMode";
import EventFailureModeList from "../failureMode/EventFailureModeList";
import { FailureMode } from "../../../../../models/failureModeModel";
import FailureModeShowDialog from "../../../../dialog/failureMode/show/FailureModeShowDialog";
import { Box } from "@mui/material";
import useStyles from "@components/editor/faultTree/menu/faultEvent/FaultEventMenu.styles";
import { asArray } from "@utils/treeUtils";
import { useTranslation } from "react-i18next";

interface Props {
shapeToolData?: FaultEvent;
Expand All @@ -17,16 +19,70 @@ interface Props {
}

const FaultEventMenu = ({ shapeToolData, onEventUpdated, refreshTree }: Props) => {
const { t } = useTranslation();
const { classes } = useStyles();
const [failureModeDialogOpen, setFailureModeDialogOpen] = useState(false);

const [failureModeOverviewDialogOpen, setFailureModeOverviewDialogOpen] = useState(false);
const [failureModeOverview, setFailureModeOverview] = useState<FailureMode | null>(null);

const [criticality, setCriticality] = useState<number | undefined>(undefined);
const [predictedFailureRate, setPredictedFailureRate] = useState<number | undefined>(undefined);
const [ataSystem, setAtaSystem] = useState<string | undefined>(undefined);
const [partNumber, setPartNumber] = useState<string | undefined>(undefined);
const [stock, setStock] = useState<string | undefined>(undefined);
const [quantity, setQuantity] = useState<number | undefined>(undefined);

const handleFailureModeClicked = (failureMode: FailureMode) => {
setFailureModeOverview(failureMode);
setFailureModeOverviewDialogOpen(true);
};

useEffect(() => {
if (shapeToolData?.supertypes?.criticality) {
setCriticality(shapeToolData.supertypes.criticality);
} else {
setCriticality(undefined);
}

const types = asArray(shapeToolData?.supertypes?.supertypes)

const filteredFailureRate = types.filter((type) => type.hasFailureRate);

if (filteredFailureRate.length === 1 && filteredFailureRate[0].hasFailureRate?.prediction?.value) {
setPredictedFailureRate(filteredFailureRate[0].hasFailureRate?.prediction?.value);
} else {
setPredictedFailureRate(undefined);
}

const superTypes = asArray(shapeToolData?.supertypes?.behavior?.item?.supertypes)

const filteredAtaCode = superTypes.filter((sType) => sType?.ataCode);
const filteredPartNumber = superTypes.filter((sType) => sType?.partNumber);

if (filteredAtaCode.length === 1 && filteredAtaCode[0].ataCode && filteredAtaCode[0].name) {
const ataSystemString = `${filteredAtaCode[0].ataCode} ${filteredAtaCode[0].name}`;
setAtaSystem(ataSystemString);
} else {
setAtaSystem(undefined);
}

if (filteredPartNumber.length === 1 && filteredPartNumber[0].partNumber && filteredPartNumber[0].stock) {
setPartNumber(filteredPartNumber[0].partNumber);
setStock(filteredPartNumber[0].stock);
} else {
setPartNumber(undefined);
setStock(undefined);
}

if (shapeToolData?.supertypes?.behavior?.item?.quantity) {
setQuantity(shapeToolData?.supertypes?.behavior?.item?.quantity);
} else {
setQuantity(undefined);
}
}, [shapeToolData]);


return (
<Box paddingLeft={2} marginRight={2}>
<Typography variant="h5" gutterBottom>
Expand All @@ -37,6 +93,45 @@ const FaultEventMenu = ({ shapeToolData, onEventUpdated, refreshTree }: Props) =

{shapeToolData && (
<EventFailureModeProvider eventIri={shapeToolData?.iri}>
<Box style={{ marginTop: 16, marginBottom: 16 }}>
{criticality && (
<Typography>
<span className={classes.label}>{t("faultEventMenu.criticality")}:</span> {criticality}
</Typography>
)}

{predictedFailureRate && (
<Typography>
{shapeToolData.eventType === EventType.INTERMEDIATE ? (
<span className={classes.label}>{t("faultEventMenu.fhaBasedFailureRate")}:</span>
) : (
<span className={classes.label}>{t("faultEventMenu.predictedFailureRate")}:</span>
)}
{` ${predictedFailureRate.toExponential(2)}`}
</Typography>
)}

{ataSystem && (
<Typography>
<span className={classes.label}>{t("faultEventMenu.ataSystem")}:</span> {ataSystem}
</Typography>
)}
{partNumber && (
<Typography>
<span className={classes.label}>{t("faultEventMenu.partNumber")}:</span> {partNumber}
</Typography>
)}
{stock && (
<Typography>
<span className={classes.label}>{t("faultEventMenu.stock")}:</span> {stock}
</Typography>
)}
{quantity && (
<Typography>
<span className={classes.label}>{t("faultEventMenu.quantity")}:</span> {quantity}
</Typography>
)}
</Box>
<Typography variant="h5" gutterBottom>
Failure Mode
</Typography>
Expand Down
19 changes: 19 additions & 0 deletions src/models/eventModel.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,15 @@ const ctx = {
hasFailureRate: VocabularyUtils.PREFIX + "has-failure-rate",
requirement: VocabularyUtils.PREFIX + "has-requirement",
upperBound: VocabularyUtils.PREFIX + "to",
criticality: VocabularyUtils.PREFIX + "criticality",
prediction: VocabularyUtils.PREFIX + "has-prediction",
value: VocabularyUtils.PREFIX + "value",
ataCode: VocabularyUtils.PREFIX + "ata-code",
partNumber: VocabularyUtils.PREFIX + "part-number",
stock: VocabularyUtils.PREFIX + "stock",
behavior: VocabularyUtils.PREFIX + "is-manifestation-of",
item: VocabularyUtils.PREFIX + "has-component",
quantity: VocabularyUtils.PREFIX + "quantity",
references: VocabularyUtils.PREFIX + "is-reference-to",
isPartOf: VocabularyUtils.PREFIX + "is-part-of",
isReference: VocabularyUtils.PREFIX + "is-reference",
Expand Down Expand Up @@ -51,6 +60,16 @@ export interface FaultEvent extends AbstractModel {
isPartOf?: string;
};
supertypes?: {
criticality?: number;
superTypes?: any;
behavior?: {
item?: {
quantity?: number;
supertypes?: {
ataCode?: string;
};
};
};
hasFailureRate?: {
iri?: string;
requirement?: {
Expand Down

0 comments on commit e91c5e1

Please sign in to comment.