> ## Documentation Index
> Fetch the complete documentation index at: https://docs.canadava.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Liste de vérification De Havilland Dash 8‑400

> Liste de vérification complète vACA Dash 8-400 Q400 avec flows turbopropulseur, réglages RPM hélice et éléments de mémoire

export const CockpitChecklist = ({sections = [], title, printLogoSrc = "/logo/light.svg", printNotice = "For flight-simulation training only - not for real-world aviation use."}) => {
  const allItems = sections.flatMap((s, si) => (s.items || []).map((_, ii) => `${si}-${ii}`));
  const [checked, setChecked] = useState({});
  const [isFullscreen, setIsFullscreen] = useState(false);
  const [backdropId] = useState(() => `cockpit-bd-${Math.random().toString(36).slice(2, 10)}`);
  const [printId] = useState(() => `cockpit-print-${Math.random().toString(36).slice(2, 10)}`);
  const fullscreenRootRef = useRef(null);
  const toggle = key => setChecked(prev => ({
    ...prev,
    [key]: !prev[key]
  }));
  const reset = () => setChecked({});
  const openFullscreen = () => setIsFullscreen(true);
  const closeFullscreen = () => setIsFullscreen(false);
  const clearPrintTarget = () => {
    if (typeof document === "undefined") return;
    const printNode = document.getElementById(printId);
    document.body.classList.remove("cockpit-printing");
    if (printNode) {
      printNode.setAttribute("data-print-active", "false");
    }
  };
  const printChecklist = () => {
    if (typeof window === "undefined" || typeof document === "undefined") return;
    const printNode = document.getElementById(printId);
    if (!printNode) return;
    printNode.setAttribute("data-print-active", "true");
    document.body.classList.add("cockpit-printing");
    window.addEventListener("afterprint", clearPrintTarget, {
      once: true
    });
    window.requestAnimationFrame(() => {
      window.print();
    });
  };
  const doneCount = Object.values(checked).filter(Boolean).length;
  const totalCount = allItems.length;
  useEffect(() => {
    if (typeof document === "undefined") return;
    [backdropId, printId].forEach(id => {
      const node = document.getElementById(id);
      if (node && node.parentNode !== document.body) {
        document.body.appendChild(node);
      }
    });
    return () => {
      [backdropId, printId].forEach(id => {
        const current = document.getElementById(id);
        if (current && current.parentNode) {
          current.parentNode.removeChild(current);
        }
      });
    };
  }, [backdropId, printId]);
  useEffect(() => {
    if (!isFullscreen) return;
    const onKey = e => {
      if (e.key === "Escape") setIsFullscreen(false);
    };
    document.addEventListener("keydown", onKey);
    const prevOverflow = document.body.style.overflow;
    document.body.style.overflow = "hidden";
    return () => {
      document.removeEventListener("keydown", onKey);
      document.body.style.overflow = prevOverflow;
    };
  }, [isFullscreen]);
  useEffect(() => {
    if (!isFullscreen) return;
    if (typeof window === "undefined") return;
    const root = fullscreenRootRef.current;
    if (!root) return;
    const MIN_SCALE = 0.7;
    const MAX_SCALE = 1;
    const MIN_LEADER_PX = 24;
    const GAP_PX = 16;
    const SAFETY_PX = 2;
    const measure = () => {
      root.style.setProperty("--cockpit-fs-font-scale", "1");
      void root.offsetWidth;
      const items = root.querySelectorAll(".cockpit-item");
      let worst = 1;
      items.forEach(item => {
        const label = item.querySelector(".cockpit-item-label");
        const value = item.querySelector(".cockpit-item-value");
        if (!label || !value) return;
        const cs = window.getComputedStyle(item);
        const padL = parseFloat(cs.paddingLeft) || 0;
        const padR = parseFloat(cs.paddingRight) || 0;
        const available = item.clientWidth - padL - padR;
        const needed = label.scrollWidth + value.scrollWidth + MIN_LEADER_PX + GAP_PX + SAFETY_PX;
        if (needed > available && available > 0) {
          const ratio = available / needed;
          if (ratio < worst) worst = ratio;
        }
      });
      const next = Math.max(MIN_SCALE, Math.min(MAX_SCALE, worst));
      root.style.setProperty("--cockpit-fs-font-scale", String(next));
    };
    measure();
    let raf = 0;
    const ro = new ResizeObserver(() => {
      cancelAnimationFrame(raf);
      raf = requestAnimationFrame(measure);
    });
    ro.observe(root);
    const backdrop = document.getElementById(backdropId);
    if (backdrop) ro.observe(backdrop);
    return () => {
      cancelAnimationFrame(raf);
      ro.disconnect();
    };
  }, [isFullscreen, sections, backdropId]);
  useEffect(() => clearPrintTarget, [printId]);
  const renderChart = (variant, rootRef) => <div ref={rootRef} className={`cockpit-checklist${variant === "fullscreen" ? " fullscreen" : ""}`}>
      <div className="cockpit-checklist-header">
        {title && <span className="cockpit-checklist-title">{title}</span>}
        <div className="cockpit-checklist-meta">
          <span className="cockpit-checklist-count">
            {doneCount}/{totalCount}
          </span>
          {doneCount > 0 && <button type="button" className="cockpit-checklist-btn" onClick={reset}>
              Reset
            </button>}
          <button type="button" className="cockpit-checklist-btn" onClick={printChecklist}>
            Print
          </button>
          {variant === "fullscreen" ? <button type="button" className="cockpit-checklist-btn" onClick={closeFullscreen} aria-label="Exit fullscreen">
              Close ✕
            </button> : <button type="button" className="cockpit-checklist-btn" onClick={openFullscreen} aria-label="Open fullscreen">
              Fullscreen ⤢
            </button>}
        </div>
      </div>

      <div className="cockpit-checklist-scroll">
        <div className="cockpit-checklist-grid">
          {sections.map((section, si) => <div key={si} className="cockpit-section">
              <div className="cockpit-section-header">
                <span className="cockpit-section-title">{section.title}</span>
                {section.subtitle && <span className="cockpit-section-subtitle">
                    {section.subtitle}
                  </span>}
              </div>
              <div className="cockpit-section-items">
                {(section.items || []).map((item, ii) => {
    const key = `${si}-${ii}`;
    const isChecked = !!checked[key];
    return <button key={key} type="button" className={`cockpit-item${isChecked ? " checked" : ""}${item.strong ? " strong" : ""}`} onClick={() => toggle(key)}>
                      <span className="cockpit-item-label">{item.label}</span>
                      <span className="cockpit-item-leader" aria-hidden="true" />
                      <span className="cockpit-item-value">{item.value}</span>
                    </button>;
  })}
              </div>
            </div>)}
        </div>
      </div>
    </div>;
  const renderPrintLayout = () => <div id={printId} className="cockpit-print-root" data-print-active="false" aria-hidden="true">
      <article className="cockpit-print-sheet">
        <header className="cockpit-print-header">
          <img className="cockpit-print-logo" src={printLogoSrc} alt="vACA" />
          <div className="cockpit-print-heading">
            {title && <h1>{title}</h1>}
            {printNotice && <div className="cockpit-print-notice">{printNotice}</div>}
          </div>
        </header>

        <div className="cockpit-print-grid">
          {sections.map((section, si) => <section key={si} className="cockpit-print-section">
              <div className="cockpit-print-section-header">
                <span className="cockpit-print-section-title">
                  {section.title}
                </span>
                {section.subtitle && <span className="cockpit-print-section-subtitle">
                    {section.subtitle}
                  </span>}
              </div>
              <div className="cockpit-print-section-items">
                {(section.items || []).map((item, ii) => <div key={`${si}-${ii}`} className={`cockpit-print-item${item.strong ? " strong" : ""}`}>
                    <span className="cockpit-print-item-label">
                      {item.label}
                    </span>
                    <span className="cockpit-print-item-leader" aria-hidden="true" />
                    <span className="cockpit-print-item-value">
                      {item.value}
                    </span>
                  </div>)}
              </div>
            </section>)}
        </div>
      </article>
    </div>;
  return <>
      {renderChart("inline")}
      {renderPrintLayout()}
      <div id={backdropId} className="cockpit-fullscreen-backdrop" data-open={isFullscreen ? "true" : "false"} onClick={e => {
    if (e.target === e.currentTarget) closeFullscreen();
  }}>
        {isFullscreen && renderChart("fullscreen", fullscreenRootRef)}
      </div>
    </>;
};

<div className="cover-image-frame">
  <Frame caption="Source de l'image : Air Canada">
    <img src="https://mintcdn.com/virtualaircanada/iQJB1gDJzxYoDw5J/images/aops/fleet/dh4.png?fit=max&auto=format&n=iQJB1gDJzxYoDw5J&q=85&s=a7e34a8fab9e8a4c1ab5b27d246b0042" alt="De Havilland Dash 8-400" noZoom className="cover-image" width="800" height="460" data-path="images/aops/fleet/dh4.png" />
  </Frame>
</div>

# De Havilland Dash 8‑400 (Q400)

**Liste de vérification complète normale et anormale ASOP**

<Info>Pour la simulation de vol uniquement - PAS pour un usage aéronautique réel.</Info>

**Version 1.1 - 23 mai 2026**

***

## Légende

* **PF** - Pilot Flying  **PM** - Pilot Monitoring
* *Italique* - Annonces  **Gras** - Élément de mémoire/déclencheur
* (A) - Annonce/alerte automatique  (M) - Manoeuvre

***

## Listes de vérification des opérations normales

<CockpitChecklist
  title="Q400 Opérations normales"
  sections={[
{
  title: "Mise sous tension et acceptation",
  items: [
    { label: "Freins de parc", value: "SET", strong: true },
    { label: "Battery Master", value: "ON (VÉRIFIER >=24 V)" },
    { label: "External Power", value: "ON (SI AVAIL)" },
    { label: "APU", value: "START - ON BUS" },
    { label: "Avionics Master", value: "ON" },
    { label: "IRS", value: "NAV", strong: true },
    { label: "Oxygène", value: "TESTED, 100%" },
    { label: "Goupilles / caches de train", value: "REMOVED ET STOWED" },
  ],
},
{
  title: "Préparation préliminaire du poste",
  items: [
    { label: "CVR", value: "TEST", strong: true },
    { label: "Emergency Exit Lights", value: "ARMED", strong: true },
    { label: "CAS Messages", value: "CHECKED (AUCUN RED/AMBER)", strong: true },
    { label: "ELT", value: "ARMED", strong: true },
    { label: "Extincteurs", value: "CHECKED" },
  ],
},
{
  title: "Préparation du poste",
  subtitle: "Flows",
  items: [
    { label: "Overhead (W-pattern) - Forward Panel - Pedestal", value: "FLOW COMPLET", strong: true },
    { label: "Fuel Boost Pumps", value: "ON (VÉRIFIER QTÉ)" },
    { label: "Hydraulic Pumps (#1 et #2)", value: "ON" },
    { label: "Bleed Air", value: "AUTO" },
    { label: "Pressurization", value: "AUTO" },
    { label: "Window / Pitot Heat", value: "OFF (JUSQU'AU DÉMARRAGE MOTEUR)" },
    { label: "FMS Preflight", value: "COMPLETE" },
    { label: "Radios / NAVAIDs", value: "SET" },
  ],
},
{
  title: "Préparation du poste",
  subtitle: "Liste (PM)",
  items: [
    { label: "Liste préparation du poste", value: "PM INITIE" },
    { label: "Goupilles et caches de train", value: "REMOVED" },
    { label: "IRS", value: "ALIGNED" },
    { label: "Qté carburant", value: "___ KG, ÉQUILIBRÉE" },
    { label: "Briefing décollage", value: "COMPLÉTÉ" },
    { label: "Liste", value: "COMPLÈTE" },
  ],
},
{
  title: "Avant démarrage",
  items: [
    { label: "Flight Deck Door", value: "CLOSED ET LOCKED" },
    { label: "Carburant", value: "___ KGS, PUMPS ON" },
    { label: "Passenger Signs", value: "ON" },
    { label: "Condition Levers", value: "START ET FEATHER" },
    { label: "Power Levers", value: "DISC" },
    { label: "Feu anticollision", value: "ON" },
    { label: "Freins de parc", value: "SET" },
  ],
},
{
  title: "Démarrage moteur",
  subtitle: "PW150A - FADEC",
  items: [
    { label: "Condition Lever (Eng 1)", value: "START ET FEATHER" },
    { label: "Start Button", value: "PUSH" },
    { label: "Surveillance", value: "NG EN ROTATION CROISSANTE" },
    { label: "À ~52% Ng", value: "CONDITION LEVER - FLIGHT IDLE (INTRODUCTION CARBURANT)" },
    { label: "Surveillance", value: "MONTÉE ITT <10 S, OIL PRESSURE EN HAUSSE" },
    { label: "FADEC Auto-Cutout", value: "~63% NG - STARTER DISENGAGES" },
    { label: "Moteur 2", value: "RÉPÉTER LA PROCÉDURE" },
    { label: "Les deux stables", value: "CONDITION LEVERS - MAX (1020 RPM)" },
  ],
},
{
  title: "Après démarrage",
  subtitle: "Flows",
  items: [
    { label: "APU", value: "OFF (SI NON REQUIS)" },
    { label: "Generators", value: "ON" },
    { label: "Pitot / Stall Heat", value: "ON" },
    { label: "Antigivrage", value: "AS REQD" },
    { label: "Commandes de vol", value: "CHECKED (PLEINE COURSE)" },
    { label: "Volets", value: "T/O CONFIG (5° OU 15°)" },
    { label: "Stabilizer Trim", value: "___ UNITS" },
    { label: "NWS", value: "ON" },
    { label: "Bleeds", value: "NORM" },
  ],
},
{
  title: "Après démarrage",
  subtitle: "Liste (PM)",
  items: [
    { label: "Liste après démarrage", value: "PM INITIE" },
    { label: "Antigivrage", value: "____" },
    { label: "Trim de direction et ailerons", value: "ZÉRO" },
    { label: "Volets", value: "__ / ____" },
    { label: "Stabilizer Trim", value: "__ UNITS" },
    { label: "Recall", value: "CHECKED" },
    { label: "Autobrake", value: "RTO" },
  ],
},
{
  title: "Roulage",
  items: [
    { label: "Condition Levers", value: "MAX (1020 RPM)" },
    { label: "Vitesse de roulage en ligne droite", value: "<= 25 KT" },
    { label: "Virages", value: "<= 10 KT" },
    { label: "Nosewheel Steering", value: "TILLER / RUDDER PEDALS" },
  ],
},
{
  title: "Avant décollage",
  subtitle: "Au-dessus de la ligne",
  items: [
    { label: "Autofeather", value: "ARMED (GREEN LIGHT)" },
    { label: "Commandes de vol", value: "CHECKED" },
    { label: "V-Speeds", value: "ANNONCÉES (V1 / VR / V2)" },
    { label: "Volets", value: "RÉGLAGE CONFIRMÉ, GREEN LIGHT" },
    { label: "Stabilizer Trim", value: "___ UNITS" },
    { label: "Cabine", value: "SECURE" },
  ],
},
{
  title: "Avant décollage",
  subtitle: "Sous la ligne",
  items: [
    { label: "TCAS", value: "TA/RA" },
    { label: "Strobes", value: "ON" },
    { label: "Landing Lights", value: "ON" },
    { label: "Transponder", value: "TA/RA" },
    { label: "Annonce de fin", value: "CABINE PRÊTE, SOUS LA LIGNE COMPLÈTE" },
  ],
},
{
  title: "Course au décollage et montée initiale",
  subtitle: "Annonces de mémoire",
  items: [
    { label: "PM \"80 Knots\"", value: "PF \"CHECKED\"" },
    { label: "PM \"V1\"", value: "-" },
    { label: "PM \"Rotate\"", value: "PF ROTATION VERS ~10° D'ASSIETTE" },
    { label: "PM \"Positive Climb\"", value: "PF \"GEAR UP\"" },
  ],
},
{
  title: "Après décollage / Montée",
  items: [
    { label: "Altitude d'accélération atteinte", value: "CLIMB POWER", strong: true },
    { label: "Rentrée des volets", value: "SELON LE PROGRAMME (SPEED BUGS)" },
    { label: "Condition Levers", value: "900 RPM (CLIMB)" },
    { label: "Autofeather", value: "OFF (AU-DESSUS DE 400 FT AGL)" },
    { label: "Bleeds", value: "NORM" },
    { label: "10 000 FT", value: "\"10 000 - LIGHTS OFF\"" },
    { label: "STD QNH", value: "RÉGLÉS LES DEUX (AU-DESSUS DE L'ALTITUDE DE TRANSITION)" },
  ],
},
{
  title: "Croisière (toutes les heures)",
  items: [
    { label: "Condition Levers", value: "850 RPM (CRUISE)" },
    { label: "Vérification carburant", value: "FOB VS PLAN (±300 KG)" },
    { label: "Systèmes", value: "CAS VERT" },
    { label: "Séquence de waypoints", value: "NEXT ET ETA À COMPARER" },
  ],
},
{
  title: "Préparation de la descente",
  items: [
    { label: "ATIS / STAR", value: "RECEIVED ET INSERTED" },
    { label: "Briefing d'approche", value: "COMPLÉTÉ" },
    { label: "Données d'atterrissage", value: "VREF ___, MINIMUMS ___" },
    { label: "Pressurisation", value: "LAND ALT ___" },
    { label: "GPWS Flap Override", value: "AS REQD" },
    { label: "Recall", value: "CHECKED" },
  ],
},
{
  title: "Approche",
  items: [
    { label: "Altimètres", value: "SET (QNH)" },
    { label: "Minimums", value: "__ FT" },
    { label: "Condition Levers", value: "MAX (1020 RPM)" },
    { label: "Gear", value: "DOWN (SOUS 200 KIAS)" },
    { label: "Flaps 15", value: "SET (SOUS 172 KIAS)" },
    { label: "Flaps 35", value: "SET (SOUS 158 KIAS)" },
    { label: "Briefing d'approche", value: "CONFIRMÉ" },
    { label: "Ceintures", value: "ON" },
  ],
},
{
  title: "Atterrissage",
  items: [
    { label: "1 000 FT", value: "STABLE/UNSTABLE - GEAR DOWN, FLAPS 35" },
    { label: "500 FT", value: "\"LANDING\" - SCAN FINAL" },
    { label: "50/40/30/20/10 FT", value: "(A) - ARRONDI" },
  ],
},
{
  title: "Après atterrissage",
  items: [
    { label: "Power Levers", value: "DISC" },
    { label: "Volets", value: "UP" },
    { label: "Autofeather", value: "OFF" },
    { label: "Pitot / Stall Heat", value: "AS REQD" },
    { label: "APU", value: "START (SI REQUIS)" },
    { label: "Strobes", value: "OFF" },
    { label: "Transponder", value: "STBY" },
    { label: "Weather Radar", value: "OFF" },
    { label: "Annonce de fin", value: "LISTE APRÈS ATTERRISSAGE COMPLÈTE" },
  ],
},
{
  title: "Arrêt des moteurs",
  items: [
    { label: "Freins de parc", value: "SET" },
    { label: "Condition Levers", value: "START ET FEATHER (REFROIDIR 30 S)" },
    { label: "Condition Levers", value: "FUEL OFF" },
    { label: "NWS", value: "OFF" },
    { label: "Passenger Signs", value: "OFF" },
    { label: "Feu anticollision", value: "OFF" },
    { label: "Fuel Boost Pumps", value: "OFF" },
  ],
},
{
  title: "Sécurisation de l'aéronef",
  items: [
    { label: "IRS", value: "OFF" },
    { label: "Emergency Exit Lights", value: "OFF" },
    { label: "Window Heat", value: "OFF" },
    { label: "Avionics Master", value: "OFF" },
    { label: "Battery Master", value: "OFF" },
    { label: "Rapport après-vol", value: "ENVOYÉ", strong: true },
  ],
},
]}
/>

### Mises en garde et notes

<Warning>
  **Démarrage interrompu** - Condition Lever FUEL OFF immédiatement. Limite ITT au démarrage 920 °C pour max 20 s. Minimum 30 s entre les tentatives de démarrage.
</Warning>

<Note>
  **Roulage** - Vérification des freins au premier mouvement : *"Brakes checked, pressure \_\_\_"*.
</Note>

<Note>
  **Atterrissage** - Toucher des roues : Power Levers DISC - GROUND RANGE - Reverse. Ralenti inversé à 60 kt.
</Note>

***

## Éléments anormaux / de mémoire (extrait)

### FEU MOTEUR ou DOMMAGE GRAVE (en vol)

| Étape | Action                                                |
| ----- | ----------------------------------------------------- |
| 1     | **Power Lever (affected)** -> FLIGHT IDLE             |
| 2     | **Condition Lever (affected)** -> CONFIRM -> FUEL OFF |
| 3     | **Alternate Feather** -> PUSH (si Np ne diminue pas)  |
| 4     | **Fuel Firewall Shutoff** -> CLOSED                   |
| 5     | **Engine Fire Handle** -> CONFIRM -> PULL             |
| 6     | **Extinguisher FWD** -> PUSH, attendre 30 s           |
| 7     | Si feu persiste -> **Extinguisher AFT** -> PUSH       |

### SURVITESSE HÉLICE

| Élément                        | Action                        |
| ------------------------------ | ----------------------------- |
| **Power Lever (affected)**     | FLIGHT IDLE                   |
| **Condition Lever (affected)** | START ET FEATHER              |
| Si Np ne diminue pas           | **Alternate Feather** -> PUSH |
| Surveillance                   | Décroissance Np vers feather  |

### DESCENTE D'URGENCE

| Élément              | Action                                                     |
| -------------------- | ---------------------------------------------------------- |
| **Annonce**          | *"EMERGENCY DESCENT"* (×3)                                 |
| SIGNS                | ON                                                         |
| Masques oxygène      | ON                                                         |
| **Condition Levers** | MAX (1020 RPM)                                             |
| **Power Levers**     | FLIGHT IDLE                                                |
| **Vitesse cible**    | VMO (dépendante de l'altitude, max \~286 KIAS à 18 000 ft) |
| Descendre            | Altitude de sécurité minimale ou 10 000 ft                 |

*(Consultez le QRH pour la procédure complète.)*

***

## Programme rapide des volets (Dash 8‑400)

| Config   | Limite affichée        |
| -------- | ---------------------- |
| Flaps 0  | 245 KIAS (SL-8 000 ft) |
| Flaps 5  | 200 KIAS               |
| Flaps 10 | 181 KIAS               |
| Flaps 15 | 172 KIAS               |
| Flaps 35 | 158 KIAS               |

## Réglages RPM hélice

| Phase                      | Np (RPM)   |
| -------------------------- | ---------- |
| Décollage / Remise des gaz | 1020 (MAX) |
| Montée                     | 900        |
| Croisière                  | 850        |

## Vitesses typiques (\~56 000 lb / Flaps 15)

| Vitesse | KIAS  |
| ------- | ----- |
| V1      | \~108 |
| VR      | \~112 |
| V2      | \~118 |
| VREF    | \~116 |

## Limites du train

| Limite                     | Vitesse  |
| -------------------------- | -------- |
| VLO (extension/rétraction) | 200 KIAS |
| VLE (sorti)                | 215 KIAS |

***

### Historique des révisions

| Rév | Date         | Note                                                                                                                                                 | Auteur    |
| --- | ------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------- | --------- |
| 1.0 | 28 mars 2026 | Publication initiale de la liste                                                                                                                     | ACVA Team |
| 1.1 | 23 mai 2026  | Passe d'exactitude : limite ITT au démarrage PW150A corrigée (920 °C / 20 s), VMO de descente d'urgence clarifiée comme étant par paliers d'altitude | ACVA Team |

***

<Note>
  ### Avis de non-responsabilité

  Ces listes de vérification sont des **adaptations abrégées** des procédures du domaine public De Havilland / Bombardier pour la simulation. Elles ne reproduisent pas le texte propriétaire du FCOM et ne doivent **pas** être utilisées pour des opérations commerciales.
</Note>
