Visual edit in Lovable

Edited UI in Lovable
This commit is contained in:
gpt-engineer-app[bot]
2025-03-15 04:07:12 +00:00
parent 315f2e3917
commit 136df4a5e9

View File

@@ -1,30 +1,25 @@
import React, { useState } from 'react'; import React, { useState } from 'react';
import { Button } from '@/components/ui/button'; import { Button } from '@/components/ui/button';
import { Check, ChevronDown, ChevronUp, Calculator } from 'lucide-react'; import { Check, ChevronDown, ChevronUp, Calculator } from 'lucide-react';
import { Collapsible, CollapsibleContent, CollapsibleTrigger } from '@/components/ui/collapsible'; import { Collapsible, CollapsibleContent, CollapsibleTrigger } from '@/components/ui/collapsible';
import BudgetProgress from './BudgetProgress'; import BudgetProgress from './BudgetProgress';
import CategoryBudgetInputs from './CategoryBudgetInputs'; import CategoryBudgetInputs from './CategoryBudgetInputs';
interface BudgetData { interface BudgetData {
targetAmount: number; targetAmount: number;
spentAmount: number; spentAmount: number;
remainingAmount: number; remainingAmount: number;
} }
interface CategoryBudget { interface CategoryBudget {
식비: number; 식비: number;
생활비: number; 생활비: number;
교통비: number; 교통비: number;
} }
interface BudgetTabContentProps { interface BudgetTabContentProps {
data: BudgetData; data: BudgetData;
formatCurrency: (amount: number) => string; formatCurrency: (amount: number) => string;
calculatePercentage: (spent: number, target: number) => number; calculatePercentage: (spent: number, target: number) => number;
onSaveBudget: (amount: number) => void; onSaveBudget: (amount: number) => void;
} }
const BudgetTabContent: React.FC<BudgetTabContentProps> = ({ const BudgetTabContent: React.FC<BudgetTabContentProps> = ({
data, data,
formatCurrency, formatCurrency,
@@ -34,29 +29,24 @@ const BudgetTabContent: React.FC<BudgetTabContentProps> = ({
const percentage = calculatePercentage(data.spentAmount, data.targetAmount); const percentage = calculatePercentage(data.spentAmount, data.targetAmount);
const [isOpen, setIsOpen] = useState(false); const [isOpen, setIsOpen] = useState(false);
const [budgetInput, setBudgetInput] = useState(data.targetAmount.toString()); const [budgetInput, setBudgetInput] = useState(data.targetAmount.toString());
const [categoryBudgets, setCategoryBudgets] = useState<CategoryBudget>({ const [categoryBudgets, setCategoryBudgets] = useState<CategoryBudget>({
식비: Math.round(data.targetAmount * 0.4), 식비: Math.round(data.targetAmount * 0.4),
생활비: Math.round(data.targetAmount * 0.4), 생활비: Math.round(data.targetAmount * 0.4),
교통비: Math.round(data.targetAmount * 0.2) 교통비: Math.round(data.targetAmount * 0.2)
}); });
const handleInputChange = (value: string) => { const handleInputChange = (value: string) => {
// Remove all non-numeric characters // Remove all non-numeric characters
const numericValue = value.replace(/[^0-9]/g, ''); const numericValue = value.replace(/[^0-9]/g, '');
setBudgetInput(numericValue); setBudgetInput(numericValue);
}; };
const handleCategoryInputChange = (value: string, category: keyof CategoryBudget) => { const handleCategoryInputChange = (value: string, category: keyof CategoryBudget) => {
// Remove all non-numeric characters // Remove all non-numeric characters
const numericValue = value.replace(/[^0-9]/g, ''); const numericValue = value.replace(/[^0-9]/g, '');
setCategoryBudgets(prev => ({ setCategoryBudgets(prev => ({
...prev, ...prev,
[category]: parseInt(numericValue) || 0 [category]: parseInt(numericValue) || 0
})); }));
}; };
const handleSave = () => { const handleSave = () => {
// Calculate total from all categories // Calculate total from all categories
const totalAmount = Object.values(categoryBudgets).reduce((sum, value) => sum + value, 0); const totalAmount = Object.values(categoryBudgets).reduce((sum, value) => sum + value, 0);
@@ -68,15 +58,8 @@ const BudgetTabContent: React.FC<BudgetTabContentProps> = ({
const formatWithCommas = (amount: string) => { const formatWithCommas = (amount: string) => {
return amount.replace(/\B(?=(\d{3})+(?!\d))/g, ','); return amount.replace(/\B(?=(\d{3})+(?!\d))/g, ',');
}; };
return <div className="space-y-4">
return ( <BudgetProgress spentAmount={data.spentAmount} targetAmount={data.targetAmount} percentage={percentage} formatCurrency={formatCurrency} />
<div className="space-y-4">
<BudgetProgress
spentAmount={data.spentAmount}
targetAmount={data.targetAmount}
percentage={percentage}
formatCurrency={formatCurrency}
/>
<div className="flex justify-between items-center pt-2 border-t border-gray-100"> <div className="flex justify-between items-center pt-2 border-t border-gray-100">
<span className="text-gray-500 text-sm"> </span> <span className="text-gray-500 text-sm"> </span>
@@ -91,10 +74,7 @@ const BudgetTabContent: React.FC<BudgetTabContentProps> = ({
</CollapsibleTrigger> </CollapsibleTrigger>
<CollapsibleContent className="pt-2 space-y-3"> <CollapsibleContent className="pt-2 space-y-3">
<CategoryBudgetInputs <CategoryBudgetInputs categoryBudgets={categoryBudgets} handleCategoryInputChange={handleCategoryInputChange} />
categoryBudgets={categoryBudgets}
handleCategoryInputChange={handleCategoryInputChange}
/>
<div className="flex items-center justify-between pt-2 border-t border-gray-100"> <div className="flex items-center justify-between pt-2 border-t border-gray-100">
<div className="flex items-center gap-1"> <div className="flex items-center gap-1">
@@ -111,12 +91,10 @@ const BudgetTabContent: React.FC<BudgetTabContentProps> = ({
</Button> </Button>
</div> </div>
<p className="text-xs text-gray-500 text-center py-[6px]"> , .</p> <p className="text-xs text-gray-500 text-center py-[6px]"> , , .</p>
</CollapsibleContent> </CollapsibleContent>
</Collapsible> </Collapsible>
</div> </div>
</div> </div>;
);
}; };
export default BudgetTabContent;
export default BudgetTabContent;