liquiddesign

Wzorzec 15

Dymek przy swojej kotwicy

Dropdowny i tooltipy budowane na bibliotekach liczą pozycję skryptem, spóźniają się o klatkę i gubią przy scrollu. Atrybut popover otwiera warstwę nad wszystkim z wbudowanym zamykaniem, a anchor positioning przykleja ją do elementu wyzwalającego czystym CSS, razem z planem awaryjnym przy krawędzi ekranu.

Menu i podpowiedź bez biblioteki pozycjonującej

Otwórz oba dymki, przewiń stronę i klikaj obok. Warstwę, zamykanie i pozycję daje przeglądarka: popover otwiera top layer, anchor positioning trzyma dymek przy przycisku.

Atlas Rebranding

Status projektu liczy się z ostatniej aktywności w repozytorium i w pliku Figmy. Aktualizuje się co godzinę.

Reguły

  • Dymek to atrybut popover z popovertarget, nie div z z-index i globalnym nasłuchem kliknięć.
  • Pozycję zadaje position-anchor z position-area, nie JavaScript przeliczający getBoundingClientRect.
  • position-try-fallbacks odwraca dymek przy krawędzi viewportu, zanim zdąży się przyciąć.
  • Top layer nie uczestniczy w layoucie strony, więc otwarcie niczego nie przesuwa.

Wzorzec w kodzie

Popover otwiera top layer, zamykanie i Escape daje przeglądarka
<button popovertarget="menu-akcji" className="kotwica">
  Akcje ⌄
</button>

<div id="menu-akcji" popover="auto" className="menu">
  <button>Duplikuj projekt</button>
  <button>Archiwizuj</button>
</div>
Kotwica w CSS zamiast getBoundingClientRect w skrypcie
.kotwica { anchor-name: --akcje; }

.menu {
  position-anchor: --akcje;
  position-area: block-end span-inline-start;
  position-try-fallbacks: flip-block, flip-inline;
  inset: auto;
  margin: 0.5rem 0;
}