1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2024-12-31 09:07:38 +01:00

typekit component

This commit is contained in:
Matthias Kretschmann 2018-05-23 21:47:54 +02:00
parent 2dff829335
commit 20491c075f
Signed by: m
GPG Key ID: 606EEEF3C479A91F
7 changed files with 52 additions and 12 deletions

View File

@ -23,6 +23,8 @@ availability:
gpg: https://kretschmann.io/pub.gpg
addressbook: /matthias-kretschmann.vcf
typekitID: dtg3zui
# Analytics tools
googleanalytics: UA-1441794-4
matomoUrl: https://analytics.kremalicious.com

View File

@ -2,9 +2,10 @@ import React, { Fragment } from 'react'
import PropTypes from 'prop-types'
import Helmet from 'react-helmet'
import SEO from './SEO'
import Typekit from './Typekit'
const Head = ({ meta }) => {
const { title, tagline } = meta
const { title, tagline, typekitID } = meta
return (
<Fragment>
@ -13,10 +14,10 @@ const Head = ({ meta }) => {
titleTemplate={`%s // ${title.toLowerCase()} { ${tagline.toLowerCase()} }`}
>
<meta name="apple-mobile-web-app-title" content={title.toLowerCase()} />
<link rel="dns-prefetch" href="https://use.typekit.net/" />
<link rel="dns-prefetch" href="https://p.typekit.net/" />
</Helmet>
{typekitID && <Typekit id={typekitID} />}
<SEO meta={meta} />
</Fragment>
)

View File

@ -0,0 +1,33 @@
import React from 'react'
import PropTypes from 'prop-types'
import Helmet from 'react-helmet'
const TypekitScript = props => (
<script>
{`
(function(d) {
var config = {
kitId: '${props.id}',
scriptTimeout: 3000,
async: true
},
h=d.documentElement,t=setTimeout(function(){h.className=h.className.replace(/\bwf-loading\b/g,"")+" wf-inactive";},config.scriptTimeout),tk=d.createElement("script"),f=false,s=d.getElementsByTagName("script")[0],a;h.className+=" wf-loading";tk.src='https://use.typekit.net/'+config.kitId+'.js';tk.async=true;tk.onload=tk.onreadystatechange=function(){a=this.readyState;if(f||a&&a!="complete"&&a!="loaded")return;f=true;clearTimeout(t);try{Typekit.load(config)}catch(e){}};s.parentNode.insertBefore(tk,s)
})(document);
`}
</script>
)
const Typekit = props => (
<Helmet>
<link rel="dns-prefetch" href="https://use.typekit.net/" />
<link rel="dns-prefetch" href="https://p.typekit.net/" />
{TypekitScript(props)}
</Helmet>
)
export default Typekit
TypekitScript.propTypes = {
id: PropTypes.string.isRequired
}

View File

@ -104,6 +104,7 @@ export const query = graphql`
}
gpg
addressbook
typekitID
}
# the package.json file

View File

@ -1,5 +1,4 @@
@import 'variables';
@import url('https://use.typekit.net/#{$typekit}.css');
*,
*::before,
@ -16,6 +15,11 @@ body {
html {
font-size: $font-size-root;
&.wf-loading,
&.wf-inactive {
font-size: $font-size-root - 2px;
}
}
body {

View File

@ -1,4 +1,3 @@
$typekit: 'dtg3zui';
$projectImageMaxWidth: 1200px;
$easing: cubic-bezier(.75, 0, .08, 1);