mirror of
https://github.com/bigcapitalhq/bigcapital.git
synced 2026-02-18 05:40:31 +00:00
fix(items): correct error type handling and add swagger documentation
- Fix error type mismatch: change 'ITEM.NAME.ALREADY.EXISTS' to 'ITEM_NAME_EXISTS' - Add ItemErrorType constant with UpperCamelCase keys for better maintainability - Update all error checks to use the new ItemErrorType constant - Add ItemErrorResponse.dto.ts with documented error types for swagger - Add @ApiResponse decorators to document 400 validation errors in swagger
This commit is contained in:
@@ -14,6 +14,18 @@ import { useSettingsSelector } from '@/hooks/state';
|
||||
import { transformItemFormData } from './ItemForm.schema';
|
||||
import { useWatch } from '@/hooks/utils';
|
||||
|
||||
/**
|
||||
* Error types for item operations.
|
||||
*/
|
||||
export const ItemErrorType = {
|
||||
ItemNameExists: 'ITEM_NAME_EXISTS',
|
||||
InventoryAccountCannotModified: 'INVENTORY_ACCOUNT_CANNOT_MODIFIED',
|
||||
TypeCannotChangeWithItemHasTransactions: 'TYPE_CANNOT_CHANGE_WITH_ITEM_HAS_TRANSACTIONS',
|
||||
ItemHasAssociatedTransactions: 'ITEM_HAS_ASSOCIATED_TRANSACTINS',
|
||||
ItemHasAssociatedInventoryAdjustment: 'ITEM_HAS_ASSOCIATED_INVENTORY_ADJUSTMENT',
|
||||
ItemHasAssociatedTransactionsPlural: 'ITEM_HAS_ASSOCIATED_TRANSACTIONS',
|
||||
} as const;
|
||||
|
||||
const defaultInitialValues = {
|
||||
active: 1,
|
||||
name: '',
|
||||
@@ -74,7 +86,7 @@ export const transitionItemTypeKeyToLabel = (itemTypeKey) => {
|
||||
// handle delete errors.
|
||||
export const handleDeleteErrors = (errors) => {
|
||||
if (
|
||||
errors.find((error) => error.type === 'ITEM_HAS_ASSOCIATED_TRANSACTINS')
|
||||
errors.find((error) => error.type === ItemErrorType.ItemHasAssociatedTransactions)
|
||||
) {
|
||||
AppToaster.show({
|
||||
message: intl.get('the_item_has_associated_transactions'),
|
||||
@@ -84,7 +96,7 @@ export const handleDeleteErrors = (errors) => {
|
||||
|
||||
if (
|
||||
errors.find(
|
||||
(error) => error.type === 'ITEM_HAS_ASSOCIATED_INVENTORY_ADJUSTMENT',
|
||||
(error) => error.type === ItemErrorType.ItemHasAssociatedInventoryAdjustment,
|
||||
)
|
||||
) {
|
||||
AppToaster.show({
|
||||
@@ -96,7 +108,7 @@ export const handleDeleteErrors = (errors) => {
|
||||
}
|
||||
if (
|
||||
errors.find(
|
||||
(error) => error.type === 'TYPE_CANNOT_CHANGE_WITH_ITEM_HAS_TRANSACTIONS',
|
||||
(error) => error.type === ItemErrorType.TypeCannotChangeWithItemHasTransactions,
|
||||
)
|
||||
) {
|
||||
AppToaster.show({
|
||||
@@ -107,7 +119,7 @@ export const handleDeleteErrors = (errors) => {
|
||||
});
|
||||
}
|
||||
if (
|
||||
errors.find((error) => error.type === 'ITEM_HAS_ASSOCIATED_TRANSACTIONS')
|
||||
errors.find((error) => error.type === ItemErrorType.ItemHasAssociatedTransactionsPlural)
|
||||
) {
|
||||
AppToaster.show({
|
||||
message: intl.get('item.error.you_could_not_delete_item_has_associated'),
|
||||
@@ -214,10 +226,10 @@ export const transformSubmitRequestErrors = (error) => {
|
||||
} = error;
|
||||
const fields = {};
|
||||
|
||||
if (errors.find((e) => e.type === 'ITEM.NAME.ALREADY.EXISTS')) {
|
||||
if (errors.find((e) => e.type === ItemErrorType.ItemNameExists)) {
|
||||
fields.name = intl.get('the_name_used_before');
|
||||
}
|
||||
if (errors.find((e) => e.type === 'INVENTORY_ACCOUNT_CANNOT_MODIFIED')) {
|
||||
if (errors.find((e) => e.type === ItemErrorType.InventoryAccountCannotModified)) {
|
||||
AppToaster.show({
|
||||
message: intl.get('cannot_change_item_inventory_account'),
|
||||
intent: Intent.DANGER,
|
||||
@@ -225,7 +237,7 @@ export const transformSubmitRequestErrors = (error) => {
|
||||
}
|
||||
if (
|
||||
errors.find(
|
||||
(e) => e.type === 'TYPE_CANNOT_CHANGE_WITH_ITEM_HAS_TRANSACTIONS',
|
||||
(e) => e.type === ItemErrorType.TypeCannotChangeWithItemHasTransactions,
|
||||
)
|
||||
) {
|
||||
AppToaster.show({
|
||||
|
||||
Reference in New Issue
Block a user