File "template-types.js"

Full Path: /home/warrior1/public_html/plugins/elementor/app/modules/site-editor/assets/js/context/template-types.js
File size: 1.63 KB
MIME-type: text/x-java
Charset: utf-8

export const Context = React.createContext();

import '../../scss/loading.scss';

class TemplateTypesContext extends React.Component {
	static propTypes = {
		children: PropTypes.object.isRequired,
	};

	constructor( props ) {
		super( props );
		this.state = {
			templateTypes: [],
			loading: true,
			error: false,
		};
	}

	componentDidMount() {
		this.getTemplateTypes()
		.then( ( response ) => {
			this.setState( {
				templateTypes: response,
				loading: false,
			} );
		} )
		.fail( ( error ) => {
			this.setState( {
				error: error.statusText ? error.statusText : error,
				loading: false,
			} );
		} );
	}

	getTemplateTypes() {
		return elementorCommon.ajax.load( {
			action: 'app_site_editor_template_types',
		} );
	}

	render() {
		if ( this.state.error ) {
			return <div className="e-loading-wrapper"><h3>{ __( 'Error:', 'elementor' ) } { this.state.error }</h3></div>;
		}

		if ( this.state.loading ) {
			return (
				<div className="elementor-loading">
					<div className="elementor-loader-wrapper">
						<div className="elementor-loader">
							<div className="elementor-loader-boxes">
								<div className="elementor-loader-box" />
								<div className="elementor-loader-box" />
								<div className="elementor-loader-box" />
								<div className="elementor-loader-box" />
							</div>
						</div>
						<div className="elementor-loading-title">{ __( 'Loading', 'elementor' ) }</div>
					</div>
				</div>
			);
		}

		return (
			<Context.Provider value={ this.state }>
				{ this.props.children }
			</Context.Provider>
		);
	}
}

export const TemplateTypesConsumer = Context.Consumer;
export default TemplateTypesContext;