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
<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 { 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;
}