1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2024-06-26 03:06:39 +02: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",
"Dribbble": "https://dribbble.com/kremalicious"
},
"available": false,
"availability": false,
"typekit": "dtg3zui",
"googleanalytics": "UA-1441794-4"
}

View File

@ -1,8 +1,9 @@
const meta = require('./data/meta.json')
const { url, googleanalytics } = meta
module.exports = {
siteMetadata: {
siteUrl: `${meta.url}`,
siteUrl: `${url}`,
},
plugins: [
'gatsby-plugin-react-next',
@ -37,7 +38,7 @@ module.exports = {
{
resolve: 'gatsby-plugin-google-analytics',
options: {
trackingId: `${meta.googleanalytics}`,
trackingId: `${googleanalytics}`,
head: false,
anonymize: 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",
"react-helmet": "^5.2.0",
"react-markdown": "^3.3.0",
"react-transition-group": "^2.3.1"
"react-transition-group": "^2.3.1",
"webfontloader": "^1.6.28"
},
"devDependencies": {
"babel-eslint": "^8.2.3",

View File

@ -1,9 +1,12 @@
import React from 'react'
import PropTypes from 'prop-types'
import Helmet from 'react-helmet'
import WebFont from 'webfontloader'
const Head = ({ meta }) => {
const { title, tagline, description } = meta
const { title, tagline, description, url, typekit } = meta
WebFont.load({ typekit: { id: typekit } })
return (
<Helmet
@ -11,7 +14,9 @@ const Head = ({ meta }) => {
titleTemplate={`%s // ${title.toLowerCase()} { ${tagline.toLowerCase()} }`}
>
<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>
)
}

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';
.footer {
margin-top: $spacer;
padding: $spacer * 2;
text-align: center;
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 PropTypes from 'prop-types'
import FadeIn from '../atoms/FadeIn'
import { Logo } from '../atoms/Icons'
import Social from './Social'
import Availability from './Availability'
import './Header.scss'
const Header = ({ meta, isHomepage }) => {
@ -12,18 +13,19 @@ const Header = ({ meta, isHomepage }) => {
return (
<header className={classes}>
<FadeIn>
<Fragment>
<Link className="header__name" to={'/'}>
<Logo className="header__logo" />
<h1 className="header__title">{meta.title.toLowerCase()}</h1>
<p className="header__description">
<span>{'{ '}</span> {meta.tagline.toLowerCase()}{' '}
<span>{' }'}</span>
</p>
</Link>
<Social meta={meta} minimal={!isHomepage} hide={!isHomepage} />
</Fragment>
<Link className="header__name" to={'/'}>
<Logo className="header__logo" />
<h1 className="header__title">{meta.title.toLowerCase()}</h1>
<p className="header__description">
<span>{'{ '}</span> {meta.tagline.toLowerCase()}{' '}
<span>{' }'}</span>
</p>
</Link>
</FadeIn>
<Social meta={meta} minimal={!isHomepage} hide={!isHomepage} />
<Availability meta={meta} hide={!isHomepage} />
</header>
)
}

View File

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

View File

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

View File

@ -63,7 +63,27 @@
height: 100%;
display: block;
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 {
margin-left: 48.5%;
@ -72,10 +92,4 @@
&:last-child {
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 { OutboundLink } from 'gatsby-plugin-google-analytics'
import { Email, Blog, Twitter, GitHub, Dribbble } from '../atoms/Icons'
import FadeIn from '../atoms/FadeIn'
import './Social.scss'
const SocialIcon = ({ title }) => {
@ -28,18 +29,20 @@ const Social = ({ meta, minimal, hide }) => {
return (
<Fragment>
{!hide && (
<aside className={classes}>
{Object.keys(social).map((key, i) => (
<OutboundLink
className="social__link"
href={social[key]}
key={i}
title={key}
>
<SocialIcon title={key} />
</OutboundLink>
))}
</aside>
<FadeIn>
<aside className={classes}>
{Object.keys(social).map((key, i) => (
<OutboundLink
className="social__link"
href={social[key]}
key={i}
title={key}
>
<SocialIcon title={key} />
</OutboundLink>
))}
</aside>
</FadeIn>
)}
</Fragment>
)

View File

@ -2,7 +2,11 @@
.project {
.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;
flex-wrap: wrap;
justify-content: space-between;
.project__image {
@media (min-width: 90rem) {
max-width: 100%;
}
}
}
.projects__project {
display: block;
position: relative;
background-color: $brand-grey-light;
margin: 0 auto $spacer * 4 auto;
@media (min-width: 90rem) {
flex: 0 0 calc(50% - #{$spacer * 2});
margin: 0;
margin-bottom: $spacer * 4;
@media (min-width: 30rem) {
margin-bottom: $spacer * 8;
}
&::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
Dribbble
}
availability
typekit
googleanalytics
}
}
}