META-INF.resources.js.OrderActions.js Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.liferay.commerce.order.content.web
Show all versions of com.liferay.commerce.order.content.web
Liferay Commerce Order Content Web
The newest version!
/**
* SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
* SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
*/
import ClayButton from '@clayui/button';
import {CommerceServiceProvider, commerceEvents} from 'commerce-frontend-js';
import {openToast} from 'frontend-js-web';
import React, {useCallback, useEffect, useState} from 'react';
import {handleOrderActionRedirect} from './orderActionRedirectHelper';
import {PAYMENT_METHOD_TYPE_OFFLINE, getOrder} from './util';
function OrderActions({
checkoutURL,
isOpen,
namespace,
orderId,
orderSummaryURL,
reorderURL,
viewReturnableOrderItemsURL,
}) {
const [actions, setActions] = useState([]);
const [currentOrder, setCurrentOrder] = useState({});
const [open, setOpen] = useState(isOpen);
const getActions = useCallback(
({order}) => {
const getTransitions = open
? CommerceServiceProvider.DeliveryCartAPI('v1')
.getCartTransitionsById
: CommerceServiceProvider.DeliveryOrderAPI('v1')
.getOrderTransitionsById;
getTransitions(orderId)
.then((response) => {
const quickCheckoutTransition = response.items.find(
(item) => item.name === 'quick-checkout'
);
let actions =
open && !quickCheckoutTransition
? [
...response.items,
{
disabled: true,
label: Liferay.Language.get(
'quick-checkout'
),
name: 'quick-checkout',
},
]
: response.items;
if (viewReturnableOrderItemsURL) {
actions = [
...actions,
{
label: Liferay.Language.get('make-a-return'),
name: 'make-return',
},
];
}
setActions(actions);
setCurrentOrder(order);
})
.catch((error) => {
openToast({
message:
error.message ||
Liferay.Language.get(
'an-unexpected-error-occurred'
),
type: 'danger',
});
});
},
[orderId, open, viewReturnableOrderItemsURL]
);
useEffect(() => {
getOrder(open, null, orderId).then((order) => setCurrentOrder(order));
}, [open, orderId]);
useEffect(() => getActions({}), [getActions]);
useEffect(() => {
Liferay.on(commerceEvents.CART_UPDATED, getActions);
Liferay.on(commerceEvents.ORDER_INFORMATION_ALTERED, getActions);
return () => {
Liferay.detach(commerceEvents.CART_UPDATED, getActions);
Liferay.detach(
commerceEvents.ORDER_INFORMATION_ALTERED,
getActions
);
};
}, [getActions]);
const onClick = (event, action) => {
event.preventDefault();
if (action.name === 'checkout') {
handleOrderActionRedirect({
checkoutURL,
id: action.name,
});
}
else if (action.name === 'make-return') {
Liferay.fire(`${namespace || ''}makeReturn`, {
accountId: Liferay.CommerceContext.account.accountId,
orderId,
});
}
else if (action.name === 'quick-checkout') {
if (
currentOrder?.paymentMethodType === PAYMENT_METHOD_TYPE_OFFLINE
) {
CommerceServiceProvider.DeliveryCartAPI('v1')
.checkoutCartById(orderId)
.then(() => {
window.location.reload();
})
.catch((error) => {
openToast({
message:
error.message ||
Liferay.Language.get(
'an-unexpected-error-occurred'
),
type: 'danger',
});
});
}
else {
window.location.href = orderSummaryURL;
}
}
else {
const executeTransitions = open
? CommerceServiceProvider.DeliveryCartAPI('v1')
.executeCartTransitionsById
: CommerceServiceProvider.DeliveryOrderAPI('v1')
.executeOrderTransitionsById;
executeTransitions(orderId, action)
.then((response) => {
Liferay.fire(commerceEvents.ORDER_INFORMATION_ALTERED);
if (open !== response?.open) {
setOpen(response.open);
}
else {
getActions({});
}
if (action.name === 'reorder') {
handleOrderActionRedirect({
id: response.name,
orderId: response.orderId,
reorderURL,
});
}
})
.catch((error) => {
openToast({
message:
error.message ||
Liferay.Language.get(
'an-unexpected-error-occurred'
),
type: 'danger',
});
});
}
};
return (
{actions.map((action) => (
onClick(event, action)}
>
{action.label}
))}
);
}
export default OrderActions;
© 2015 - 2025 Weber Informatics LLC | Privacy Policy