All Downloads are FREE. Search and download functionalities are using the official Maven repository.

META-INF.resources.js.OrderActions.js Maven / Gradle / Ivy

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