diff --git a/package.json b/package.json index 0444edd35..e4e9428c5 100644 --- a/package.json +++ b/package.json @@ -20,6 +20,8 @@ "cssrecipes-grid": "^1.0.0", "cssrecipes-reset": "^0.5.0", "cssrecipes-utils": "^0.6.2", + "fontfaceobserver": "^2.1.0", + "handlebars": "^4.1.0", "suitcss-utils-align": "^1.0.0", "suitcss-utils-display": "^1.0.2", "yargs": "^12.0.2" diff --git a/webcompat/static/css/src/typo.css b/webcompat/static/css/src/typo.css index a174bde2a..46e6493e0 100644 --- a/webcompat/static/css/src/typo.css +++ b/webcompat/static/css/src/typo.css @@ -73,3 +73,11 @@ blockquote { margin-right: 0; padding-left: 1em; } + +.font-mobile body { + font-family: Verdana, sans-serif !important; +} + +.fonts-loaded body { + font-family: "Open Sans", Helvetica, Arial, sans-serif !important; +} diff --git a/webcompat/static/js/lib/fonts.js b/webcompat/static/js/lib/fonts.js new file mode 100644 index 000000000..1e501ebda --- /dev/null +++ b/webcompat/static/js/lib/fonts.js @@ -0,0 +1,27 @@ +if (/Mobi/.test(navigator.userAgent)) { + document.documentElement.className += " font-mobile"; + var sourceSansPro300 = new FontFaceObserver("Source Sans Pro", { + weight: 300 + }); + + var sourceSansPro400 = new FontFaceObserver("Source Sans Pro", { + weight: 400 + }); + + var openSans400 = new FontFaceObserver("Open Sans", { + weight: 400 + }); + + var openSans600 = new FontFaceObserver("Open Sans", { + weight: 600 + }); + + Promise.all([ + sourceSansPro300.load(null, 20000), + sourceSansPro400.load(null, 20000), + openSans400.load(null, 20000), + openSans600.load(null, 20000) + ]).then(function() { + document.documentElement.className += " fonts-loaded"; + }); +} \ No newline at end of file diff --git a/webcompat/static/js/vendor/fontfaceobserver.js b/webcompat/static/js/vendor/fontfaceobserver.js new file mode 100644 index 000000000..8405a206a --- /dev/null +++ b/webcompat/static/js/vendor/fontfaceobserver.js @@ -0,0 +1,12 @@ +/* Font Face Observer v2.1.0 - © Bram Stein. License: BSD-3-Clause */(function(){'use strict';var f,g=[];function l(a){g.push(a);1==g.length&&f()}function m(){for(;g.length;)g[0](),g.shift()}f=function(){setTimeout(m)};function n(a){this.a=p;this.b=void 0;this.f=[];var b=this;try{a(function(a){q(b,a)},function(a){r(b,a)})}catch(c){r(b,c)}}var p=2;function t(a){return new n(function(b,c){c(a)})}function u(a){return new n(function(b){b(a)})}function q(a,b){if(a.a==p){if(b==a)throw new TypeError;var c=!1;try{var d=b&&b.then;if(null!=b&&"object"==typeof b&&"function"==typeof d){d.call(b,function(b){c||q(a,b);c=!0},function(b){c||r(a,b);c=!0});return}}catch(e){c||r(a,e);return}a.a=0;a.b=b;v(a)}} +function r(a,b){if(a.a==p){if(b==a)throw new TypeError;a.a=1;a.b=b;v(a)}}function v(a){l(function(){if(a.a!=p)for(;a.f.length;){var b=a.f.shift(),c=b[0],d=b[1],e=b[2],b=b[3];try{0==a.a?"function"==typeof c?e(c.call(void 0,a.b)):e(a.b):1==a.a&&("function"==typeof d?e(d.call(void 0,a.b)):b(a.b))}catch(h){b(h)}}})}n.prototype.g=function(a){return this.c(void 0,a)};n.prototype.c=function(a,b){var c=this;return new n(function(d,e){c.f.push([a,b,d,e]);v(c)})}; +function w(a){return new n(function(b,c){function d(c){return function(d){h[c]=d;e+=1;e==a.length&&b(h)}}var e=0,h=[];0==a.length&&b(h);for(var k=0;kparseInt(a[1],10)}else D=!1;return D}function J(){null===F&&(F=!!document.fonts);return F} +function K(){if(null===E){var a=document.createElement("div");try{a.style.font="condensed 100px sans-serif"}catch(b){}E=""!==a.style.font}return E}function L(a,b){return[a.style,a.weight,K()?a.stretch:"","100px",b].join(" ")} +B.prototype.load=function(a,b){var c=this,k=a||"BESbswy",r=0,n=b||3E3,H=(new Date).getTime();return new Promise(function(a,b){if(J()&&!G()){var M=new Promise(function(a,b){function e(){(new Date).getTime()-H>=n?b(Error(""+n+"ms timeout exceeded")):document.fonts.load(L(c,'"'+c.family+'"'),k).then(function(c){1<=c.length?a():setTimeout(e,25)},b)}e()}),N=new Promise(function(a,c){r=setTimeout(function(){c(Error(""+n+"ms timeout exceeded"))},n)});Promise.race([N,M]).then(function(){clearTimeout(r);a(c)}, +b)}else m(function(){function v(){var b;if(b=-1!=f&&-1!=g||-1!=f&&-1!=h||-1!=g&&-1!=h)(b=f!=g&&f!=h&&g!=h)||(null===C&&(b=/AppleWebKit\/([0-9]+)(?:\.([0-9]+))/.exec(window.navigator.userAgent),C=!!b&&(536>parseInt(b[1],10)||536===parseInt(b[1],10)&&11>=parseInt(b[2],10))),b=C&&(f==w&&g==w&&h==w||f==x&&g==x&&h==x||f==y&&g==y&&h==y)),b=!b;b&&(d.parentNode&&d.parentNode.removeChild(d),clearTimeout(r),a(c))}function I(){if((new Date).getTime()-H>=n)d.parentNode&&d.parentNode.removeChild(d),b(Error(""+ +n+"ms timeout exceeded"));else{var a=document.hidden;if(!0===a||void 0===a)f=e.a.offsetWidth,g=p.a.offsetWidth,h=q.a.offsetWidth,v();r=setTimeout(I,50)}}var e=new t(k),p=new t(k),q=new t(k),f=-1,g=-1,h=-1,w=-1,x=-1,y=-1,d=document.createElement("div");d.dir="ltr";u(e,L(c,"sans-serif"));u(p,L(c,"serif"));u(q,L(c,"monospace"));d.appendChild(e.a);d.appendChild(p.a);d.appendChild(q.a);document.body.appendChild(d);w=e.a.offsetWidth;x=p.a.offsetWidth;y=q.a.offsetWidth;I();A(e,function(a){f=a;v()});u(e, +L(c,'"'+c.family+'",sans-serif'));A(p,function(a){g=a;v()});u(p,L(c,'"'+c.family+'",serif'));A(q,function(a){h=a;v()});u(q,L(c,'"'+c.family+'",monospace'))})})};"object"===typeof module?module.exports=B:(window.FontFaceObserver=B,window.FontFaceObserver.prototype.load=B.prototype.load);}()); diff --git a/webcompat/templates/layout.html b/webcompat/templates/layout.html index 463ea4759..65763efd3 100644 --- a/webcompat/templates/layout.html +++ b/webcompat/templates/layout.html @@ -9,7 +9,7 @@ - + @@ -24,6 +24,8 @@ {% else %} + +