[HN Gopher] SVG favicons have some cool benefits
       ___________________________________________________________________
        
       SVG favicons have some cool benefits
        
       Author : feross
       Score  : 107 points
       Date   : 2021-07-07 16:32 UTC (6 hours ago)
        
 (HTM) web link (austingil.com)
 (TXT) w3m dump (austingil.com)
        
       | lokl wrote:
       | Related: If you're looking for a favicon generator, check out
       | https://realfavicongenerator.net (I am not affiliated, just a
       | satisfied user).
        
       | unilynx wrote:
       | I wonder if the Gmail people could use this to give their app a
       | non-blurry Favicon. It looks really poor when task switching
       | between apps
        
       | legulere wrote:
       | I find the most interesting part how < and especially " don't
       | need to be escaped inside the href attribute. How does the HTML
       | parser know when the attribute stops?
        
         | svieira wrote:
         | I don't think it's actually valid - the examples just aren't
         | base64-encoding in order to make it possible to read them
         | easily.
         | 
         | Edit: Yeah, you at least need to change the `"` to `'` in the
         | inline SVG before it will parse correctly (tested in Firefox)
        
       | chrismorgan wrote:
       | People keep on talking about (prefers-color-scheme: dark), but it
       | isn't what they want it to be--never has been, and probably never
       | will be (though I will admit that prefers-color-scheme _could_
       | theoretically be special-cased for favicon rendering).
       | 
       | For example, in Firefox, I use the dark theme for the UI, but
       | that's completely unrelated to the content, and prefers-color-
       | scheme matches the content, not the chrome. Content I keep
       | normal, light.
       | 
       | It's quite possible (not uncommon, even) for the active tab to
       | have a light background and inactive tabs to have a darker
       | background. (A decade ago, this is what would happen by default
       | on the default Windows XP theme, though it was the XP blue rather
       | than anything _dark_ dark.)
       | 
       | Or Chromium: like Firefox, it has themes; but beyond that,
       | incognito window chrome gets a dark background.
       | 
       | Admittedly, (prefers-color-scheme: dark) matching makes it almost
       | certain that you're rendering against a dark background of some
       | form, but it _not_ matching tells you absolutely nothing about
       | the background.
       | 
       | The fact of the matter is that your favicon could be rendered
       | against absolutely any colour, and you need to make sure your
       | icon will work on very light colours and very dark colours, and
       | not be _too_ bad on anything in between.
        
         | krono wrote:
         | Yes GitHub does it too. The icon can't update itself so it's
         | stuck on the color it was when you last visited the site.
         | 
         | Example: https://i.imgur.com/PTPJ3Fm.png
        
         | mjsir911 wrote:
         | > For example, in Firefox, I use the dark theme for the UI, but
         | that's completely unrelated to the content, and prefers-color-
         | scheme matches the content, not the chrome. Content I keep
         | normal, light.
         | 
         | Of note is https://bugzilla.mozilla.org/show_bug.cgi?id=1529323
         | which is requesting to change this behaviour to align prefers-
         | color-scheme to the UI theme if there is no overriding
         | behaviour.
         | 
         | I prefer this because now rather than setting dark mode to each
         | site I go to, they can be signalled this already. There's no
         | user friendly way to set firefox's prefer-color-scheme: dark if
         | the OS does not have the capabilities to do that.
        
           | chrismorgan wrote:
           | Yeah, I've been waiting for that to inevitably happen so that
           | I can revert it. Speaking overly broadly, dark mode
           | everything is normally an at-least-slightly bad idea, but
           | there's good cause for aesthetic (low-contrast) dark mode of
           | chrome in order to get it mostly out of the way, so that you
           | can focus on the content. This is essentially what most
           | graphics programs default to nowadays, and the same reasoning
           | can be applied to browsers. (Though it only really works if
           | your windows are maximised, otherwise dark between two lights
           | could become a distraction.) No one says "you have a dark
           | desktop background, you must want everything on your system
           | to be dark". Comment 47's "When using the "Dark" theme,
           | "prefers-color-scheme" should be dark, because that's what
           | the user requested." is simply not right. Choosing a dark
           | browser theme is honestly quite a weak hint about whether you
           | want _content_ to be dark. The conflation of this that recent
           | forays into OS-wide dark modes has encouraged is not good.
        
       | dlbucci wrote:
       | I agree they are great, especially for simple icons that work as
       | SVG. Support for SVG favicons, however, keeps me from using them:
       | https://caniuse.com/link-icon-svg
        
         | clone1018 wrote:
         | When you look at it compared to actual browser usage, you end
         | up with 89.62% support, which is not bad at all. WebP & CSS
         | Grid are at about 95%.
        
         | chrismorgan wrote:
         | Oh wow, Safari _still_ doesn't do regular SVG favicons? Huh.
         | Somehow I thought that got sorted out a couple of years back in
         | 12 or something.
        
       | makeworld wrote:
       | No need to use SVGs for an emoji favicon. Just put the emoji and
       | a space at the beginning of your <title>.
        
       | MattIPv4 wrote:
       | Was wondering if you could use this to run a version of your site
       | in the favicon directly using `foreignObject`, but it looks like
       | Chromium browsers at least render the SVGs in static mode [1][2].
       | Maybe it'll work in others though?
       | 
       | [1] https://www.chromestatus.com/feature/5180316371124224
       | 
       | [2] https://svgwg.org/svg2-draft/conform.html#secure-static-mode
        
         | chrismorgan wrote:
         | Secure static mode doesn't block foreignObject. Script
         | execution, external references, declarative animation and
         | interactivity, but not foreign content. Indeed, such processing
         | modes are propagated to such foreign content:
         | https://svgwg.org/svg2-draft/conform.html#referencing-modes.
         | 
         | See https://news.ycombinator.com/item?id=26922244#26923436 for
         | an example. It works in Chromium.
        
       | dmit wrote:
       | _Awkward ad intermission_
       | 
       | Tired of all the "404 Not Found: /favicon.ico" log messages from
       | your local test server? Fret no more! Just add this minor
       | incantation to your HTML and you're set!                 <link
       | rel="icon" href="data:," />
        
         | soheil wrote:
         | why not just                 touch favicon.ico
         | 
         | so it gets cached and forget about it?
        
         | blacksmith_tb wrote:
         | Seems like the author is ahead of you, inlining the svg in your
         | head tag should fix that too?
        
         | teddyh wrote:
         | I prefer this:                   <link rel="icon"
         | href="
         | gAAACAAAAAgCAMAAABEpIrGAAAAG1BMVEU5PT85PT///7X22GDtiUvVOkKxOF5q
         | Mk////9bF0DJAAAAAXRSTlMAQObYZgAAAD5JREFUeNq906UBwEAUwNBy95+4cOA
         | +09OxWSKsCE2wAQKCRhrsiMrgQFQGJ6IyuBCVwQ1YG1+wTHgQdpbTC3XuCmFsTK
         | U6AAAAAElFTkSuQmCC>
        
           | soheil wrote:
           | There won't be any overhead once the file is cached. Your
           | method requires the favicon to keep getting downloaded on
           | every page load.
        
         | TheRealPomax wrote:
         | 2: Why? Are there even any systems left on the planet that
         | aren't past EOL but don't have emoji fonts preinstalled at the
         | OS level?
        
           | reaperducer wrote:
           | Maybe because you can't guarantee that even if an OS has
           | emoji support that it supports the latest version of emojis.
           | 
           | I run into this every time my wife updates her phone. She
           | sends me text messages with "Lookit the cool new emojis!" But
           | since I haven't updated mine, they came through as missing
           | icon glyphs.
        
           | shadowfaxRodeo wrote:
           | I think google renders them in a raster format. Whatever they
           | use to do that doesn't support emojis.
           | 
           | It could be by design, by rendering any text in the svg icon
           | google is making a design decision for you. They're choosing
           | a font, or a specific emoji type. Maybe they want to avoid
           | the problems that would ensue.
        
       ___________________________________________________________________
       (page generated 2021-07-07 23:01 UTC)