-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathAttributionsList.tsx
88 lines (81 loc) · 2.97 KB
/
AttributionsList.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
// SPDX-FileCopyrightText: Meta Platforms, Inc. and its affiliates
// SPDX-FileCopyrightText: TNG Technology Consulting GmbH <https://www.tngtech.com>
//
// SPDX-License-Identifier: Apache-2.0
import MuiDivider from '@mui/material/Divider';
import { without } from 'lodash';
import { TRANSITION } from '../../../../shared-styles';
import { changeSelectedAttributionOrOpenUnsavedPopup } from '../../../../state/actions/popup-actions/popup-actions';
import { useAppDispatch } from '../../../../state/hooks';
import { useAttributionIdsForReplacement } from '../../../../state/variables/use-attribution-ids-for-replacement';
import { isPackageInfoIncomplete } from '../../../../util/is-important-attribution-information-missing';
import { List, ListItemContentProps } from '../../../List/List';
import { PackageCard } from '../../../PackageCard/PackageCard';
import { SearchList } from '../../../SearchList/SearchList';
import { PackagesPanelChildrenProps } from '../../PackagesPanel/PackagesPanel';
export const AttributionsList: React.FC<PackagesPanelChildrenProps> = ({
attributions,
activeAttributionIds,
selectedAttributionId,
contentHeight,
loading,
setMultiSelectedAttributionIds,
multiSelectedAttributionIds,
}) => {
const dispatch = useAppDispatch();
const [attributionIdsForReplacement] = useAttributionIdsForReplacement();
return (
<List
renderItemContent={renderAttributionCard}
data={activeAttributionIds}
components={{ List: SearchList }}
selectedId={selectedAttributionId}
loading={loading}
sx={{ transition: TRANSITION, height: contentHeight }}
/>
);
function renderAttributionCard(
attributionId: string,
{ selected, focused }: ListItemContentProps,
) {
const attribution = attributions?.[attributionId];
if (!attribution) {
return null;
}
return (
<>
<PackageCard
onClick={() => {
selectedAttributionId !== attributionId &&
dispatch(
changeSelectedAttributionOrOpenUnsavedPopup(attribution),
);
}}
cardConfig={{
selected,
focused,
resolved: attributionIdsForReplacement.includes(attributionId),
incomplete: isPackageInfoIncomplete(attribution),
}}
packageInfo={attribution}
checkbox={{
checked: multiSelectedAttributionIds.includes(attributionId),
disabled: !!attributionIdsForReplacement.length,
onChange: (event) => {
setMultiSelectedAttributionIds(
event.target.checked
? [...multiSelectedAttributionIds, attributionId]
: without(multiSelectedAttributionIds, attributionId),
);
!selectedAttributionId &&
dispatch(
changeSelectedAttributionOrOpenUnsavedPopup(attribution),
);
},
}}
/>
<MuiDivider />
</>
);
}
};