Fix budget calculation and storage
Correct budget calculation and storage issues for 교통 and 기타 categories, and ensure daily/weekly budgets are displayed correctly.
This commit is contained in:
@@ -6,7 +6,6 @@ import { EXPENSE_CATEGORIES } from '@/constants/categoryIcons';
|
||||
export const DEFAULT_CATEGORY_BUDGETS: Record<string, number> = {
|
||||
음식: 0,
|
||||
쇼핑: 0,
|
||||
교통비: 0,
|
||||
교통: 0,
|
||||
기타: 0
|
||||
};
|
||||
@@ -23,7 +22,7 @@ export const calculateCategorySpending = (
|
||||
|
||||
// 모든 카테고리에 대해 초기값 0 설정
|
||||
Object.keys(categoryBudgets).forEach(category => {
|
||||
// 3개 카테고리만 유지
|
||||
// 정의된 카테고리만 유지
|
||||
if (EXPENSE_CATEGORIES.includes(category)) {
|
||||
categorySpending[category] = 0;
|
||||
}
|
||||
@@ -42,9 +41,12 @@ export const calculateCategorySpending = (
|
||||
} else if (EXPENSE_CATEGORIES.includes(t.category)) {
|
||||
// 지원되는 카테고리이지만 초기화되지 않은 경우
|
||||
categorySpending[t.category] = t.amount;
|
||||
} else if (t.category === '교통비') {
|
||||
// 예전 카테고리명 '교통비'를 '교통'으로 매핑
|
||||
categorySpending['교통'] = (categorySpending['교통'] || 0) + t.amount;
|
||||
} else {
|
||||
// 지원되지 않는 카테고리는 '쇼핑'으로 집계
|
||||
categorySpending['쇼핑'] = (categorySpending['쇼핑'] || 0) + t.amount;
|
||||
// 지원되지 않는 카테고리는 '기타'로 집계
|
||||
categorySpending['기타'] = (categorySpending['기타'] || 0) + t.amount;
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
@@ -20,19 +20,20 @@ export const useExtendedBudgetUpdate = (
|
||||
|
||||
// 카테고리 예산이 제공된 경우 업데이트
|
||||
if (newCategoryBudgets) {
|
||||
// 카테고리 예산 저장
|
||||
updateCategoryBudgets(newCategoryBudgets);
|
||||
|
||||
// 총액 계산
|
||||
const totalAmount = Object.values(newCategoryBudgets).reduce((sum, val) => sum + val, 0);
|
||||
console.log('카테고리 총액:', totalAmount);
|
||||
|
||||
// 예산 데이터 업데이트를 위해 월간 금액으로 처리 (type은 'monthly'로 설정)
|
||||
// 월간 예산 금액으로 예산 데이터 업데이트 (type에 관계없이 월간으로 처리)
|
||||
handleBudgetGoalUpdate('monthly', totalAmount);
|
||||
} else {
|
||||
// 카테고리 예산이 없는 경우, 기존 로직 사용
|
||||
// 카테고리 예산이 없는 경우, 선택된 기간 유형에 따라 예산 설정
|
||||
handleBudgetGoalUpdate(type, amount);
|
||||
}
|
||||
}, [budgetData, categoryBudgets, handleBudgetGoalUpdate, updateCategoryBudgets]);
|
||||
}, [categoryBudgets, handleBudgetGoalUpdate, updateCategoryBudgets]);
|
||||
|
||||
return { extendedBudgetGoalUpdate };
|
||||
};
|
||||
|
||||
@@ -20,8 +20,8 @@ export const loadCategoryBudgetsFromStorage = (): Record<string, number> => {
|
||||
// 이전 카테고리명이 있을 경우 새 카테고리명으로 값 이전
|
||||
if (category === '음식' && parsed['식비'] !== undefined) {
|
||||
filteredBudgets[category] = parsed['식비'];
|
||||
} else if (category === '쇼핑' && parsed['생활비'] !== undefined) {
|
||||
filteredBudgets[category] = parsed['생활비'];
|
||||
} else if (category === '교통' && parsed['교통비'] !== undefined) {
|
||||
filteredBudgets[category] = parsed['교통비'];
|
||||
} else {
|
||||
filteredBudgets[category] = parsed[category] || 0;
|
||||
}
|
||||
@@ -42,8 +42,8 @@ export const loadCategoryBudgetsFromStorage = (): Record<string, number> => {
|
||||
// 이전 카테고리명이 있을 경우 새 카테고리명으로 값 이전
|
||||
if (category === '음식' && parsedBackup['식비'] !== undefined) {
|
||||
filteredBudgets[category] = parsedBackup['식비'];
|
||||
} else if (category === '쇼핑' && parsedBackup['생활비'] !== undefined) {
|
||||
filteredBudgets[category] = parsedBackup['생활비'];
|
||||
} else if (category === '교통' && parsedBackup['교통비'] !== undefined) {
|
||||
filteredBudgets[category] = parsedBackup['교통비'];
|
||||
} else {
|
||||
filteredBudgets[category] = parsedBackup[category] || 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user