1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2025-01-05 11:25:00 +01:00
This commit is contained in:
Matthias Kretschmann 2018-05-22 22:41:59 +02:00
parent 34ef21cf52
commit 0d5b0f223f
Signed by: m
GPG Key ID: 606EEEF3C479A91F
3 changed files with 23 additions and 12 deletions

View File

@ -9,6 +9,7 @@
</p> </p>
<p align="center"> <p align="center">
<a href="https://travis-ci.com/kremalicious/portfolio"><img src="https://travis-ci.com/kremalicious/portfolio.svg?branch=master" /></a> <a href="https://travis-ci.com/kremalicious/portfolio"><img src="https://travis-ci.com/kremalicious/portfolio.svg?branch=master" /></a>
<a href="https://codeclimate.com/github/kremalicious/portfolio/maintainability"><img src="https://api.codeclimate.com/v1/badges/8f561ec93e0f8c6b15d9/maintainability" /></a>
<a href="https://greenkeeper.io/"><img src="https://badges.greenkeeper.io/kremalicious/portfolio.svg" /></a> <a href="https://greenkeeper.io/"><img src="https://badges.greenkeeper.io/kremalicious/portfolio.svg" /></a>
</p> </p>

View File

@ -2,21 +2,19 @@ import React from 'react'
import CSSTransition from 'react-transition-group/CSSTransition' import CSSTransition from 'react-transition-group/CSSTransition'
import './Animations.scss' import './Animations.scss'
const Animation = props => <CSSTransition appear={true} in={true} {...props} />
export const FadeIn = props => ( export const FadeIn = props => (
<CSSTransition <Animation
classNames="fadein" classNames="fadein"
appear={true}
in={true}
timeout={{ enter: 200, exit: 200, appear: 200 }} timeout={{ enter: 200, exit: 200, appear: 200 }}
{...props} {...props}
/> />
) )
export const MoveIn = props => ( export const MoveIn = props => (
<CSSTransition <Animation
classNames="movein" classNames="movein"
appear={true}
in={true}
timeout={{ enter: 300, exit: 200, appear: 300 }} timeout={{ enter: 300, exit: 200, appear: 300 }}
{...props} {...props}
/> />

View File

@ -11,6 +11,17 @@ import ProjectNav from '../components/molecules/ProjectNav'
import SEO from '../components/atoms/SEO' import SEO from '../components/atoms/SEO'
import './Project.scss' import './Project.scss'
const ProjectMeta = props => {
const { links, techstack } = props
return (
<footer className="project__meta">
{!!links && <ProjectLinks links={links} />}
{!!techstack && <ProjectTechstack techstack={techstack} />}
</footer>
)
}
class Project extends Component { class Project extends Component {
constructor(props) { constructor(props) {
super(props) super(props)
@ -27,7 +38,6 @@ class Project extends Component {
const project = this.props.data.projectsYaml const project = this.props.data.projectsYaml
const projectImages = this.props.data.projectImages.edges const projectImages = this.props.data.projectImages.edges
const pathContext = this.props.pathContext const pathContext = this.props.pathContext
const { title, links, techstack } = project const { title, links, techstack } = project
const { next, previous } = pathContext const { next, previous } = pathContext
@ -53,10 +63,7 @@ class Project extends Component {
))} ))}
</FullWidth> </FullWidth>
<footer className="project__meta"> <ProjectMeta links={links} techstack={techstack} />
{!!links && <ProjectLinks links={links} />}
{!!techstack && <ProjectTechstack techstack={techstack} />}
</footer>
</Content> </Content>
</article> </article>
@ -66,6 +73,11 @@ class Project extends Component {
} }
} }
ProjectMeta.propTypes = {
links: PropTypes.array,
techstack: PropTypes.array
}
Project.propTypes = { Project.propTypes = {
data: PropTypes.object.isRequired, data: PropTypes.object.isRequired,
pathContext: PropTypes.object.isRequired pathContext: PropTypes.object.isRequired