Refactor product pricing: catalog owns base price, pricing manager owns rules

This commit is contained in:
2026-02-21 19:52:25 -03:00
parent 841cc961b5
commit 6d1eb908a0
17 changed files with 90 additions and 26 deletions

View File

@@ -10,6 +10,7 @@ interface AdEditorModalProps {
onClose: () => void;
onConfirm: (listingId: number, price: number, description: string) => void;
clientId: number | null; // El aviso se vinculará a este cliente
productId: number; // Necesario para el precio base
}
interface PricingResult {
@@ -18,7 +19,7 @@ interface PricingResult {
details: string;
}
export default function AdEditorModal({ isOpen, onClose, onConfirm, clientId }: AdEditorModalProps) {
export default function AdEditorModal({ isOpen, onClose, onConfirm, clientId, productId }: AdEditorModalProps) {
const [flatCategories, setFlatCategories] = useState<FlatCategory[]>([]);
const [operations, setOperations] = useState<any[]>([]);
const [loading, setLoading] = useState(false);
@@ -72,6 +73,7 @@ export default function AdEditorModal({ isOpen, onClose, onConfirm, clientId }:
try {
const res = await api.post('/pricing/calculate', {
categoryId: parseInt(categoryId),
productId: productId,
text: debouncedText,
days: days,
isBold: styles.isBold,