META-INF.resources.js.info_box.OrderNotesView.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) 2024 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 {useModal} from '@clayui/modal';
import {CommerceServiceProvider} from 'commerce-frontend-js';
import {openConfirmModal, openToast, sub} from 'frontend-js-web';
import moment from 'moment';
import React, {useCallback, useEffect, useState} from 'react';
import InfoBoxModalNotes from '../InfoBoxModalNotes';
const OrderNotesView = ({
buttonDisplayType,
elementId,
hasPermission,
label,
namespace,
orderId,
spritemap,
}) => {
const {observer, onOpenChange, open} = useModal();
const [inputValue, setInputValue] = useState();
const [isRestricted, setIsRestricted] = useState(false);
const [isValid, setIsValid] = useState(true);
const [notes, setNotes] = useState([]);
const [updateNotes, setUpdateNotes] = useState(notes);
const modifiedDate = notes.map((date) => date.modifiedDate).splice(-1);
useEffect(() => {
CommerceServiceProvider.DeliveryCartAPI('v1')
.getCommentsByCartId(orderId)
.then(({items}) => {
setNotes(items.reverse());
});
}, [orderId, updateNotes]);
const formatDate = (value) => {
if (value.length) {
return moment(moment(value, 'YYYYMMDDHHmmss'))
.locale(Liferay.ThemeDisplay.getBCP47LanguageId())
.format('L LT');
}
};
const handleDelete = useCallback(
(commentId) => {
openConfirmModal({
message: sub(
Liferay.Language.get('are-you-sure-you-want-to-delete-this')
),
onConfirm: (isConfirmed) => {
if (isConfirmed) {
CommerceServiceProvider.DeliveryCartAPI('v1')
.deleteCommentsByCartId(commentId)
.then(() => {
setUpdateNotes(
notes.filter((note) => note !== commentId)
);
openToast({
message: Liferay.Language.get(
'your-request-completed-successfully'
),
type: 'success',
});
handleToggle(false);
onOpenChange(false);
})
.catch((error) => {
setIsValid(false);
openToast({
message:
error.message ||
error.title ||
Liferay.Language.get(
'an-error-occurred'
),
type: 'danger',
});
});
}
},
});
},
[notes, onOpenChange, setIsValid]
);
const handleSubmit = async (event) => {
event.preventDefault();
CommerceServiceProvider.DeliveryCartAPI('v1')
.createCommentsByCartId(orderId, {
content: inputValue,
restricted: isRestricted,
})
.then((newNote) => {
setUpdateNotes(newNote);
handleToggle(false);
onOpenChange(false);
openToast({
message: Liferay.Language.get(
'your-request-completed-successfully'
),
type: 'success',
});
})
.catch((error) => {
setIsValid(false);
openToast({
message:
error.message ||
Liferay.Language.get('an-error-occurred'),
type: 'danger',
});
});
};
const handleToggle = (value) => {
setIsRestricted(value);
};
return (
{label ? (
{label}
{hasPermission ? (
onOpenChange(true)}
size="xs"
>
{Liferay.Language.get('open')}
) : null}
) : null}
{formatDate(modifiedDate)}
);
};
export default OrderNotesView;
© 2015 - 2025 Weber Informatics LLC | Privacy Policy