1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2025-01-03 18:35:00 +01:00

ES7 constructor kill

This commit is contained in:
Matthias Kretschmann 2018-09-06 14:28:01 +02:00
parent 593a4bd26d
commit ecc549a551
Signed by: m
GPG Key ID: 606EEEF3C479A91F
9 changed files with 95 additions and 146 deletions

View File

@ -14,10 +14,10 @@ const query = graphql`
`
class LogoUnit extends PureComponent {
constructor(props) {
super(props)
state = { minimal: false }
this.state = { minimal: false }
static propTypes = {
minimal: PropTypes.bool
}
checkMinimal = () => {
@ -60,8 +60,4 @@ class LogoUnit extends PureComponent {
}
}
LogoUnit.propTypes = {
minimal: PropTypes.bool
}
export default LogoUnit

View File

@ -37,56 +37,9 @@ const Vcard = () => (
render={data => {
const meta = data.dataYaml
const constructVcard = () => {
const contact = new vCard()
const photoSrc = meta.avatar.childImageSharp.original.src
// first, convert the avatar to base64,
// then construct all vCard elements
toDataURL(
photoSrc,
dataUrl => {
// stripping this data out of base64 string is required
// for vcard to actually display the image for whatever reason
const dataUrlCleaned = dataUrl
.split('data:image/jpeg;base64,')
.join('')
contact.set('photo', dataUrlCleaned, {
encoding: 'b',
type: 'JPEG'
})
contact.set('fn', meta.title)
contact.set('title', meta.tagline)
contact.set('email', meta.email)
contact.set('url', meta.url, { type: 'Portfolio' })
contact.add('url', meta.social.Blog, { type: 'Blog' })
contact.set('nickname', 'kremalicious')
contact.add('x-socialprofile', meta.social.Twitter, {
type: 'twitter'
})
contact.add('x-socialprofile', meta.social.GitHub, {
type: 'GitHub'
})
const vcard = contact.toString('3.0')
downloadVcard(vcard)
},
'image/jpeg'
)
}
// Construct the download from a blob of the just constructed vCard,
// and save it to user's file system
const downloadVcard = vcard => {
const name = meta.addressbook.split('/').join('')
const blob = new Blob([vcard], { type: 'text/x-vcard' })
FileSaver.saveAs(blob, name)
}
const handleAddressbookClick = e => {
e.preventDefault()
constructVcard()
constructVcard(meta)
}
return (
@ -103,6 +56,43 @@ const Vcard = () => (
/>
)
// Construct the download from a blob of the just constructed vCard,
// and save it to user's file system
const downloadVcard = (vcard, meta) => {
const name = meta.addressbook.split('/').join('')
const blob = new Blob([vcard], { type: 'text/x-vcard' })
FileSaver.saveAs(blob, name)
}
const constructVcard = meta => {
const contact = new vCard()
const photoSrc = meta.avatar.childImageSharp.original.src
// first, convert the avatar to base64, then construct all vCard elements
toDataURL(
photoSrc,
dataUrl => {
// stripping this data out of base64 string is required
// for vcard to actually display the image for whatever reason
const dataUrlCleaned = dataUrl.split('data:image/jpeg;base64,').join('')
contact.set('photo', dataUrlCleaned, { encoding: 'b', type: 'JPEG' })
contact.set('fn', meta.title)
contact.set('title', meta.tagline)
contact.set('email', meta.email)
contact.set('url', meta.url, { type: 'Portfolio' })
contact.add('url', meta.social.Blog, { type: 'Blog' })
contact.set('nickname', 'kremalicious')
contact.add('x-socialprofile', meta.social.Twitter, { type: 'twitter' })
contact.add('x-socialprofile', meta.social.GitHub, { type: 'GitHub' })
const vcard = contact.toString('3.0')
downloadVcard(vcard, meta)
},
'image/jpeg'
)
}
// Helper function to create base64 string from avatar image
// without the need to read image file from file system
const toDataURL = (src, callback, outputFormat) => {

View File

@ -16,10 +16,8 @@ const query = graphql`
}
`
class Availability extends PureComponent {
constructor(props) {
super(props)
}
export default class Availability extends PureComponent {
static propTypes = { hide: PropTypes.bool }
render() {
return (
@ -55,9 +53,3 @@ class Availability extends PureComponent {
)
}
}
Availability.propTypes = {
hide: PropTypes.bool
}
export default Availability

View File

@ -43,13 +43,14 @@ const NetworkIcon = props => {
}
}
class Network extends PureComponent {
constructor(props) {
super(props)
this.state = {
classes: styles.networks
export default class Network extends PureComponent {
static propTypes = {
minimal: PropTypes.bool,
hide: PropTypes.bool
}
state = {
classes: styles.networks
}
componentDidMount() {
@ -94,10 +95,3 @@ class Network extends PureComponent {
)
}
}
Network.propTypes = {
minimal: PropTypes.bool,
hide: PropTypes.bool
}
export default Network

View File

@ -36,17 +36,11 @@ const ProjectLink = ({ node }) => (
</Link>
)
class ProjectNav extends Component {
constructor(props) {
super(props)
this.state = {
export default class ProjectNav extends Component {
state = {
scrolledToCurrent: false
}
this.scrollToCurrent = this.scrollToCurrent.bind(this)
}
componentDidMount() {
this.scrollToCurrent()
this.setState({ scrolledToCurrent: true })
@ -113,5 +107,3 @@ ProjectLink.propTypes = {
ProjectNav.propTypes = {
slug: PropTypes.string
}
export default ProjectNav

View File

@ -5,21 +5,21 @@ import Day from '../svg/Day'
import Night from '../svg/Night'
import styles from './ThemeSwitch.module.scss'
const ThemeToggle = props => (
const ThemeToggle = ({ dark }) => (
<span id="toggle" className={styles.checkboxContainer} aria-live="assertive">
<Day className={props.dark ? null : 'active'} />
<Day className={dark ? null : 'active'} />
<span className={styles.checkboxFake} />
<Night className={props.dark ? 'active' : null} />
<Night className={dark ? 'active' : null} />
</span>
)
class ThemeSwitch extends PureComponent {
constructor(props) {
super(props)
this.state = { dark: null }
ThemeToggle.propTypes = {
dark: PropTypes.bool
}
export default class ThemeSwitch extends PureComponent {
state = { dark: null }
isDark = () => this.state.dark === true
darkLocalStorageMode = darkLocalStorage => {
@ -78,9 +78,3 @@ class ThemeSwitch extends PureComponent {
)
}
}
ThemeToggle.propTypes = {
dark: PropTypes.bool
}
export default ThemeSwitch

View File

@ -1,4 +1,5 @@
import React, { PureComponent } from 'react'
import PropTypes from 'prop-types'
import { StaticQuery, graphql } from 'gatsby'
import Vcard from '../atoms/Vcard'
import LogoUnit from '../atoms/LogoUnit'
@ -22,22 +23,7 @@ const query = graphql`
}
`
class Footer extends PureComponent {
constructor(props) {
super(props)
this.state = { year: new Date().getFullYear() }
}
render() {
return (
<StaticQuery
query={query}
render={data => {
const pkg = data.portfolioJson
const meta = data.dataYaml
return (
const FooterMarkup = ({ meta, pkg, year }) => (
<footer className={styles.footer}>
<LogoUnit minimal />
<Networks minimal />
@ -49,16 +35,32 @@ class Footer extends PureComponent {
</p>
<p className={styles.footer__copyright}>
<small>
&copy; {this.state.year} {meta.title} &mdash; All Rights
Reserved
&copy; {year} {meta.title} &mdash; All Rights Reserved
</small>
</p>
</footer>
)
FooterMarkup.propTypes = {
meta: PropTypes.object,
pkg: PropTypes.object,
year: PropTypes.number
}
export default class Footer extends PureComponent {
state = { year: new Date().getFullYear() }
render() {
return (
<StaticQuery
query={query}
render={data => {
const pkg = data.portfolioJson
const meta = data.dataYaml
return <FooterMarkup year={this.state.year} pkg={pkg} meta={meta} />
}}
/>
)
}
}
export default Footer

View File

@ -17,12 +17,8 @@ const query = graphql`
}
`
class Header extends PureComponent {
constructor(props) {
super(props)
this.state = { minimal: false }
}
export default class Header extends PureComponent {
state = { minimal: false }
checkMinimal = () => {
const { isHomepage } = this.props
@ -70,5 +66,3 @@ class Header extends PureComponent {
Header.propTypes = {
isHomepage: PropTypes.bool
}
export default Header

View File

@ -12,10 +12,11 @@ import './404.scss'
const giphyClient = giphyAPI('LfXRwufRyt6PK414G2kKJBv3L8NdnxyR')
const tag = 'fail-cat'
class NotFound extends Component {
constructor(props) {
super(props)
this.state = { gif: '' }
export default class NotFound extends Component {
state = { gif: '' }
static propTypes = {
location: PropTypes.object
}
componentDidMount() {
@ -62,9 +63,3 @@ class NotFound extends Component {
)
}
}
NotFound.propTypes = {
location: PropTypes.object
}
export default NotFound