From ba54b16275e6a3d9c57a0ca4b9050bc5c71799db Mon Sep 17 00:00:00 2001 From: Bruno Windels Date: Wed, 29 May 2019 11:59:50 +0200 Subject: [PATCH] sniff safari 12, macos 10.14 to support COLR, as safari doesn't wait for the font to load to emit load --- src/utils/FontManager.js | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/src/utils/FontManager.js b/src/utils/FontManager.js index bf47bcd7d2..2d5f7c5dc0 100644 --- a/src/utils/FontManager.js +++ b/src/utils/FontManager.js @@ -21,6 +21,23 @@ limitations under the License. * MIT license */ +function safariVersionCheck(ua) { + const safariVersionMatch = ua.match(/Mac OS X ([\d|_]+).*Version\/([\d|\.]+) Safari/); + if (safariVersionMatch) { + const macOSVersionStr = safariVersionMatch[1]; + const safariVersionStr = safariVersionMatch[2]; + const macOSVersion = macOSVersionStr.split("_").map(n => parseInt(n, 10)); + const safariVersion = safariVersionStr.split(".").map(n => parseInt(n, 10)); + const colrFontSupported = macOSVersion[0] >= 10 && macOSVersion[1] >= 14 && safariVersion[0] >= 12; + // https://www.colorfonts.wtf/ states safari supports COLR fonts from this version on + console.log(`Browser is Safari - requiring macOS 10.14 and Safari 12,` + + `detected Safari ${safariVersionStr} on macOS ${macOSVersionStr},` + + `supported: ${colrFontSupported}`); + return colrFontSupported; + } + return false; +} + async function isColrFontSupported() { console.log("Checking for COLR support"); @@ -32,6 +49,12 @@ async function isColrFontSupported() { console.log("Browser is Firefox - assuming COLR is supported"); return true; } + // Safari doesn't wait for the font to load (if it doesn't have it in cache) + // to emit the load event on the image, so there is no way to not make the check + // reliable. Instead sniff the version. + if (navigator.userAgent.includes("Safari")) { + return safariVersionCheck(navigator.userAgent); + } try { const canvas = document.createElement('canvas');