Skip to content

Commit

Permalink
[Cases] Do not show status dropdown on modal cases selector (#111101)
Browse files Browse the repository at this point in the history
  • Loading branch information
cnasikas authored Sep 3, 2021
1 parent 71571c5 commit 6f357e0
Show file tree
Hide file tree
Showing 3 changed files with 63 additions and 35 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -203,7 +203,8 @@ export const AllCasesGeneric = React.memo<AllCasesGenericProps>(
handleIsLoading,
isLoadingCases: loading,
refreshCases,
showActions,
// isSelectorView is boolean | undefined. We need to convert it to a boolean.
isSelectorView: !!isSelectorView,
userCanCrud,
connectors,
});
Expand Down
68 changes: 36 additions & 32 deletions x-pack/plugins/cases/public/components/all_cases/columns.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ export interface GetCasesColumn {
handleIsLoading: (a: boolean) => void;
isLoadingCases: string[];
refreshCases?: (a?: boolean) => void;
showActions: boolean;
isSelectorView: boolean;
userCanCrud: boolean;
connectors?: ActionConnector[];
}
Expand All @@ -84,7 +84,7 @@ export const useCasesColumns = ({
handleIsLoading,
isLoadingCases,
refreshCases,
showActions,
isSelectorView,
userCanCrud,
connectors = [],
}: GetCasesColumn): CasesColumns[] => {
Expand Down Expand Up @@ -281,38 +281,42 @@ export const useCasesColumns = ({
return getEmptyTagValue();
},
},
{
name: i18n.STATUS,
render: (theCase: Case) => {
if (theCase?.subCases == null || theCase.subCases.length === 0) {
if (theCase.status == null || theCase.type === CaseType.collection) {
return getEmptyTagValue();
}
return (
<StatusContextMenu
currentStatus={theCase.status}
disabled={!userCanCrud || isLoadingCases.length > 0}
onStatusChanged={(status) =>
handleDispatchUpdate({
updateKey: 'status',
updateValue: status,
caseId: theCase.id,
version: theCase.version,
})
...(!isSelectorView
? [
{
name: i18n.STATUS,
render: (theCase: Case) => {
if (theCase?.subCases == null || theCase.subCases.length === 0) {
if (theCase.status == null || theCase.type === CaseType.collection) {
return getEmptyTagValue();
}
return (
<StatusContextMenu
currentStatus={theCase.status}
disabled={!userCanCrud || isLoadingCases.length > 0}
onStatusChanged={(status) =>
handleDispatchUpdate({
updateKey: 'status',
updateValue: status,
caseId: theCase.id,
version: theCase.version,
})
}
/>
);
}
/>
);
}

const badges = getSubCasesStatusCountsBadges(theCase.subCases);
return badges.map(({ color, count }, index) => (
<EuiBadge key={index} color={color}>
{count}
</EuiBadge>
));
},
},
...(showActions
const badges = getSubCasesStatusCountsBadges(theCase.subCases);
return badges.map(({ color, count }, index) => (
<EuiBadge key={index} color={color}>
{count}
</EuiBadge>
));
},
},
]
: []),
...(userCanCrud && !isSelectorView
? [
{
name: (
Expand Down
27 changes: 25 additions & 2 deletions x-pack/plugins/cases/public/components/all_cases/index.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ describe('AllCasesGeneric', () => {
filterStatus: CaseStatuses.open,
handleIsLoading: jest.fn(),
isLoadingCases: [],
showActions: true,
isSelectorView: false,
userCanCrud: true,
};

Expand Down Expand Up @@ -377,7 +377,7 @@ describe('AllCasesGeneric', () => {
isLoadingCases: [],
filterStatus: CaseStatuses.open,
handleIsLoading: jest.fn(),
showActions: false,
isSelectorView: true,
userCanCrud: true,
})
);
Expand Down Expand Up @@ -926,4 +926,27 @@ describe('AllCasesGeneric', () => {
).toBeFalsy();
});
});

it('should not render status when isSelectorView=true', async () => {
const wrapper = mount(
<TestProviders>
<AllCases {...defaultAllCasesProps} isSelectorView={true} />
</TestProviders>
);

const { result } = renderHook<GetCasesColumn, CasesColumns[]>(() =>
useCasesColumns({
...defaultColumnArgs,
isSelectorView: true,
})
);

expect(result.current.find((i) => i.name === 'Status')).toBeFalsy();

await waitFor(() => {
expect(wrapper.find('[data-test-subj="cases-table"]').exists()).toBeTruthy();
});

expect(wrapper.find('[data-test-subj="case-view-status-dropdown"]').exists()).toBeFalsy();
});
});

0 comments on commit 6f357e0

Please sign in to comment.