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:
parent
a7744ef8d0
commit
c09f97b658
@ -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"
|
||||||
}
|
}
|
||||||
|
@ -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,
|
||||||
|
@ -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',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -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",
|
||||||
|
@ -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>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
33
src/components/molecules/Availability.js
Normal file
33
src/components/molecules/Availability.js
Normal 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}">Let’s 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
|
19
src/components/molecules/Availability.scss
Normal file
19
src/components/molecules/Availability.scss
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
@ -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;
|
||||||
|
@ -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>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
)
|
)
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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 |
@ -44,6 +44,9 @@ export const query = graphql`
|
|||||||
GitHub
|
GitHub
|
||||||
Dribbble
|
Dribbble
|
||||||
}
|
}
|
||||||
|
availability
|
||||||
|
typekit
|
||||||
|
googleanalytics
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user