Fix : Vendor Select List

This commit is contained in:
elforjani3
2020-11-03 08:09:45 +02:00
parent 083a2dfbc5
commit 64ca4d2a8a
4 changed files with 84 additions and 35 deletions

View File

@@ -0,0 +1,58 @@
import React, { useCallback } from 'react';
import { FormattedMessage as T } from 'react-intl';
import { ListSelect } from 'components';
import { MenuItem } from '@blueprintjs/core';
export default function VendorSelecetList({
vendorsList,
selectedVendorId,
defaultSelectText = <T id={'select_vender_account'} />,
onVenderSelected,
// disabled = false,
...restProps
}) {
// Filter Vendors List
const FilterVendors = (query, vender, index, exactMatch) => {
const normalizedTitle = vender.display_name.toLowerCase();
const normalizedQuery = query.toLowerCase();
if (exactMatch) {
return normalizedTitle === normalizedQuery;
} else {
return (
`${vender.display_name} ${normalizedTitle}`.indexOf(normalizedQuery) >=
0
);
}
};
const handleVendorSelected = useCallback(
(Vendor) => onVenderSelected && onVenderSelected(Vendor),
[],
);
const handleVenderRenderer = useCallback(
(vender, { handleClick }) => (
<MenuItem
key={vender.id}
text={vender.display_name}
onClick={handleClick}
/>
),
[],
);
return (
<ListSelect
items={vendorsList}
selectedItemProp={'id'}
selectedItem={selectedVendorId}
labelProp={'display_name'}
defaultText={defaultSelectText}
onItemSelect={handleVendorSelected}
itemPredicate={FilterVendors}
itemRenderer={handleVenderRenderer}
popoverProps={{ minimal: true }}
{...restProps}
/>
);
}

View File

@@ -30,6 +30,7 @@ import Row from './Grid/Row';
import Col from './Grid/Col';
import CloudLoadingIndicator from './CloudLoadingIndicator';
import MoneyExchangeRate from './MoneyExchangeRate';
import VendorSelecetList from './VendorSelecetList';
const Hint = FieldHint;
@@ -67,4 +68,5 @@ export {
Row,
CloudLoadingIndicator,
MoneyExchangeRate,
VendorSelecetList,
};