(I managed to note down 3️⃣9️⃣ of them 😱)
🧵 Here is a thread of what were shared in the podcast 👇👇👇
🌎 meta information, eg: language, history of navigator
☑️ state of the element, eg: checked, active, disabled
✨Pseudo-classes are great for implementing micro-interactivity
😌 unvisited links
🔗 <a>, <area>, <link> with href attribute
2️⃣ :visited
😳 visited links
🔐 limited styles that can be applied due to security reasons
👀 @Una's workaround una.im/hacking-visite…
3️⃣ :hover
4️⃣ :active
📝 different states when interacting with links
data:image/s3,"s3://crabby-images/36c2f/36c2f47f973addcb71b880f49a96f1e73866beab" alt=""
📝 targets element when it is in focus
6️⃣ :focus-within
📝 targets element when it or its children are in focus
📕 web.dev/next-gen-css-2…
✨ useful when showing elements when on focus to maintain visible when focus into the child elements
data:image/s3,"s3://crabby-images/6f9b2/6f9b270499831352169ed147bbc708ef618af8af" alt=""
data:image/s3,"s3://crabby-images/d7ceb/d7ceb5708a443b9e018ef22cdf1e079f456cf221" alt=""
🧪 experimental
👨🔬 allow responsibly removal of focus ring
🙈 instead of :focus { outline: none; }
📕 github.com/WICG/focus-vis…
data:image/s3,"s3://crabby-images/4036b/4036b29d32180189b1a0f3983b262b98c3f082dd" alt=""
1️⃣3️⃣ :disabled
😀 anything not disabled is enabled
👀 enabled is something that can be activated, clicked, tab-ed into, selecteded, typed within, or accepted focus
1️⃣5️⃣ :indeterminate
🎯 input[type="checkbox"]
🎯 input[type="radio"]
🎯 select > option
📕 CSS games with checkbox una.im/css-games/
data:image/s3,"s3://crabby-images/0e02d/0e02dab083136540ae3db825bfd70cfc9fd62490" alt=""
data:image/s3,"s3://crabby-images/614d4/614d42b4dd53de941183105a343abdb72c235366" alt=""
🎯 Matches element in full screen mode
😢 Safari uses `-webkit-full-screen` (👀 note the extra dash '-')
🎯 selects any node that has 0 children
⚠️ text node or whitespace is considered children
⚠️ frameworks may insert empty text node unknowingly
📕 show fallback content when node is empty codepen.io/una/pen/BaBrePg
📕 hide buttons that are empty
data:image/s3,"s3://crabby-images/69fa8/69fa8f24999811918ddb443312aac20183813647" alt=""
data:image/s3,"s3://crabby-images/0556f/0556f2b2c492599617ab90afd1e62675582bba20" alt=""
2️⃣1️⃣ :required
😀 anything not required is optional
🎯 :required selects <input>, <select>, <textarea> with required attribute
📜 CSS draft
🎯 selects <input>, <textarea> that is empty
🗣 Discussion on the name: github.com/w3c/csswg-draf…