Skip to content

Commit

Permalink
chore(ts): refactor types into separate modules
Browse files Browse the repository at this point in the history
Signed-off-by: Thuan Vo <[email protected]>
  • Loading branch information
tthvo committed Sep 29, 2023
1 parent 1c6c35d commit 5f69a43
Show file tree
Hide file tree
Showing 12 changed files with 95 additions and 59 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -624,7 +624,7 @@ export const AutomatedAnalysisCard: DashboardCardFC<AutomatedAnalysisCardProps>
key={topic}
>
{evaluations.map((evaluation) => {
return <ClickableAutomatedAnalysisLabel label={evaluation} key={clickableAutomatedAnalysisKey} />;
return <ClickableAutomatedAnalysisLabel result={evaluation} key={clickableAutomatedAnalysisKey} />;
})}
</LabelGroup>
</GridItem>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ export interface AutomatedAnalysisCardListProps {
evaluations: CategorizedRuleEvaluations[];
}

export const AutomatedAnalysisCardList: React.FC<AutomatedAnalysisCardListProps> = (props) => {
export const AutomatedAnalysisCardList: React.FC<AutomatedAnalysisCardListProps> = ({ evaluations }) => {
const { t } = useTranslation();

const [sortBy, setSortBy] = React.useState<ISortBy>({});
Expand Down Expand Up @@ -80,7 +80,7 @@ export const AutomatedAnalysisCardList: React.FC<AutomatedAnalysisCardListProps>
);

const flatFiltered = React.useMemo(() => {
return props.evaluations
return evaluations
.flatMap(([_, evaluations]) => {
return evaluations.map((evaluation) => evaluation);
})
Expand Down Expand Up @@ -108,7 +108,7 @@ export const AutomatedAnalysisCardList: React.FC<AutomatedAnalysisCardListProps>
}
return 0;
});
}, [sortBy, props.evaluations]);
}, [sortBy, evaluations]);

return (
<OuterScrollContainer className="automated-analysis-datalist-outerscroll">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,12 +25,12 @@ import { useTranslation } from 'react-i18next';
import { transformAADescription } from './utils';

export interface ClickableAutomatedAnalysisLabelProps {
label: AnalysisResult;
result: AnalysisResult;
}

export const clickableAutomatedAnalysisKey = 'clickable-automated-analysis-label';

export const ClickableAutomatedAnalysisLabel: React.FC<ClickableAutomatedAnalysisLabelProps> = ({ label: result }) => {
export const ClickableAutomatedAnalysisLabel: React.FC<ClickableAutomatedAnalysisLabelProps> = ({ result }) => {
const { t } = useTranslation();

const [isHoveredOrFocused, setIsHoveredOrFocused] = React.useState(false);
Expand Down Expand Up @@ -83,7 +83,7 @@ export const ClickableAutomatedAnalysisLabel: React.FC<ClickableAutomatedAnalysi

return (
<Popover
aria-label={t('ClickableAutomatedAnalysisLabel.ARIA_LABELS.POPOVER')}
aria-label={t('ClickableAutomatedAnalysisresult.ARIA_LABELS.POPOVER')}
isVisible={isDescriptionVisible}
headerContent={<div className={`${clickableAutomatedAnalysisKey}-popover-header`}>{result.name}</div>}
alertSeverityVariant={alertPopoverVariant}
Expand Down
6 changes: 3 additions & 3 deletions src/app/Dashboard/AutomatedAnalysis/utils.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { AnalysisResult } from '@app/Shared/Services/api.types';
import { Stack, StackItem, Title, Label, Text } from '@patternfly/react-core';
import { AnalysisResult, Evaluation } from '@app/Shared/Services/api.types';
import { Stack, StackItem, Label, Title, Text } from '@patternfly/react-core';
import _ from 'lodash';
import * as React from 'react';

export const transformAADescription = (result: AnalysisResult): JSX.Element => {
const format = (s): JSX.Element => {
const format = (s: Evaluation): JSX.Element => {
if (typeof s === 'string') {
return <Text>{s}</Text>;
}
Expand Down
21 changes: 13 additions & 8 deletions src/app/Recordings/ActiveRecordingsTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@
*/

import {
clickableAutomatedAnalysisKey,
ClickableAutomatedAnalysisLabel,
clickableAutomatedAnalysisKey,
} from '@app/Dashboard/AutomatedAnalysis/ClickableAutomatedAnalysisLabel';
import { authFailMessage } from '@app/ErrorView/types';
import { DeleteOrDisableWarningType } from '@app/Modal/types';
Expand All @@ -33,8 +33,14 @@ import {
RootState,
StateDispatch,
} from '@app/Shared/Redux/ReduxStore';
import { ActiveRecording, NotificationCategory, RecordingState, Target } from '@app/Shared/Services/api.types';
import { AnalysisResult, CategorizedRuleEvaluations } from '@app/Shared/Services/Report.service';
import {
ActiveRecording,
AnalysisResult,
CategorizedRuleEvaluations,
NotificationCategory,
RecordingState,
Target,
} from '@app/Shared/Services/api.types';
import { ServiceContext } from '@app/Shared/Services/Services';
import { useDayjs } from '@app/utils/hooks/useDayjs';
import { useSort } from '@app/utils/hooks/useSort';
Expand Down Expand Up @@ -555,8 +561,8 @@ export const ActiveRecordingsTable: React.FC<ActiveRecordingsTableProps> = (prop
>
{filteredRecordings.map((r) => (
<ActiveRecordingRow
targetConnectUrl={targetConnectURL}
key={r.name}
targetConnectUrl={targetConnectURL}
recording={r}
labelFilters={targetRecordingFilters.Label}
index={r.id}
Expand Down Expand Up @@ -845,6 +851,8 @@ export const ActiveRecordingRow: React.FC<ActiveRecordingRowProps> = ({
}) => {
const [dayjs, datetimeContext] = useDayjs();
const context = React.useContext(ServiceContext);
const [loadingAnalysis, setLoadingAnalysis] = React.useState(false);
const [analyses, setAnalyses] = React.useState<CategorizedRuleEvaluations[]>([]);

const expandedRowId = React.useMemo(
() => `active-table-row-${recording.name}-${recording.startTime}-exp`,
Expand All @@ -868,9 +876,6 @@ export const ActiveRecordingRow: React.FC<ActiveRecordingRowProps> = ({
[index, handleRowCheck],
);

const [loadingAnalysis, setLoadingAnalysis] = React.useState(false);
const [analyses, setAnalyses] = React.useState<CategorizedRuleEvaluations[]>([]);

const handleLoadAnalysis = React.useCallback(() => {
setLoadingAnalysis(true);
context.reports
Expand Down Expand Up @@ -1031,7 +1036,7 @@ export const ActiveRecordingRow: React.FC<ActiveRecordingRowProps> = ({
>
{evaluations.map((evaluation) => {
return (
<ClickableAutomatedAnalysisLabel label={evaluation} key={clickableAutomatedAnalysisKey} />
<ClickableAutomatedAnalysisLabel result={evaluation} key={clickableAutomatedAnalysisKey} />
);
})}
</LabelGroup>
Expand Down
39 changes: 32 additions & 7 deletions src/app/Recordings/ArchivedRecordingsTable.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@

import { ArchiveUploadModal } from '@app/Archives/ArchiveUploadModal';
import {
clickableAutomatedAnalysisKey,
ClickableAutomatedAnalysisLabel,
clickableAutomatedAnalysisKey,
} from '@app/Dashboard/AutomatedAnalysis/ClickableAutomatedAnalysisLabel';
import { DeleteWarningModal } from '@app/Modal/DeleteWarningModal';
import { DeleteOrDisableWarningType } from '@app/Modal/types';
Expand All @@ -41,8 +41,9 @@ import {
UPLOADS_SUBDIRECTORY,
NotificationCategory,
NullableTarget,
CategorizedRuleEvaluations,
AnalysisResult,
} from '@app/Shared/Services/api.types';
import { AnalysisResult, CategorizedRuleEvaluations } from '@app/Shared/Services/Report.service';
import { ServiceContext } from '@app/Shared/Services/Services';
import { useSort } from '@app/utils/hooks/useSort';
import { useSubscriptions } from '@app/utils/hooks/useSubscriptions';
Expand Down Expand Up @@ -768,6 +769,8 @@ export const ArchivedRecordingRow: React.FC<ArchivedRecordingRowProps> = ({
updateFilters,
}) => {
const context = React.useContext(ServiceContext);
const [loadingAnalysis, setLoadingAnalysis] = React.useState(false);
const [analyses, setAnalyses] = React.useState<CategorizedRuleEvaluations[]>([]);

const parsedLabels = React.useMemo(() => {
return parseLabels(recording.metadata.labels);
Expand All @@ -790,9 +793,6 @@ export const ArchivedRecordingRow: React.FC<ArchivedRecordingRowProps> = ({
[index, handleRowCheck],
);

const [loadingAnalysis, setLoadingAnalysis] = React.useState(false);
const [analyses, setAnalyses] = React.useState<CategorizedRuleEvaluations[]>([]);

React.useEffect(() => {
if (!isExpanded) {
return;
Expand Down Expand Up @@ -886,6 +886,31 @@ export const ArchivedRecordingRow: React.FC<ArchivedRecordingRowProps> = ({
handleToggle,
]);

React.useEffect(() => {
if (!isExpanded) {
return;
}
setLoadingAnalysis(true);
context.reports
.reportJson(recording, currentSelectedTargetURL)
.pipe(first())
.subscribe((report) => {
const map = new Map<string, AnalysisResult[]>();
report.forEach((evaluation) => {
const topicValue = map.get(evaluation.topic);
if (topicValue === undefined) {
map.set(evaluation.topic, [evaluation]);
} else {
topicValue.push(evaluation);
topicValue.sort((a, b) => b.score - a.score || a.name.localeCompare(b.name));
}
});
const sorted = (Array.from(map) as CategorizedRuleEvaluations[]).sort();
setAnalyses(sorted);
setLoadingAnalysis(false);
});
}, [context.reports, isExpanded, recording, currentSelectedTargetURL, setAnalyses, setLoadingAnalysis]);

const childRow = React.useMemo(() => {
return (
<Tr key={`${index}_child`} isExpanded={isExpanded}>
Expand All @@ -911,7 +936,7 @@ export const ArchivedRecordingRow: React.FC<ArchivedRecordingRowProps> = ({
>
{evaluations.map((evaluation) => {
return (
<ClickableAutomatedAnalysisLabel label={evaluation} key={clickableAutomatedAnalysisKey} />
<ClickableAutomatedAnalysisLabel result={evaluation} key={clickableAutomatedAnalysisKey} />
);
})}
</LabelGroup>
Expand All @@ -924,7 +949,7 @@ export const ArchivedRecordingRow: React.FC<ArchivedRecordingRowProps> = ({
</Td>
</Tr>
);
}, [index, isExpanded, loadingAnalysis, analyses]);
}, [index, isExpanded, analyses, loadingAnalysis]);

return (
<Tbody key={index} isExpanded={isExpanded}>
Expand Down
10 changes: 5 additions & 5 deletions src/app/utils/fakeData.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ import {
NullableTarget,
EventType,
CachedReportValue,
SimpleResponse,
AnalysisResult,
SimpleResponse,
} from '@app/Shared/Services/api.types';
import { LoginService } from '@app/Shared/Services/Login.service';
import { NotificationService, NotificationsInstance } from '@app/Shared/Services/Notifications.service';
Expand Down Expand Up @@ -107,9 +107,9 @@ export const fakeEvaluations: AnalysisResult[] = [
},
},
{
topic: 'classloading',
name: 'Class Leak',
score: 0,
topic: 'classloading',
evaluation: {
summary: 'leaked classes',
explanation: 'classes were loaded and leaked',
Expand All @@ -124,9 +124,9 @@ export const fakeEvaluations: AnalysisResult[] = [
},
},
{
topic: 'classloading',
name: 'Class Loading Pressure',
score: 0,
topic: 'classloading',
evaluation: {
summary: 'too much loading pressure',
explanation: 'lots of classloading slowing things down',
Expand All @@ -141,9 +141,9 @@ export const fakeEvaluations: AnalysisResult[] = [
},
},
{
topic: 'jvm_information',
name: 'Discouraged Management Agent Settings',
score: 50,
topic: 'jvm_information',
evaluation: {
summary: 'bad settings set',
explanation: 'these settings can cause problems',
Expand All @@ -158,9 +158,9 @@ export const fakeEvaluations: AnalysisResult[] = [
},
},
{
topic: 'exceptions',
name: 'Thrown Exceptions',
score: 0.2,
topic: 'exceptions',
evaluation: {
summary: 'many exceptions thrown which is slow',
explanation: 'exception processing is slower than normal code execution',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,10 @@ import { AutomatedAnalysisCard } from '@app/Dashboard/AutomatedAnalysis/Automate
import { RootState } from '@app/Shared/Redux/ReduxStore';
import {
CachedReportValue,
AnalysisResult,
ArchivedRecording,
FAILED_REPORT_MESSAGE,
NO_RECORDINGS_MESSAGE,
AnalysisResult,
automatedAnalysisRecordingName,
} from '@app/Shared/Services/api.types';
import { defaultAutomatedAnalysisRecordingConfig } from '@app/Shared/Services/service.types';
Expand Down Expand Up @@ -49,9 +49,9 @@ const mockEmptyCachedReport: CachedReportValue = {
};

const mockRuleEvaluation1: AnalysisResult = {
topic: 'myTopic',
name: 'rule1',
score: 100,
topic: 'myTopic',
evaluation: {
summary: 'rule1 summary',
explanation: 'rule1 explanation',
Expand All @@ -67,9 +67,9 @@ const mockRuleEvaluation1: AnalysisResult = {
};

const mockRuleEvaluation2: AnalysisResult = {
topic: 'fakeTopic',
name: 'rule2',
score: 0,
topic: 'fakeTopic',
evaluation: {
summary: 'rule2 summary',
explanation: 'rule2 explanation',
Expand All @@ -85,9 +85,9 @@ const mockRuleEvaluation2: AnalysisResult = {
};

const mockRuleEvaluation3: AnalysisResult = {
topic: 'fakeTopic',
name: 'rule3',
score: 55,
topic: 'fakeTopic',
evaluation: {
summary: 'rule3 summary',
explanation: 'rule3 explanation',
Expand All @@ -103,9 +103,9 @@ const mockRuleEvaluation3: AnalysisResult = {
};

const mockNaRuleEvaluation: AnalysisResult = {
topic: 'fakeTopic',
name: 'N/A rule',
score: -1,
topic: 'fakeTopic',
evaluation: {
summary: 'NArule summary',
explanation: 'NArule explanation',
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,9 @@ import { Provider } from 'react-redux';
import renderer, { act } from 'react-test-renderer';

const mockRuleEvaluation1: AnalysisResult = {
topic: 'myTopic',
name: 'rule1',
score: 100,
topic: 'myTopic',
evaluation: {
summary: 'first thing happened',
explanation: 'first reason',
Expand All @@ -41,9 +41,9 @@ const mockRuleEvaluation1: AnalysisResult = {
};

const mockRuleEvaluation2: AnalysisResult = {
topic: 'fakeTopic',
name: 'rule2',
score: 0,
topic: 'fakeTopic',
evaluation: {
summary: 'second thing happened',
explanation: 'second reason',
Expand All @@ -53,9 +53,9 @@ const mockRuleEvaluation2: AnalysisResult = {
};

const mockRuleEvaluation3: AnalysisResult = {
topic: 'fakeTopic',
name: 'rule3',
score: 55,
topic: 'fakeTopic',
evaluation: {
summary: 'third thing happened',
explanation: 'third reason',
Expand All @@ -65,9 +65,9 @@ const mockRuleEvaluation3: AnalysisResult = {
};

const mockNaRuleEvaluation: AnalysisResult = {
topic: 'fakeTopic',
name: 'N/A rule',
score: -1,
topic: 'fakeTopic',
evaluation: {
summary: 'fourth thing happened',
explanation: 'fourth reason',
Expand Down
Loading

0 comments on commit 5f69a43

Please sign in to comment.