#!/bin/sh set -eu main() { cd src/browser/media # We need .ico for backwards compatibility. # The other two are the only icon sizes required by Chrome and # we use them for stuff like apple-touch-icon as well. # https://web.dev/add-manifest/ # # This should be enough and we can always add more if there are problems. # -background defaults to white but we want it transparent. # https://imagemagick.org/script/command-line-options.php#background convert -quiet -background transparent -resize 256x256 favicon.svg favicon.ico # We do not generate the pwa-icon from the favicon as they are slightly different # designs and sizes. # See favicon.afdesign and #2401 for details on the differences. convert -quiet -background transparent -resize 192x192 pwa-icon.png pwa-icon-192.png convert -quiet -background transparent -resize 512x512 pwa-icon.png pwa-icon-512.png # We use -quiet above to avoid https://github.com/ImageMagick/ImageMagick/issues/884 # The following adds dark mode support for the favicon as favicon-dark-support.svg # There is no similar capability for pwas or .ico so we can only add support to the svg. favicon_dark_style="<style> @media (prefers-color-scheme: dark) { * { fill: white; } } </style>" # See https://stackoverflow.com/a/22901380/4283659 # This escapes all newlines so that sed will accept them. favicon_dark_style="$(printf "%s\n" "$favicon_dark_style" | sed -e ':a' -e 'N' -e '$!ba' -e 's/\n/\\n/g')" sed "$( cat -n << EOF s%<rect id="favicon"%$favicon_dark_style<rect id="favicon"% EOF )" favicon.svg > favicon-dark-support.svg } main "$@"