Files
planka/client/src/components/LabelsStep/Item.jsx

66 lines
1.7 KiB
React
Raw Normal View History

import upperFirst from 'lodash/upperFirst';
import camelCase from 'lodash/camelCase';
2019-08-31 04:07:25 +05:00
import React, { useCallback } from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';
import { Button } from 'semantic-ui-react';
import styles from './Item.module.scss';
import globalStyles from '../../styles.module.scss';
2019-08-31 04:07:25 +05:00
2022-11-10 15:28:43 +01:00
const Item = React.memo(
({ name, color, isPersisted, isActive, canEdit, onSelect, onDeselect, onEdit }) => {
const handleToggleClick = useCallback(() => {
if (isActive) {
onDeselect();
} else {
onSelect();
}
}, [isActive, onSelect, onDeselect]);
2019-08-31 04:07:25 +05:00
2022-11-10 15:28:43 +01:00
return (
<div className={styles.wrapper}>
<Button
fluid
content={name}
active={isActive}
disabled={!isPersisted}
className={classNames(
styles.labelButton,
isActive && styles.labelButtonActive,
globalStyles[`background${upperFirst(camelCase(color))}`],
)}
onClick={handleToggleClick}
/>
{canEdit && (
<Button
icon="pencil"
size="small"
floated="right"
disabled={!isPersisted}
className={styles.editButton}
onClick={onEdit}
/>
)}
2022-11-10 15:28:43 +01:00
</div>
);
},
);
2019-08-31 04:07:25 +05:00
Item.propTypes = {
2019-10-09 18:48:19 +05:00
name: PropTypes.string,
2019-08-31 04:07:25 +05:00
color: PropTypes.string.isRequired,
isPersisted: PropTypes.bool.isRequired,
isActive: PropTypes.bool.isRequired,
2022-11-10 15:28:43 +01:00
canEdit: PropTypes.bool.isRequired,
2019-08-31 04:07:25 +05:00
onSelect: PropTypes.func.isRequired,
onDeselect: PropTypes.func.isRequired,
onEdit: PropTypes.func.isRequired,
};
2019-10-09 18:48:19 +05:00
Item.defaultProps = {
name: undefined,
};
2019-08-31 04:07:25 +05:00
export default Item;