cspace-ui
Version:
CollectionSpace user interface for browsers
55 lines (46 loc) • 1.13 kB
JSX
import React from 'react';
import PropTypes from 'prop-types';
import { defineMessages, FormattedMessage } from 'react-intl';
import { components as inputComponents } from 'cspace-input';
import styles from '../../../styles/cspace-ui/CloneButton.css';
const { Button } = inputComponents;
const messages = defineMessages({
label: {
id: 'cloneButton.label',
description: 'Label of the clone button.',
defaultMessage: 'Clone',
},
});
const propTypes = {
isCloneable: PropTypes.bool,
isModified: PropTypes.bool,
isSavePending: PropTypes.bool,
onClick: PropTypes.func,
};
const defaultProps = {
isCloneable: true,
};
export default function CloneButton(props) {
const {
isCloneable,
isModified,
isSavePending,
onClick,
} = props;
if (!isCloneable) {
return null;
}
return (
<Button
className={styles.common}
disabled={isModified || isSavePending}
icon
name="clone"
onClick={onClick}
>
<FormattedMessage {...messages.label} />
</Button>
);
}
CloneButton.propTypes = propTypes;
CloneButton.defaultProps = defaultProps;