import React, { useCallback } from 'react'; import { Intent, Button, ButtonGroup, Popover, PopoverInteractionKind, Position, Menu, MenuItem, } from '@blueprintjs/core'; import { useFormikContext } from 'formik'; import { FormattedMessage as T } from 'react-intl'; import { CLASSES } from 'common/classes'; import classNames from 'classnames'; import { saveInvoke } from 'utils'; import { If, Icon } from 'components'; /** * Invoice floating actions bar. */ export default function InvoiceFloatingActions({ isSubmitting, onSubmitClick, onCancelClick, onClearClick, invoice, isDelivered, }) { const { resetForm, submitForm } = useFormikContext(); const handleSubmitDeliverBtnClick = (event) => { saveInvoke(onSubmitClick, event, { redirect: true, delivered: true, }); }; const handleSubmitDeliverAndNewBtnClick = (event) => { submitForm(); saveInvoke(onSubmitClick, event, { redirect: false, delivered: true, resetForm: true, }); }; const handleSubmitDeliverContinueEditingBtnClick = (event) => { submitForm(); saveInvoke(onSubmitClick, event, { redirect: false, delivered: true, }); }; const handleSubmitDraftBtnClick = (event) => { saveInvoke(onSubmitClick, event, { redirect: true, delivered: false, }); }; const handleSubmitDraftAndNewBtnClick = (event) => { submitForm(); saveInvoke(onSubmitClick, event, { redirect: false, delivered: false, resetForm: true, }); }; const handleSubmitDraftContinueEditingBtnClick = (event) => { submitForm(); saveInvoke(onSubmitClick, event, { redirect: false, delivered: false, }); }; const handleCancelBtnClick = (event) => { saveInvoke(onCancelClick, event); }; const handleClearBtnClick = (event) => { // saveInvoke(onClearClick, event); resetForm(); }; return (
{/* ----------- Save And Deliver ----------- */}
); }