1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2025-01-20 17:29:54 +01:00

so much stuff

This commit is contained in:
Matthias Kretschmann 2018-04-21 02:03:45 +02:00
parent a7744ef8d0
commit c09f97b658
Signed by: m
GPG Key ID: 606EEEF3C479A91F
18 changed files with 144 additions and 56 deletions

View File

@ -10,6 +10,7 @@
"GitHub": "https://github.com/kremalicious", "GitHub": "https://github.com/kremalicious",
"Dribbble": "https://dribbble.com/kremalicious" "Dribbble": "https://dribbble.com/kremalicious"
}, },
"available": false, "availability": false,
"typekit": "dtg3zui",
"googleanalytics": "UA-1441794-4" "googleanalytics": "UA-1441794-4"
} }

View File

@ -1,8 +1,9 @@
const meta = require('./data/meta.json') const meta = require('./data/meta.json')
const { url, googleanalytics } = meta
module.exports = { module.exports = {
siteMetadata: { siteMetadata: {
siteUrl: `${meta.url}`, siteUrl: `${url}`,
}, },
plugins: [ plugins: [
'gatsby-plugin-react-next', 'gatsby-plugin-react-next',
@ -37,7 +38,7 @@ module.exports = {
{ {
resolve: 'gatsby-plugin-google-analytics', resolve: 'gatsby-plugin-google-analytics',
options: { options: {
trackingId: `${meta.googleanalytics}`, trackingId: `${googleanalytics}`,
head: false, head: false,
anonymize: true, anonymize: true,
respectDNT: true, respectDNT: true,

View File

@ -72,3 +72,13 @@ exports.createPages = ({ boundActionCreators, graphql }) => {
})) }))
}) })
} }
// https://github.com/gatsbyjs/gatsby/issues/2285#issuecomment-333343938
exports.modifyWebpackConfig = ({ config, stage }) => {
if (stage === 'build-html') {
config.loader('null', {
test: /webfontloader/,
loader: 'null-loader',
})
}
}

View File

@ -17,7 +17,8 @@
"gatsby-transformer-sharp": "^1.6.23", "gatsby-transformer-sharp": "^1.6.23",
"react-helmet": "^5.2.0", "react-helmet": "^5.2.0",
"react-markdown": "^3.3.0", "react-markdown": "^3.3.0",
"react-transition-group": "^2.3.1" "react-transition-group": "^2.3.1",
"webfontloader": "^1.6.28"
}, },
"devDependencies": { "devDependencies": {
"babel-eslint": "^8.2.3", "babel-eslint": "^8.2.3",

View File

@ -1,9 +1,12 @@
import React from 'react' import React from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import Helmet from 'react-helmet' import Helmet from 'react-helmet'
import WebFont from 'webfontloader'
const Head = ({ meta }) => { const Head = ({ meta }) => {
const { title, tagline, description } = meta const { title, tagline, description, url, typekit } = meta
WebFont.load({ typekit: { id: typekit } })
return ( return (
<Helmet <Helmet
@ -11,7 +14,9 @@ const Head = ({ meta }) => {
titleTemplate={`%s // ${title.toLowerCase()} { ${tagline.toLowerCase()} }`} titleTemplate={`%s // ${title.toLowerCase()} { ${tagline.toLowerCase()} }`}
> >
<meta name="description" content={description} /> <meta name="description" content={description} />
<link rel="stylesheet" href="https://use.typekit.net/dtg3zui.css" />
{window.location.protocol + '//' + window.location.hostname !==
`${url}` && <meta content="noindex,nofollow" name="robots" />}
</Helmet> </Helmet>
) )
} }

View File

@ -0,0 +1,33 @@
import React, { Fragment } from 'react'
import PropTypes from 'prop-types'
import FadeIn from '../atoms/FadeIn'
import './Availability.scss'
const Availability = ({ meta, hide }) => {
const { availability, social } = meta
const available = `👔 Available for new projects. <a href="${social.Email}">Lets talk</a>!`
const unavailable = 'Not available for new projects.'
return (
<Fragment>
{!hide && (
<FadeIn>
<aside className={availability ? 'availability available' : 'availability unavailable'}>
<p dangerouslySetInnerHTML={{
__html: availability ? available : unavailable
}}
/>
</aside>
</FadeIn>
)}
</Fragment>
)
}
Availability.propTypes = {
meta: PropTypes.object,
hide: PropTypes.bool,
}
export default Availability

View File

@ -0,0 +1,19 @@
@import 'variables';
.availability {
position: absolute;
bottom: 0;
background: rgba($brand-light, .8);
border-radius: .25rem;
color: $brand-grey-light;
z-index: 1;
padding: $spacer / 2;
p { margin-bottom: 0; }
&.available {
color: $brand-main;
position: fixed;
bottom: $spacer;
}
}

View File

@ -1,7 +1,6 @@
@import 'variables'; @import 'variables';
.footer { .footer {
margin-top: $spacer;
padding: $spacer * 2; padding: $spacer * 2;
text-align: center; text-align: center;
color: $brand-grey-light; color: $brand-grey-light;

View File

@ -1,9 +1,10 @@
import React, { Fragment } from 'react' import React from 'react'
import Link from 'gatsby-link' import Link from 'gatsby-link'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import FadeIn from '../atoms/FadeIn' import FadeIn from '../atoms/FadeIn'
import { Logo } from '../atoms/Icons' import { Logo } from '../atoms/Icons'
import Social from './Social' import Social from './Social'
import Availability from './Availability'
import './Header.scss' import './Header.scss'
const Header = ({ meta, isHomepage }) => { const Header = ({ meta, isHomepage }) => {
@ -12,18 +13,19 @@ const Header = ({ meta, isHomepage }) => {
return ( return (
<header className={classes}> <header className={classes}>
<FadeIn> <FadeIn>
<Fragment> <Link className="header__name" to={'/'}>
<Link className="header__name" to={'/'}> <Logo className="header__logo" />
<Logo className="header__logo" /> <h1 className="header__title">{meta.title.toLowerCase()}</h1>
<h1 className="header__title">{meta.title.toLowerCase()}</h1> <p className="header__description">
<p className="header__description"> <span>{'{ '}</span> {meta.tagline.toLowerCase()}{' '}
<span>{'{ '}</span> {meta.tagline.toLowerCase()}{' '} <span>{' }'}</span>
<span>{' }'}</span> </p>
</p> </Link>
</Link>
<Social meta={meta} minimal={!isHomepage} hide={!isHomepage} />
</Fragment>
</FadeIn> </FadeIn>
<Social meta={meta} minimal={!isHomepage} hide={!isHomepage} />
<Availability meta={meta} hide={!isHomepage} />
</header> </header>
) )
} }

View File

@ -1,12 +1,15 @@
@import 'variables'; @import 'variables';
.header { .header {
position: relative;
padding: $spacer; padding: $spacer;
min-height: calc(100vh - #{$spacer}); height: calc(100vh - #{$spacer});
max-height: 1000px;
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
align-content: center; align-content: center;
justify-content: center; justify-content: center;
text-align: center;
} }
.header__logo { .header__logo {
@ -41,15 +44,14 @@
} }
.header__name { .header__name {
height: 100%;
pointer-events: none; pointer-events: none;
} }
.header--minimal { .header--minimal {
min-height: 0; height: auto;
@media (min-width: 30rem) { @media (min-width: 30rem) {
margin-top: $spacer / 2; margin-top: $spacer;
margin-bottom: $spacer; margin-bottom: $spacer;
} }

View File

@ -28,9 +28,7 @@
width: 100%; width: 100%;
color: $brand-cyan; color: $brand-cyan;
text-align: center; text-align: center;
border-top-left-radius: .25rem; border-radius: .25rem;
border-top-right-radius: .25rem;
border-bottom: 1px solid $brand-cyan;
padding: $spacer / 4 $spacer / 2; padding: $spacer / 4 $spacer / 2;
transition-property: all; transition-property: all;
background: rgba(#fff, .15); background: rgba(#fff, .15);

View File

@ -63,7 +63,27 @@
height: 100%; height: 100%;
display: block; display: block;
align-self: center; align-self: center;
margin-top: -$spacer; margin-top: $spacer * 8;
transition: .2s ease-out;
@media (min-width: 45rem) {
margin-top: -$spacer;
}
.icon {
fill: $brand-grey-light;
width: 1.5rem;
height: 1.5rem;
}
&:hover,
&:focus {
transform: translate3d(0, -.3rem, 0);
.icon {
fill: $brand-cyan;
}
}
&:first-child { &:first-child {
margin-left: 48.5%; margin-left: 48.5%;
@ -72,10 +92,4 @@
&:last-child { &:last-child {
margin-right: auto; margin-right: auto;
} }
.icon {
fill: $brand-grey-light;
width: 1.5rem;
height: 1.5rem;
}
} }

View File

@ -2,6 +2,7 @@ import React, { Fragment } from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import { OutboundLink } from 'gatsby-plugin-google-analytics' import { OutboundLink } from 'gatsby-plugin-google-analytics'
import { Email, Blog, Twitter, GitHub, Dribbble } from '../atoms/Icons' import { Email, Blog, Twitter, GitHub, Dribbble } from '../atoms/Icons'
import FadeIn from '../atoms/FadeIn'
import './Social.scss' import './Social.scss'
const SocialIcon = ({ title }) => { const SocialIcon = ({ title }) => {
@ -28,18 +29,20 @@ const Social = ({ meta, minimal, hide }) => {
return ( return (
<Fragment> <Fragment>
{!hide && ( {!hide && (
<aside className={classes}> <FadeIn>
{Object.keys(social).map((key, i) => ( <aside className={classes}>
<OutboundLink {Object.keys(social).map((key, i) => (
className="social__link" <OutboundLink
href={social[key]} className="social__link"
key={i} href={social[key]}
title={key} key={i}
> title={key}
<SocialIcon title={key} /> >
</OutboundLink> <SocialIcon title={key} />
))} </OutboundLink>
</aside> ))}
</aside>
</FadeIn>
)} )}
</Fragment> </Fragment>
) )

View File

@ -2,7 +2,11 @@
.project { .project {
.project__image { .project__image {
margin-bottom: $spacer * 6; margin-bottom: $spacer * 3;
@media (min-width: 30rem) {
margin-bottom: $spacer * 6;
}
} }
} }

View File

@ -4,23 +4,16 @@
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
justify-content: space-between; justify-content: space-between;
.project__image {
@media (min-width: 90rem) {
max-width: 100%;
}
}
} }
.projects__project { .projects__project {
display: block;
position: relative; position: relative;
background-color: $brand-grey-light; background-color: $brand-grey-light;
margin: 0 auto $spacer * 4 auto; margin: 0 auto $spacer * 4 auto;
@media (min-width: 90rem) { @media (min-width: 30rem) {
flex: 0 0 calc(50% - #{$spacer * 2}); margin-bottom: $spacer * 8;
margin: 0;
margin-bottom: $spacer * 4;
} }
&::after { &::after {

Binary file not shown.

Before

Width:  |  Height:  |  Size: 501 KiB

After

Width:  |  Height:  |  Size: 559 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 422 KiB

After

Width:  |  Height:  |  Size: 422 KiB

View File

@ -44,6 +44,9 @@ export const query = graphql`
GitHub GitHub
Dribbble Dribbble
} }
availability
typekit
googleanalytics
} }
} }
} }