@adaptabletools/adaptable
Version:
Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements
53 lines (52 loc) • 3.14 kB
JavaScript
import React from 'react';
import { Box, Flex } from 'rebass';
import AdaptableInput from '../../View/Components/AdaptableInput';
import { IconComponent } from '../Icon';
import { allIcons, Icon } from '../icons';
import OverlayTrigger from '../OverlayTrigger';
import SimpleButton from '../SimpleButton';
const IconButton = (props) => {
return (React.createElement(SimpleButton, { onClick: () => props.onClick(), p: 2, variant: props.active ? 'raised' : 'text', tone: props.active ? 'accent' : 'none', icon: props.icon }, props.children));
};
export const IconSelector = (props) => {
const [query, setQuery] = React.useState('');
const allIconsNames = Object.keys(allIcons);
const filteredIcons = query
? allIconsNames.filter((iconName) => {
return iconName.toLowerCase().includes(query.toLowerCase());
})
: allIconsNames;
const iconsElements = filteredIcons.map((iconName) => {
return (React.createElement(Flex, { key: iconName },
React.createElement(IconButton, { onClick: () => props.onChange(iconName), active: iconName === props.value, icon: iconName })));
});
const customIconsElements = props.customIcons?.map((def) => {
return (React.createElement(IconButton, { key: def.name, active: false, onClick: () => props.onChange(def.name) },
React.createElement(IconComponent, { key: def.name, icon: def.icon })));
});
const popup = (React.createElement(Box, { className: "ab-IconSelector__Popup" },
React.createElement(Box, { mb: 2 },
React.createElement(Box, { mb: 2, fontSize: 4 }, "Select an Icon"),
React.createElement(AdaptableInput, { value: query, onChange: (event) => setQuery(event.target.value ?? ''), width: "100%" })),
React.createElement(Flex, { p: 2, style: { width: 300, maxHeight: 300, overflow: 'auto' }, flexWrap: "wrap" },
iconsElements,
" ",
customIconsElements)));
let value = 'No Icon Selected';
if (props.value in allIcons) {
value = (React.createElement(Icon, { style: { display: 'inline-block' }, name: props.value }));
}
else {
const icon = props.customIcons?.find((def) => def.name === props.value);
if (icon)
value = React.createElement(IconComponent, { icon: icon.icon });
}
return (React.createElement(Flex, { className: "ab-IconSelector" },
React.createElement(OverlayTrigger, { preventPortalEventPropagation: false, render: () => popup, showEvent: "mouseenter", hideEvent: "mouseleave", hideDelay: 300 },
React.createElement(SimpleButton, { className: "ab-IconSelector__trigger", textAlign: "center", onClick: () => null, variant: "raised", width: 150, justifyContent: "center" }, value)),
(props.clearable ?? true) && (React.createElement(SimpleButton, { disabled: !props.value, className: "ab-IconSelector__clear-button", ml: 2, onClick: (event) => {
event.stopPropagation();
event.preventDefault();
props.onChange('');
}, variant: "text", icon: "close" }))));
};