Comparateur Toyota Prius 2026 — Outil de vente (QC)
Résumé rapide (client)
Les coûts d’usage se recalculent en direct selon tes sliders (carburant seulement, sans prix véhicule).
Conso calculée (selon % ville)
—
Basée sur ville/route officiels + mix ville/route.
Coût carburant (projection)
—
Carburant seulement (aucun prix véhicule).
Puissance
—
196 hp (XLE AWD / Limited AWD).
Rouage
—
AWD électrique (selon fiche Canada).
Coffre
—
575 L (20.3 pi³).
Score priorités client
— /100
Pondéré par les sliders ci-dessous.
Sliders (usage)
Priorités du client (pondération)
0–100. Le score compare la Prius vs 5 concurrents (placeholders).
Arguments “flash” (à dire au client)
Ce que l’outil démontre
- Usage : coût carburant sur X ans (selon km/an, % ville, $/L).
- Économie : L/100 très bas pour un véhicule AWD hybride.
- Sécurité : mise en avant de l’ensemble d’aides à la conduite.
- Praticité : coffre 575 L + polyvalence au quotidien.
Fiche comparative (sans prix)
Défilement horizontal sur mobile. Remplace les placeholders par des chiffres officiels si désiré.
| Modèle |
Motorisation |
Puissance (hp) |
0–100 km/h |
Rouage |
Ville (L/100) |
Route (L/100) |
Combinée (L/100) |
Coffre (L) |
Sécurité |
${m.isToyota ? "Mise en avant" : "Concurrent (placeholder)"}
`; const pill = m.isToyota ?`
${m.safetyTag}` : `
${m.safetyTag}`; tr.innerHTML = `
${modelCell} |
${m.powertrain || "—"} |
${m.hp ?? "—"} |
${m.zero100 ? fmt(m.zero100,1)+" s" : "—"} |
${m.drive ?? "—"} |
${isFinite(m.cityL) ? fmt(m.cityL,1) : "—"} |
${isFinite(m.hwyL) ? fmt(m.hwyL,1): "—"} |
${isFinite(m.combL) ? fmt(m.combL,1) : "—"} |
${(m.cargoL ?? "—").toLocaleString("fr-CA")} |
${pill} |
`; tbody.appendChild(tr); }); // mga tsart const label = ms.map(m => (m.isToyota ? "★ " : "") + shortName(m)); const fuelBars = ms.map(m=>{ const mix2 = blendedL100(m.cityL,m.hwyL,cityPct); return isFinite(mix2) ? +mix2.toFixed(2) : (isFinite(m.combL) ? m.combL : 0); }); const scoreBars = ms.map(m => scores.find(s=>s.key===m.key)?.total ?? 0); const pracBars = ms.map(m => { const cargoScore = clamp((m.cargoL||350)/650*100,0,100); return Math.round(cargoScore); }); chartFuel = upsertBar(chartFuel, "chartFuel", {mga label, label:"Conso (L/100) — kasama ang bas = mieux", data:fuelBars}, {reverseY:true}); chartScore = upsertBar(chartScore, "chartScore", {mga label, label:"Mga prayoridad ng Iskor (0–100) — kasama ang taas = mieux", data:scoreBars}); chartPrac = upsertBar(chartPrac, "chartPrac", {mga label, label:"Indice coffre (0–100) — kasama ang taas = mieux", data:pracBars}); window.__ESTADO__ = {kmYear,Presyo ng Panggatong,lungsodPct,taon,timbang,ms,l100,costHorizon,scoreCar}; } [ "baryant","kmYear","fuelPrice","cityPct","years", "wFuel","wPerf","wSafety","wPrac","wAwd","wPeace" ].forEach(id => $(id).addEventListener("input", render)); $("resetBtn").addEventListener("click", ()=>{ $("variant").value = "xle"; $("kmYear").value = 20000; $("fuelPrice").value = 1.75; $("cityPct").value = 60; $("years").value = 5; $("wFuel").value = 80; $("wPerf").value = 30; $("wSafety").value = 75; $("wPrac").value = 55; $("wAwd").value = 55; $("wPeace").value = 80; render(); }); $("exportBtn").addEventListener("click", async ()=>{ const s = window.__STATE__; const car = s.ms[0]; const l100Txt = isFinite(s.l100) ? s.l100.toFixed(1).replace(".",",") : "—"; const costTxt = isFinite(s.costHorizon) ? Math.round(s.costHorizon).toLocaleString("fr-CA") : "—"; const txt = `Résumé client — ${car.brand} ${car.model} • Paggamit: ${s.kmYear.toLocaleString("fr-CA")} km/araw, ${s.cityPct}% lungsod, ${s.years} taon, esensya ${s.fuelPrice.toFixed(2)} $/L • Conso calculée: ${l100Txt} L/100 km • Projection carburant: ~${costTxt} $ sur ${s.years} ans (carburant seulement) • Puissance: ${car.hp} hp | Rouage: ${car.drive} | Coffre: ${car.cargoL} L • Sécurité: ${car.safetyTag} • Mga priyoridad ng Score: ${s.scoreCar}/100 Disclaimer: valeurs indicatives; iba't ibang bersyon/kondisyon ng selon; vérifier données officielles.`; subukan{ hintayin ang navigator.clipboard.writeText(txt); $("exportBtn").textContent = "Résumé copié ✓"; setTimeout(()=>$("exportBtn").textContent="Copier resume", 1200); }catch(e){ alert("Kopya automatique imposible. Copiez manuellement."); } }); render();