feat: audit Phase 1 — P0/P1 quick wins
All checks were successful
CI/CD — Build & Deploy / Build & Deploy (push) Successful in 35s

- Fix vitalité: HP initial = 100 + (vitalité-1)×10
- Arme de départ: Bâton de Roseau équipé à la création
- Rebalance forge: niv3 200, niv4 400, niv5 700 (−30%)
- Confirmation avant vente d'item (confirm dialog)
- Fix forge costs dupliqués (shop sellback + inventaire)
This commit is contained in:
2026-03-24 21:53:45 +01:00
parent 23843cb72c
commit 0d917a8b39
5 changed files with 30 additions and 10 deletions

View File

@@ -23,9 +23,9 @@ const RARITY_LABELS: Record<string, string> = {
const FORGE_TABLE = [
{ level: 1, gold: 50, endurance: 10, risk: '0%', bonus: '+2' },
{ level: 2, gold: 100, endurance: 10, risk: '0%', bonus: '+4' },
{ level: 3, gold: 250, endurance: 10, risk: '20%', bonus: '+6' },
{ level: 4, gold: 500, endurance: 10, risk: '30%', bonus: '+8' },
{ level: 5, gold: 1000, endurance: 10, risk: '40%', bonus: '+10' },
{ level: 3, gold: 200, endurance: 10, risk: '20%', bonus: '+6' },
{ level: 4, gold: 400, endurance: 10, risk: '30%', bonus: '+8' },
{ level: 5, gold: 700, endurance: 10, risk: '40%', bonus: '+10' },
];
const TABS = [

View File

@@ -16,7 +16,7 @@ function ItemCard({ ci, onEquip, onUnequip, onSell, selling }: {
const forgeBonusDEF = item.type === 'armor' ? ci.forgeLevel * 2 : 0;
const totalATK = item.attackBonus + forgeBonusATK;
const totalDEF = item.defenseBonus + forgeBonusDEF;
const FORGE_COSTS: Record<number, number> = { 1: 50, 2: 100, 3: 250, 4: 500, 5: 1000 };
const FORGE_COSTS: Record<number, number> = { 1: 50, 2: 100, 3: 200, 4: 400, 5: 700 };
let forgeInvestment = 0;
for (let i = 1; i <= ci.forgeLevel; i++) forgeInvestment += FORGE_COSTS[i] ?? 0;
const sellPrice = Math.floor(((item as any).buyPrice || 0) * 0.4 + forgeInvestment * 0.5);
@@ -125,7 +125,7 @@ export function InventoryPage() {
key={ci.id} ci={ci}
onEquip={() => equipMut.mutate(ci.id)}
onUnequip={() => unequipMut.mutate('weapon')}
onSell={() => sellMut.mutate(ci.id)}
onSell={() => { if (confirm(`Vendre ${ci.item.name} ?`)) sellMut.mutate(ci.id); }}
selling={sellMut.isPending}
/>
))}
@@ -145,7 +145,7 @@ export function InventoryPage() {
key={ci.id} ci={ci}
onEquip={() => equipMut.mutate(ci.id)}
onUnequip={() => unequipMut.mutate('armor')}
onSell={() => sellMut.mutate(ci.id)}
onSell={() => { if (confirm(`Vendre ${ci.item.name} ?`)) sellMut.mutate(ci.id); }}
selling={sellMut.isPending}
/>
))}