Learn more  » Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

jsarnowski / jsarnowski/cartflows-pro   php

Repository URL to install this package:

Version: 1.6.10 

/ gutenberg / src / components / typography / fontloader.js

if ( googlefonts === undefined ) {
	var googlefonts = []
}
const {
	Component,
} = wp.element
import PropTypes from "prop-types"
import WebFont from "webfontloader"
const statuses = {
	inactive: "inactive",
	active: "active",
	loading: "loading",
}

const noop = () => {}

class WebfontLoader extends Component {

	constructor(props) {
	    super(props)

	    this.state = {
			status: undefined,
	    }

		this.handleLoading = () => {
			this.setState( { status: statuses.loading } )
		}
		
		this.addFont = ( font ) => {
			if ( ! googlefonts.includes( font ) ) {
				googlefonts.push( font )
			}
		}
		
		this.handleActive = () => {
			this.setState( { status: statuses.active } )
		}

		this.handleInactive = () => {
			this.setState( { status: statuses.inactive } )
		}

		this.loadFonts = () => {
			//if ( ! this.state.fonts.includes( this.props.config.google.families[ 0 ] ) ) {
			if ( ! googlefonts.includes( this.props.config.google.families[ 0 ] ) ) {
				
				WebFont.load( {
					...this.props.config,
					loading: this.handleLoading,
					active: this.handleActive,
					inactive: this.handleInactive,
				} )
				this.addFont( this.props.config.google.families[ 0 ] )
			}
		}
	}

	componentDidMount() {
		this.loadFonts()
	}

	componentDidUpdate( prevProps, prevState ) {
		const { onStatus, config } = this.props

		if ( prevState.status !== this.state.status ) {
			onStatus( this.state.status )
		}
		if ( prevProps.config !== config ) {
			this.loadFonts()
		}
	}



	render() {
		const { children } = this.props
		return children || null
	}
}

WebfontLoader.propTypes = {
	config: PropTypes.object.isRequired,
	children: PropTypes.element,
	onStatus: PropTypes.func.isRequired,
}

WebfontLoader.defaultProps = {
	onStatus: noop,
}

export default WebfontLoader