import { useRef, useState } from 'react' import { useLocation } from 'react-router-dom' import { Space, Flex, Card, Modal } from 'antd' import { LoadingOutlined } from '@ant-design/icons' import loglevel from 'loglevel' import config from '../../../../config.js' import useCollapseState from '../../hooks/useCollapseState.js' import NotesPanel from '../../common/NotesPanel.jsx' import InfoCollapse from '../../common/InfoCollapse.jsx' import ObjectInfo from '../../common/ObjectInfo.jsx' import ViewButton from '../../common/ViewButton.jsx' import InfoCircleIcon from '../../../Icons/InfoCircleIcon.jsx' import NoteIcon from '../../../Icons/NoteIcon.jsx' import AuditLogIcon from '../../../Icons/AuditLogIcon.jsx' import ObjectForm from '../../common/ObjectForm.jsx' import EditButtons from '../../common/EditButtons.jsx' import LockIndicator from '../../common/LockIndicator.jsx' import ActionHandler from '../../common/ActionHandler.jsx' import ObjectActions from '../../common/ObjectActions.jsx' import ObjectTable from '../../common/ObjectTable.jsx' import InfoCollapsePlaceholder from '../../common/InfoCollapsePlaceholder.jsx' import DocumentPrintButton from '../../common/DocumentPrintButton.jsx' import ScrollBox from '../../common/ScrollBox.jsx' import OrderItemsIcon from '../../../Icons/OrderItemIcon.jsx' import NewOrderItem from '../../Inventory/OrderItems/NewOrderItem.jsx' import NewShipment from '../../Inventory/Shipments/NewShipment.jsx' import PostSalesOrder from './PostSalesOrder.jsx' import ConfirmSalesOrder from './ConfirmSalesOrder.jsx' import CancelSalesOrder from './CancelSalesOrder.jsx' import ShipmentIcon from '../../../Icons/ShipmentIcon.jsx' import InvoiceIcon from '../../../Icons/InvoiceIcon.jsx' import StockEventIcon from '../../../Icons/StockEventIcon.jsx' import { getModelByName } from '../../../../database/ObjectModels.js' const log = loglevel.getLogger('SalesOrderInfo') log.setLevel(config.logLevel) const SalesOrderInfo = () => { const location = useLocation() const objectFormRef = useRef(null) const orderItemsTableRef = useRef(null) const shipmentsTableRef = useRef(null) const actionHandlerRef = useRef(null) const [newOrderItemOpen, setNewOrderItemOpen] = useState(false) const [newShipmentOpen, setNewShipmentOpen] = useState(false) const [postSalesOrderOpen, setPostSalesOrderOpen] = useState(false) const [confirmSalesOrderOpen, setConfirmSalesOrderOpen] = useState(false) const [cancelSalesOrderOpen, setCancelSalesOrderOpen] = useState(false) const salesOrderId = new URLSearchParams(location.search).get('salesOrderId') const [collapseState, updateCollapseState] = useCollapseState( 'SalesOrderInfo', { info: true, notes: true, auditLogs: true, invoices: true, stockEvents: true } ) const [objectFormState, setEditFormState] = useState({ isEditing: false, editLoading: false, formValid: false, lock: null, loading: false, objectData: {} }) const actions = { reload: () => { objectFormRef?.current?.handleFetchObject?.() return true }, edit: () => { orderItemsTableRef?.current?.startEditing?.() objectFormRef?.current?.startEditing?.() return false }, cancelEdit: () => { orderItemsTableRef?.current?.cancelEditing?.() objectFormRef?.current?.cancelEditing?.() return true }, finishEdit: () => { orderItemsTableRef?.current?.handleUpdate?.() objectFormRef?.current?.handleUpdate?.() return true }, delete: () => { objectFormRef?.current?.handleDelete?.() return true }, newOrderItem: () => { setNewOrderItemOpen(true) return true }, newShipment: () => { setNewShipmentOpen(true) return true }, post: () => { setPostSalesOrderOpen(true) return true }, confirm: () => { setConfirmSalesOrderOpen(true) return true }, cancel: () => { setCancelSalesOrderOpen(true) return true } } const editDisabled = getModelByName('salesOrder') .actions.find((action) => action.name === 'edit') .disabled(objectFormState.objectData) return ( <> { actionHandlerRef.current.callAction('finishEdit') }} cancelEditing={() => { actionHandlerRef.current.callAction('cancelEdit') }} startEditing={() => { actionHandlerRef.current.callAction('edit') }} editLoading={objectFormState.editLoading} formValid={objectFormState.formValid} disabled={ objectFormState.lock?.locked || objectFormState.loading || editDisabled } loading={objectFormState.editLoading} /> { setEditFormState((prev) => ({ ...prev, ...state })) }} > {({ loading, isEditing, objectData }) => ( } active={collapseState.info} onToggle={(expanded) => updateCollapseState('info', expanded) } collapseKey='info' > } isEditing={isEditing} type='salesOrder' labelWidth='225px' objectData={objectData} visibleProperties={{ items: false }} /> } active={collapseState.orderItems} onToggle={(expanded) => updateCollapseState('orderItems', expanded) } collapseKey='orderItems' > } active={collapseState.shipments} onToggle={(expanded) => updateCollapseState('shipments', expanded) } collapseKey='shipments' > } active={collapseState.invoices} onToggle={(expanded) => updateCollapseState('invoices', expanded) } collapseKey='invoices' > {objectFormState.loading ? ( ) : ( )} } active={collapseState.stockEvents} onToggle={(expanded) => updateCollapseState('stockEvents', expanded) } collapseKey='stockEvents' > {objectFormState.loading ? ( ) : ( )} )} } active={collapseState.notes} onToggle={(expanded) => updateCollapseState('notes', expanded)} collapseKey='notes' > } active={collapseState.auditLogs} onToggle={(expanded) => updateCollapseState('auditLogs', expanded) } collapseKey='auditLogs' > {objectFormState.loading ? ( ) : ( )} { setNewOrderItemOpen(false) }} width={800} footer={null} destroyOnHidden={true} > { setNewOrderItemOpen(false) }} reset={newOrderItemOpen} defaultValues={{ order: { _id: salesOrderId }, orderType: 'salesOrder', syncAmount: 'itemCost' }} /> { setNewShipmentOpen(false) }} width={800} footer={null} destroyOnHidden={true} > { setNewShipmentOpen(false) }} reset={newShipmentOpen} defaultValues={{ orderType: 'salesOrder', order: { _id: salesOrderId } }} /> { setPostSalesOrderOpen(false) }} width={500} footer={null} destroyOnHidden={true} centered={true} > { setPostSalesOrderOpen(false) actions.reload() }} objectData={objectFormState.objectData} /> { setConfirmSalesOrderOpen(false) }} width={515} footer={null} destroyOnHidden={true} centered={true} > { setConfirmSalesOrderOpen(false) actions.reload() }} objectData={objectFormState.objectData} /> { setCancelSalesOrderOpen(false) }} width={515} footer={null} destroyOnHidden={true} centered={true} > { setCancelSalesOrderOpen(false) actions.reload() }} objectData={objectFormState.objectData} /> ) } export default SalesOrderInfo