import "./add-remove-buttons.scss"; import * as React from "react"; import { cssNames } from "../../utils"; import { Button } from "../button"; import { Icon } from "../icon"; export interface AddRemoveButtonsProps extends React.HTMLAttributes { onAdd?: () => void; onRemove?: () => void; addTooltip?: React.ReactNode; removeTooltip?: React.ReactNode; } export class AddRemoveButtons extends React.PureComponent { renderButtons() { const { onRemove, onAdd, addTooltip, removeTooltip } = this.props const buttons = [ { onClick: onRemove, className: "remove-button", icon: "remove", tooltip: removeTooltip, }, { onClick: onAdd, className: "add-button", icon: "add", tooltip: addTooltip, }, ]; return buttons.map(button => { if (!button.onClick) { return null; } const { onClick, className, icon, tooltip } = button return ( ) }) } render() { return (
{this.renderButtons()}
) } }